/*
Theme Name: Rural y Campo
Theme URI: https://campolibre.com
Author: Campo Libre Digital
Description: Rural y Campo — Conocimiento Rural. Diario digital agropecuario con MetaHumano IA, clasificados, 5 idiomas y pasarelas de pago.
Version: 2.0.0
Requires at least: 6.0
Text Domain: campo-libre
Tags: news, rural, magazine, classifieds, multilingual
*/

/* =====================================================
   TOKENS DE DISEÑO
===================================================== */
:root {
  --c-verde:       #1B5E20;
  --c-verde-2:     #2E7D32;
  --c-verde-3:     #43A047;
  --c-verde-4:     #A5D6A7;
  --c-verde-bg:    #F1F8F1;
  --c-tierra:      #4E342E;
  --c-tierra-2:    #6D4C41;
  --c-trigo:       #F9A825;
  --c-trigo-2:     #FDD835;
  --c-acento:      #E65100;
  --c-acento-2:    #FF6D00;
  --c-crema:       #FAFAF7;
  --c-fondo:       #F4F4F0;
  --c-blanco:      #FFFFFF;
  --c-negro:       #111111;
  --c-texto:       #1C1C1C;
  --c-texto-2:     #444444;
  --c-texto-3:     #777777;
  --c-borde:       #E0DDD8;
  --c-borde-2:     #C8C4BE;
  --c-surface:     #FFFFFF;
  --c-surface-2:   #F8F7F4;

  --font-head:  'Playfair Display', Georgia, serif;
  --font-body:  'Lora', 'Times New Roman', serif;
  --font-ui:    'Inter', 'Source Sans 3', system-ui, sans-serif;
  --font-mono:  'JetBrains Mono', 'Courier New', monospace;

  --r-sm:  4px;
  --r-md:  8px;
  --r-lg:  14px;
  --r-xl:  20px;
  --r-2xl: 28px;

  --sh-1: 0 1px 3px rgba(0,0,0,.06), 0 1px 2px rgba(0,0,0,.04);
  --sh-2: 0 4px 12px rgba(0,0,0,.08), 0 2px 4px rgba(0,0,0,.04);
  --sh-3: 0 8px 28px rgba(0,0,0,.12), 0 4px 8px rgba(0,0,0,.04);
  --sh-verde: 0 4px 16px rgba(27,94,32,.2);

  --t: all .22s cubic-bezier(.4,0,.2,1);
  --max-w: 1320px;
}

/* =====================================================
   RESET
===================================================== */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:16px;scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:var(--font-body);color:var(--c-texto);background:var(--c-fondo);line-height:1.75;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}
img{max-width:100%;height:auto;display:block}
a{color:var(--c-verde-2);text-decoration:none;transition:var(--t)}
a:hover{color:var(--c-acento)}
ul,ol{list-style:none}
button{cursor:pointer;font-family:inherit}
input,select,textarea{font-family:var(--font-ui)}

/* =====================================================
   TIPOGRAFÍA
===================================================== */
h1,h2,h3,h4,h5,h6{font-family:var(--font-head);font-weight:700;line-height:1.18;color:var(--c-tierra);letter-spacing:-.01em}
h1{font-size:clamp(1.9rem,4.5vw,3.2rem)}
h2{font-size:clamp(1.4rem,3vw,2.2rem)}
h3{font-size:clamp(1.15rem,2.5vw,1.55rem)}
h4{font-size:1.15rem}
p{margin-bottom:1rem;font-size:1.06rem;color:var(--c-texto-2)}
blockquote{border-left:4px solid var(--c-trigo);padding:1rem 1.5rem;margin:2rem 0;font-style:italic;font-size:1.18rem;color:var(--c-tierra);background:var(--c-verde-bg);border-radius:0 var(--r-md) var(--r-md) 0}
.lead{font-size:1.22rem;font-style:italic;color:var(--c-texto-3);line-height:1.6}

/* =====================================================
   LAYOUT
===================================================== */
.contenedor{max-width:var(--max-w);margin:0 auto;padding:0 24px}
.contenedor-sm{max-width:880px;margin:0 auto;padding:0 24px}
.grilla-principal{display:grid;grid-template-columns:1fr 340px;gap:48px;align-items:start}
.grilla-3{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.grilla-2{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}
.grilla-auto{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:24px}

/* =====================================================
   BARRA SUPERIOR
===================================================== */
.barra-sup{background:var(--c-tierra);color:rgba(255,255,255,.85);font-family:var(--font-ui);font-size:11.5px;letter-spacing:.01em}
.barra-sup .inner{max-width:var(--max-w);margin:0 auto;padding:6px 24px;display:flex;justify-content:space-between;align-items:center;gap:12px}
.idiomas{display:flex;gap:4px}
.idioma-btn{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.12);color:rgba(255,255,255,.75);padding:3px 10px;border-radius:24px;font-size:10.5px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;transition:var(--t);cursor:pointer}
.idioma-btn:hover,.idioma-btn.activo{background:var(--c-trigo);color:var(--c-tierra);border-color:var(--c-trigo)}
.barra-sup-der{display:flex;gap:16px;align-items:center}
.barra-sup-der a{color:rgba(255,255,255,.7);font-size:11px;display:flex;align-items:center;gap:4px}
.barra-sup-der a:hover{color:var(--c-trigo)}

