/*
Theme Name: SMASHLINE
Theme URI: https://smashline.es
Author: SMASHLINE Team
Description: SMASHLINE - The Power Behind the Game. Plataforma digital del pádel.
Version: 2.0.0
Text Domain: smashline
Requires at least: 6.0
Requires PHP: 8.0
*/

/* ============================================
   NEW SMASHLINE PALETTE — Juvenil & Dinámico
   ============================================ */
:root {
  /* Core palette: electric lime + deep navy + hot coral */
  --sm-lime: #CCFF00;
  --sm-lime-dark: #A8D600;
  --sm-navy: #0B0E1A;
  --sm-navy-mid: #141829;
  --sm-navy-light: #1C2237;
  --sm-coral: #FF4757;
  --sm-coral-light: #FF6B7A;
  --sm-blue: #3742FA;
  --sm-cyan: #18DCFF;
  --sm-white: #F8F9FA;
  --sm-gray-100: #EDEEF2;
  --sm-gray-200: #D1D3DB;
  --sm-gray-300: #9CA0AE;
  --sm-gray-400: #6B7084;
  --sm-gray-500: #3E4255;

  /* Typography */
  --sm-font-display: 'Bebas Neue', sans-serif;
  --sm-font-body: 'Sora', sans-serif;
  --sm-font-mono: 'Space Mono', monospace;

  /* Spacing & Sizing */
  --sm-max-w: 1340px;
  --sm-radius: 16px;
  --sm-radius-sm: 10px;
  --sm-transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

/* Reset */
*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; -webkit-font-smoothing:antialiased; }
body { font-family:var(--sm-font-body); background:var(--sm-navy); color:var(--sm-gray-200); line-height:1.6; overflow-x:hidden; }
a { text-decoration:none; color:inherit; transition:var(--sm-transition); }
img { max-width:100%; display:block; }
ul, ol { list-style:none; }

/* Container */
.container { max-width:var(--sm-max-w); margin:0 auto; padding:0 24px; }

/* ============================================
   HEADER — v3 compact + mobile-first
   ============================================ */
.header {
  position:fixed; top:0; left:0; right:0; z-index:100;
  padding:14px 0;
  background:rgba(11,14,26,0.88);
  backdrop-filter:blur(24px);
  -webkit-backdrop-filter:blur(24px);
  border-bottom:1px solid rgba(204,255,0,0.06);
  transition:padding 0.3s ease;
}
.header--scrolled { padding:8px 0; }
.header__inner {
  display:flex; justify-content:space-between; align-items:center;
}
.logo {
  display:flex; align-items:center; gap:10px;
  font-family:var(--sm-font-display); font-size:1.8rem; letter-spacing:2px; color:var(--sm-white);
  flex-shrink:0;
}
.logo__mark {
  width:34px; height:34px; background:var(--sm-lime); color:var(--sm-navy);
  display:flex; align-items:center; justify-content:center;
  font-family:var(--sm-font-display); font-size:1.1rem; font-weight:700;
  border-radius:8px; transform:rotate(-6deg);
}
.logo span { color:var(--sm-lime); }

/* Desktop nav */
.nav {
  display:flex; align-items:center; gap:2px;
  flex:1; justify-content:center;
  margin:0 16px;
}
.nav__close { display:none; }
.nav__divider { width:1px; height:20px; background:rgba(255,255,255,0.1); margin:0 8px; flex-shrink:0; }
.nav__link {
  padding:7px 14px; font-size:0.78rem; font-weight:500; color:var(--sm-gray-300);
  border-radius:30px; white-space:nowrap; transition:var(--sm-transition);
}
.nav__link:hover, .nav__link.active { color:var(--sm-white); background:rgba(204,255,0,0.1); }
.nav__link-icon { display:none; } /* hidden on desktop, visible on mobile */
.nav__cta {
  margin-left:8px; padding:8px 20px !important;
  background:var(--sm-lime) !important; color:var(--sm-navy) !important;
  font-weight:700 !important; border-radius:30px; font-size:0.75rem !important;
  text-transform:uppercase; letter-spacing:1px; white-space:nowrap; flex-shrink:0;
}
.nav__cta:hover { background:var(--sm-coral) !important; color:var(--sm-white) !important; }

/* Header actions (search + hamburger) */
.header__actions { display:flex; align-items:center; gap:4px; flex-shrink:0; }

/* Hamburger — hidden on desktop */
.hamburger { display:none; flex-direction:column; gap:5px; cursor:pointer; background:none; border:none; padding:8px; z-index:1001; }
.hamburger span { display:block; width:22px; height:2px; background:var(--sm-white); border-radius:2px; transition:var(--sm-transition); }
.hamburger.active span:nth-child(1) { transform:rotate(45deg) translateY(7px); }
.hamburger.active span:nth-child(2) { opacity:0; }
.hamburger.active span:nth-child(3) { transform:rotate(-45deg) translateY(-7px); }

/* ============================================
   HERO MEDIA
   ============================================ */
.media-hero {
  padding:140px 0 60px;
  position:relative;
  overflow:hidden;
}
.media-hero::before {
  content:'MEDIA'; position:absolute; top:50%; left:50%; transform:translate(-50%,-50%);
  font-family:var(--sm-font-display); font-size:clamp(12rem,25vw,22rem);
  color:rgba(204,255,0,0.03); pointer-events:none; white-space:nowrap;
  letter-spacing:20px;
}
.media-hero__content { position:relative; z-index:2; }
.media-hero__tag {
  display:inline-flex; align-items:center; gap:8px;
  font-family:var(--sm-font-mono); font-size:0.72rem; font-weight:700;
  color:var(--sm-lime); text-transform:uppercase; letter-spacing:3px;
  margin-bottom:20px;
}
.media-hero__tag::before {
  content:''; width:32px; height:2px; background:var(--sm-lime);
}
.media-hero__title {
  font-family:var(--sm-font-display); font-size:clamp(3.5rem,8vw,6.5rem);
  color:var(--sm-white); line-height:0.95; letter-spacing:3px;
  margin-bottom:16px;
}
.media-hero__title span { color:var(--sm-lime); }
.media-hero__sub {
  font-size:1.05rem; color:var(--sm-gray-300); max-width:600px; line-height:1.6;
}

/* Filters removed — navigation now in header */

/* ============================================
   FEATURED (HERO ARTICLE)
   ============================================ */
.featured {
  display:grid; grid-template-columns:1.4fr 0.6fr; gap:24px; margin-bottom:64px;
}
.featured__main {
  position:relative; border-radius:var(--sm-radius); overflow:hidden;
  min-height:520px; cursor:pointer;
  background:linear-gradient(135deg, var(--sm-navy-mid), var(--sm-blue));
}
.featured__main:hover .featured__img { transform:scale(1.04); }
.featured__img {
  width:100%; height:100%; object-fit:cover; transition:transform 0.7s ease;
  position:absolute; inset:0;
}
.featured__overlay {
  position:absolute; bottom:0; left:0; right:0; padding:40px;
  background:linear-gradient(to top, rgba(11,14,26,0.95) 0%, rgba(11,14,26,0.6) 50%, transparent 100%);
  z-index:2;
}
.featured__cat {
  display:inline-block; padding:5px 14px;
  background:var(--sm-lime); color:var(--sm-navy);
  font-family:var(--sm-font-mono); font-size:0.65rem; font-weight:700;
  text-transform:uppercase; letter-spacing:2px; border-radius:20px;
  margin-bottom:16px;
}
.featured__cat--coral { background:var(--sm-coral); color:var(--sm-white); }
.featured__cat--blue { background:var(--sm-blue); color:var(--sm-white); }
.featured__cat--cyan { background:var(--sm-cyan); color:var(--sm-navy); }
.featured__title {
  font-family:var(--sm-font-display); font-size:clamp(1.8rem,3vw,2.6rem);
  color:var(--sm-white); letter-spacing:1px; line-height:1.05; margin-bottom:12px;
}
.featured__excerpt { font-size:0.92rem; color:var(--sm-gray-300); line-height:1.5; max-width:90%; }
.featured__meta {
  display:flex; gap:20px; margin-top:16px;
  font-size:0.78rem; color:var(--sm-gray-400);
  font-family:var(--sm-font-mono);
}

/* Featured sidebar */
.featured__sidebar { display:flex; flex-direction:column; gap:12px; }
.sidebar-card {
  display:flex; gap:14px; padding:16px;
  background:var(--sm-navy-light); border:1px solid rgba(255,255,255,0.05);
  border-radius:var(--sm-radius-sm); cursor:pointer; transition:var(--sm-transition);
  flex:1;
}
.sidebar-card:hover { border-color:var(--sm-lime); transform:translateX(4px); }
.sidebar-card__img {
  width:90px; min-height:70px; border-radius:8px; overflow:hidden; flex-shrink:0;
  background:linear-gradient(135deg, var(--sm-navy-mid), var(--sm-blue));
}
.sidebar-card__img img { width:100%; height:100%; object-fit:cover; }
.sidebar-card__title {
  font-size:0.88rem; font-weight:600; color:var(--sm-white);
  line-height:1.3; margin-bottom:6px;
}
.sidebar-card__meta {
  font-size:0.72rem; color:var(--sm-gray-400); font-family:var(--sm-font-mono);
}