/* =====================================================
   CABECERA
===================================================== */
.cabecera{background:var(--c-blanco);border-bottom:2px solid var(--c-verde-4);box-shadow:var(--sh-1);position:sticky;top:0;z-index:900}
.cab-inner{max-width:var(--max-w);margin:0 auto;padding:12px 24px;display:flex;align-items:center;gap:20px}
.logo{display:flex;flex-direction:column;line-height:1;flex-shrink:0;text-decoration:none}
.logo-nombre{font-family:var(--font-head);font-size:1.9rem;font-weight:900;color:var(--c-verde);letter-spacing:-.03em;line-height:1}
.logo-slogan{font-family:var(--font-ui);font-size:9.5px;color:var(--c-trigo);text-transform:uppercase;letter-spacing:.18em;font-weight:700;margin-top:2px}
.cab-search{flex:1;max-width:420px;position:relative}
.cab-search input{width:100%;height:40px;padding:0 44px 0 16px;border:1.5px solid var(--c-borde);border-radius:24px;font-size:13.5px;background:var(--c-fondo);outline:none;transition:var(--t);color:var(--c-texto)}
.cab-search input:focus{border-color:var(--c-verde-3);background:var(--c-blanco);box-shadow:0 0 0 3px rgba(67,160,71,.12)}
.cab-search input::placeholder{color:var(--c-texto-3)}
.cab-search .ico-search{position:absolute;right:14px;top:50%;transform:translateY(-50%);color:var(--c-texto-3);font-size:14px;pointer-events:none}
.busq-resultados{position:absolute;top:calc(100% + 6px);left:0;right:0;background:var(--c-blanco);border:1px solid var(--c-borde);border-radius:var(--r-lg);box-shadow:var(--sh-3);z-index:999;overflow:hidden;max-height:420px;overflow-y:auto}
.busq-item{display:flex;align-items:center;gap:12px;padding:10px 14px;border-bottom:1px solid var(--c-fondo);transition:var(--t)}
.busq-item:last-child{border-bottom:none}
.busq-item:hover{background:var(--c-verde-bg)}
.busq-item img,.busq-thumb{width:52px;height:38px;object-fit:cover;border-radius:var(--r-sm);flex-shrink:0}
.busq-thumb{background:var(--c-verde-3);display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,.3)}
.busq-title{font-family:var(--font-ui);font-size:13px;font-weight:600;color:var(--c-texto);line-height:1.3}
.busq-meta{font-size:11px;color:var(--c-texto-3);margin-top:2px}
.cab-acciones{display:flex;gap:8px;align-items:center;margin-left:auto;flex-shrink:0}
.btn-pub{background:var(--c-acento);color:#fff;padding:9px 18px;border-radius:var(--r-md);font-family:var(--font-ui);font-size:12.5px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;transition:var(--t);border:none;display:flex;align-items:center;gap:6px}
.btn-pub:hover{background:var(--c-tierra);color:#fff;transform:translateY(-1px);box-shadow:var(--sh-2)}

/* =====================================================
   NAVEGACIÓN PRINCIPAL
===================================================== */
.nav-wrap{background:var(--c-verde);position:relative}
.nav-wrap::after{content:'';position:absolute;bottom:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--c-trigo),var(--c-acento-2),var(--c-trigo))}
.nav-inner{max-width:var(--max-w);margin:0 auto;padding:0 24px;display:flex;align-items:stretch}
.nav-inner ul{display:flex;align-items:stretch}
.nav-inner ul li{position:relative}
.nav-inner ul li > a{display:flex;align-items:center;padding:11px 14px;color:rgba(255,255,255,.88);font-family:var(--font-ui);font-size:12.5px;font-weight:600;letter-spacing:.05em;text-transform:uppercase;transition:var(--t);position:relative;gap:4px;height:100%}
.nav-inner ul li > a::before{content:'';position:absolute;bottom:0;left:50%;transform:translateX(-50%);width:0;height:3px;background:var(--c-trigo);transition:width .2s ease}
.nav-inner ul li > a:hover,.nav-inner ul li > a.activo{color:#fff;background:rgba(255,255,255,.08)}
.nav-inner ul li > a:hover::before,.nav-inner ul li > a.activo::before{width:calc(100% - 16px)}
.nav-inner ul li:hover > ul{display:flex}
.nav-inner ul li ul{display:none;position:absolute;top:100%;left:0;background:var(--c-tierra);min-width:200px;border-radius:0 0 var(--r-md) var(--r-md);box-shadow:var(--sh-3);flex-direction:column;z-index:800;border-top:2px solid var(--c-trigo)}
.nav-inner ul li ul li a{padding:9px 16px;font-size:12px;color:rgba(255,255,255,.8);letter-spacing:.02em}
.nav-inner ul li ul li a:hover{background:rgba(255,255,255,.1);color:#fff;padding-left:20px}
.nav-hamburger{display:none;background:none;border:none;color:#fff;font-size:1.3rem;padding:8px;margin-left:auto}

/* =====================================================
   TICKER
===================================================== */
.ticker{background:var(--c-tierra);overflow:hidden;padding:0}
.ticker-inner{display:flex;align-items:stretch;height:34px}
.ticker-tag{background:var(--c-acento);color:#fff;padding:0 16px;font-family:var(--font-ui);font-size:10px;font-weight:800;letter-spacing:.1em;text-transform:uppercase;display:flex;align-items:center;gap:6px;flex-shrink:0;clip-path:polygon(0 0,calc(100% - 8px) 0,100% 50%,calc(100% - 8px) 100%,0 100%);padding-right:24px}
.ticker-scroll{overflow:hidden;display:flex;align-items:center;flex:1}
.ticker-pista{display:flex;gap:0;white-space:nowrap;animation:ticker 50s linear infinite}
.ticker-pista:hover{animation-play-state:paused}
.ticker-pista a{color:rgba(255,255,255,.78);font-family:var(--font-ui);font-size:12px;padding:0 28px;border-right:1px solid rgba(255,255,255,.12);transition:color .2s}
.ticker-pista a:hover{color:var(--c-trigo)}
@keyframes ticker{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}

/* =====================================================
   HERO PRINCIPAL
===================================================== */
.hero-section{padding:28px 0 0}
.hero-grid{display:grid;grid-template-columns:1fr 380px;grid-template-rows:auto auto;gap:4px;border-radius:var(--r-xl);overflow:hidden;box-shadow:var(--sh-3)}
.hero-main{grid-row:1/3;position:relative;overflow:hidden}
.hero-main img{width:100%;height:100%;object-fit:cover;min-height:440px;transition:transform .6s ease}
.hero-main:hover img{transform:scale(1.03)}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(10,5,2,.9) 0%,rgba(10,5,2,.4) 50%,transparent 100%);display:flex;flex-direction:column;justify-content:flex-end;padding:32px}
.hero-badge{display:inline-flex;align-items:center;gap:6px;background:var(--c-acento);color:#fff;padding:4px 12px;border-radius:24px;font-family:var(--font-ui);font-size:10.5px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;margin-bottom:12px;width:fit-content}
.hero-title{font-size:clamp(1.4rem,3.2vw,2.1rem);color:#fff;line-height:1.2;margin-bottom:10px;text-shadow:0 2px 8px rgba(0,0,0,.4)}
.hero-title a{color:inherit}
.hero-meta{display:flex;gap:14px;font-family:var(--font-ui);font-size:12px;color:rgba(255,255,255,.72)}
.hero-meta span{display:flex;align-items:center;gap:5px}
.hero-side-1{position:relative;overflow:hidden}
.hero-side-2{position:relative;overflow:hidden}
.hero-side-1 img,.hero-side-2 img{width:100%;height:100%;object-fit:cover;min-height:210px;transition:transform .5s ease}
.hero-side-1:hover img,.hero-side-2:hover img{transform:scale(1.04)}
.hero-side-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(10,5,2,.85) 0%,transparent 60%);padding:16px;display:flex;flex-direction:column;justify-content:flex-end}
.hero-side-cat{font-family:var(--font-ui);font-size:9.5px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--c-trigo);margin-bottom:5px}
.hero-side-title{font-size:.9rem;font-weight:700;color:#fff;line-height:1.3;font-family:var(--font-head)}
.hero-side-title a{color:inherit}

/* =====================================================
   SECCIÓN TÍTULO
===================================================== */
.sec-hd{display:flex;align-items:center;gap:14px;margin-bottom:24px;padding-bottom:12px;position:relative}
.sec-hd::after{content:'';position:absolute;bottom:0;left:0;right:0;height:1px;background:var(--c-borde)}
.sec-hd::before{content:'';position:absolute;bottom:-1px;left:0;width:60px;height:3px;background:var(--c-verde);border-radius:2px;z-index:1}
.sec-hd h2{font-size:1.05rem;text-transform:uppercase;letter-spacing:.12em;color:var(--c-tierra);font-family:var(--font-ui);font-weight:800}
.sec-hd .ico{font-size:.95rem}
.sec-hd-actions{margin-left:auto;display:flex;gap:8px}
.btn-ver-mas{font-family:var(--font-ui);font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--c-verde-2);border:1.5px solid var(--c-verde-4);padding:4px 12px;border-radius:24px;transition:var(--t)}
.btn-ver-mas:hover{background:var(--c-verde-2);color:#fff;border-color:var(--c-verde-2)}

/* =====================================================
   TARJETAS DE NOTICIAS
===================================================== */
.card{background:var(--c-blanco);border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--sh-1);border:1px solid var(--c-borde);transition:var(--t);display:flex;flex-direction:column}
.card:hover{transform:translateY(-4px);box-shadow:var(--sh-3);border-color:var(--c-verde-4)}
.card-img{aspect-ratio:16/9;overflow:hidden;position:relative;flex-shrink:0}
.card-img img{width:100%;height:100%;object-fit:cover;transition:transform .45s ease}
.card:hover .card-img img{transform:scale(1.06)}
.card-img-ph{width:100%;height:100%;background:var(--c-verde-bg);display:flex;align-items:center;justify-content:center;color:var(--c-verde-4);font-size:2.2rem}
.card-body{padding:16px 18px;flex:1;display:flex;flex-direction:column;gap:6px}
.card-cat{font-family:var(--font-ui);font-size:10px;font-weight:800;text-transform:uppercase;letter-spacing:.1em;color:var(--c-verde-2)}
.card-cat.ganaderia{color:#6D4C41}
.card-cat.clima{color:#1565C0}
.card-cat.mercados{color:#6A1B9A}
.card-cat.politica{color:#B71C1C}
.card-cat.tecnologia{color:#004D40}
.card-cat.comunidad{color:#E65100}
.card-title{font-size:1rem;line-height:1.32;color:var(--c-tierra)}
.card-title a{color:inherit;transition:var(--t)}
.card-title a:hover{color:var(--c-verde-2)}
.card-excerpt{font-size:.875rem;color:var(--c-texto-3);line-height:1.58;flex:1;margin:0}
.card-foot{display:flex;justify-content:space-between;align-items:center;font-family:var(--font-ui);font-size:11px;color:var(--c-texto-3);padding-top:10px;border-top:1px solid var(--c-fondo);margin-top:auto}
.card-autor{display:flex;align-items:center;gap:5px}
.card-avatar{width:22px;height:22px;border-radius:50%;background:var(--c-verde-3);color:#fff;font-size:9px;font-weight:700;display:flex;align-items:center;justify-content:center;font-family:var(--font-ui);flex-shrink:0}

/* Tarjeta horizontal */
.card-h{flex-direction:row;align-items:stretch}
.card-h .card-img{width:130px;flex-shrink:0;aspect-ratio:auto;border-radius:var(--r-lg) 0 0 var(--r-lg)}
.card-h .card-img img{height:100%}

/* Tarjeta grande */
.card-lg .card-body{padding:22px 24px}
.card-lg .card-title{font-size:1.25rem}

/* =====================================================
   BADGES / ETIQUETAS
===================================================== */
.badge{display:inline-flex;align-items:center;padding:2px 9px;border-radius:24px;font-family:var(--font-ui);font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:#fff;background:var(--c-verde-2)}
.badge-ganaderia{background:#5D4037}
.badge-agricultura{background:var(--c-verde-2)}
.badge-clima{background:#1565C0}
.badge-mercados{background:#6A1B9A}
.badge-politica{background:#B71C1C}
.badge-tecnologia{background:#004D40}
.badge-comunidad{background:#E65100}
.badge-ingles{background:#003087}

/* =====================================================
   SIDEBAR
===================================================== */
.sidebar{display:flex;flex-direction:column;gap:20px}
.widget{background:var(--c-blanco);border-radius:var(--r-lg);padding:20px;box-shadow:var(--sh-1);border:1px solid var(--c-borde)}
.widget-title{font-family:var(--font-ui);font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.14em;color:var(--c-tierra);margin-bottom:14px;padding-bottom:10px;border-bottom:2px solid var(--c-verde-4);display:flex;align-items:center;gap:6px}
.widget-title span.ico{font-size:.85rem}

/* Widget clima */
.widget-clima{background:linear-gradient(155deg,#1B5E20 0%,#2E7D32 55%,#43A047 100%);border:none;color:#fff}
.widget-clima .widget-title{color:rgba(255,255,255,.8);border-bottom-color:rgba(255,255,255,.15)}
.clima-temp{font-family:var(--font-head);font-size:3.2rem;font-weight:300;line-height:1;letter-spacing:-.03em}
.clima-desc{font-family:var(--font-ui);font-size:12px;opacity:.82;margin:4px 0 16px}
.clima-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:6px;background:rgba(255,255,255,.1);border-radius:var(--r-md);padding:10px}
.clima-item{text-align:center;font-family:var(--font-ui)}
.clima-item .v{display:block;font-size:15px;font-weight:700;line-height:1}
.clima-item .l{font-size:10px;opacity:.75;margin-top:3px}

/* Widget precios */
.precio-row{display:flex;justify-content:space-between;align-items:center;padding:7px 0;border-bottom:1px solid var(--c-fondo);font-family:var(--font-ui);font-size:12.5px}
.precio-row:last-child{border-bottom:none}
.precio-prod{color:var(--c-texto);font-weight:600}
.precio-val{color:var(--c-texto-2)}
.precio-var{font-size:11px;font-weight:700;min-width:42px;text-align:right}
.precio-var.up{color:#2E7D32}
.precio-var.dn{color:#C62828}

/* Widget links cortos */
.widget-links a{display:flex;align-items:center;gap:8px;padding:7px 0;border-bottom:1px solid var(--c-fondo);font-family:var(--font-ui);font-size:12.5px;color:var(--c-texto);font-weight:500;transition:var(--t)}
.widget-links a:last-child{border-bottom:none}
.widget-links a:hover{color:var(--c-verde-2);padding-left:4px}
.widget-links a .ico{color:var(--c-verde-3);flex-shrink:0}

/* =====================================================
   SECCIÓN CLASIFICADOS
===================================================== */
.sec-clasificados{background:linear-gradient(135deg,var(--c-tierra) 0%,#3E2723 100%);padding:48px 0;margin:40px 0}
.sec-clasificados .sec-hd h2{color:rgba(255,255,255,.9)}
.sec-clasificados .sec-hd::after{background:rgba(255,255,255,.1)}
.sec-clasificados .sec-hd::before{background:var(--c-trigo)}

/* Filtros de clasificados */
.cl-filtros{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);border-radius:var(--r-lg);padding:16px 20px;margin-bottom:24px;display:flex;gap:12px;flex-wrap:wrap;align-items:flex-end}
.cl-filtro-grupo{display:flex;flex-direction:column;gap:4px;flex:1;min-width:140px}
.cl-filtro-grupo label{font-family:var(--font-ui);font-size:10.5px;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:rgba(255,255,255,.6)}
.cl-filtro-grupo select,.cl-filtro-grupo input{background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.15);color:#fff;padding:7px 12px;border-radius:var(--r-md);font-size:12.5px;font-family:var(--font-ui);outline:none;transition:var(--t);-webkit-appearance:none}
.cl-filtro-grupo select:focus,.cl-filtro-grupo input:focus{border-color:var(--c-trigo);background:rgba(255,255,255,.15)}
.cl-filtro-grupo select option{background:#3E2723;color:#fff}

/* Cards de clasificados */
.cl-card{background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.1);border-radius:var(--r-lg);padding:16px 18px;position:relative;transition:var(--t)}
.cl-card:hover{background:rgba(255,255,255,.12);border-color:rgba(200,168,80,.4);transform:translateY(-2px)}
.cl-card.dest{border-color:var(--c-trigo);border-width:1.5px;background:rgba(249,168,37,.06)}
.cl-card.dest::before{content:'⭐ DESTACADO';position:absolute;top:-10px;left:14px;background:var(--c-trigo);color:var(--c-tierra);font-family:var(--font-ui);font-size:9px;font-weight:800;padding:2px 10px;border-radius:24px;letter-spacing:.06em}
.cl-tag{position:absolute;top:12px;right:12px;background:var(--c-verde-3);color:#fff;font-family:var(--font-ui);font-size:9.5px;font-weight:700;padding:2px 8px;border-radius:24px;text-transform:uppercase;letter-spacing:.06em}
.cl-title{font-size:.95rem;font-weight:700;color:rgba(255,255,255,.92);margin-bottom:4px;line-height:1.3;font-family:var(--font-head)}
.cl-title a{color:inherit}
.cl-price{font-family:var(--font-ui);font-size:1.15rem;font-weight:800;color:var(--c-trigo);margin-bottom:4px}
.cl-loc{font-family:var(--font-ui);font-size:11.5px;color:rgba(255,255,255,.55);display:flex;align-items:center;gap:4px;margin-bottom:10px}
.cl-pais-flag{font-size:.95rem}
.cl-btns{display:flex;gap:6px;flex-wrap:wrap}
.cl-btn-ver{font-family:var(--font-ui);font-size:11px;font-weight:700;padding:4px 12px;border:1.5px solid rgba(255,255,255,.25);border-radius:24px;color:rgba(255,255,255,.75);transition:var(--t);text-transform:uppercase;letter-spacing:.05em}
.cl-btn-ver:hover{border-color:#fff;color:#fff}
.cl-btn-wa{background:#25D366;color:#fff;font-family:var(--font-ui);font-size:11px;font-weight:700;padding:4px 12px;border-radius:24px;display:flex;align-items:center;gap:4px;transition:var(--t)}
.cl-btn-wa:hover{background:#128C7E;color:#fff}

/* CTA publicar clasificado */
.cl-cta{background:linear-gradient(135deg,var(--c-acento),#BF360C);border-radius:var(--r-xl);padding:28px 32px;text-align:center;margin-top:28px}
.cl-cta h3{color:#fff;font-size:1.3rem;margin-bottom:8px}
.cl-cta p{color:rgba(255,255,255,.8);font-size:.9rem;margin-bottom:18px}

/* =====================================================
   BOTONES GLOBALES
===================================================== */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:10px 22px;border-radius:var(--r-md);font-family:var(--font-ui);font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;transition:var(--t);border:none;line-height:1;cursor:pointer;text-decoration:none}
.btn:hover{text-decoration:none}
.btn-primary{background:var(--c-verde-2);color:#fff}
.btn-primary:hover{background:var(--c-verde);color:#fff;box-shadow:var(--sh-verde);transform:translateY(-1px)}
.btn-outline{background:transparent;color:var(--c-verde-2);border:2px solid var(--c-verde-3)}
.btn-outline:hover{background:var(--c-verde-2);color:#fff}
.btn-accent{background:var(--c-acento);color:#fff}
.btn-accent:hover{background:var(--c-tierra);color:#fff;transform:translateY(-1px)}
.btn-white{background:#fff;color:var(--c-tierra)}
.btn-white:hover{background:var(--c-crema);color:var(--c-tierra)}
.btn-sm{padding:6px 14px;font-size:11.5px}
.btn-lg{padding:13px 28px;font-size:14px}
.btn-full{width:100%}
.btn-pill{border-radius:32px}

/* =====================================================
   METAHUMANO (actualizado diseño moderno)
===================================================== */
.sec-metahumano{background:var(--c-negro);padding:48px 0;margin:0;position:relative;overflow:hidden}
.sec-metahumano::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--c-verde-3),var(--c-trigo),var(--c-acento))}
.sec-metahumano .sec-hd h2{color:rgba(255,255,255,.9)}
.sec-metahumano .sec-hd::after{background:rgba(255,255,255,.08)}
.sec-metahumano .sec-hd::before{background:var(--c-trigo)}
.mh-grid{display:grid;grid-template-columns:260px 1fr;gap:32px;align-items:start}
.mh-frame{background:rgba(255,255,255,.04);border:1.5px solid rgba(255,255,255,.1);border-radius:var(--r-xl);overflow:hidden;aspect-ratio:3/4;position:relative}
.mh-img{width:100%;height:100%;object-fit:cover;object-position:top}
.mh-img.hablando{filter:brightness(1.1)}
.mh-waves{position:absolute;bottom:14px;left:50%;transform:translateX(-50%);display:flex;gap:3px;align-items:flex-end;height:24px;opacity:0;transition:opacity .3s}
.mh-waves.on{opacity:1}
.mh-waves span{width:3px;border-radius:2px;background:var(--c-trigo)}
.mh-waves span:nth-child(1){animation:w 0.8s .0s ease-in-out infinite}
.mh-waves span:nth-child(2){animation:w 0.8s .1s ease-in-out infinite}
.mh-waves span:nth-child(3){animation:w 0.8s .2s ease-in-out infinite}
.mh-waves span:nth-child(4){animation:w 0.8s .1s ease-in-out infinite}
.mh-waves span:nth-child(5){animation:w 0.8s .0s ease-in-out infinite}
@keyframes w{0%,100%{height:4px}50%{height:22px}}
.mh-status-badge{position:absolute;bottom:10px;left:50%;transform:translateX(-50%);background:rgba(0,0,0,.72);backdrop-filter:blur(8px);padding:4px 12px;border-radius:24px;font-family:var(--font-ui);font-size:10.5px;color:rgba(255,255,255,.8);white-space:nowrap;display:flex;align-items:center;gap:5px}
.mh-dot{width:6px;height:6px;border-radius:50%;background:var(--c-acento-2);animation:pulse 1.5s infinite}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.8)}}
.mh-info{text-align:center;margin-top:12px}
.mh-name{font-family:var(--font-head);font-size:1.15rem;font-weight:700;color:#fff}
.mh-role{font-family:var(--font-ui);font-size:11px;color:rgba(255,255,255,.45);text-transform:uppercase;letter-spacing:.1em;margin:3px 0 10px}
.mh-langs{display:flex;gap:4px;justify-content:center;flex-wrap:wrap}
.mh-lb{background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.12);color:rgba(255,255,255,.6);padding:3px 9px;border-radius:24px;font-size:10.5px;font-weight:600;cursor:pointer;transition:var(--t);font-family:var(--font-ui)}
.mh-lb:hover,.mh-lb.on{background:var(--c-trigo);color:var(--c-tierra);border-color:var(--c-trigo)}
.mh-panel-hd{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px}
.mh-panel-hd h3{color:rgba(255,255,255,.85);font-size:1rem}
.mh-active{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.1);border-radius:var(--r-lg);padding:16px;margin-bottom:14px;display:none}
.mh-active-cat{font-family:var(--font-ui);font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--c-trigo);margin-bottom:6px}
.mh-active-title{color:#fff;font-size:1rem;line-height:1.3;margin-bottom:8px}
.mh-active-text{font-size:.855rem;color:rgba(255,255,255,.65);line-height:1.6;margin-bottom:12px}
.mh-controls{display:flex;gap:8px;align-items:center}
.mh-btn{width:34px;height:34px;border-radius:50%;background:var(--c-trigo);color:var(--c-tierra);border:none;display:flex;align-items:center;justify-content:center;font-size:.82rem;transition:var(--t);flex-shrink:0;cursor:pointer}
.mh-btn:hover{background:var(--c-acento-2);color:#fff}
.mh-bar{flex:1;height:3px;background:rgba(255,255,255,.1);border-radius:2px;overflow:hidden}
.mh-fill{height:100%;background:var(--c-trigo);width:0%;transition:width .3s}
.mh-list{display:flex;flex-direction:column;gap:5px;max-height:320px;overflow-y:auto;padding-right:2px}
.mh-list::-webkit-scrollbar{width:3px}
.mh-list::-webkit-scrollbar-thumb{background:rgba(255,255,255,.2);border-radius:2px}
.mh-item{display:flex;align-items:center;gap:10px;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.07);border-radius:var(--r-md);padding:8px 10px;cursor:pointer;transition:var(--t)}
.mh-item:hover,.mh-item.on{background:rgba(249,168,37,.1);border-color:rgba(249,168,37,.3)}
.mh-item-img{width:52px;height:38px;border-radius:var(--r-sm);object-fit:cover;flex-shrink:0}
.mh-item-img.ph{background:var(--c-verde);display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,.2)}
.mh-item-body{flex:1;min-width:0}
.mh-item-cat{font-family:var(--font-ui);font-size:9.5px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--c-trigo)}
.mh-item-title{font-family:var(--font-ui);font-size:12.5px;font-weight:600;color:rgba(255,255,255,.82);line-height:1.3;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.mh-item-play{background:none;border:none;color:rgba(255,255,255,.4);font-size:1.3rem;transition:var(--t);padding:4px;flex-shrink:0;cursor:pointer}
.mh-item-play:hover{color:var(--c-trigo);transform:scale(1.15)}
.mh-region{display:flex;align-items:center;gap:8px;padding-top:12px;margin-top:12px;border-top:1px solid rgba(255,255,255,.07)}
.mh-region label{font-family:var(--font-ui);font-size:11px;color:rgba(255,255,255,.45);white-space:nowrap}
.mh-region select{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);color:rgba(255,255,255,.75);padding:5px 10px;border-radius:var(--r-sm);font-size:12px;font-family:var(--font-ui);outline:none;flex:1}
.mh-region select option{background:#111;color:#fff}

/* =====================================================
   COMENTARIOS
===================================================== */
.comentario{display:flex;gap:14px;padding:18px 0;border-bottom:1px solid var(--c-borde)}
.coment-av{width:44px;height:44px;border-radius:50%;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-family:var(--font-ui);font-weight:700;font-size:1rem;color:#fff}
.coment-body{flex:1}
.coment-hd{display:flex;align-items:baseline;gap:8px;margin-bottom:5px}
.coment-autor{font-family:var(--font-ui);font-size:13.5px;font-weight:700;color:var(--c-tierra)}
.coment-fecha{font-family:var(--font-ui);font-size:11.5px;color:var(--c-texto-3)}
.coment-text{font-size:.95rem;color:var(--c-texto-2);line-height:1.65}

/* =====================================================
   FORMULARIOS
===================================================== */
.form-grupo{margin-bottom:16px}
.form-grupo label{display:block;font-family:var(--font-ui);font-size:12.5px;font-weight:700;color:var(--c-tierra);margin-bottom:5px;letter-spacing:.01em}
.form-grupo label .req{color:var(--c-acento)}
.form-input,.form-select,.form-textarea{width:100%;padding:10px 14px;border:1.5px solid var(--c-borde);border-radius:var(--r-md);font-size:14px;background:var(--c-blanco);color:var(--c-texto);outline:none;transition:var(--t);font-family:var(--font-ui)}
.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--c-verde-3);box-shadow:0 0 0 3px rgba(67,160,71,.1)}
.form-textarea{min-height:120px;resize:vertical;line-height:1.65}
.form-hint{font-size:11.5px;color:var(--c-texto-3);margin-top:4px;font-family:var(--font-ui)}

/* Planes */
.planes-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin:20px 0}
.plan-card{border:2px solid var(--c-borde);border-radius:var(--r-lg);padding:18px;text-align:center;cursor:pointer;transition:var(--t);position:relative;background:var(--c-blanco)}
.plan-card:hover,.plan-card.sel{border-color:var(--c-verde-3);background:var(--c-verde-bg)}
.plan-card.pop{border-color:var(--c-trigo)}
.plan-badge{position:absolute;top:-10px;left:50%;transform:translateX(-50%);background:var(--c-trigo);color:var(--c-tierra);font-size:9px;font-weight:800;padding:2px 10px;border-radius:24px;white-space:nowrap;letter-spacing:.06em;text-transform:uppercase}
.plan-name{font-family:var(--font-ui);font-size:11px;font-weight:800;text-transform:uppercase;letter-spacing:.1em;color:var(--c-tierra);margin-bottom:6px}
.plan-price{font-family:var(--font-head);font-size:2rem;font-weight:700;color:var(--c-verde-2);line-height:1}
.plan-price sub{font-size:.9rem;font-weight:400;color:var(--c-texto-3);font-family:var(--font-ui)}
.plan-dur{font-family:var(--font-ui);font-size:11px;color:var(--c-texto-3);margin:4px 0}
.plan-feats{text-align:left;margin-top:10px;font-family:var(--font-ui);font-size:11.5px;color:var(--c-texto-2)}
.plan-feats li{padding:2px 0}
.plan-feats li::before{content:'✓ ';color:var(--c-verde-2);font-weight:700}

/* Métodos de pago */
.pago-metodos{display:flex;gap:10px;flex-wrap:wrap;margin:14px 0}
.pago-metodo{display:flex;align-items:center;gap:8px;padding:9px 16px;border:2px solid var(--c-borde);border-radius:var(--r-md);cursor:pointer;font-family:var(--font-ui);font-size:13px;font-weight:700;transition:var(--t);background:var(--c-blanco)}
.pago-metodo.mp{color:#009EE3}
.pago-metodo.pp{color:#003087}
.pago-metodo.st{color:#635BFF}
.pago-metodo.sel,.pago-metodo:hover{border-color:currentColor;background:rgba(0,0,0,.02)}

/* =====================================================
   FOOTER
===================================================== */
.footer{background:var(--c-tierra);color:rgba(255,255,255,.75);margin-top:64px}
.footer-top{padding:52px 0 36px}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:48px}
.footer-col h4{font-family:var(--font-ui);font-size:10.5px;font-weight:800;text-transform:uppercase;letter-spacing:.14em;color:var(--c-trigo);margin-bottom:14px;padding-bottom:8px;border-bottom:1px solid rgba(255,255,255,.1)}
.footer-col ul li{margin-bottom:6px}
.footer-col ul li a{font-family:var(--font-ui);font-size:13px;color:rgba(255,255,255,.65);transition:var(--t)}
.footer-col ul li a:hover{color:var(--c-trigo);padding-left:4px}
.footer-col p{font-size:13px;line-height:1.75;color:rgba(255,255,255,.55)}
.footer-logo-n{font-family:var(--font-head);font-size:1.65rem;font-weight:900;color:var(--c-verde-4);letter-spacing:-.02em;line-height:1}
.footer-logo-s{font-family:var(--font-ui);font-size:9px;color:var(--c-trigo);text-transform:uppercase;letter-spacing:.2em;margin-top:3px}
.footer-social{display:flex;gap:7px;margin-top:16px}
.footer-social a{width:34px;height:34px;border-radius:50%;background:rgba(255,255,255,.08);color:rgba(255,255,255,.65);display:flex;align-items:center;justify-content:center;font-size:13px;transition:var(--t)}
.footer-social a:hover{background:var(--c-trigo);color:var(--c-tierra)}
.footer-langs{display:flex;gap:5px;margin-top:12px;flex-wrap:wrap}
.footer-langs a{font-size:10.5px;padding:2px 8px;border:1px solid rgba(255,255,255,.15);border-radius:24px;color:rgba(255,255,255,.55);font-family:var(--font-ui);transition:var(--t)}
.footer-langs a:hover,.footer-langs a.activo{background:var(--c-trigo);color:var(--c-tierra);border-color:var(--c-trigo)}
.footer-bottom{border-top:1px solid rgba(255,255,255,.08);padding:16px 0;display:flex;justify-content:space-between;align-items:center;font-family:var(--font-ui);font-size:11.5px;color:rgba(255,255,255,.4)}
.footer-bottom a{color:rgba(255,255,255,.4)}
.footer-bottom a:hover{color:var(--c-trigo)}

/* =====================================================
   ACCESIBILIDAD
===================================================== */
.a11y-bar{position:fixed;right:0;top:50%;transform:translateY(-50%);z-index:9990;display:flex;flex-direction:column;gap:3px}
.a11y-btn{width:34px;height:34px;background:var(--c-verde-2);color:#fff;border:none;border-radius:4px 0 0 4px;display:flex;align-items:center;justify-content:center;font-size:13px;transition:var(--t);cursor:pointer}
.a11y-btn:hover{background:var(--c-tierra);width:40px}

/* =====================================================
   PUBLICIDADES
===================================================== */
.ad-slot{background:linear-gradient(135deg,var(--c-fondo),var(--c-borde));border:1px dashed var(--c-borde-2);border-radius:var(--r-md);display:flex;align-items:center;justify-content:center;font-family:var(--font-ui);font-size:10.5px;color:var(--c-texto-3);text-transform:uppercase;letter-spacing:.06em;overflow:hidden}
.ad-slot.leaderboard{height:90px;width:100%;margin:16px 0}
.ad-slot.rectangle{height:250px;width:100%}
.ad-slot.banner-med{height:60px;width:100%;margin:10px 0}

/* =====================================================
   ANUNCIOS (CPT)
===================================================== */
.anuncio-card{background:var(--c-blanco);border:1px solid var(--c-borde);border-radius:var(--r-lg);padding:18px;display:flex;gap:16px;align-items:flex-start;box-shadow:var(--sh-1);transition:var(--t)}
.anuncio-card:hover{box-shadow:var(--sh-2);border-color:var(--c-verde-4)}
.anuncio-ico{width:48px;height:48px;border-radius:var(--r-md);background:var(--c-verde-bg);display:flex;align-items:center;justify-content:center;font-size:1.4rem;flex-shrink:0}
.anuncio-body{flex:1}
.anuncio-cat{font-family:var(--font-ui);font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--c-verde-2);margin-bottom:4px}
.anuncio-title{font-size:.95rem;font-weight:700;color:var(--c-tierra);margin-bottom:4px}
.anuncio-desc{font-size:.855rem;color:var(--c-texto-3);line-height:1.55;margin-bottom:8px}
.anuncio-foot{display:flex;gap:8px;align-items:center;font-family:var(--font-ui);font-size:11px;color:var(--c-texto-3)}

/* =====================================================
   UTILIDADES
===================================================== */
.text-center{text-align:center}
.text-muted{color:var(--c-texto-3)}
.mb-0{margin-bottom:0}
.mb-sm{margin-bottom:8px}
.mb-md{margin-bottom:16px}
.mb-lg{margin-bottom:24px}
.mb-xl{margin-bottom:40px}
.mt-xl{margin-top:40px}
.py-xl{padding:40px 0}
.py-2xl{padding:64px 0}
.gap-sm{gap:8px}
.hidden{display:none}
.show{display:block}
.chip{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:24px;font-family:var(--font-ui);font-size:10.5px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;cursor:pointer;transition:var(--t);border:1.5px solid var(--c-borde);color:var(--c-texto-3)}
.chip:hover,.chip.on{background:var(--c-verde-2);color:#fff;border-color:var(--c-verde-2)}

/* =====================================================
   ANIMACIONES
===================================================== */
@keyframes fadeUp{from{opacity:0;transform:translateY(18px)}to{opacity:1;transform:translateY(0)}}
.fade-up{animation:fadeUp .45s ease forwards}
@keyframes shimmer{0%{background-position:-200% 0}100%{background-position:200% 0}}
.skeleton{background:linear-gradient(90deg,var(--c-fondo) 25%,var(--c-borde) 50%,var(--c-fondo) 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:var(--r-sm)}

/* =====================================================
   RESPONSIVE
===================================================== */
@media(max-width:1100px){
  .grilla-principal{grid-template-columns:1fr;gap:32px}
  .hero-grid{grid-template-columns:1fr 1fr;grid-template-rows:auto auto auto}
  .hero-main{grid-row:1/2;grid-column:1/3}
  .footer-grid{grid-template-columns:1fr 1fr}
  .mh-grid{grid-template-columns:220px 1fr}
}
@media(max-width:860px){
  .grilla-3{grid-template-columns:repeat(2,1fr)}
  .nav-hamburger{display:flex}
  .nav-inner ul{display:none;flex-direction:column;width:100%;padding-bottom:8px}
  .nav-inner ul.open{display:flex}
  .hero-grid{grid-template-columns:1fr;grid-template-rows:auto}
  .hero-main img{min-height:320px}
  .hero-side-1,.hero-side-2{display:none}
  .mh-grid{grid-template-columns:1fr}
  .mh-frame{max-width:220px;margin:0 auto}
  .planes-grid{grid-template-columns:1fr}
}
@media(max-width:600px){
  :root{--max-w:100%}
  .grilla-3,.grilla-2,.grilla-auto{grid-template-columns:1fr}
  .barra-sup .inner{flex-direction:column;gap:5px;text-align:center}
  .footer-grid{grid-template-columns:1fr}
  .cab-inner{flex-wrap:wrap}
  .cab-search{order:3;flex:1 1 100%;max-width:100%}
  .btn-pub{display:none}
}
@media print{
  .cabecera,.nav-wrap,.sidebar,.footer,.a11y-bar{display:none}
  body{background:#fff}
}

/* =====================================================
   TURISMO RURAL
===================================================== */
.turismo-card {
  background: var(--c-blanco);
  border-radius: var(--r-lg);
  overflow: hidden;
  border: 1px solid var(--c-borde);
  box-shadow: var(--sh-1);
  transition: var(--t);
  display: flex;
  flex-direction: column;
}
.turismo-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--sh-3);
  border-color: #A5D6A7;
}
.turismo-card-img {
  aspect-ratio: 16/9;
  overflow: hidden;
  position: relative;
}
.turismo-card-img img {
  width: 100%; height: 100%;
  object-fit: cover;
  transition: transform .45s ease;
}
.turismo-card:hover .turismo-card-img img { transform: scale(1.06); }
.turismo-card-img-ph {
  width: 100%; height: 100%;
  min-height: 180px;
  background: linear-gradient(135deg, #1B5E20, #4CAF50, #8BC34A);
  display: flex; align-items: center; justify-content: center;
  font-size: 3rem;
}
.turismo-tipo-badge {
  position: absolute;
  top: 10px; left: 10px;
  background: rgba(27,94,32,.88);
  color: #fff;
  font-family: var(--font-ui);
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .07em;
  padding: 3px 10px;
  border-radius: 24px;
}
.turismo-card-body {
  padding: 16px 18px;
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.turismo-card-title {
  font-size: 1rem;
  font-weight: 700;
  color: var(--c-tierra);
  line-height: 1.3;
}
.turismo-card-title a { color: inherit; transition: var(--t); }
.turismo-card-title a:hover { color: var(--c-verde-2); }
.turismo-card-desc {
  font-size: .875rem;
  color: var(--c-texto-3);
  line-height: 1.55;
  flex: 1;
}
.turismo-card-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  font-family: var(--font-ui);
  font-size: 11.5px;
  color: var(--c-texto-3);
  padding-top: 10px;
  border-top: 1px solid var(--c-fondo);
  margin-top: auto;
}
.turismo-card-meta span { display: flex; align-items: center; gap: 4px; }
.turismo-card-precio {
  font-family: var(--font-ui);
  font-size: 1rem;
  font-weight: 800;
  color: var(--c-verde-2);
}
.turismo-card-btns {
  display: flex; gap: 6px; margin-top: 10px; flex-wrap: wrap;
}

/* Hero turismo */
.turismo-hero {
  background: linear-gradient(135deg, #1B5E20 0%, #2E7D32 40%, #4CAF50 70%, #8BC34A 100%);
  padding: 64px 0 48px;
  text-align: center;
  color: #fff;
  position: relative;
  overflow: hidden;
}
.turismo-hero::before {
  content: '🌿🌄🏡🐄🌾';
  position: absolute;
  top: 10px; left: 0; right: 0;
  font-size: 3rem;
  opacity: .1;
  letter-spacing: 2rem;
  white-space: nowrap;
  overflow: hidden;
}
.turismo-hero h1 { color: #fff; margin-bottom: 12px; }
.turismo-hero p  { color: rgba(255,255,255,.82); font-size: 1.1rem; max-width: 600px; margin: 0 auto 28px; }

/* =====================================================
   AGENDA CULTURAL — EVENTOS
===================================================== */
.evento-card {
  background: var(--c-blanco);
  border-radius: var(--r-lg);
  border: 1px solid var(--c-borde);
  box-shadow: var(--sh-1);
  transition: var(--t);
  display: flex;
  gap: 0;
  overflow: hidden;
}
.evento-card:hover {
  transform: translateY(-3px);
  box-shadow: var(--sh-2);
  border-color: #F9A825;
}
.evento-fecha-bloque {
  background: var(--c-tierra);
  color: #fff;
  padding: 16px 14px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  min-width: 72px;
  flex-shrink: 0;
  text-align: center;
}
.evento-dia  { font-family: var(--font-head); font-size: 2rem; font-weight: 900; line-height: 1; }
.evento-mes  { font-family: var(--font-ui); font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: .1em; opacity: .8; margin-top: 3px; }
.evento-year { font-family: var(--font-ui); font-size: 10px; opacity: .6; margin-top: 2px; }
.evento-card-body { padding: 14px 16px; flex: 1; min-width: 0; }
.evento-tipo {
  font-family: var(--font-ui); font-size: 9.5px; font-weight: 700;
  text-transform: uppercase; letter-spacing: .1em; color: var(--c-acento);
  margin-bottom: 4px;
}
.evento-titulo {
  font-size: .98rem; font-weight: 700; color: var(--c-tierra);
  line-height: 1.3; margin-bottom: 6px;
}
.evento-titulo a { color: inherit; }
.evento-titulo a:hover { color: var(--c-verde-2); }
.evento-info {
  display: flex; flex-wrap: wrap; gap: 8px;
  font-family: var(--font-ui); font-size: 11.5px; color: var(--c-texto-3);
  margin-bottom: 8px;
}
.evento-info span { display: flex; align-items: center; gap: 4px; }
.evento-estado {
  display: inline-flex; align-items: center; gap: 4px;
  padding: 2px 8px; border-radius: 24px;
  font-family: var(--font-ui); font-size: 10px; font-weight: 700;
}
.evento-estado.confirmado { background: #E8F5E9; color: #1B5E20; }
.evento-estado.tentativo  { background: #FFF3E0; color: #E65100; }
.evento-estado.cancelado  { background: #FFEBEE; color: #B71C1C; }

/* Calendario mini */
.agenda-cal-header {
  display: flex; align-items: center; justify-content: space-between;
  padding: 16px 20px; background: var(--c-tierra); color: #fff;
  font-family: var(--font-ui);
}
.agenda-cal-header h3 { color: #F9A825; font-size: 1rem; }
.agenda-cal-nav { display: flex; gap: 6px; }
.agenda-cal-nav button {
  background: rgba(255,255,255,.15); border: none; color: #fff;
  width: 28px; height: 28px; border-radius: 50%;
  cursor: pointer; font-size: .9rem; display: flex;
  align-items: center; justify-content: center; transition: var(--t);
}
.agenda-cal-nav button:hover { background: var(--c-trigo); color: var(--c-tierra); }

/* Hero agenda */
.agenda-hero {
  background: linear-gradient(135deg, #4E342E 0%, #6D4C41 40%, #795548 70%, #F9A825 140%);
  padding: 64px 0 48px;
  text-align: center;
  color: #fff;
}
.agenda-hero h1 { color: #fff; margin-bottom: 12px; }
.agenda-hero p  { color: rgba(255,255,255,.82); font-size: 1.1rem; max-width: 600px; margin: 0 auto 28px; }

/* Filtros compartidos turismo/agenda */
.seccion-filtros {
  background: var(--c-blanco);
  border: 1px solid var(--c-borde);
  border-radius: var(--r-xl);
  padding: 18px 22px;
  margin-bottom: 28px;
  box-shadow: var(--sh-1);
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
  align-items: flex-end;
}
.filtro-grupo {
  display: flex; flex-direction: column; gap: 4px; flex: 1; min-width: 130px;
}
.filtro-grupo label {
  font-family: var(--font-ui); font-size: 10.5px; font-weight: 700;
  text-transform: uppercase; letter-spacing: .07em; color: var(--c-tierra);
}
.filtro-grupo select,
.filtro-grupo input {
  height: 38px; padding: 0 12px;
  border: 1.5px solid var(--c-borde);
  border-radius: var(--r-md);
  font-size: 13px; font-family: var(--font-ui);
  outline: none; transition: var(--t);
  background: var(--c-crema); color: var(--c-texto);
}
.filtro-grupo select:focus,
.filtro-grupo input:focus {
  border-color: var(--c-verde-3);
  background: var(--c-blanco);
  box-shadow: 0 0 0 3px rgba(67,160,71,.1);
}

/* Meses chips para agenda */
.meses-chips {
  display: flex; gap: 6px; flex-wrap: wrap; margin-bottom: 20px;
}
.mes-chip {
  padding: 5px 14px;
  border: 1.5px solid var(--c-borde);
  border-radius: 24px;
  font-family: var(--font-ui); font-size: 12px; font-weight: 600;
  cursor: pointer; transition: var(--t);
  background: var(--c-blanco); color: var(--c-texto-3);
}
.mes-chip:hover, .mes-chip.on {
  background: var(--c-tierra); color: #fff; border-color: var(--c-tierra);
}

@media (max-width: 768px) {
  .evento-card { flex-direction: column; }
  .evento-fecha-bloque { flex-direction: row; gap: 8px; padding: 10px 16px; min-width: auto; }
  .seccion-filtros { flex-direction: column; }
}

/* =====================================================
   GEOLOCALIZACIÓN — TOAST Y SECCIÓN POR PAÍS
===================================================== */

/* Toast de bienvenida — posición y animación base en el JS */
#cl-geo-toast button { transition: all .18s ease; }
#cl-geo-toast button:hover { opacity: .85; transform: scale(.97); }

/* Indicador de país detectado */
#cl-pais-indicador {
  display: none;
  align-items: center;
  gap: 5px;
  font-family: var(--font-ui);
  font-size: 12px;
  color: var(--c-texto-3);
  background: var(--c-fondo);
  padding: 3px 12px;
  border-radius: 24px;
  border: 1px solid var(--c-borde);
  animation: fadeUp .4s ease forwards;
}

/* Sección noticias por país */
#cl-noticias-pais-seccion {
  animation: fadeUp .5s ease forwards;
}
#cl-noticias-pais-seccion .sec-hd::before {
  background: var(--c-acento); /* naranja para diferenciar */
}

/* =====================================================
   BOTONES COMPARTIR EN REDES SOCIALES
===================================================== */
.cl-share-bar {
  margin: 32px 0;
  padding: 20px 24px;
  background: var(--c-surface-2);
  border-radius: var(--r-xl);
  border: 1px solid var(--c-borde);
}
.cl-share-bar-header {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 14px;
  font-family: var(--font-ui);
  font-size: 12px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .1em;
  color: var(--c-texto-3);
}
.cl-share-btns {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  align-items: center;
}
.cl-share-btn {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  padding: 8px 16px;
  border-radius: var(--r-md);
  font-family: var(--font-ui);
  font-size: 13px;
  font-weight: 700;
  cursor: pointer;
  border: none;
  transition: var(--t);
  text-decoration: none;
  line-height: 1;
  white-space: nowrap;
}
.cl-share-btn:hover {
  transform: translateY(-2px);
  box-shadow: var(--sh-2);
}
.cl-share-btn i { font-size: 1rem; }

.cl-share-btn.fb       { background: #1877F2; color: #fff; }
.cl-share-btn.tw       { background: #000;    color: #fff; }
.cl-share-btn.wa       { background: #25D366; color: #fff; }
.cl-share-btn.tg       { background: #0088CC; color: #fff; }
.cl-share-btn.li       { background: #0A66C2; color: #fff; }
.cl-share-btn.em       { background: var(--c-tierra); color: #fff; }
.cl-share-btn.cp       { background: var(--c-fondo); color: var(--c-texto); border: 1.5px solid var(--c-borde); }
.cl-share-btn.nativo   { background: var(--c-verde-2); color: #fff; display: none; }

.cl-share-btn.fb:hover { background: #166FE5; color: #fff; }
.cl-share-btn.wa:hover { background: #128C7E; color: #fff; }
.cl-share-btn.tw:hover { background: #1a1a1a; color: #fff; }

/* Barra flotante en móvil */
.cl-share-float {
  position: fixed;
  bottom: 80px;
  right: 16px;
  z-index: 888;
  display: flex;
  flex-direction: column;
  gap: 8px;
  opacity: 0;
  transform: translateX(80px);
  transition: all .3s cubic-bezier(.34,1.56,.64,1);
  pointer-events: none;
}
.cl-share-float.visible {
  opacity: 1;
  transform: translateX(0);
  pointer-events: all;
}
.cl-share-float-btn {
  width: 46px;
  height: 46px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.1rem;
  cursor: pointer;
  border: none;
  box-shadow: var(--sh-2);
  transition: var(--t);
  color: #fff;
}
.cl-share-float-btn:hover { transform: scale(1.12); }
.cl-share-float-btn.fb  { background: #1877F2; }
.cl-share-float-btn.wa  { background: #25D366; }
.cl-share-float-btn.tw  { background: #000; }
.cl-share-float-btn.tg  { background: #0088CC; }
.cl-share-float-btn.nv  { background: var(--c-verde-2); }

/* Badge "compartido" en tarjeta */
.cl-shared-badge {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-family: var(--font-ui);
  font-size: 11px;
  color: var(--c-texto-3);
}

@media (min-width: 769px) {
  .cl-share-float { display: none; }
}