/* ============================================
   ARTICLES GRID
   ============================================ */
.section-title {
  font-family:var(--sm-font-display); font-size:2.2rem; color:var(--sm-white);
  letter-spacing:2px; margin-bottom:32px;
  display:flex; align-items:center; gap:16px;
}
.section-title::after {
  content:''; flex:1; height:1px; background:rgba(255,255,255,0.08);
}

.articles-grid {
  display:grid; grid-template-columns:repeat(3, 1fr); gap:24px;
}

.article-card {
  background:var(--sm-navy-light); border:1px solid rgba(255,255,255,0.05);
  border-radius:var(--sm-radius); overflow:hidden;
  transition:var(--sm-transition); cursor:pointer; position:relative;
}
.article-card:hover {
  transform:translateY(-6px);
  border-color:var(--sm-lime);
  box-shadow:0 12px 40px rgba(204,255,0,0.08);
}
.article-card__img {
  height:210px; overflow:hidden; position:relative;
  background:linear-gradient(135deg, var(--sm-navy-mid), #1a1f3a);
}
.article-card__img img { width:100%; height:100%; object-fit:cover; transition:transform 0.5s ease; }
.article-card:hover .article-card__img img { transform:scale(1.06); }
.article-card__cat {
  position:absolute; top:14px; left:14px;
  padding:4px 12px; border-radius:20px;
  font-family:var(--sm-font-mono); font-size:0.6rem; font-weight:700;
  text-transform:uppercase; letter-spacing:1.5px; z-index:2;
}
.article-card__body { padding:22px; }
.article-card__title {
  font-size:1rem; font-weight:700; color:var(--sm-white);
  line-height:1.3; margin-bottom:10px;
}
.article-card__excerpt {
  font-size:0.85rem; color:var(--sm-gray-400); line-height:1.5; margin-bottom:16px;
}
.article-card__footer {
  display:flex; justify-content:space-between; align-items:center;
  font-size:0.72rem; color:var(--sm-gray-400); font-family:var(--sm-font-mono);
  padding-top:14px; border-top:1px solid rgba(255,255,255,0.05);
}
.article-card__author {
  display:flex; align-items:center; gap:8px;
}
.article-card__avatar {
  width:24px; height:24px; border-radius:50%;
  background:var(--sm-lime); display:flex; align-items:center; justify-content:center;
  font-size:0.6rem; font-weight:700; color:var(--sm-navy);
}

/* ============================================
   NEWSLETTER BANNER
   ============================================ */
.newsletter-banner {
  margin:80px 0 60px;
  background:linear-gradient(135deg, var(--sm-navy-mid) 0%, rgba(55,66,250,0.15) 100%);
  border:1px solid rgba(204,255,0,0.1);
  border-radius:var(--sm-radius);
  padding:48px;
  display:flex; justify-content:space-between; align-items:center; gap:32px;
  position:relative; overflow:hidden;
}
.newsletter-banner::before {
  content:''; position:absolute; top:-50px; right:-50px;
  width:200px; height:200px; border-radius:50%;
  background:radial-gradient(circle, rgba(204,255,0,0.1), transparent);
}
.newsletter-banner__text h3 {
  font-family:var(--sm-font-display); font-size:2rem; color:var(--sm-white);
  letter-spacing:2px; margin-bottom:6px;
}
.newsletter-banner__text p { color:var(--sm-gray-300); font-size:0.92rem; }
.newsletter-banner__form { display:flex; gap:10px; z-index:2; }
.newsletter-banner__form input {
  padding:14px 24px; background:rgba(255,255,255,0.06);
  border:1px solid rgba(255,255,255,0.12); border-radius:30px;
  font-family:var(--sm-font-body); font-size:0.9rem; color:var(--sm-white);
  min-width:300px; outline:none; transition:var(--sm-transition);
}
.newsletter-banner__form input::placeholder { color:var(--sm-gray-400); }
.newsletter-banner__form input:focus { border-color:var(--sm-lime); }
.newsletter-banner__form button {
  padding:14px 28px; background:var(--sm-lime); color:var(--sm-navy);
  border:none; border-radius:30px; font-family:var(--sm-font-body);
  font-weight:700; font-size:0.82rem; cursor:pointer;
  text-transform:uppercase; letter-spacing:1px; transition:var(--sm-transition);
}
.newsletter-banner__form button:hover { background:var(--sm-coral); color:var(--sm-white); }

/* ============================================
   TRENDING BAR
   ============================================ */
.trending-bar {
  display:flex; align-items:center; gap:16px;
  padding:14px 0; margin-bottom:48px;
  border-top:1px solid rgba(255,255,255,0.06);
  border-bottom:1px solid rgba(255,255,255,0.06);
  overflow:hidden;
}
.trending-bar__label {
  flex-shrink:0; padding:4px 14px;
  background:var(--sm-coral); color:var(--sm-white);
  font-family:var(--sm-font-mono); font-size:0.65rem; font-weight:700;
  text-transform:uppercase; letter-spacing:2px; border-radius:20px;
}
.trending-bar__scroll {
  display:flex; gap:32px; animation:marquee 35s linear infinite;
  white-space:nowrap;
}
.trending-bar__item {
  font-size:0.85rem; color:var(--sm-gray-300); font-weight:500;
  cursor:pointer; flex-shrink:0;
}
.trending-bar__item:hover { color:var(--sm-lime); }
.trending-bar__item::before {
  content:'#'; color:var(--sm-lime); font-weight:700; margin-right:4px;
}
@keyframes marquee {
  0% { transform:translateX(0); }
  100% { transform:translateX(-50%); }
}

/* ============================================
   FOOTER
   ============================================ */
.footer {
  background:var(--sm-navy); padding:60px 0 28px;
  border-top:1px solid rgba(255,255,255,0.05);
  margin-top:40px;
}
.footer__grid { display:grid; grid-template-columns:1.5fr 1fr 1fr 1fr; gap:48px; margin-bottom:48px; }
.footer__brand-desc { font-size:0.85rem; color:var(--sm-gray-400); margin-top:12px; line-height:1.6; }
.footer__social { display:flex; gap:10px; margin-top:20px; }
.footer__social a {
  width:36px; height:36px; background:rgba(255,255,255,0.05); border-radius:50%;
  display:flex; align-items:center; justify-content:center; font-size:0.85rem;
}
.footer__social a:hover { background:var(--sm-lime); color:var(--sm-navy); }
.footer__col-title {
  font-family:var(--sm-font-display); font-size:1.1rem; color:var(--sm-white);
  letter-spacing:2px; margin-bottom:16px;
}
.footer__col li { margin-bottom:8px; }
.footer__col li a { font-size:0.84rem; color:var(--sm-gray-400); }
.footer__col li a:hover { color:var(--sm-lime); }
.footer__bottom {
  border-top:1px solid rgba(255,255,255,0.05); padding-top:24px;
  display:flex; justify-content:space-between; font-size:0.78rem; color:var(--sm-gray-400);
}

/* ============================================
   STAGGERED ANIMATION
   ============================================ */
.fade-up {
  opacity:0; transform:translateY(28px);
  transition:opacity 0.6s ease, transform 0.6s ease;
}
.fade-up.visible { opacity:1; transform:translateY(0); }

/* ============================================
   RESPONSIVE — comprehensive mobile-first
   ============================================ */

/* Tablet */
@media (max-width:1024px) {
  .featured { grid-template-columns:1fr; }
  .articles-grid { grid-template-columns:repeat(2,1fr); }
  .footer__grid { grid-template-columns:repeat(2,1fr); }
  .nav__link { padding:6px 10px; font-size:0.72rem; }
  .nav__cta { padding:7px 16px !important; font-size:0.7rem !important; }
  .nav-dropdown__toggle { font-size:0.72rem; padding:6px 10px; }
}

/* Mobile */
@media (max-width:768px) {
  /* ── Mobile Nav ── */
  .nav {
    display:none; position:fixed; inset:0; z-index:999;
    background:rgba(11,14,26,0.98);
    backdrop-filter:blur(30px); -webkit-backdrop-filter:blur(30px);
    flex-direction:column; align-items:stretch;
    padding:72px 20px 32px; gap:0;
    overflow-y:auto; -webkit-overflow-scrolling:touch;
  }
  .nav.open { display:flex; animation:navSlideIn 0.35s ease; }
  @keyframes navSlideIn { from{opacity:0;transform:translateX(100%)}to{opacity:1;transform:translateX(0)} }
  .nav__close { display:block; position:absolute; top:16px; right:20px; background:none; border:none; color:var(--sm-gray-300); font-size:1.5rem; cursor:pointer; padding:8px; z-index:10; }
  .nav__link { display:flex; align-items:center; gap:12px; padding:14px 16px; font-size:1rem; font-weight:600; border-bottom:1px solid rgba(255,255,255,0.04); border-radius:0; color:var(--sm-gray-200); }
  .nav__link:hover,.nav__link.active { background:rgba(204,255,0,0.06); color:var(--sm-lime); }
  .nav__link-icon { display:inline; font-size:1.1rem; }
  .nav__divider { width:100%; height:1px; margin:10px 0; }
  .nav-dropdown { width:100%; }
  .nav-dropdown__toggle { width:100%; padding:14px 16px; font-size:1rem; font-weight:600; text-align:left; display:flex; align-items:center; gap:8px; color:var(--sm-gray-200); border-bottom:1px solid rgba(255,255,255,0.04); }
  .nav-dropdown__menu { position:relative; top:0; width:100%; background:rgba(255,255,255,0.02); border:none; box-shadow:none; padding:0 0 0 16px; border-radius:0; }
  .nav-dropdown__item { padding:12px 14px; border-radius:8px; }
  .nav-dropdown__icon { width:36px; height:36px; font-size:1rem; }
  .nav__cta { margin:16px 0 0 !important; padding:14px 24px !important; font-size:0.85rem !important; text-align:center; display:block; border-radius:30px; }
  .hamburger { display:flex; }
  .header-search__toggle { font-size:1rem; }
  .header-search__form { left:12px; right:12px; }

  /* ── Hero ── */
  .media-hero { padding:100px 0 32px; }
  .media-hero::before { font-size:6rem; letter-spacing:8px; } /* Smaller watermark */
  .media-hero__title { font-size:clamp(2.2rem,9vw,3rem); letter-spacing:1px; }
  .media-hero__sub { font-size:0.88rem; line-height:1.5; }

  /* ── Trending ── */
  .trending-bar { margin-bottom:20px; padding:10px 0; gap:10px; }
  .trending-bar__label { font-size:0.6rem; padding:3px 10px; }
  .trending-bar__item { font-size:0.78rem; }

  /* ── Mosaic — proper mobile proportions ── */
  .mosaic { grid-template-columns:1fr; gap:10px; margin-bottom:20px; }
  .mosaic__hero { min-height:240px; border-radius:12px; }
  .mosaic__overlay { padding:16px; }
  .mosaic__title { font-size:1.1rem; line-height:1.08; display:-webkit-box; -webkit-line-clamp:3; -webkit-box-orient:vertical; overflow:hidden; }
  .mosaic__excerpt { font-size:0.78rem; line-height:1.35; display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden; }
  .featured__meta { font-size:0.62rem; gap:8px; flex-wrap:wrap; margin-top:8px; }
  .featured__cat { font-size:0.55rem; padding:3px 9px; margin-bottom:6px; }
  .mosaic__side { flex-direction:column; gap:6px; }
  .mosaic__card { min-height:90px; border-radius:10px; }
  .mosaic__card-overlay { padding:10px 12px; }
  .mosaic__card-title { font-size:0.8rem; line-height:1.2; display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden; margin-top:4px; }
  .mosaic__card-meta { font-size:0.58rem; margin-top:2px; }

  /* ── Sabías que ── */
  .sabias-que { flex-direction:column; text-align:center; gap:10px; padding:18px 16px; margin:16px 0; }
  .sabias-que__icon { font-size:1.4rem; }
  .sabias-que__label { font-size:0.6rem; }
  .sabias-que__text { font-size:0.85rem; }
  .sabias-que__next { align-self:center; width:36px; height:36px; }
  .sabias-que__counter { align-self:center; }

  /* ── Stats bar ── */
  .stats-bar { display:grid; grid-template-columns:repeat(2,1fr); gap:12px; padding:20px 16px; margin:16px 0 24px; }
  .stat-item { padding:8px 0; }
  .stat-item__number { font-size:1.8rem; }
  .stat-item__label { font-size:0.62rem; letter-spacing:0.5px; }
  .stat-item:last-child { grid-column:1/-1; } /* center the 5th item */

  /* ── Section divider ── */
  .section-divider { margin:16px 0; }

  /* ── Category blocks on home ── */
  .cat-block { margin-bottom:16px; }
  .cat-block__header { flex-direction:column; align-items:flex-start; gap:8px; }
  .cat-block__label { font-size:0.9rem; padding:6px 16px; }
  .cat-block__desc { font-size:0.78rem; margin-top:4px; }
  .cat-section__link { font-size:0.72rem; padding:6px 14px; }

  /* ── Layout A: Banner + List → stacked, compact list items ── */
  .cat-layout-a { grid-template-columns:1fr; gap:10px; }
  .cat-banner { min-height:200px; border-radius:12px; }
  .cat-banner__text { padding:16px; }
  .cat-banner__title { font-size:1.05rem; line-height:1.08; display:-webkit-box; -webkit-line-clamp:3; -webkit-box-orient:vertical; overflow:hidden; }
  .cat-banner__excerpt { font-size:0.78rem; line-height:1.35; display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden; margin-bottom:6px; }
  .cat-banner__meta { font-size:0.65rem; }
  .cat-list { gap:4px; }
  .cat-list__item { padding:11px 12px; gap:10px; border-radius:8px; }
  .cat-list__dot { width:6px; height:6px; margin-top:5px; }
  .cat-list__title { font-size:0.82rem; line-height:1.25; display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden; margin-bottom:2px; }
  .cat-list__meta { font-size:0.62rem; }
  .cat-list__item p { display:none !important; } /* hide excerpt on mobile */

  /* ── Layout B: 2-column → single column ── */
  .cat-layout-b { grid-template-columns:1fr; gap:12px; }
  .cat-feature__img { height:150px; }
  .cat-feature__body { padding:16px; }
  .cat-feature__title { font-size:0.9rem; display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden; }
  .cat-feature__excerpt { font-size:0.78rem; display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden; }
  .cat-feature__meta { font-size:0.65rem; }

  /* ── Layout 2x2 Mosaic → stack ── */
  .cat-mosaic-grid { grid-template-columns:1fr; gap:8px; min-height:auto; }
  .cat-mosaic-card { min-height:130px; border-radius:10px; }
  .cat-mosaic-card--big { grid-row:auto; min-height:170px; }
  .cat-mosaic-card__text { padding:12px 14px; }
  .cat-mosaic-card__text h3 { font-size:0.85rem; line-height:1.2; display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden; }
  .cat-mosaic-card--big .cat-mosaic-card__text h3 { font-size:1rem; }
  .cat-mosaic-card__text p { font-size:0.72rem; display:-webkit-box; -webkit-line-clamp:1; -webkit-box-orient:vertical; overflow:hidden; }
  .cat-mosaic-card__text span { font-size:0.6rem; }

  /* ── Horizontal scroll → smaller cards ── */
  .cat-scroll { gap:10px; padding-bottom:8px; }
  .cat-scroll__card { flex:0 0 190px; border-radius:10px; }
  .cat-scroll__img { height:110px; }
  .cat-scroll__title { font-size:0.8rem; padding:10px 12px 3px; line-height:1.2; display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden; }
  .cat-scroll__meta { padding:0 12px 10px; font-size:0.6rem; }

  /* ── Full-width → shorter ── */
  .cat-fullwidth { min-height:170px; border-radius:12px; }
  .cat-fullwidth__text { padding:14px; }
  .cat-fullwidth__text h3 { font-size:1rem; display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden; }
  .cat-fullwidth__text p { font-size:0.78rem; display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden; }
  .cat-fullwidth__text span { font-size:0.62rem; }

  /* ── Gallery → 2 col compact ── */
  .cat-gallery { grid-template-columns:1fr 1fr; gap:8px; }
  .cat-gallery__item { border-radius:8px; }
  .cat-gallery__img { height:95px; }
  .cat-gallery__info { padding:8px 10px; }
  .cat-gallery__info h4 { font-size:0.72rem; line-height:1.2; display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden; margin-bottom:3px; }
  .cat-gallery__info span { font-size:0.58rem; }

  /* ── Editorial list → tight rows ── */
  .cat-editorial { gap:2px; }
  .cat-editorial__row { padding:11px 10px; gap:8px; border-radius:6px; }
  .cat-editorial__num { font-size:1.1rem; min-width:24px; }
  .cat-editorial__row--featured { padding:13px 10px; }
  .cat-editorial__row--featured .cat-editorial__num { font-size:1.4rem; }
  .cat-editorial__content h4 { font-size:0.82rem; line-height:1.2; display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden; }
  .cat-editorial__content p { font-size:0.72rem; display:-webkit-box; -webkit-line-clamp:1; -webkit-box-orient:vertical; overflow:hidden; }
  .cat-editorial__content span { font-size:0.6rem; }
  .cat-editorial__arrow { font-size:0.85rem; }

  /* ── Article cards ── */
  .articles-grid { grid-template-columns:1fr; gap:12px; }
  .article-card { border-radius:12px; }
  .article-card__img { height:160px; }
  .article-card__body { padding:16px; }
  .article-card__title { font-size:0.9rem; line-height:1.25; display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden; margin-bottom:6px; }
  .article-card__title a { color:inherit; }
  .article-card__excerpt { font-size:0.8rem; line-height:1.4; display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden; margin-bottom:12px; }
  .article-card__footer { font-size:0.65rem; padding-top:10px; }
  .article-card__avatar { width:20px; height:20px; font-size:0.5rem; }
  .article-card__read-time { font-size:0.55rem; padding:3px 7px; }

  /* ── Interactive elements ── */
  .interactive-row { flex-direction:column; gap:12px; }
  .tip-card { padding:16px 14px; gap:10px; }
  .tip-card__icon { font-size:1.2rem; }
  .tip-card__label { font-size:0.6rem; }
  .tip-card__text { font-size:0.82rem; }
  .fact-card { flex-direction:column; gap:10px; padding:16px 14px; }
  .fact-card__text { font-size:0.82rem; }
  .quiz-card { padding:16px 14px; }
  .quiz-card__q { font-size:0.88rem; }
  .quiz-card__options { flex-direction:column; gap:8px; }
  .quiz-card__opt { padding:10px 14px; font-size:0.8rem; }
  .quiz-card__next { width:100%; text-align:center; }

  /* ── Sub-filters ── */
  .sub-filters { padding:10px 0 14px; gap:6px; }
  .sub-filter { padding:6px 14px; font-size:0.72rem; }

  /* ── Cat Hero ── */
  .cat-hero { padding:20px 16px; margin-bottom:20px; }
  .cat-hero__content { flex-direction:column; align-items:flex-start; gap:12px; }
  .cat-hero__icon { width:44px; height:44px; font-size:1.3rem; }
  .cat-hero__title { font-size:1.5rem; }
  .cat-hero__desc { font-size:0.85rem; }
  .cat-hero__stats { font-size:0.68rem; flex-wrap:wrap; }

  /* ── Pro tip ── */
  .protip-banner { padding:22px 16px; }
  .protip-banner__title { font-size:1.15rem; }
  .protip-banner__text { font-size:0.85rem; }

  /* ── Mundo banner ── */
  .mundo-banner { padding:28px 16px 24px; }
  .mundo-banner__title { font-size:2rem; }
  .mundo-banner__desc { font-size:0.88rem; }
  .mundo-banner__cards { grid-template-columns:1fr; gap:12px; }
  .mundo-card { padding:20px 16px; }
  .mundo-card__title { font-size:1.1rem; }
  .mundo-card__desc { font-size:0.8rem; }

  /* ── Newsletter ── */
  .newsletter-banner { flex-direction:column; text-align:center; padding:28px 16px; }
  .newsletter-banner__text h3 { font-size:1.5rem; }
  .newsletter-banner__form { flex-direction:column; width:100%; }
  .newsletter-banner__form input { min-width:auto; width:100%; padding:12px 18px; }

  /* ── Footer ── */
  .footer__grid { grid-template-columns:1fr 1fr; gap:24px; }
  .footer__bottom { flex-direction:column; gap:10px; text-align:center; }

  /* ── Single post ── */
  .post-content { padding:28px 16px; }
  .post-content p { font-size:0.95rem; line-height:1.7; }
  .post-content h2 { font-size:1.5rem; }
  .post-content h3 { font-size:1.2rem; }
  .post-content img { margin:16px 0; border-radius:12px; }
  .post-nav { grid-template-columns:1fr; }
  .author-box { flex-direction:column; align-items:center; text-align:center; padding:20px 16px; }
  .share-bar { flex-wrap:wrap; justify-content:center; gap:8px; padding:16px 0; }
  .back-to-top { bottom:16px; right:16px; width:40px; height:40px; font-size:1rem; }

  /* ── Section title ── */
  .section-title { font-size:1.6rem; margin-bottom:20px; }
}

/* Small phones */
@media (max-width:380px) {
  .logo { font-size:1.3rem; gap:6px; }
  .logo__mark { width:26px; height:26px; font-size:0.85rem; }
  .media-hero { padding:88px 0 20px; }
  .media-hero::before { font-size:3.5rem; }
  .media-hero__title { font-size:1.9rem; }
  .media-hero__sub { font-size:0.8rem; }
  .mosaic__hero { min-height:200px; }
  .mosaic__card { min-height:80px; }
  .mosaic__title { font-size:1rem; }
  .cat-banner { min-height:160px; }
  .cat-banner__title { font-size:0.95rem; }
  .cat-gallery { grid-template-columns:1fr; }
  .cat-gallery__img { height:120px; }
  .stats-bar { grid-template-columns:1fr 1fr; gap:8px; }
  .stat-item__number { font-size:1.4rem; }
  .mundo-banner__title { font-size:1.6rem; }
  .newsletter-banner__text h3 { font-size:1.1rem; }
  .footer__grid { grid-template-columns:1fr; }
  .article-card__img { height:140px; }
  .cat-mosaic-card { min-height:110px; }
  .cat-mosaic-card--big { min-height:140px; }
  .cat-fullwidth { min-height:150px; }
  .cat-scroll__card { flex:0 0 170px; }
}

/* === WordPress Single Post === */
.post-content { max-width:800px; margin:0 auto; padding:48px 24px; }
.post-content p { font-size:1.05rem; line-height:1.8; margin-bottom:1.3rem; color:var(--sm-gray-200); }
.post-content h2,.post-content h3 { font-family:var(--sm-font-display); color:var(--sm-white); margin:40px 0 14px; letter-spacing:2px; }
.post-content h2 { font-size:2rem; } .post-content h3 { font-size:1.5rem; }
.post-content img { border-radius:var(--sm-radius); margin:32px 0; }
.post-content blockquote { border-left:4px solid var(--sm-lime); padding:16px 24px; margin:32px 0; background:var(--sm-navy-light); border-radius:0 var(--sm-radius-sm) var(--sm-radius-sm) 0; font-style:italic; color:var(--sm-gray-300); }
.post-content ul,.post-content ol { margin:20px 0; padding-left:24px; }
.post-content ul li { list-style:disc; margin-bottom:8px; } .post-content ol li { list-style:decimal; margin-bottom:8px; }
.post-content a { color:var(--sm-lime); } .post-content a:hover { text-decoration:underline; }
.post-tags { display:flex; flex-wrap:wrap; gap:8px; margin-top:40px; padding-top:24px; border-top:1px solid rgba(255,255,255,0.06); }
.post-tag { padding:6px 16px; background:var(--sm-navy-light); border-radius:20px; font-size:0.78rem; color:var(--sm-gray-300); border:1px solid rgba(255,255,255,0.06); }
.post-tag:hover { border-color:var(--sm-lime); color:var(--sm-lime); }
.breadcrumbs { font-size:0.8rem; color:var(--sm-gray-400); margin-bottom:16px; font-family:var(--sm-font-mono); }
.breadcrumbs a { color:var(--sm-gray-400); } .breadcrumbs a:hover { color:var(--sm-lime); }
.breadcrumbs em { margin:0 6px; font-style:normal; }
a.filter-btn { display:inline-block; }
.wp-block-image img { border-radius:var(--sm-radius); }
.screen-reader-text { clip:rect(1px,1px,1px,1px); position:absolute; height:1px; width:1px; overflow:hidden; }

/* ============================================
   UX IMPROVEMENTS v3
   ============================================ */

/* === BACK TO TOP BUTTON === */
.back-to-top {
  position:fixed; bottom:32px; right:32px; z-index:90;
  width:48px; height:48px; border-radius:50%;
  background:var(--sm-lime); color:var(--sm-navy);
  display:flex; align-items:center; justify-content:center;
  font-size:1.2rem; cursor:pointer; border:none;
  box-shadow:0 4px 20px rgba(204,255,0,0.25);
  opacity:0; transform:translateY(20px); pointer-events:none;
  transition:var(--sm-transition);
}
.back-to-top.visible { opacity:1; transform:translateY(0); pointer-events:auto; }
.back-to-top:hover { background:var(--sm-coral); color:var(--sm-white); transform:translateY(-3px); }

/* === READING PROGRESS BAR === */
.reading-progress {
  position:fixed; top:0; left:0; height:3px; z-index:101;
  background:linear-gradient(90deg, var(--sm-lime), var(--sm-cyan));
  width:0%; transition:width 0.1s linear;
}

/* === SEARCH BAR IN HEADER === */
.header-search {
  display:flex; align-items:center; margin-right:8px;
}
.header-search__toggle {
  background:none; border:none; color:var(--sm-gray-300); cursor:pointer;
  font-size:1.1rem; padding:8px; border-radius:50%;
  transition:var(--sm-transition);
}
.header-search__toggle:hover { color:var(--sm-lime); background:rgba(204,255,0,0.08); }
.header-search__form {
  position:absolute; top:100%; right:24px; left:24px;
  background:var(--sm-navy-mid); border:1px solid rgba(204,255,0,0.15);
  border-radius:var(--sm-radius); padding:16px; display:none;
  box-shadow:0 12px 40px rgba(0,0,0,0.4);
}
.header-search__form.open { display:flex; gap:10px; }
.header-search__form input {
  flex:1; padding:12px 20px; background:rgba(255,255,255,0.06);
  border:1px solid rgba(255,255,255,0.1); border-radius:30px;
  font-family:var(--sm-font-body); font-size:0.92rem; color:var(--sm-white);
  outline:none;
}
.header-search__form input:focus { border-color:var(--sm-lime); }
.header-search__form button {
  padding:12px 24px; background:var(--sm-lime); color:var(--sm-navy);
  border:none; border-radius:30px; font-weight:700; font-size:0.82rem;
  cursor:pointer; text-transform:uppercase; letter-spacing:1px;
}

/* === SECTION DIVIDERS === */
.section-divider {
  width:100%; height:1px; margin:20px 0;
  background:linear-gradient(90deg, transparent, rgba(204,255,0,0.15), transparent);
}

/* === CATEGORY SECTION HEADERS === */
.cat-section {
  margin-bottom:56px; scroll-margin-top:100px;
}
.cat-section__header {
  display:flex; align-items:center; justify-content:space-between;
  margin-bottom:28px; padding-bottom:16px;
  border-bottom:2px solid rgba(255,255,255,0.06);
}
.cat-section__title {
  font-family:var(--sm-font-display); font-size:1.8rem;
  color:var(--sm-white); letter-spacing:2px;
  display:flex; align-items:center; gap:12px;
}
.cat-section__title-dot {
  width:10px; height:10px; border-radius:50%; flex-shrink:0;
}
.cat-section__link {
  font-size:0.78rem; font-family:var(--sm-font-mono);
  color:var(--sm-lime); text-transform:uppercase; letter-spacing:1px;
  padding:8px 18px; border:1px solid rgba(204,255,0,0.3);
  border-radius:30px;
}
.cat-section__link:hover { background:var(--sm-lime); color:var(--sm-navy); }

/* === IMPROVED ARTICLE CARD — time to read indicator === */
.article-card__read-time {
  position:absolute; top:14px; right:14px;
  padding:4px 10px; border-radius:20px;
  background:rgba(11,14,26,0.7); backdrop-filter:blur(8px);
  font-family:var(--sm-font-mono); font-size:0.6rem; font-weight:600;
  color:var(--sm-white); z-index:2;
}

/* === SINGLE POST — TABLE OF CONTENTS === */
.toc {
  background:var(--sm-navy-light); border:1px solid rgba(204,255,0,0.1);
  border-radius:var(--sm-radius); padding:28px 32px; margin:32px 0;
}
.toc__title {
  font-family:var(--sm-font-display); font-size:1.3rem;
  color:var(--sm-white); letter-spacing:2px; margin-bottom:16px;
  display:flex; align-items:center; gap:10px;
}
.toc__title::before { content:'📋'; }
.toc ol {
  list-style:none; counter-reset:toc; padding-left:0;
}
.toc ol li {
  counter-increment:toc; padding:8px 0;
  border-bottom:1px solid rgba(255,255,255,0.04);
  font-size:0.9rem;
}
.toc ol li:last-child { border-bottom:none; }
.toc ol li a {
  color:var(--sm-gray-300); display:flex; align-items:center; gap:10px;
}
.toc ol li a::before {
  content:counter(toc,decimal-leading-zero);
  font-family:var(--sm-font-mono); font-size:0.72rem;
  color:var(--sm-lime); font-weight:700; min-width:24px;
}
.toc ol li a:hover { color:var(--sm-lime); }

/* === SINGLE POST — SHARE BUTTONS === */
.share-bar {
  display:flex; align-items:center; gap:12px;
  margin:32px 0; padding:20px 0;
  border-top:1px solid rgba(255,255,255,0.06);
  border-bottom:1px solid rgba(255,255,255,0.06);
}
.share-bar__label {
  font-family:var(--sm-font-mono); font-size:0.72rem;
  color:var(--sm-gray-400); text-transform:uppercase; letter-spacing:2px;
  margin-right:8px;
}
.share-btn {
  width:40px; height:40px; border-radius:50%;
  background:var(--sm-navy-light); border:1px solid rgba(255,255,255,0.08);
  display:flex; align-items:center; justify-content:center;
  font-size:0.9rem; cursor:pointer; transition:var(--sm-transition);
  color:var(--sm-gray-300);
}
.share-btn:hover { background:var(--sm-lime); color:var(--sm-navy); border-color:var(--sm-lime); }

/* === SINGLE POST — AUTHOR BOX === */
.author-box {
  display:flex; gap:20px; padding:28px;
  background:var(--sm-navy-light); border:1px solid rgba(204,255,0,0.08);
  border-radius:var(--sm-radius); margin:40px 0;
}
.author-box__avatar {
  width:64px; height:64px; border-radius:50%; flex-shrink:0;
  background:var(--sm-lime); display:flex; align-items:center; justify-content:center;
  font-family:var(--sm-font-display); font-size:1.5rem; color:var(--sm-navy);
}
.author-box__name {
  font-weight:700; color:var(--sm-white); margin-bottom:4px; font-size:1rem;
}
.author-box__bio { font-size:0.85rem; color:var(--sm-gray-400); line-height:1.5; }

/* === SINGLE POST — NAV PREV/NEXT === */
.post-nav {
  display:grid; grid-template-columns:1fr 1fr; gap:20px;
  margin:40px 0;
}
.post-nav__item {
  padding:24px; background:var(--sm-navy-light);
  border:1px solid rgba(255,255,255,0.05); border-radius:var(--sm-radius-sm);
  transition:var(--sm-transition); display:block;
}
.post-nav__item:hover { border-color:var(--sm-lime); }
.post-nav__label {
  font-family:var(--sm-font-mono); font-size:0.7rem;
  color:var(--sm-gray-400); text-transform:uppercase; letter-spacing:1px;
  display:block; margin-bottom:8px;
}
.post-nav__title {
  font-weight:700; color:var(--sm-white); font-size:0.92rem; line-height:1.3;
}

/* === LOAD MORE — AJAX PAGINATION === */
.load-more-btn {
  padding:14px 40px; background:transparent;
  border:2px solid var(--sm-lime); color:var(--sm-lime);
  border-radius:30px; font-family:var(--sm-font-body);
  font-weight:700; font-size:0.85rem; cursor:pointer;
  text-transform:uppercase; letter-spacing:1px;
  transition:var(--sm-transition); display:inline-block;
}
.load-more-btn:hover { background:var(--sm-lime); color:var(--sm-navy); }
.load-more-btn.loading { opacity:0.6; pointer-events:none; }

/* ============================================
   EDITORIAL HOME — MAGAZINE LAYOUTS v2
   ============================================ */

/* === MOSAIC: Hero + 3 sub-heroes === */
.mosaic {
  display:grid; grid-template-columns:1.5fr 1fr; gap:20px;
  margin-bottom:48px;
}
.mosaic__hero {
  position:relative; border-radius:var(--sm-radius); overflow:hidden;
  min-height:560px; display:block;
}
.mosaic__bg { position:absolute; inset:0; }
.mosaic__img { position:absolute; inset:0; width:100%; height:100%; object-fit:cover; transition:transform 0.7s ease; }
.mosaic__hero:hover .mosaic__img { transform:scale(1.04); }
.mosaic__overlay {
  position:absolute; bottom:0; left:0; right:0; padding:36px;
  background:linear-gradient(to top, rgba(11,14,26,0.95) 0%, rgba(11,14,26,0.5) 60%, transparent 100%);
  z-index:2;
}
.mosaic__title {
  font-family:var(--sm-font-display); font-size:clamp(1.8rem,3vw,2.5rem);
  color:var(--sm-white); letter-spacing:1px; line-height:1.05; margin:12px 0 10px;
}
.mosaic__excerpt { font-size:0.88rem; color:var(--sm-gray-300); line-height:1.5; max-width:95%; }

.mosaic__side { display:flex; flex-direction:column; gap:12px; }
.mosaic__card {
  position:relative; flex:1; border-radius:var(--sm-radius-sm); overflow:hidden;
  display:block; min-height:170px;
}
.mosaic__card-bg { position:absolute; inset:0; }
.mosaic__card-img { position:absolute; inset:0; width:100%; height:100%; object-fit:cover; transition:transform 0.5s ease; opacity:0.7; }
.mosaic__card:hover .mosaic__card-img { transform:scale(1.06); opacity:0.85; }
.mosaic__card-overlay {
  position:absolute; bottom:0; left:0; right:0; padding:18px 20px;
  background:linear-gradient(to top, rgba(11,14,26,0.92) 0%, transparent 100%);
  z-index:2;
}
.mosaic__card-title { font-size:0.95rem; font-weight:700; color:var(--sm-white); line-height:1.25; margin-top:8px; }
.mosaic__card-meta { font-size:0.7rem; color:var(--sm-gray-400); font-family:var(--sm-font-mono); margin-top:6px; display:block; }

/* === CATEGORY MEGA BLOCKS === */
.cat-block { margin-bottom:24px; }
.cat-block__header {
  display:flex; align-items:center; justify-content:space-between;
  margin-bottom:24px;
}
.cat-block__label {
  display:inline-flex; align-items:center; gap:8px;
  padding:8px 22px; border-radius:30px;
  font-family:var(--sm-font-display); font-size:1.1rem;
  letter-spacing:2px;
}
.cat-block__icon { font-size:1rem; }

/* Layout A: Banner + list */
.cat-layout-a {
  display:grid; grid-template-columns:1.4fr 0.6fr; gap:24px;
}
.cat-banner {
  position:relative; display:block; border-radius:var(--sm-radius);
  overflow:hidden; min-height:340px; border:1px solid rgba(255,255,255,0.05);
}
.cat-banner__bg { position:absolute; inset:0; }
.cat-banner__img {
  position:absolute; inset:0; width:100%; height:100%; object-fit:cover;
  transition:transform 0.6s ease; opacity:0.6;
}
.cat-banner:hover .cat-banner__img { transform:scale(1.04); opacity:0.75; }
.cat-banner__text {
  position:absolute; bottom:0; left:0; right:0; padding:32px;
  background:linear-gradient(to top, rgba(11,14,26,0.95), transparent);
  z-index:2;
}
.cat-banner__title {
  font-family:var(--sm-font-display); font-size:clamp(1.3rem,2.5vw,1.9rem);
  color:var(--sm-white); letter-spacing:1px; line-height:1.08; margin-bottom:10px;
}
.cat-banner__excerpt { font-size:0.85rem; color:var(--sm-gray-300); line-height:1.5; margin-bottom:10px; }
.cat-banner__meta { font-size:0.72rem; color:var(--sm-gray-400); font-family:var(--sm-font-mono); }

.cat-list { display:flex; flex-direction:column; gap:8px; }
.cat-list__item {
  display:flex; align-items:flex-start; gap:14px;
  padding:18px 16px; background:var(--sm-navy-light);
  border:1px solid rgba(255,255,255,0.04); border-radius:var(--sm-radius-sm);
  transition:var(--sm-transition); flex:1;
}
.cat-list__item:hover { border-color:var(--sm-lime); transform:translateX(4px); }
.cat-list__dot { width:8px; height:8px; border-radius:50%; flex-shrink:0; margin-top:6px; }
.cat-list__title { font-size:0.92rem; font-weight:600; color:var(--sm-white); line-height:1.3; margin-bottom:6px; }
.cat-list__meta { font-size:0.7rem; color:var(--sm-gray-400); font-family:var(--sm-font-mono); }

/* Layout B: 2-column feature */
.cat-layout-b { display:grid; grid-template-columns:1fr 1fr; gap:20px; }
.cat-feature {
  display:block; background:var(--sm-navy-light);
  border:1px solid rgba(255,255,255,0.05); border-radius:var(--sm-radius);
  overflow:hidden; transition:var(--sm-transition);
}
.cat-feature:hover { border-color:var(--sm-lime); transform:translateY(-4px); box-shadow:0 12px 40px rgba(204,255,0,0.06); }
.cat-feature__img {
  height:200px; overflow:hidden; position:relative;
}
.cat-feature__img img { width:100%; height:100%; object-fit:cover; transition:transform 0.5s ease; }
.cat-feature:hover .cat-feature__img img { transform:scale(1.06); }
.cat-feature__body { padding:22px; }
.cat-feature__title { font-size:1.05rem; font-weight:700; color:var(--sm-white); line-height:1.3; margin-bottom:8px; }
.cat-feature__excerpt { font-size:0.83rem; color:var(--sm-gray-400); line-height:1.5; margin-bottom:10px; }
.cat-feature__meta { font-size:0.72rem; color:var(--sm-gray-400); font-family:var(--sm-font-mono); }

/* Layout C: Horizontal scroll */
.cat-scroll {
  display:flex; gap:20px; overflow-x:auto; padding-bottom:16px;
  scroll-snap-type:x mandatory;
  -ms-overflow-style:none; scrollbar-width:thin;
  scrollbar-color:var(--sm-navy-light) transparent;
}
.cat-scroll::-webkit-scrollbar { height:6px; }
.cat-scroll::-webkit-scrollbar-track { background:transparent; }
.cat-scroll::-webkit-scrollbar-thumb { background:var(--sm-navy-light); border-radius:3px; }
.cat-scroll__card {
  flex:0 0 280px; scroll-snap-align:start;
  background:var(--sm-navy-light); border:1px solid rgba(255,255,255,0.05);
  border-radius:var(--sm-radius-sm); overflow:hidden;
  transition:var(--sm-transition); display:block;
}
.cat-scroll__card:hover { border-color:var(--sm-lime); transform:translateY(-4px); }
.cat-scroll__img {
  height:160px; overflow:hidden; position:relative;
}
.cat-scroll__img img { width:100%; height:100%; object-fit:cover; transition:transform 0.5s ease; }
.cat-scroll__card:hover .cat-scroll__img img { transform:scale(1.06); }
.cat-scroll__title { font-size:0.92rem; font-weight:700; color:var(--sm-white); line-height:1.3; padding:16px 16px 6px; }
.cat-scroll__meta { font-size:0.7rem; color:var(--sm-gray-400); font-family:var(--sm-font-mono); padding:0 16px 16px; display:block; }

/* ============================================
   CATEGORY HERO HEADER — per-section landing
   ============================================ */
.cat-hero {
  padding:32px; margin-bottom:32px;
  background:var(--sm-navy-light);
  border:1px solid rgba(255,255,255,0.06);
  border-radius:var(--sm-radius);
  position:relative; overflow:hidden;
}
.cat-hero__accent {
  position:absolute; top:0; left:0; bottom:0; width:5px;
}
.cat-hero__content {
  display:flex; align-items:center; gap:20px;
  position:relative; z-index:2;
}
.cat-hero__icon {
  width:56px; height:56px; border-radius:14px; flex-shrink:0;
  display:flex; align-items:center; justify-content:center;
  font-size:1.6rem;
}
.cat-hero__title {
  font-family:var(--sm-font-display); font-size:2.2rem;
  color:var(--sm-white); letter-spacing:3px; line-height:1;
}
.cat-hero__desc {
  font-size:0.92rem; color:var(--sm-gray-300); margin-top:6px; line-height:1.4;
}
.cat-hero__stats {
  display:flex; gap:8px; margin-top:8px;
  font-size:0.75rem; color:var(--sm-gray-400);
  font-family:var(--sm-font-mono);
}

/* Category block description */
.cat-block__desc {
  font-size:0.82rem; color:var(--sm-gray-400);
  margin-top:8px; line-height:1.4;
}

/* Smooth section transitions */
.home-section {
  animation:sectionFadeIn 0.5s ease;
}
@keyframes sectionFadeIn {
  from { opacity:0; transform:translateY(20px); }
  to { opacity:1; transform:translateY(0); }
}

/* ============================================
   LAYOUT VARIATIONS v2 — 7 unique styles
   ============================================ */

/* ━━ LAYOUT 2: Mosaic 2x2 grid ━━ */
.cat-mosaic-grid {
  display:grid; grid-template-columns:1.3fr 0.7fr; grid-template-rows:1fr 1fr;
  gap:14px; min-height:440px;
}
.cat-mosaic-card {
  position:relative; border-radius:var(--sm-radius-sm); overflow:hidden; display:block;
}
.cat-mosaic-card--big { grid-row:1/3; }
.cat-mosaic-card__bg { position:absolute; inset:0; }
.cat-mosaic-card__img { position:absolute; inset:0; width:100%; height:100%; object-fit:cover; transition:transform 0.6s ease; opacity:0.55; }
.cat-mosaic-card:hover .cat-mosaic-card__img { transform:scale(1.06); opacity:0.75; }
.cat-mosaic-card__text {
  position:absolute; bottom:0; left:0; right:0; padding:20px;
  background:linear-gradient(to top,rgba(11,14,26,0.92),transparent); z-index:2;
}
.cat-mosaic-card__text h3 { font-size:1rem; font-weight:700; color:var(--sm-white); line-height:1.25; margin-bottom:4px; }
.cat-mosaic-card--big .cat-mosaic-card__text h3 { font-family:var(--sm-font-display); font-size:clamp(1.3rem,2.5vw,1.8rem); letter-spacing:1px; }
.cat-mosaic-card__text p { font-size:0.82rem; color:var(--sm-gray-300); line-height:1.4; margin-bottom:6px; }
.cat-mosaic-card__text span { font-size:0.7rem; color:var(--sm-gray-400); font-family:var(--sm-font-mono); }

/* ━━ LAYOUT 4: Full-width featured ━━ */
.cat-fullwidth {
  position:relative; display:block; border-radius:var(--sm-radius); overflow:hidden;
  min-height:320px; border:1px solid rgba(255,255,255,0.05);
}
.cat-fullwidth__bg { position:absolute; inset:0; }
.cat-fullwidth__img { position:absolute; inset:0; width:100%; height:100%; object-fit:cover; transition:transform 0.6s ease; opacity:0.45; }
.cat-fullwidth:hover .cat-fullwidth__img { transform:scale(1.04); opacity:0.6; }
.cat-fullwidth__text {
  position:absolute; bottom:0; left:0; right:0; padding:36px;
  background:linear-gradient(to top,rgba(11,14,26,0.95),transparent); z-index:2;
}
.cat-fullwidth__text h3 { font-family:var(--sm-font-display); font-size:clamp(1.4rem,3vw,2.2rem); color:var(--sm-white); letter-spacing:1px; line-height:1.05; margin-bottom:10px; }
.cat-fullwidth__text p { font-size:0.88rem; color:var(--sm-gray-300); line-height:1.5; max-width:700px; margin-bottom:10px; }
.cat-fullwidth__text span { font-size:0.72rem; color:var(--sm-gray-400); font-family:var(--sm-font-mono); }

/* ━━ LAYOUT 6: Compact gallery ━━ */
.cat-gallery {
  display:grid; grid-template-columns:repeat(4,1fr); gap:14px;
}
.cat-gallery__item {
  display:block; background:var(--sm-navy-light);
  border:1px solid rgba(255,255,255,0.05); border-radius:var(--sm-radius-sm);
  overflow:hidden; transition:var(--sm-transition);
}
.cat-gallery__item:hover { border-color:var(--sm-lime); transform:translateY(-4px); }
.cat-gallery__img { height:140px; overflow:hidden; }
.cat-gallery__img img { width:100%; height:100%; object-fit:cover; transition:transform 0.5s ease; }
.cat-gallery__item:hover .cat-gallery__img img { transform:scale(1.08); }
.cat-gallery__info { padding:14px; }
.cat-gallery__info h4 { font-size:0.85rem; font-weight:700; color:var(--sm-white); line-height:1.25; margin-bottom:6px; }
.cat-gallery__info span { font-size:0.68rem; color:var(--sm-gray-400); font-family:var(--sm-font-mono); }

/* ━━ LAYOUT 7: Editorial numbered list ━━ */
.cat-editorial { display:flex; flex-direction:column; gap:2px; }
.cat-editorial__row {
  display:flex; align-items:center; gap:20px; padding:18px 20px;
  background:var(--sm-navy-light); border-radius:var(--sm-radius-sm);
  transition:var(--sm-transition); border:1px solid rgba(255,255,255,0.03);
}
.cat-editorial__row:hover { border-color:var(--sm-lime); transform:translateX(6px); }
.cat-editorial__row--featured { padding:24px 20px; background:var(--sm-navy-mid); }
.cat-editorial__num {
  font-family:var(--sm-font-display); font-size:2rem; letter-spacing:1px;
  flex-shrink:0; min-width:44px; text-align:center; opacity:0.8;
}
.cat-editorial__row--featured .cat-editorial__num { font-size:2.8rem; }
.cat-editorial__content { flex:1; }
.cat-editorial__content h4 { font-size:0.95rem; font-weight:700; color:var(--sm-white); line-height:1.3; margin-bottom:4px; }
.cat-editorial__row--featured .cat-editorial__content h4 { font-size:1.1rem; }
.cat-editorial__content p { font-size:0.82rem; color:var(--sm-gray-400); line-height:1.4; margin-bottom:4px; }
.cat-editorial__content span { font-size:0.7rem; color:var(--sm-gray-400); font-family:var(--sm-font-mono); }
.cat-editorial__arrow { font-size:1.2rem; color:var(--sm-gray-400); transition:var(--sm-transition); flex-shrink:0; }
.cat-editorial__row:hover .cat-editorial__arrow { color:var(--sm-lime); transform:translateX(4px); }

/* ============================================
   INTERACTIVE ELEMENTS — Tips, Facts, etc.
   ============================================ */

/* Tip card */
.tip-card {
  display:flex; gap:16px; align-items:flex-start;
  padding:20px 24px; margin:20px 0 28px;
  background:var(--sm-navy-light); border-left:4px solid var(--sm-lime);
  border-radius:0 var(--sm-radius-sm) var(--sm-radius-sm) 0;
}
.tip-card__icon { font-size:1.4rem; flex-shrink:0; margin-top:2px; }
.tip-card__label { font-family:var(--sm-font-mono); font-size:0.65rem; font-weight:700; text-transform:uppercase; letter-spacing:2px; margin-bottom:4px; }
.tip-card__text { font-size:0.9rem; color:var(--sm-gray-200); line-height:1.5; }

/* Fact card */
.fact-card {
  display:flex; align-items:center; gap:16px;
  padding:20px 24px; margin:24px 0;
  border:1px solid rgba(255,255,255,0.06); border-radius:var(--sm-radius-sm);
}
.fact-card__label {
  padding:5px 12px; border-radius:20px;
  font-family:var(--sm-font-mono); font-size:0.6rem; font-weight:700;
  text-transform:uppercase; letter-spacing:2px; flex-shrink:0;
}
.fact-card__text { font-size:0.9rem; color:var(--sm-gray-200); line-height:1.5; }

/* ============================================
   NAV DROPDOWN — Mundo SMASHLINE
   ============================================ */
.nav-dropdown { position:relative; }
.nav-dropdown__toggle {
  padding:8px 18px; font-size:0.82rem; font-weight:500; color:var(--sm-gray-300);
  border-radius:30px; background:none; border:none; cursor:pointer;
  font-family:var(--sm-font-body); transition:var(--sm-transition);
  display:flex; align-items:center; gap:4px;
}
.nav-dropdown__toggle:hover { color:var(--sm-white); background:rgba(204,255,0,0.08); }
.nav-dropdown__arrow { font-size:0.65rem; transition:transform 0.3s ease; }
.nav-dropdown.open .nav-dropdown__arrow { transform:rotate(180deg); }
.nav-dropdown__menu {
  display:none; position:absolute; top:calc(100% + 12px); right:0;
  width:320px; background:var(--sm-navy-mid);
  border:1px solid rgba(204,255,0,0.12); border-radius:var(--sm-radius);
  padding:8px; box-shadow:0 16px 48px rgba(0,0,0,0.5);
  z-index:200;
}
.nav-dropdown.open .nav-dropdown__menu { display:block; animation:dropIn 0.25s ease; }
@keyframes dropIn { from { opacity:0; transform:translateY(-8px); } to { opacity:1; transform:translateY(0); } }
.nav-dropdown__item {
  display:flex; align-items:center; gap:14px; padding:14px 16px;
  border-radius:var(--sm-radius-sm); transition:var(--sm-transition);
}
.nav-dropdown__item:hover { background:rgba(204,255,0,0.06); }
.nav-dropdown__icon {
  width:42px; height:42px; border-radius:10px; flex-shrink:0;
  display:flex; align-items:center; justify-content:center;
  font-size:1.2rem; background:var(--sm-navy-light);
}
.nav-dropdown__item strong { display:block; font-size:0.88rem; color:var(--sm-white); font-weight:600; }
.nav-dropdown__item small { display:block; font-size:0.73rem; color:var(--sm-gray-400); margin-top:2px; }

/* Nav overflow scroll on desktop when many items */
.nav { overflow-x:auto; scrollbar-width:none; -ms-overflow-style:none; }
.nav::-webkit-scrollbar { display:none; }

/* ============================================
   MUNDO SMASHLINE BANNER — home section
   ============================================ */
.mundo-banner {
  position:relative; margin:48px 0 20px;
  background:var(--sm-navy-mid); border:1px solid rgba(204,255,0,0.08);
  border-radius:var(--sm-radius); padding:56px 48px 48px; overflow:hidden;
}
.mundo-banner__glow {
  position:absolute; top:-80px; right:-80px;
  width:300px; height:300px; border-radius:50%;
  background:radial-gradient(circle, rgba(204,255,0,0.08), rgba(55,66,250,0.04), transparent);
  pointer-events:none;
}
.mundo-banner__tag {
  display:inline-block; font-family:var(--sm-font-mono); font-size:0.68rem;
  font-weight:700; color:var(--sm-lime); text-transform:uppercase;
  letter-spacing:3px; margin-bottom:12px;
}
.mundo-banner__tag::before { content:'◆ '; }
.mundo-banner__title {
  font-family:var(--sm-font-display); font-size:clamp(2.5rem,5vw,4rem);
  color:var(--sm-white); letter-spacing:3px; line-height:0.95; margin-bottom:16px;
}
.mundo-banner__title span { color:var(--sm-lime); }
.mundo-banner__desc {
  font-size:1rem; color:var(--sm-gray-300); line-height:1.7;
  max-width:720px; margin-bottom:40px;
}
.mundo-banner__cards {
  display:grid; grid-template-columns:repeat(3,1fr); gap:20px;
  position:relative; z-index:2;
}
.mundo-card {
  padding:28px 24px; background:var(--sm-navy-light);
  border:1px solid rgba(255,255,255,0.06); border-radius:var(--sm-radius-sm);
  transition:var(--sm-transition); display:block;
}
.mundo-card:hover {
  border-color:var(--sm-lime); transform:translateY(-6px);
  box-shadow:0 12px 40px rgba(204,255,0,0.08);
}
.mundo-card__icon {
  width:48px; height:48px; border-radius:12px;
  display:flex; align-items:center; justify-content:center;
  font-size:1.3rem; margin-bottom:16px;
}
.mundo-card__title {
  font-family:var(--sm-font-display); font-size:1.3rem;
  color:var(--sm-white); letter-spacing:1px; margin-bottom:8px;
}
.mundo-card__desc {
  font-size:0.84rem; color:var(--sm-gray-400); line-height:1.5; margin-bottom:16px;
}
.mundo-card__cta {
  font-size:0.78rem; font-weight:700; color:var(--sm-lime);
  font-family:var(--sm-font-mono); text-transform:uppercase; letter-spacing:1px;
}
.mundo-card:hover .mundo-card__cta { text-decoration:underline; }


/* ============================================
   SUB-FILTERS — contextual within categories
   ============================================ */
.sub-filters {
  display:flex; gap:6px; flex-wrap:nowrap; overflow-x:auto;
  padding:16px 0 20px; margin-bottom:8px;
  scrollbar-width:none; -ms-overflow-style:none;
  border-bottom:1px solid rgba(255,255,255,0.06);
}
.sub-filters::-webkit-scrollbar { display:none; }
.sub-filter {
  padding:7px 18px; background:var(--sm-navy-light);
  border:1px solid rgba(255,255,255,0.08); border-radius:30px;
  font-family:var(--sm-font-body); font-size:0.78rem; font-weight:500;
  color:var(--sm-gray-300); cursor:pointer; transition:var(--sm-transition);
  white-space:nowrap; flex-shrink:0;
}
.sub-filter:hover { border-color:var(--accent, var(--sm-lime)); color:var(--accent, var(--sm-lime)); }
.sub-filter.active {
  background:var(--accent, var(--sm-lime)); color:var(--sm-navy);
  border-color:var(--accent, var(--sm-lime)); font-weight:700;
}

/* ============================================
   INTERACTIVE ELEMENTS v2
   ============================================ */

/* ¿Sabías que? rotating card */
.sabias-que {
  display:flex; align-items:center; gap:16px;
  padding:20px 24px; margin:24px 0;
  background:linear-gradient(135deg,rgba(55,66,250,0.1),rgba(204,255,0,0.05));
  border:1px solid rgba(204,255,0,0.12); border-radius:var(--sm-radius);
}
.sabias-que__icon { font-size:1.8rem; flex-shrink:0; }
.sabias-que__label {
  font-family:var(--sm-font-mono); font-size:0.65rem; font-weight:700;
  color:var(--sm-lime); text-transform:uppercase; letter-spacing:2px; margin-bottom:4px;
}
.sabias-que__text { font-size:0.92rem; color:var(--sm-gray-200); line-height:1.5; transition:opacity 0.25s ease; }
.sabias-que__content { flex:1; }
.sabias-que__next {
  width:40px; height:40px; border-radius:50%; flex-shrink:0;
  background:var(--sm-navy-light); border:1px solid rgba(204,255,0,0.2);
  color:var(--sm-lime); font-size:1.1rem; cursor:pointer;
  display:flex; align-items:center; justify-content:center;
  transition:var(--sm-transition);
}
.sabias-que__next:hover { background:var(--sm-lime); color:var(--sm-navy); }

/* Stats counter bar */
.stats-bar {
  display:flex; justify-content:space-around; gap:16px;
  padding:28px 20px; margin:20px 0 32px;
  background:var(--sm-navy-light); border:1px solid rgba(255,255,255,0.05);
  border-radius:var(--sm-radius);
}
.stat-item { text-align:center; }
.stat-item__number {
  display:block; font-family:var(--sm-font-display);
  font-size:clamp(2rem,4vw,3rem); color:var(--sm-lime); letter-spacing:1px;
}
.stat-item__label { font-size:0.72rem; color:var(--sm-gray-400); font-family:var(--sm-font-mono); text-transform:uppercase; letter-spacing:1px; }

/* Quiz card */
.quiz-card {
  padding:20px 24px; background:var(--sm-navy-light);
  border:1px solid rgba(255,255,255,0.06); border-radius:var(--sm-radius-sm);
}
.quiz-card__label {
  font-family:var(--sm-font-mono); font-size:0.6rem; font-weight:700;
  color:var(--qcolor,var(--sm-lime)); text-transform:uppercase; letter-spacing:2px; margin-bottom:8px;
}
.quiz-card__q { font-size:0.95rem; color:var(--sm-white); font-weight:600; line-height:1.3; margin-bottom:14px; }
.quiz-card__options { display:flex; gap:10px; }
.quiz-card__opt {
  flex:1; padding:10px 16px; background:rgba(255,255,255,0.04);
  border:1px solid rgba(255,255,255,0.1); border-radius:30px;
  font-family:var(--sm-font-body); font-size:0.82rem; font-weight:600;
  color:var(--sm-gray-200); cursor:pointer; transition:var(--sm-transition);
}
.quiz-card__opt:hover:not(:disabled) { border-color:var(--qcolor,var(--sm-lime)); color:var(--qcolor,var(--sm-lime)); }
.quiz-card__opt:disabled { cursor:default; opacity:0.6; }
.quiz-card__opt--correct { background:rgba(0,184,148,0.2) !important; border-color:#00b894 !important; color:#00b894 !important; opacity:1 !important; }
.quiz-card__opt--wrong { background:rgba(255,71,87,0.2) !important; border-color:#ff4757 !important; color:#ff4757 !important; opacity:1 !important; }
.quiz-card__result { display:none; margin-top:12px; font-size:0.82rem; font-weight:600; }

/* Interactive row (tip + quiz side by side) */
.interactive-row { display:flex; gap:16px; margin:20px 0 28px; }

/* Pro tip banner */
.protip-banner {
  padding:32px; background:var(--sm-navy-light);
  border:1px solid rgba(0,184,148,0.15); border-radius:var(--sm-radius);
  position:relative;
}
.protip-banner__badge {
  display:inline-block; padding:4px 14px; margin-bottom:12px;
  background:#00b894; color:var(--sm-white); border-radius:20px;
  font-family:var(--sm-font-mono); font-size:0.6rem; font-weight:700;
  text-transform:uppercase; letter-spacing:2px;
}
.protip-banner__title { font-family:var(--sm-font-display); font-size:1.5rem; color:var(--sm-white); letter-spacing:1px; margin-bottom:10px; }
.protip-banner__text { font-size:0.92rem; color:var(--sm-gray-300); line-height:1.6; max-width:800px; }
.protip-banner__text strong { color:var(--sm-lime); }

/* ── Quiz improvements ── */
.quiz-card__header { display:flex; justify-content:space-between; align-items:center; margin-bottom:8px; }
.quiz-card__score { font-family:var(--sm-font-mono); font-size:0.75rem; color:var(--qcolor,var(--sm-lime)); font-weight:700; }
.quiz-card__next {
  margin-top:12px; padding:8px 20px;
  background:transparent; border:1px solid var(--qcolor,var(--sm-lime));
  color:var(--qcolor,var(--sm-lime)); border-radius:30px;
  font-family:var(--sm-font-body); font-size:0.78rem; font-weight:700;
  cursor:pointer; transition:var(--sm-transition);
}
.quiz-card__next:hover { background:var(--qcolor,var(--sm-lime)); color:var(--sm-navy); }
.sabias-que__counter {
  font-family:var(--sm-font-mono); font-size:0.65rem; color:var(--sm-gray-400);
  flex-shrink:0; white-space:nowrap;
}
