/*
Theme Name: Dunes Theme
Theme URI: https://groupdunes.com/dunes-theme
Author: Group Dunes
Author URI: https://groupdunes.com
Description: Theme premium para periódicos digitales (FT/NYT/The Information style). Tipografía Inter, monocromo, multi-tenant: rebrandeable cambiando los tokens en Studio → Marca. Diseñado para acompañar al plugin Dunes AI como pack editorial completo.
Version: 2.34.1
Requires at least: 6.0
Requires PHP: 7.4
License: Commercial
License URI: https://groupdunes.com/license
Text Domain: estenerife
Tags: news, magazine, editorial, monochrome, premium, multi-tenant
*/

:root {
  --et-bg: #FFFFFF; --et-bg-soft: #FAFAFA; --et-bg-panel: #F5F5F4;
  --et-bg-row: #F9F9F8; --et-bg-ink: #0A0A0A; --et-bg-chip: #F0F0EE;
  --et-ink: #0A0A0A; --et-ink2: #1F1F1F; --et-ink3: #525252;
  --et-ink4: #8C8C8C; --et-ink5: #BDBDBD; --et-ink6: #E0E0E0;
  --et-line: #E5E5E5; --et-line-hi: #D4D4D4; --et-line-dk: #0A0A0A;
  --et-red: #C8102E; --et-green: #15803D; --et-amber: #B45309;
  /* HARBOR BLUE — premium accent (FT/NYT inspired) */
  --et-harbor: #1B4965; --et-harbor-deep: #0E2F46; --et-harbor-mid: #2D6A8E;
  --et-harbor-light: #62B6CB; --et-harbor-soft: #E8F0F4; --et-harbor-tint: #F4F8FA;
  --et-font: 'Inter', -apple-system, BlinkMacSystemFont, system-ui, sans-serif;
  --et-mono: 'JetBrains Mono', 'SF Mono', Menlo, monospace;
  --et-serif: var(--et-font);
  --et-max: 1440px; --et-pad: 40px;
}

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body { font-family: var(--et-font); background: var(--et-bg); color: var(--et-ink); -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; font-size: 15px; line-height: 1.5; }
a { color: inherit; text-decoration: none; }
img, svg { max-width: 100%; display: block; }
button { font-family: inherit; cursor: pointer; }
input, textarea, select { font-family: inherit; }
::selection { background: var(--et-ink); color: var(--et-bg); }

@keyframes etPulse { 0%,100% { opacity: 1; transform: scale(1); } 50% { opacity: 0.4; transform: scale(1.4); } }

.et-cat { font-size: 11px; font-weight: 700; letter-spacing: 2px; text-transform: uppercase; color: var(--et-ink); display: inline-block; line-height: 1; }
.et-cat--sm { font-size: 10px; letter-spacing: 1.6px; }
.et-cat--muted { color: var(--et-ink3); }
.et-meta { font-size: 12px; color: var(--et-ink3); font-weight: 400; font-variant-numeric: tabular-nums; letter-spacing: 0.1px; }

.et-photo { width: 100%; aspect-ratio: 16/9; position: relative; overflow: hidden; background: linear-gradient(160deg,#0A0A0A 0%,#1F1F1F 38%,#3A3A3A 72%,#5A5A5A 100%); }
.et-photo--v2 { background: linear-gradient(135deg,#171717 0%,#2D2D2D 50%,#454545 100%); }
.et-photo--v3 { background: linear-gradient(170deg,#0F0F0F 0%,#262626 60%,#3D3D3D 100%); }
.et-photo--v4 { background: linear-gradient(140deg,#1A1A1A 0%,#2A2A2A 40%,#404040 100%); }
.et-photo--v5 { background: linear-gradient(160deg,#0D0D0D 0%,#1F1F1F 50%,#363636 100%); }
.et-photo--v6 { background: linear-gradient(180deg,#000000 0%,#1A1A1A 50%,#2E2E2E 100%); }
.et-photo--v7 { background: linear-gradient(150deg,#141414 0%,#2D2D2D 60%,#444444 100%); }
.et-photo--v8 { background: linear-gradient(165deg,#0A0A0A 0%,#222222 45%,#3A3A3A 100%); }
.et-photo::before { content: ""; position: absolute; inset: 0; background: radial-gradient(ellipse at 28% 22%, rgba(255,255,255,0.10) 0%, transparent 55%); }
.et-photo img { width: 100%; height: 100%; object-fit: cover; position: relative; z-index: 1; }
.et-photo--4-3 { aspect-ratio: 4/3; } .et-photo--3-2 { aspect-ratio: 3/2; }
.et-photo--21-9 { aspect-ratio: 21/9; } .et-photo--1-1 { aspect-ratio: 1/1; }
.et-photo__credit { position: absolute; bottom: 14px; right: 18px; z-index: 2; font-size: 10px; color: rgba(255,255,255,0.62); font-weight: 400; letter-spacing: 0.2px; text-align: right; max-width: 60%; }
.et-photo__eyebrow { position: absolute; top: 18px; left: 20px; z-index: 2; font-size: 9.5px; color: rgba(255,255,255,0.85); font-weight: 700; letter-spacing: 2px; text-transform: uppercase; padding: 4px 10px; background: rgba(0,0,0,0.55); backdrop-filter: blur(6px); }

.et-dot { display: inline-block; width: 6px; height: 6px; border-radius: 50%; background: var(--et-red); flex-shrink: 0; animation: etPulse 1.5s ease-in-out infinite; }
.et-dot--green { background: var(--et-green); }

/* UTILITY BAR */
.et-utility { background: var(--et-bg-ink); color: #D4D4D4; font-size: 11px; border-bottom: 1px solid #1A1A1A; }
.et-utility__inner { display: flex; align-items: center; justify-content: space-between; max-width: var(--et-max); margin: 0 auto; padding: 10px var(--et-pad); letter-spacing: 0.3px; }
.et-utility__left, .et-utility__right { display: flex; align-items: center; gap: 18px; }
.et-utility__right { gap: 22px; }
.et-utility__sep { color: #525252; }
.et-utility__date { color: #FAFAFA; font-weight: 500; text-transform: capitalize; }
.et-utility__time { font-family: var(--et-mono); color: #FAFAFA; font-weight: 500; font-variant-numeric: tabular-nums; }
.et-utility__loc { color: #A8A8A8; }
.et-utility__loc strong { font-family: var(--et-mono); color: #FAFAFA; font-weight: 500; }
.et-utility a { color: #A8A8A8; }
.et-utility a:hover { color: #FFF; }
.et-utility__cta { background: #FFF; color: var(--et-ink); border: 0; padding: 6px 16px; font-size: 10.5px; font-weight: 700; letter-spacing: 1.6px; text-transform: uppercase; cursor: pointer; }

/* MASTHEAD */
.et-masthead { background: var(--et-bg); border-bottom: 1px solid var(--et-line); }
.et-masthead__top { max-width: var(--et-max); margin: 0 auto; padding: 16px var(--et-pad) 0; display: grid; grid-template-columns: 1fr auto 1fr; align-items: center; gap: 24px; }
.et-masthead__top span { font-size: 9.5px; font-weight: 600; letter-spacing: 2.6px; text-transform: uppercase; color: var(--et-ink4); font-family: var(--et-mono); }
.et-masthead__top span:nth-child(2) { text-align: center; }
.et-masthead__top span:nth-child(3) { text-align: right; }
.et-masthead__main { max-width: var(--et-max); margin: 0 auto; padding: 20px var(--et-pad) 22px; display: grid; grid-template-columns: 1fr auto 1fr; align-items: center; gap: 32px; }
.et-masthead__menu { display: flex; align-items: center; gap: 18px; }
.et-masthead__menu-btn { width: 36px; height: 36px; border: 1px solid var(--et-line); background: transparent; display: flex; align-items: center; justify-content: center; cursor: pointer; }
.et-masthead__menu-btn span { font-family: var(--et-mono); font-size: 14px; font-weight: 600; color: var(--et-ink); line-height: 1; }
.et-masthead__menu-label { font-size: 11px; color: var(--et-ink3); font-weight: 500; }
.et-wordmark { text-decoration: none; text-align: center; display: block; }
.et-wordmark__h1 { margin: 0; color: var(--et-ink); font-size: 76px; line-height: 0.95; display: flex; align-items: baseline; justify-content: center; }
.et-wordmark__es { font-weight: 200; letter-spacing: -1px; }
.et-wordmark__name { font-weight: 900; letter-spacing: -4px; }
.et-masthead__actions { display: flex; justify-content: flex-end; align-items: center; gap: 10px; }
.et-search { display: flex; align-items: center; gap: 8px; border: 1px solid var(--et-line); padding: 8px 12px; background: var(--et-bg); min-width: 220px; }
.et-search input { border: 0; background: transparent; outline: none; flex: 1; font-size: 12.5px; color: var(--et-ink); }
.et-search__kbd { font-size: 9px; color: var(--et-ink4); padding: 2px 6px; border: 1px solid var(--et-line); font-family: var(--et-mono); background: var(--et-bg-soft); font-weight: 500; }
.et-icon-btn { width: 36px; height: 36px; border: 1px solid var(--et-line); background: transparent; cursor: pointer; display: flex; align-items: center; justify-content: center; }

.et-tagline-rule { border-top: 1px solid var(--et-line); border-bottom: 2px solid var(--et-ink); }
.et-tagline-rule__inner { max-width: var(--et-max); margin: 0 auto; padding: 10px var(--et-pad); display: flex; align-items: center; justify-content: center; gap: 16px; }
.et-tagline-rule__inner span { font-size: 9.5px; font-weight: 700; letter-spacing: 3.5px; text-transform: uppercase; color: var(--et-ink); }
.et-tagline-rule__inner span.muted { font-weight: 500; letter-spacing: 2.4px; color: var(--et-ink3); }
.et-tagline-rule__inner span.mono { font-family: var(--et-mono); font-weight: 500; letter-spacing: 2.4px; color: var(--et-ink3); }
.et-tagline-rule__dot { width: 4px; height: 4px; background: var(--et-ink); border-radius: 50%; }

/* NAV */
.et-nav { background: var(--et-bg); border-bottom: 1px solid var(--et-line); position: sticky; top: 0; z-index: 50; backdrop-filter: saturate(180%) blur(8px); }
.et-nav__inner { max-width: var(--et-max); margin: 0 auto; padding: 0 var(--et-pad); display: flex; align-items: stretch; justify-content: space-between; }
.et-nav__list { display: flex; align-items: stretch; list-style: none; }
.et-nav__list a { padding: 16px 18px; font-size: 13px; font-weight: 500; color: var(--et-ink2); letter-spacing: -0.1px; border-bottom: 2px solid transparent; margin-bottom: -1px; transition: all 0.15s; display: inline-flex; align-items: center; gap: 6px; }
.et-nav__list a.is-active, .et-nav__list .current-menu-item a { font-weight: 700; color: var(--et-ink); border-bottom-color: var(--et-ink); }
.et-nav__list a:hover { color: var(--et-ink); }
.et-nav__right { display: flex; align-items: center; gap: 22px; }
.et-nav__right a { font-size: 11.5px; font-weight: 500; color: var(--et-ink3); }
.et-nav__right a.live { font-weight: 600; color: var(--et-ink2); display: flex; align-items: center; gap: 5px; letter-spacing: 0.5px; }

/* TICKER */
.et-ticker { background: var(--et-bg); border-bottom: 1px solid var(--et-line); }
.et-ticker__inner { max-width: var(--et-max); margin: 0 auto; padding: 0 var(--et-pad); display: flex; align-items: center; height: 44px; }
.et-ticker__label { display: inline-flex; align-items: center; gap: 9px; color: var(--et-red); font-size: 10.5px; font-weight: 800; letter-spacing: 2.2px; padding-right: 20px; border-right: 1px solid var(--et-line); }
.et-ticker__label .et-dot { width: 7px; height: 7px; }
.et-ticker__text { flex: 1; padding-left: 20px; font-size: 13.5px; font-weight: 500; color: var(--et-ink); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; transition: opacity 0.28s; }
.et-ticker__text.is-out { opacity: 0; }
.et-ticker__nav { display: flex; align-items: center; gap: 12px; }
.et-ticker__count { font-size: 10.5px; color: var(--et-ink4); font-family: var(--et-mono); font-weight: 500; letter-spacing: 0.5px; }
.et-ticker__count em { color: var(--et-ink5); font-style: normal; }
.et-ticker__btn { width: 24px; height: 24px; border: 1px solid var(--et-line); background: transparent; display: flex; align-items: center; justify-content: center; color: var(--et-ink3); cursor: pointer; }

/* HERO */
.et-hero { max-width: var(--et-max); margin: 0 auto; padding: 56px var(--et-pad) 0; }
.et-hero__grid { display: grid; grid-template-columns: 1.7fr 1fr; gap: 64px; margin-top: 40px; align-items: start; }
.et-hero__eyebrows { margin-bottom: 18px; display: flex; align-items: center; gap: 14px; flex-wrap: wrap; }
.et-hero__pipe { width: 1px; height: 12px; background: var(--et-line); }
.et-hero__kicker { font-size: 12px; color: var(--et-ink3); font-weight: 400; letter-spacing: 0.1px; }
.et-hero__badge { padding: 4px 9px; background: var(--et-ink); color: var(--et-bg); font-size: 9.5px; font-weight: 800; letter-spacing: 1.8px; }
.et-hero__title { margin: 0 0 24px; font-weight: 800; font-size: 64px; line-height: 1.02; letter-spacing: -2.6px; color: var(--et-ink); }
.et-hero__lede { margin: 0 0 32px; font-size: 19px; line-height: 1.55; color: var(--et-ink2); font-weight: 400; max-width: 760px; letter-spacing: -0.2px; }

.et-byline { display: flex; align-items: center; gap: 16px; padding-top: 22px; border-top: 1px solid var(--et-line); }
.et-avatar { width: 42px; height: 42px; border-radius: 50%; background: #1F1F1F; display: flex; align-items: center; justify-content: center; color: #FFF; font-weight: 600; font-size: 12px; letter-spacing: 0.5px; flex-shrink: 0; position: relative; overflow: hidden; }
.et-byline__main { flex: 1; display: flex; flex-direction: column; gap: 3px; }
.et-byline__name { font-size: 14px; font-weight: 700; color: var(--et-ink); letter-spacing: -0.2px; }
.et-byline__role { font-size: 12px; color: var(--et-ink3); font-weight: 400; }
.et-byline__meta { display: flex; align-items: center; gap: 8px; }
.et-byline__tools { display: flex; gap: 6px; }
.et-byline__tools button { width: 36px; height: 36px; border: 1px solid var(--et-line); background: var(--et-bg); display: flex; align-items: center; justify-content: center; cursor: pointer; transition: border-color 0.15s; }
.et-byline__tools button:hover { border-color: var(--et-ink); }

.et-hero__side h3 { margin: 0; font-weight: 800; font-size: 18px; color: var(--et-ink); letter-spacing: -0.5px; }
.et-hero__side-head { padding-bottom: 14px; border-bottom: 2px solid var(--et-ink); display: flex; align-items: baseline; justify-content: space-between; }
.et-hero__side-head .live { font-size: 9.5px; font-weight: 700; letter-spacing: 2px; color: var(--et-red); text-transform: uppercase; display: inline-flex; align-items: center; gap: 6px; }

.et-side-item { display: flex; gap: 18px; padding: 20px 0; border-bottom: 1px solid var(--et-line); }
.et-side-item:last-of-type { border-bottom: 0; }
.et-side-item__num { font-size: 36px; font-weight: 200; color: var(--et-ink5); line-height: 0.9; min-width: 36px; font-variant-numeric: tabular-nums; letter-spacing: -2px; }
.et-side-item__title { margin: 8px 0 8px; font-weight: 700; font-size: 16px; line-height: 1.28; color: var(--et-ink); letter-spacing: -0.4px; }
.et-side-item__title a:hover { opacity: 0.7; }

.et-pq { padding-top: 28px; border-top: 1px solid var(--et-line); margin-top: 28px; }
.et-pq__label { font-size: 9.5px; font-weight: 700; letter-spacing: 2.4px; color: var(--et-ink4); display: block; margin-bottom: 16px; }
.et-pq__text { margin: 0 0 20px; font-weight: 600; font-size: 22px; line-height: 1.32; color: var(--et-ink); letter-spacing: -0.7px; }
.et-pq__attr { display: flex; align-items: center; gap: 12px; }
.et-pq__attr-rule { width: 24px; height: 1px; background: var(--et-ink); }
.et-pq__attr-name { font-size: 12.5px; font-weight: 700; color: var(--et-ink); letter-spacing: -0.1px; }
.et-pq__attr-role { font-size: 11.5px; color: var(--et-ink3); margin-top: 2px; display: block; }

/* SECTION HEAD */
.et-section-head { max-width: var(--et-max); margin: 88px auto 36px; padding: 0 var(--et-pad); }
.et-section-head__row { display: flex; align-items: flex-end; justify-content: space-between; gap: 20px; }
.et-section-head__num { font-size: 10px; font-family: var(--et-mono); font-weight: 600; color: var(--et-ink3); letter-spacing: 2.4px; }
.et-section-head__sub { font-size: 12px; color: var(--et-ink3); font-weight: 400; letter-spacing: 0.1px; }
.et-section-head__top { display: flex; align-items: center; gap: 12px; margin-bottom: 14px; }
.et-section-head__top-rule { width: 36px; height: 1px; background: var(--et-line-hi); }
.et-section-head h3 { margin: 0; font-weight: 800; font-size: 48px; color: var(--et-ink); letter-spacing: -2px; line-height: 1; }
.et-section-head__rule { height: 2px; background: var(--et-ink); margin-top: 20px; }
.et-section-head__action { font-size: 11.5px; font-weight: 600; letter-spacing: 1.6px; text-transform: uppercase; color: var(--et-ink); display: inline-flex; align-items: center; gap: 6px; padding-bottom: 4px; border-bottom: 1px solid var(--et-ink); }

/* TENERIFE GRID */
.et-tnf { max-width: var(--et-max); margin: 0 auto; padding: 0 var(--et-pad); }
.et-tnf__layout { display: grid; grid-template-columns: 1fr 380px; gap: 56px; }
.et-tnf__lead-grid { display: grid; grid-template-columns: 1.3fr 1fr; gap: 32px; margin-bottom: 44px; }
.et-tnf__lead-text { display: flex; flex-direction: column; justify-content: center; }
.et-tnf__lead-title { margin: 14px 0 14px; font-weight: 800; font-size: 34px; line-height: 1.08; color: var(--et-ink); letter-spacing: -1.2px; }
.et-tnf__lead-summary { margin: 0 0 22px; font-size: 16px; line-height: 1.55; color: var(--et-ink2); font-weight: 400; letter-spacing: -0.1px; }
.et-tnf__lead-byline { display: flex; align-items: center; gap: 12px; }
.et-tnf__lead-byline-rule { width: 18px; height: 1px; background: var(--et-ink); }
.et-tnf__lead-byline-name { font-size: 12.5px; font-weight: 700; color: var(--et-ink); letter-spacing: -0.1px; }
.et-tnf__cards { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 32px; margin: 36px 0 44px; }
.et-tnf__card-title { margin: 12px 0 12px; font-weight: 700; font-size: 19px; line-height: 1.25; color: var(--et-ink); letter-spacing: -0.5px; }
.et-tnf__list { margin-top: 36px; }
.et-tnf__list-row { padding: 22px 0; display: grid; grid-template-columns: 44px 130px 1fr 100px 16px; align-items: center; gap: 24px; border-bottom: 1px solid var(--et-line); transition: background 0.15s; }
.et-tnf__list-row:last-child { border-bottom: 0; }
.et-tnf__list-row:hover { background: var(--et-bg-soft); }
.et-tnf__list-num { font-size: 11px; font-family: var(--et-mono); color: var(--et-ink5); letter-spacing: 1px; font-weight: 500; }
.et-tnf__list-title { margin: 0; font-size: 16px; font-weight: 600; line-height: 1.35; color: var(--et-ink); letter-spacing: -0.3px; }

.et-sb { position: sticky; top: 80px; align-self: start; }
.et-sb__head { padding-bottom: 14px; border-bottom: 2px solid var(--et-ink); display: flex; align-items: baseline; justify-content: space-between; }
.et-sb__head h4 { margin: 0; font-weight: 800; font-size: 18px; color: var(--et-ink); letter-spacing: -0.5px; }
.et-sb__head-tag { font-size: 9.5px; font-weight: 700; letter-spacing: 2px; color: var(--et-ink3); font-family: var(--et-mono); }
.et-sb__row { padding: 18px 0; display: flex; gap: 18px; align-items: flex-start; border-bottom: 1px solid var(--et-line); }
.et-sb__row:last-child { border-bottom: 0; }
.et-sb__rank { font-size: 40px; font-weight: 200; color: var(--et-ink5); line-height: 0.9; letter-spacing: -2.5px; font-variant-numeric: tabular-nums; min-width: 36px; }
.et-sb__row:first-child .et-sb__rank { color: var(--et-ink); }
.et-sb__title { margin: 0 0 8px; font-weight: 600; font-size: 15px; line-height: 1.32; color: var(--et-ink); letter-spacing: -0.3px; }
.et-sb__ad { padding: 24px; margin-bottom: 36px; margin-top: 44px; border: 1px solid var(--et-line); background: var(--et-bg); }
.et-sb__ad-label { font-size: 9px; font-weight: 700; letter-spacing: 2.4px; color: var(--et-ink4); margin-bottom: 18px; }
.et-sb__ad-title { margin: 18px 0 10px; font-weight: 700; font-size: 17px; color: var(--et-ink); line-height: 1.25; letter-spacing: -0.4px; }
.et-sb__ad-desc { margin: 0 0 16px; font-size: 13px; color: var(--et-ink2); line-height: 1.5; }
.et-sb__ad-cta { font-size: 11px; font-weight: 700; letter-spacing: 1.5px; text-transform: uppercase; color: var(--et-ink); display: inline-flex; align-items: center; gap: 6px; padding-bottom: 3px; border-bottom: 1px solid var(--et-ink); }

/* OPINION */
.et-op { max-width: var(--et-max); margin: 0 auto; padding: 0 var(--et-pad); }
.et-op__grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 0; }
.et-op__col { padding: 0 28px; display: flex; flex-direction: column; gap: 22px; border-right: 1px solid var(--et-line); }
.et-op__col:first-child { padding-left: 0; }
.et-op__col:last-child { padding-right: 0; border-right: 0; }
.et-op__author { display: flex; align-items: center; gap: 14px; }
.et-op__avatar { width: 56px; height: 56px; border-radius: 50%; display: flex; align-items: center; justify-content: center; color: #FFF; font-size: 14px; font-weight: 700; letter-spacing: 0.5px; }
.et-op__avatar.v1 { background: #1A1A1A; }
.et-op__avatar.v2 { background: #2D2D2D; }
.et-op__avatar.v3 { background: #404040; }
.et-op__avatar.v4 { background: #525252; }
.et-op__name { font-weight: 700; font-size: 15px; color: var(--et-ink); letter-spacing: -0.2px; }
.et-op__role { font-size: 10px; font-weight: 700; letter-spacing: 1.8px; text-transform: uppercase; color: var(--et-ink3); margin-top: 3px; display: block; }
.et-op__title { margin: 0; font-weight: 700; font-size: 22px; line-height: 1.2; color: var(--et-ink); letter-spacing: -0.7px; min-height: 80px; }
.et-op__cta { font-size: 11px; font-weight: 700; letter-spacing: 1.5px; text-transform: uppercase; color: var(--et-ink); display: inline-flex; align-items: center; gap: 5px; margin-top: auto; padding-bottom: 3px; border-bottom: 1px solid var(--et-ink); align-self: flex-start; }

/* ECONOMY */
.et-eco { background: var(--et-bg-panel); border-top: 1px solid var(--et-line); border-bottom: 1px solid var(--et-line); padding: 72px 0; margin-top: 80px; }
.et-eco__inner { max-width: var(--et-max); margin: 0 auto; padding: 0 var(--et-pad); }
.et-eco__grid { display: grid; grid-template-columns: 1.4fr 1fr; gap: 40px; }
.et-eco__chart-card { background: var(--et-bg); padding: 36px; border: 1px solid var(--et-line); }
.et-eco__chart-head { display: flex; align-items: flex-end; justify-content: space-between; margin-bottom: 28px; }
.et-eco__chart-val { margin: 12px 0 0; font-weight: 800; font-size: 48px; color: var(--et-ink); letter-spacing: -2.5px; font-variant-numeric: tabular-nums; line-height: 1; }
.et-eco__chg { display: inline-flex; align-items: center; gap: 6px; margin-bottom: 8px; }
.et-eco__chg-val { font-size: 20px; font-weight: 700; color: var(--et-green); font-variant-numeric: tabular-nums; letter-spacing: -0.5px; }
.et-eco__pts { font-size: 11.5px; color: var(--et-ink3); font-family: var(--et-mono); font-weight: 500; letter-spacing: 0.5px; }
.et-eco__periods { display: flex; margin-top: 22px; justify-content: center; border: 1px solid var(--et-line); }
.et-eco__period { padding: 9px 20px; background: transparent; color: var(--et-ink3); border: 0; border-right: 1px solid var(--et-line); font-size: 11px; font-weight: 600; letter-spacing: 1.2px; cursor: pointer; }
.et-eco__period:last-child { border-right: 0; }
.et-eco__period.is-active { background: var(--et-ink); color: var(--et-bg); }

.et-mkt { background: var(--et-bg); border: 1px solid var(--et-line); }
.et-mkt__row { display: grid; grid-template-columns: 1fr auto auto; gap: 16px; padding: 15px 22px; align-items: center; border-bottom: 1px solid var(--et-line); transition: background 0.15s; cursor: pointer; }
.et-mkt__row:last-child { border-bottom: 0; }
.et-mkt__row:hover { background: var(--et-bg-soft); }
.et-mkt__sym { font-size: 11.5px; font-weight: 700; color: var(--et-ink); letter-spacing: 1.2px; }
.et-mkt__val { font-size: 14.5px; font-weight: 600; font-family: var(--et-mono); color: var(--et-ink); font-variant-numeric: tabular-nums; }
.et-mkt__chg { font-size: 12px; font-weight: 700; font-family: var(--et-mono); min-width: 70px; text-align: right; font-variant-numeric: tabular-nums; }
.et-mkt__chg.up { color: var(--et-green); }
.et-mkt__chg.down { color: var(--et-red); }

/* CULTURE */
.et-cul { max-width: var(--et-max); margin: 0 auto; padding: 0 var(--et-pad); }
.et-cul__grid { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 32px; }
.et-cul__card { cursor: pointer; transition: transform 0.25s; }
.et-cul__card:hover { transform: translateY(-4px); }
.et-cul__card-title { margin: 14px 0 0; font-weight: 700; font-size: 23px; line-height: 1.2; color: var(--et-ink); letter-spacing: -0.7px; }

/* WEATHER + SEISMIC */
.et-data { max-width: var(--et-max); margin: 0 auto; padding: 0 var(--et-pad); }
.et-data__grid { display: grid; grid-template-columns: 1.3fr 1fr; gap: 40px; }
.et-data__card { background: var(--et-bg); border: 1px solid var(--et-line); }
.et-data__head { padding: 24px 28px; border-bottom: 1px solid var(--et-line); display: flex; align-items: baseline; justify-content: space-between; }
.et-data__head h4 { margin: 0; font-weight: 800; font-size: 18px; color: var(--et-ink); letter-spacing: -0.5px; }
.et-data__head-meta { font-size: 9.5px; font-weight: 600; letter-spacing: 1.6px; color: var(--et-ink4); font-family: var(--et-mono); }

.et-weather__row { display: grid; grid-template-columns: repeat(7, 1fr); }
.et-weather__cell { padding: 26px 8px 28px; text-align: center; border-right: 1px solid var(--et-line); }
.et-weather__cell:last-child { border-right: 0; }
.et-weather__cell.is-home { background: var(--et-bg-soft); }
.et-weather__isle { font-size: 9.5px; font-weight: 700; letter-spacing: 1.4px; color: var(--et-ink3); margin-bottom: 14px; }
.et-weather__t { font-size: 32px; font-weight: 200; color: var(--et-ink); line-height: 1; letter-spacing: -2px; font-variant-numeric: tabular-nums; }
.et-weather__t span { font-size: 16px; color: var(--et-ink4); font-weight: 400; }
.et-weather__lh { font-size: 10.5px; color: var(--et-ink4); margin-top: 10px; font-family: var(--et-mono); font-weight: 500; letter-spacing: 0.5px; }

.et-quake__row { padding: 18px 28px; display: flex; align-items: center; gap: 20px; border-bottom: 1px solid var(--et-line); }
.et-quake__row:last-child { border-bottom: 0; }
.et-quake__mag { min-width: 56px; height: 56px; display: flex; flex-direction: column; align-items: center; justify-content: center; background: var(--et-bg-soft); color: var(--et-ink); border: 1px solid var(--et-line); }
.et-quake__mag.is-strong { background: var(--et-ink); color: var(--et-bg); border: 0; }
.et-quake__mag-num { font-weight: 700; font-size: 19px; line-height: 1; font-variant-numeric: tabular-nums; letter-spacing: -0.5px; }
.et-quake__mag-lbl { font-size: 8.5px; font-weight: 600; letter-spacing: 1px; margin-top: 4px; opacity: 0.7; }
.et-quake__place { font-size: 14.5px; font-weight: 600; color: var(--et-ink); margin-bottom: 4px; letter-spacing: -0.2px; }
.et-quake__live { font-size: 9px; font-weight: 800; letter-spacing: 1.8px; color: var(--et-red); padding: 4px 9px; border: 1px solid var(--et-red); }

/* NEWSLETTER */
.et-news { background: var(--et-harbor-deep); color: #fff; padding: 96px var(--et-pad); margin-top: 0; border-top: 4px solid var(--et-harbor-light); }
.et-news__inner { max-width: 1100px; margin: 0 auto; display: grid; grid-template-columns: 1.2fr 1fr; gap: 72px; align-items: center; }
.et-news__kicker { font-size: 10.5px; font-weight: 700; letter-spacing: 2.6px; color: #A8A8A8; text-transform: uppercase; }
.et-news h3 { margin: 20px 0 22px; font-weight: 800; font-size: 48px; line-height: 1.05; color: #FFF; letter-spacing: -2px; }
.et-news p { margin: 0; font-size: 16px; color: #A8A8A8; line-height: 1.6; max-width: 480px; font-weight: 400; letter-spacing: -0.1px; }
.et-news__form { background: #FFF; padding: 6px; display: flex; gap: 6px; margin-bottom: 16px; }
.et-news__form input { flex: 1; padding: 13px 16px; background: transparent; border: 0; outline: none; font-size: 15px; color: var(--et-ink); }
.et-news__form button { padding: 10px 26px; background: var(--et-harbor); color: #FFF; border: 0; font-size: 11px; font-weight: 700; letter-spacing: 1.8px; text-transform: uppercase; cursor: pointer; }
.et-news__legal { font-size: 11px; color: #737373; margin: 0; line-height: 1.6; }
.et-news__legal a { color: #FFF; text-decoration: underline; }

/* FOOTER */
.et-footer { background: #000; color: #A8A8A8; padding: 72px var(--et-pad) 36px; }
.et-footer__inner { max-width: var(--et-max); margin: 0 auto; }
.et-footer__top { display: flex; align-items: flex-start; justify-content: space-between; padding-bottom: 44px; border-bottom: 1px solid #1A1A1A; }
.et-footer__brand h4 { margin: 0; color: #FFF; font-size: 40px; line-height: 1; display: flex; align-items: baseline; }
.et-footer__brand h4 .es { font-weight: 200; letter-spacing: -0.5px; }
.et-footer__brand h4 .name { font-weight: 900; letter-spacing: -2.5px; }
.et-footer__brand p { margin: 14px 0 0; font-size: 13px; color: #737373; max-width: 420px; line-height: 1.6; }
.et-footer__social { display: flex; gap: 8px; }
.et-footer__social a { width: 38px; height: 38px; border: 1px solid #262626; display: flex; align-items: center; justify-content: center; color: #737373; transition: all 0.2s; }
.et-footer__social a:hover { border-color: #FFF; color: #FFF; }
.et-footer__cols { display: grid; grid-template-columns: repeat(4, 1fr); gap: 40px; padding: 44px 0; }
.et-footer__col h5 { margin: 0 0 20px; font-size: 10px; font-weight: 700; letter-spacing: 2.6px; color: #FFF; text-transform: uppercase; }
.et-footer__col ul { list-style: none; padding: 0; margin: 0; }
.et-footer__col li { margin-bottom: 10px; }
.et-footer__col a { color: #A8A8A8; font-size: 13px; font-weight: 400; transition: color 0.15s; }
.et-footer__col a:hover { color: #FFF; }
.et-footer__bottom { padding-top: 30px; border-top: 1px solid #1A1A1A; display: flex; align-items: center; justify-content: space-between; font-size: 11.5px; color: #525252; font-weight: 400; }
.et-footer__bottom em { font-family: var(--et-mono); font-weight: 500; font-style: normal; }

/* ARTICLE */
.et-article__progress { position: fixed; top: 0; left: 0; right: 0; height: 2px; background: transparent; z-index: 100; }
.et-article__progress > div { height: 100%; width: 0; background: var(--et-red); transition: width 0.1s ease-out; }
.et-article__head { max-width: var(--et-max); margin: 0 auto; padding: 48px var(--et-pad) 0; }
.et-breadcrumb { display: flex; align-items: center; gap: 10px; font-size: 11.5px; color: var(--et-ink3); margin-bottom: 36px; }
.et-breadcrumb a { color: var(--et-ink3); display: inline-flex; align-items: center; gap: 4px; }
.et-breadcrumb a:hover { color: var(--et-ink); }
.et-breadcrumb strong { color: var(--et-ink); font-weight: 500; }
.et-article__eyebrows { margin-bottom: 28px; display: flex; align-items: center; gap: 14px; }
.et-article__center { max-width: 1100px; margin: 0 auto; text-align: center; }
.et-article__title { margin: 0 0 28px; font-weight: 800; font-size: 72px; line-height: 1.0; letter-spacing: -3px; color: var(--et-ink); }
.et-article__subhead { margin: 0 auto 36px; font-size: 22px; line-height: 1.45; color: var(--et-ink2); font-weight: 400; letter-spacing: -0.4px; max-width: 880px; }
.et-article__byline-row { max-width: 1100px; margin: 0 auto; padding: 28px 0; border-top: 1px solid var(--et-line); border-bottom: 1px solid var(--et-line); display: flex; align-items: center; gap: 20px; }
.et-article__updated { font-size: 9.5px; font-weight: 700; letter-spacing: 2px; color: var(--et-ink4); text-transform: uppercase; margin-right: 8px; }
.et-article__hero { max-width: var(--et-max); margin: 0 auto; padding: 48px var(--et-pad) 0; }
.et-article__caption { max-width: 880px; margin: 16px auto 0; display: flex; align-items: flex-start; gap: 12px; }
.et-article__caption .rule { width: 18px; height: 1px; background: var(--et-ink); margin-top: 10px; flex-shrink: 0; }
.et-article__caption p { margin: 0; font-size: 13px; color: var(--et-ink3); line-height: 1.55; letter-spacing: -0.1px; font-style: italic; }
.et-article__caption strong { font-style: normal; font-weight: 500; color: var(--et-ink2); }

/* ═══ Banda de patrocinio sobre imagen (DEPRECATED — ahora va atribución debajo) ═══ */
.et-article__sponsor {
    max-width: 100%;
    margin: 0 0 10px;
    border-radius: 6px 6px 0 0;
    overflow: hidden;
    font-family: 'Inter', -apple-system, BlinkMacSystemFont, sans-serif;
}
.et-article__sponsor-inner {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 12px;
    padding: 12px 18px;
    text-decoration: none;
    transition: opacity 0.2s, transform 0.2s;
}
a.et-article__sponsor-inner:hover { opacity: 0.92; }
.et-article__sponsor-intro { font-size: 11.5px; font-weight: 600; letter-spacing: 1.6px; text-transform: uppercase; line-height: 1; }
.et-article__sponsor-brand { font-size: 17px; font-weight: 800; letter-spacing: -0.4px; line-height: 1; font-family: 'Inter', sans-serif; }
.et-article__sponsor-logo  { height: 24px; width: auto; max-width: 180px; object-fit: contain; display: block; filter: drop-shadow(0 1px 2px rgba(0,0,0,0.08)); }

/* ═══════════════════════════════════════════════════════════════════
   ATRIBUCIÓN DE PATROCINIO — debajo de la imagen del artículo
   Diseño FT/Bloomberg: hairlines a los lados + brand centrado
═══════════════════════════════════════════════════════════════════ */
.et-article__attribution {
    max-width: 880px;
    margin: 24px auto 0;
    display: flex;
    align-items: center;
    gap: 14px;
    font-family: 'Inter', -apple-system, BlinkMacSystemFont, sans-serif;
}
.et-article__attribution-rule {
    flex: 1;
    height: 1px;
    background: linear-gradient(to right, transparent, var(--et-line, #D4D2CB), transparent);
    min-width: 30px;
}
.et-article__attribution-inner {
    display: inline-flex;
    align-items: center;
    gap: 12px;
    padding: 4px 0;
    text-decoration: none;
    color: var(--et-ink, #0A0A0A);
    transition: opacity 0.2s;
    flex-shrink: 0;
}
a.et-article__attribution-inner:hover { opacity: 0.7; }
.et-article__attribution-intro {
    font-size: 10.5px;
    font-weight: 600;
    color: var(--et-ink3, #8A8987);
    letter-spacing: 2px;
    text-transform: uppercase;
    line-height: 1;
}
.et-article__attribution-brand {
    font-size: 18px;
    font-weight: 700;
    color: var(--et-ink, #0A0A0A);
    letter-spacing: -0.4px;
    line-height: 1;
    font-family: 'Inter', sans-serif;
}
.et-article__attribution-logo {
    height: 28px;
    width: auto;
    max-width: 160px;
    object-fit: contain;
    display: block;
}
@media (max-width: 720px) {
    .et-article__attribution { margin-top: 18px; gap: 10px; }
    .et-article__attribution-intro { font-size: 9.5px; letter-spacing: 1.6px; }
    .et-article__attribution-brand { font-size: 16px; }
    .et-article__attribution-logo  { height: 22px; max-width: 130px; }
    .et-article__attribution-rule  { min-width: 16px; }
}

/* ═══════════════════════════════════════════════════════════════════
   BANDA DE PATROCINIO EN CARDS DEL HOME
   La banda va DENTRO del photo wrapper como overlay absoluto top
   para no afectar a la altura de la imagen ni romper la grid.
═══════════════════════════════════════════════════════════════════ */
.et-card-sponsor {
    position: absolute;
    top: 0; left: 0; right: 0;
    z-index: 5;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    padding: 7px 12px;
    font-family: 'Inter', -apple-system, BlinkMacSystemFont, sans-serif;
    text-decoration: none;
    line-height: 1;
    transition: opacity 0.2s;
    min-height: 30px;
}
/* Photo wrappers necesitan position: relative para que el sponsor absoluto se ancle */
.et-m-cover__photo,
.et-m-grid__photo,
.et-m-g3__photo,
.et-m-carousel__photo,
.et-m-l2__lead-photo, .et-m-l2__second-photo,
.et-m-mag__lead-photo, .et-m-mag__row-photo {
    position: relative !important;
}
a.et-card-sponsor { pointer-events: auto; }
a.et-card-sponsor:hover { opacity: 0.92; }
.et-card-sponsor__intro {
    font-size: 8.5px;
    font-weight: 700;
    letter-spacing: 1.4px;
    text-transform: uppercase;
    opacity: 0.7;
    line-height: 1;
}
.et-card-sponsor__brand {
    font-size: 13px;
    font-weight: 800;
    letter-spacing: -0.3px;
    line-height: 1;
}
.et-card-sponsor__logo {
    height: 16px;
    width: auto;
    max-width: 100px;
    object-fit: contain;
    display: block;
}

.et-keyfacts { max-width: 760px; margin: 64px auto 0; padding: 32px 36px; border: 1px solid var(--et-line); background: var(--et-bg-soft); }
.et-keyfacts__head { font-size: 10px; font-weight: 700; letter-spacing: 2.8px; color: var(--et-ink4); margin-bottom: 20px; display: flex; align-items: center; gap: 12px; }
.et-keyfacts__head .rule { width: 18px; height: 1px; background: var(--et-ink4); }
.et-keyfacts__head .flex { flex: 1; height: 1px; background: var(--et-line); }
.et-keyfacts ul { list-style: none; padding: 0; margin: 0; }
.et-keyfacts li { padding: 12px 0; display: flex; gap: 16px; align-items: flex-start; border-bottom: 1px solid var(--et-line); }
.et-keyfacts li:last-child { border-bottom: 0; }
.et-keyfacts__num { font-size: 11px; font-family: var(--et-mono); color: var(--et-ink3); font-weight: 600; letter-spacing: 0.5px; min-width: 24px; padding-top: 4px; }
.et-keyfacts__text { margin: 0; font-size: 16px; color: var(--et-ink); line-height: 1.5; font-weight: 500; letter-spacing: -0.2px; }

.et-body { max-width: 760px; margin: 56px auto 0; padding: 0 var(--et-pad); }
.et-body p { margin: 0 0 24px; font-size: 19px; line-height: 1.7; color: var(--et-ink2); font-weight: 400; letter-spacing: -0.1px; }
.et-body p.lead { font-size: 21px; line-height: 1.6; letter-spacing: -0.2px; }
.et-body a { color: var(--et-ink); font-weight: 500; text-decoration: underline; text-underline-offset: 3px; }
.et-body a:hover { opacity: 0.6; }
.et-body h2 { margin: 56px 0 24px; font-weight: 800; font-size: 32px; line-height: 1.15; color: var(--et-ink); letter-spacing: -1px; }
.et-body h3 { margin: 44px 0 20px; font-weight: 800; font-size: 22px; line-height: 1.2; color: var(--et-ink); letter-spacing: -0.5px; }
.et-body figure { margin: 40px 0; }
.et-body figcaption { margin-top: 12px; padding-left: 18px; border-left: 2px solid var(--et-ink); font-size: 13px; color: var(--et-ink3); line-height: 1.5; font-weight: 400; }
.et-body figcaption strong { font-weight: 700; color: var(--et-ink); }
.et-body blockquote { margin: 56px -80px; padding: 32px 0; border-top: 1px solid var(--et-ink); border-bottom: 1px solid var(--et-ink); text-align: center; }
.et-body blockquote .label { font-size: 10px; font-weight: 700; letter-spacing: 2.8px; color: var(--et-ink4); display: block; margin-bottom: 20px; }
.et-body blockquote p { margin: 0 0 20px; font-weight: 500; font-size: 32px; line-height: 1.32; color: var(--et-ink); letter-spacing: -1px; }
.et-body blockquote .attr { display: flex; align-items: center; justify-content: center; gap: 12px; }
.et-body blockquote .attr .rule { width: 18px; height: 1px; background: var(--et-ink); }
.et-body blockquote .attr-name { font-size: 13px; font-weight: 700; color: var(--et-ink); letter-spacing: -0.2px; }
.et-body blockquote .attr-role { font-size: 12px; color: var(--et-ink3); }
.et-body ul.et-claves { list-style: none; padding: 0; margin: 0 0 32px; }
.et-body ul.et-claves li { padding: 14px 0; display: flex; gap: 16px; align-items: flex-start; border-bottom: 1px solid var(--et-line); }
.et-body ul.et-claves li .rule { width: 18px; height: 1px; background: var(--et-ink); margin-top: 14px; flex-shrink: 0; }
.et-body ul.et-claves li p { margin: 0; font-size: 17px; line-height: 1.55; color: var(--et-ink2); letter-spacing: -0.1px; }
.et-body ul.et-claves li strong { font-weight: 700; color: var(--et-ink); }
.et-endmark { display: inline-block; width: 10px; height: 10px; background: var(--et-ink); margin-left: 6px; margin-bottom: -1px; }

/* ═══ TAGS PREMIUM ═══ */
.et-tags { padding-top: 32px; margin-top: 28px; border-top: 1px solid var(--et-line); }
.et-tags__label { display: block; font-size: 10.5px; font-weight: 700; letter-spacing: 1.8px; color: var(--et-ink4); margin-bottom: 14px; text-transform: uppercase; }
.et-tags__list { display: flex; flex-wrap: wrap; gap: 7px; }
.et-tag { padding: 8px 16px; background: var(--et-bg-soft); border: 1px solid var(--et-line); font-size: 13px; font-weight: 500; color: var(--et-ink); letter-spacing: -0.1px; transition: all 0.15s; border-radius: 7px; text-decoration: none; }
.et-tag:hover { border-color: var(--et-ink); background: var(--et-ink); color: #fff; transform: translateY(-1px); box-shadow: 0 4px 12px -4px rgba(10,10,10,0.18); }

.et-rail-left { position: fixed; left: 24px; top: 200px; z-index: 30; display: flex; flex-direction: column; gap: 10px; align-items: center; }
.et-rail-left__label { font-size: 9px; font-weight: 700; letter-spacing: 1.6px; color: var(--et-ink4); writing-mode: vertical-rl; transform: rotate(180deg); margin-bottom: 12px; }
.et-rail-btn { width: 40px; height: 40px; background: var(--et-bg); color: var(--et-ink2); border: 1px solid var(--et-line); cursor: pointer; display: flex; align-items: center; justify-content: center; transition: all 0.15s; }
.et-rail-btn:hover { border-color: var(--et-ink); }
.et-rail-btn.is-active { background: var(--et-ink); color: var(--et-bg); border-color: var(--et-ink); }
.et-rail-right { position: fixed; right: 24px; top: 200px; z-index: 30; width: 220px; }
.et-rail-right__label { font-size: 9.5px; font-weight: 700; letter-spacing: 2.4px; color: var(--et-ink4); margin-bottom: 16px; display: flex; align-items: center; gap: 10px; }
.et-rail-right__label .flex { flex: 1; height: 1px; background: var(--et-line); }
.et-toc { list-style: none; padding: 0; margin: 0; }
.et-toc li a { display: flex; gap: 10px; align-items: flex-start; padding: 8px 0 8px 12px; margin-left: -14px; border-left: 2px solid transparent; transition: all 0.15s; }
.et-toc li a:hover, .et-toc li a.is-active { border-left-color: var(--et-ink); }
.et-toc__num { font-size: 10px; font-family: var(--et-mono); color: var(--et-ink5); font-weight: 600; letter-spacing: 0.4px; padding-top: 2px; }
.et-toc li a.is-active .et-toc__num { color: var(--et-ink); }
.et-toc__txt { font-size: 12.5px; color: var(--et-ink3); font-weight: 400; line-height: 1.4; letter-spacing: -0.1px; }
.et-toc li a.is-active .et-toc__txt { color: var(--et-ink); font-weight: 600; }

/* ═══ Sponsorship DESKTOP (reemplaza breadcrumb cuando hay sponsor) ═══ */
.et-article__sponsorship {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 16px;
    margin-bottom: 32px;
    font-family: 'Inter', sans-serif;
}
.et-article__sponsorship-rule {
    flex: 1;
    height: 1px;
    background: linear-gradient(to right, transparent, var(--et-line), transparent);
    max-width: 180px;
}
.et-article__sponsorship-inner {
    display: inline-flex;
    align-items: center;
    gap: 12px;
    text-decoration: none;
    color: var(--et-ink);
    transition: opacity 0.2s;
    flex-shrink: 0;
}
a.et-article__sponsorship-inner:hover { opacity: 0.7; }
.et-article__sponsorship-intro { font-size: 10.5px; font-weight: 700; color: var(--et-ink3); letter-spacing: 2px; text-transform: uppercase; line-height: 1; }
.et-article__sponsorship-brand { font-size: 18px; font-weight: 700; color: var(--et-ink); letter-spacing: -0.4px; line-height: 1; }
.et-article__sponsorship-logo { height: 28px; width: auto; max-width: 160px; object-fit: contain; display: block; }

/* ═══ BIO PREMIUM ═══ */
.et-bio { max-width: 760px; margin: 72px auto 0; padding: 0 var(--et-pad); }
.et-bio__rule { height: 1px; background: linear-gradient(to right, var(--et-ink) 0%, transparent 80px); margin-bottom: 18px; }
.et-bio__kicker { display: block; font-size: 10.5px; font-weight: 700; letter-spacing: 1.8px; color: var(--et-ink4); text-transform: uppercase; margin-bottom: 16px; }
.et-bio__inner {
    padding: 32px 36px;
    border: 1px solid var(--et-line);
    background: var(--et-bg-soft);
    border-radius: 14px;
    display: flex;
    gap: 24px;
    position: relative;
    transition: border-color 0.2s, transform 0.2s, box-shadow 0.2s;
}
.et-bio__inner:hover {
    border-color: var(--et-ink2, #2A2A2A);
    box-shadow: 0 12px 32px -12px rgba(10,10,10,0.08);
}
.et-bio__avatar {
    width: 80px;
    height: 80px;
    flex-shrink: 0;
    border-radius: 50%;
    background: linear-gradient(135deg, #0A0A0A 0%, #1B4965 100%);
    color: #fff;
    display: flex;
    align-items: center;
    justify-content: center;
    background-size: cover;
    background-position: center;
    overflow: hidden;
    box-shadow: 0 8px 16px -8px rgba(10,10,10,0.2);
}
.et-bio__initials { font-size: 26px; font-weight: 700; letter-spacing: -0.5px; color: #fff; }
.et-bio__body { flex: 1; min-width: 0; }
.et-bio__name { margin: 0; font-weight: 700; font-size: 22px; color: var(--et-ink); letter-spacing: -0.6px; line-height: 1.2; }
.et-bio__role { display: block; margin-top: 6px; font-size: 13px; color: #1B4965; font-weight: 500; letter-spacing: -0.1px; line-height: 1.4; }
.et-bio__text { margin: 16px 0 18px; font-size: 14.5px; color: var(--et-ink2); line-height: 1.6; font-weight: 400; }
.et-bio__link {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    font-size: 12.5px;
    font-weight: 600;
    color: var(--et-ink);
    text-decoration: none;
    padding-top: 16px;
    border-top: 1px solid var(--et-line);
    width: 100%;
    transition: color 0.15s;
    letter-spacing: -0.1px;
}
.et-bio__link:hover { color: #1B4965; }
.et-bio__link svg { transition: transform 0.2s; }
.et-bio__link:hover svg { transform: translateX(3px); }

.et-comments { max-width: 760px; margin: 32px auto 0; padding: 0 var(--et-pad); }
.et-comments__bar { display: flex; align-items: center; justify-content: space-between; padding: 20px 0; border-top: 1px solid var(--et-line); border-bottom: 1px solid var(--et-line); }
.et-comments__count { font-size: 14.5px; font-weight: 700; color: var(--et-ink); letter-spacing: -0.2px; }
.et-related { max-width: var(--et-max); margin: 88px auto 0; padding: 0 var(--et-pad); }
.et-related__head { margin-bottom: 36px; }
.et-related__head h3 { margin: 0; font-weight: 800; font-size: 40px; color: var(--et-ink); letter-spacing: -1.6px; line-height: 1; }
.et-related__rule { height: 2px; background: var(--et-ink); margin-top: 20px; }
.et-related__grid { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 32px; }
.et-related__card { cursor: pointer; transition: transform 0.25s; }
.et-related__card:hover { transform: translateY(-4px); }
.et-related__title { margin: 12px 0 12px; font-weight: 700; font-size: 22px; line-height: 1.2; color: var(--et-ink); letter-spacing: -0.7px; }

/* WP defaults */
.alignleft { float: left; margin: 0 24px 12px 0; }
.alignright { float: right; margin: 0 0 12px 24px; }
.aligncenter { display: block; margin: 0 auto 12px; }
.alignwide { max-width: 1100px; margin: 0 auto; }
.alignfull { width: 100%; margin: 0; }
.comment-list { list-style: none; padding: 0; }
.screen-reader-text { position: absolute; width: 1px; height: 1px; overflow: hidden; clip: rect(0,0,0,0); }

/* ═══════════════════════════════════════════════════════════════════
   PREMIUM HOME — REDESIGN v2
   Harbor blue accents + structured grid sections
═══════════════════════════════════════════════════════════════════ */

/* Common section rhythm */
.et-hero, .et-canarias, .et-tnf, .et-op, .et-weather, .et-seismic, .et-eco, .et-cul, .et-sp {
    background: var(--et-bg);
    border-bottom: 1px solid var(--et-line);
    padding: 56px 0;
}
.et-hero__inner, .et-canarias__inner, .et-tnf__inner, .et-op__inner,
.et-weather__inner, .et-seismic__inner, .et-eco__inner, .et-cul__inner, .et-sp__inner {
    max-width: var(--et-max);
    margin: 0 auto;
    padding: 0 var(--et-pad);
}

/* Section head */
.et-section-head {
    display: flex; align-items: baseline; justify-content: space-between;
    gap: 24px; margin-bottom: 36px;
    padding-bottom: 20px;
    border-bottom: 2px solid var(--et-line-dk);
}
.et-section-head__left {
    display: flex; align-items: baseline; gap: 16px; flex: 1; min-width: 0;
}
.et-section-head__num {
    font-family: var(--et-mono); font-size: 11px; font-weight: 600;
    color: var(--et-harbor); letter-spacing: 2px; flex-shrink: 0;
}
.et-section-head__title {
    margin: 0; font-size: 32px; font-weight: 800;
    letter-spacing: -1.2px; color: var(--et-ink); line-height: 1;
}
.et-section-head__rule {
    flex: 1; min-width: 24px; height: 1px; background: var(--et-line-hi);
    align-self: center;
}
.et-section-head__sub {
    font-size: 13px; font-weight: 500; color: var(--et-ink3);
    letter-spacing: -0.1px; flex-shrink: 0;
}
.et-section-head__more {
    font-size: 12px; font-weight: 700; color: var(--et-harbor);
    letter-spacing: 0.4px; text-transform: uppercase;
    display: inline-flex; align-items: center; gap: 6px;
    transition: gap 0.2s ease, color 0.2s ease;
    text-decoration: none;
}
.et-section-head__more:hover { gap: 10px; color: var(--et-harbor-deep); }
.et-section-head__more svg { display: block; }
.et-section-head--mute .et-section-head__title,
.et-section-head--mute .et-section-head__num { color: var(--et-ink3); }
.et-section-head--alt {
    border-bottom-color: var(--et-harbor);
    border-bottom-width: 2px;
}

.et-live-dot {
    display: inline-block; width: 7px; height: 7px;
    border-radius: 50%; background: var(--et-red);
    margin-right: 6px; vertical-align: middle;
    animation: etPulse 1.6s infinite;
}



/* ─── CANARIAS section ─────────────────────────────────────────── */
.et-canarias__grid {
    display: grid; grid-template-columns: 1fr 320px; gap: 56px;
}
.et-canarias__main { min-width: 0; }
.et-canarias__lead {
    display: block; margin-bottom: 32px; text-decoration: none; color: inherit;
}
.et-canarias__lead-photo {
    border-radius: 5px;
    overflow: hidden;
    aspect-ratio: 16/9; background-color: #1B4965; background-image: linear-gradient(160deg,#1B4965,#2D6A8E); background-size: cover; background-position: center;
    margin-bottom: 20px;
}
.et-canarias__lead-cat {
    font-size: 11px; font-weight: 700; color: var(--et-harbor);
    letter-spacing: 2px; margin-bottom: 12px; display: block;
}
.et-canarias__lead-title {
    margin: 0 0 12px;
    font-family: var(--et-font);
    font-size: 30px; font-weight: 700;
    line-height: 1.12; letter-spacing: -0.5px; color: var(--et-ink);
}
.et-canarias__lead-sub {
    margin: 0 0 14px; font-size: 15px; line-height: 1.55; color: var(--et-ink2);
}
.et-canarias__lead-meta {
    font-size: 12px; color: var(--et-ink3);
}
.et-canarias__lead-meta .by { color: var(--et-ink); font-weight: 600; }
.et-canarias__lead-meta .sep { margin: 0 6px; color: var(--et-ink5); }
.et-canarias__lead:hover .et-canarias__lead-title { color: var(--et-harbor); }

/* List */
.et-canarias__list { list-style: none; margin: 0; padding: 0; border-top: 1px solid var(--et-line); }
.et-canarias__item {
    padding: 18px 0;
    border-bottom: 1px solid var(--et-line);
}
.et-canarias__item-link { text-decoration: none; color: inherit; display: block; }
.et-canarias__item-cat {
    font-size: 9.5px; font-weight: 700; color: var(--et-harbor);
    letter-spacing: 1.6px; margin-bottom: 6px; display: block;
}
.et-canarias__item-title {
    margin: 0 0 6px; font-size: 17px; font-weight: 600;
    line-height: 1.3; color: var(--et-ink);
    transition: color 0.2s;
}
.et-canarias__item-link:hover .et-canarias__item-title { color: var(--et-harbor); }
.et-canarias__item-meta {
    font-size: 11.5px; color: var(--et-ink3);
}



/* ─── TENERIFE section ─────────────────────────────────────────── */
.et-tnf__grid {
    display: grid;
    grid-template-columns: 2fr 1fr 1fr;
    grid-template-rows: auto auto;
    grid-auto-flow: row;
    gap: 32px 28px;
}
.et-tnf__card {
    text-decoration: none; color: inherit;
    display: flex; flex-direction: column;
}
.et-tnf__card.is-lead {
    grid-column: 1 / 2;
    grid-row: 1 / 3;
}
.et-tnf__card-photo {
    border-radius: 5px;
    overflow: hidden;
    aspect-ratio: 4/3; background-color: #1B4965; background-image: linear-gradient(160deg,#1B4965,#2D6A8E); background-size: cover; background-position: center;
    margin-bottom: 16px;
}
.et-tnf__card.is-lead .et-tnf__card-photo {
    aspect-ratio: 5/4;
}
.et-tnf__card-cat {
    font-size: 10px; font-weight: 700; color: var(--et-harbor);
    letter-spacing: 1.8px; margin-bottom: 8px; display: block;
}
.et-tnf__card-title {
    margin: 0 0 8px;
    font-family: var(--et-font);
    font-size: 17px; font-weight: 700;
    line-height: 1.2; color: var(--et-ink);
    transition: color 0.2s;
}
.et-tnf__card.is-lead .et-tnf__card-title {
    font-size: 26px; line-height: 1.13;
}
.et-tnf__card-sub {
    margin: 0 0 12px; font-size: 14px; line-height: 1.5; color: var(--et-ink2);
}
.et-tnf__card-meta {
    font-size: 11.5px; color: var(--et-ink3);
}
.et-tnf__card-meta .sep { margin: 0 5px; color: var(--et-ink5); }
.et-tnf__card:hover .et-tnf__card-title { color: var(--et-harbor); }

/* ─── OPINION ─────────────────────────────────────────────────── */
.et-op { background: var(--et-harbor-tint); }
.et-op__grid {
    display: grid; grid-template-columns: repeat(4, 1fr); gap: 28px;
}
.et-op__card {
    background: #fff;
    padding: 32px 24px;
    border-top: 3px solid var(--et-harbor);
    text-decoration: none; color: inherit;
    display: flex; flex-direction: column;
    transition: box-shadow 0.25s ease, transform 0.25s ease;
}
.et-op__card:hover {
    box-shadow: 0 12px 32px rgba(14, 47, 70, 0.12);
    transform: translateY(-2px);
}
.et-op__avatar-wrap {
    margin-bottom: 18px;
}
.et-op__avatar {
    width: 72px; height: 72px; border-radius: 50%;
    object-fit: cover;
    border: 2px solid var(--et-harbor-tint);
    box-shadow: 0 0 0 1px var(--et-harbor) inset;
    display: block;
}
.et-op__avatar--initials {
    background: var(--et-harbor);
    color: #fff;
    display: flex; align-items: center; justify-content: center;
    font-weight: 700; font-size: 22px; letter-spacing: 1px;
    border: none; box-shadow: none;
}
.et-op__author {
    font-size: 16px; font-weight: 700; color: var(--et-ink);
    display: block; margin-bottom: 2px;
}
.et-op__role {
    font-size: 11px; color: var(--et-harbor); font-weight: 600;
    letter-spacing: 0.4px; text-transform: uppercase;
    display: block; margin-bottom: 18px;
}
.et-op__quote {
    margin: 0 0 14px;
    font-family: var(--et-font);
    font-size: 19px; font-weight: 700;
    line-height: 1.25; color: var(--et-ink);
    font-style: italic;
}
.et-op__teaser {
    margin: 0 0 18px; font-size: 13.5px; line-height: 1.5;
    color: var(--et-ink3);
}
.et-op__read {
    margin-top: auto;
    font-size: 12px; font-weight: 700;
    color: var(--et-harbor);
    text-transform: uppercase; letter-spacing: 1px;
}

/* ─── WEATHER ─────────────────────────────────────────────────── */
.et-weather__grid {
    display: grid; grid-template-columns: repeat(7, 1fr); gap: 14px;
    margin-bottom: 36px;
}
.et-weather__card {
    background: #fff;
    border: 1px solid var(--et-line);
    padding: 18px 14px 16px;
    text-align: center;
    display: flex; flex-direction: column;
    transition: border-color 0.2s, transform 0.2s;
}
.et-weather__card:hover {
    border-color: var(--et-harbor);
    transform: translateY(-2px);
}
.et-weather__card-top { margin-bottom: 6px; }
.et-weather__island {
    font-size: 12px; font-weight: 700; color: var(--et-ink);
    letter-spacing: 0.2px;
}
.et-weather__card-mid {
    display: flex; align-items: center; justify-content: center;
    gap: 6px; margin: 8px 0;
}
.et-weather__icon { width: 56px; height: 56px; }
.et-weather__icon .et-wsvg { width: 100%; height: 100%; }
.et-weather__temp {
    font-size: 32px; font-weight: 200; letter-spacing: -1.5px;
    color: var(--et-ink); line-height: 1;
}
.et-weather__card-bottom {
    display: flex; flex-direction: column; gap: 4px;
    align-items: center;
}
.et-weather__minmax {
    font-family: var(--et-mono); font-size: 11px; color: var(--et-ink3);
    font-weight: 500;
}
.et-weather__wind {
    display: inline-flex; align-items: center; gap: 4px;
    font-size: 11px; color: var(--et-harbor); font-weight: 600;
}

/* Weather news card */
.et-weather__news {
    display: grid; grid-template-columns: 1fr 1.4fr; gap: 32px;
    background: #fff;
    border: 1px solid var(--et-line);
    text-decoration: none; color: inherit;
    overflow: hidden;
    transition: border-color 0.2s;
}
.et-weather__news:hover { border-color: var(--et-harbor); }
.et-weather__news-photo {
    border-radius: 5px;
    overflow: hidden;
    aspect-ratio: 16/11; background-color: #1B4965; background-image: linear-gradient(160deg,#1B4965,#62B6CB); background-size: cover; background-position: center;
}
.et-weather__news-body { padding: 28px 32px 28px 0; align-self: center; }
.et-weather__news-kicker {
    font-family: var(--et-mono); font-size: 10.5px; font-weight: 600;
    color: var(--et-harbor); letter-spacing: 2px;
    display: block; margin-bottom: 14px;
}
.et-weather__news-title {
    margin: 0 0 12px;
    font-family: var(--et-font);
    font-size: 26px; font-weight: 700; line-height: 1.18;
    color: var(--et-ink);
}
.et-weather__news-sub {
    margin: 0 0 14px; font-size: 14.5px; line-height: 1.55; color: var(--et-ink2);
}
.et-weather__news-meta {
    font-size: 12px; color: var(--et-ink3);
}

/* ─── SEISMIC — clean panel, no map ─────────────────────── */
.et-seismic__panel {
    background: #fff;
    border: 1px solid var(--et-line);
    border-radius: 4px;
    margin-bottom: 36px;
    overflow: hidden;
}
.et-seismic__list-head {
    display: grid; grid-template-columns: 80px 1fr 140px 140px; gap: 16px;
    padding: 14px 24px;
    background: var(--et-bg-soft);
    border-bottom: 2px solid var(--et-ink);
    font-family: var(--et-mono);
    font-size: 10px; font-weight: 700; color: var(--et-ink3);
    letter-spacing: 1.6px;
}
.et-seismic__row {
    display: grid; grid-template-columns: 80px 1fr 140px 140px; gap: 16px;
    padding: 16px 24px; align-items: center;
    border-bottom: 1px solid var(--et-line);
    font-size: 14px;
    transition: background 0.15s;
}
.et-seismic__row:last-child { border-bottom: 0; }
.et-seismic__row:hover { background: var(--et-harbor-tint); }
.et-seismic__row.is-live {
    background: linear-gradient(90deg, rgba(200,16,46,0.06), transparent 70%);
    border-left: 3px solid var(--et-red);
    padding-left: 21px;
}
.et-seismic__mag {
    font-family: var(--et-mono);
    font-size: 18px; font-weight: 700;
    color: var(--et-ink); letter-spacing: -0.3px;
    display: inline-flex; align-items: center; justify-content: center;
    padding: 6px 0;
    border: 1px solid var(--et-line-hi);
    background: #fff;
    border-radius: 3px;
    text-align: center;
}
.et-seismic__mag.is-strong {
    background: var(--et-ink); color: #fff; border-color: var(--et-ink);
}
.et-seismic__place { color: var(--et-ink); font-weight: 600; font-size: 14px; }
.et-seismic__depth, .et-seismic__time {
    font-family: var(--et-mono);
    font-size: 12px; color: var(--et-ink3);
    letter-spacing: 0.3px;
}

/* Seismic news (same shape as weather news) */
.et-seismic__news {
    display: grid; grid-template-columns: 1fr 1.4fr; gap: 32px;
    background: #fff; border: 1px solid var(--et-line);
    border-radius: 5px;
    text-decoration: none; color: inherit; overflow: hidden;
    transition: border-color 0.2s, box-shadow 0.2s;
}
.et-seismic__news:hover { border-color: var(--et-harbor); box-shadow: 0 8px 24px rgba(14,47,70,0.08); }
.et-seismic__news-body { padding: 32px 36px 32px 0; align-self: center; }
.et-seismic__news-kicker {
    font-family: var(--et-mono); font-size: 10.5px; font-weight: 600;
    color: var(--et-harbor); letter-spacing: 2px;
    display: block; margin-bottom: 14px;
}
.et-seismic__news-title {
    margin: 0 0 14px;
    font-size: 26px; font-weight: 700; line-height: 1.2;
    color: var(--et-ink); letter-spacing: -0.4px;
}
.et-seismic__news-sub {
    margin: 0 0 14px; font-size: 14.5px; line-height: 1.55; color: var(--et-ink2);
}
.et-seismic__news-meta { font-size: 12px; color: var(--et-ink3); }



/* ─── CULTURE ─────────────────────────────────────────────────── */
.et-cul__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 32px; }
.et-cul__card {
    text-decoration: none; color: inherit;
    display: flex; flex-direction: column;
}
.et-cul__photo {
    border-radius: 5px;
    overflow: hidden;
    aspect-ratio: 4/3; background-color: #1B4965; background-image: linear-gradient(160deg,#1B4965,#62B6CB); background-size: cover; background-position: center;
    margin-bottom: 16px;
}
.et-cul__cat {
    font-size: 10px; font-weight: 700; color: var(--et-harbor);
    letter-spacing: 2px; margin-bottom: 8px; display: block;
}
.et-cul__title {
    margin: 0 0 8px; font-family: var(--et-font);
    font-size: 22px; font-weight: 700; line-height: 1.18;
    color: var(--et-ink); transition: color 0.2s;
}
.et-cul__sub { margin: 0 0 10px; font-size: 14px; line-height: 1.5; color: var(--et-ink2); }
.et-cul__meta { font-size: 11.5px; color: var(--et-ink3); margin-top: auto; }
.et-cul__card:hover .et-cul__title { color: var(--et-harbor); }

/* ─── SPONSORED ─────────────────────────────────────────────── */
.et-sp { background: var(--et-bg-soft); }
.et-sp__grid {
    display: grid; grid-template-columns: repeat(4, 1fr); gap: 24px;
}
.et-sp__card {
    background: #fff;
    border: 1px solid var(--et-line);
    text-decoration: none; color: inherit;
    display: flex; flex-direction: column;
    transition: border-color 0.2s, transform 0.2s;
}
.et-sp__card:hover {
    border-color: var(--et-harbor);
    transform: translateY(-2px);
}
.et-sp__photo {
    border-radius: 5px;
    overflow: hidden;
    aspect-ratio: 16/10; background-color: #E8F0F4; background-image: linear-gradient(135deg,#E8F0F4,#62B6CB); background-size: cover; background-position: center;
}
.et-sp__body { padding: 18px 20px 20px; flex: 1; display: flex; flex-direction: column; }
.et-sp__sponsor {
    font-size: 9.5px; font-weight: 700; color: var(--et-ink3);
    letter-spacing: 1.6px; text-transform: uppercase;
    display: block; margin-bottom: 8px;
}
.et-sp__title {
    margin: 0 0 14px;
    font-size: 15px; font-weight: 600; line-height: 1.35;
    color: var(--et-ink);
}
.et-sp__cta {
    margin-top: auto;
    font-size: 11.5px; font-weight: 700; color: var(--et-harbor);
    letter-spacing: 0.5px;
}

/* ═══════════════════════════════════════════════════════════════════
   RESPONSIVE — mid-width breakpoints
═══════════════════════════════════════════════════════════════════ */
@media (max-width: 1100px) {
    .et-canarias__grid { grid-template-columns: 1fr; }
    .et-canarias__side { border-left: 0; padding-left: 0; padding-top: 32px; border-top: 1px solid var(--et-line); }
    .et-op__grid { grid-template-columns: repeat(2, 1fr); }
    .et-weather__grid { grid-template-columns: repeat(4, 1fr); }
    .et-eco__markets-grid { grid-template-columns: repeat(2, 1fr); }
    .et-sp__grid { grid-template-columns: repeat(2, 1fr); }
    .et-section-head__title { font-size: 26px; }
}

@media (max-width: 900px) {
    .et-hero__lead { grid-template-columns: 1fr; }
    .et-hero__lead-text { border-right: 0; padding: 28px 24px; }
    .et-hero__secondary { grid-template-columns: 1fr; gap: 24px; }
    .et-tnf__grid { grid-template-columns: 1fr 1fr; }
    .et-tnf__card.is-lead { grid-column: 1 / -1; grid-row: auto; }
    .et-eco__news { grid-template-columns: 1fr; }
    .et-cul__grid { grid-template-columns: 1fr; }
    .et-weather__news, .et-seismic__news { grid-template-columns: 1fr; }
    .et-weather__news-body, .et-seismic__news-body { padding: 24px; }
    .et-seismic__grid { grid-template-columns: 1fr; }
    --et-pad: 24px;
}

@media (max-width: 640px) {
    .et-weather__grid { grid-template-columns: repeat(2, 1fr); }
    .et-op__grid, .et-sp__grid { grid-template-columns: 1fr; }
    .et-eco__markets-grid { grid-template-columns: 1fr 1fr; }
}

/* ═══════════════════════════════════════════════════════════════════
   USER PANEL — /mi-cuenta/
═══════════════════════════════════════════════════════════════════ */
.et-up {
    background: var(--et-harbor-tint);
    min-height: 70vh;
    padding: 56px 0 80px;
}
.et-up__inner {
    max-width: 1180px;
    margin: 0 auto;
    padding: 0 var(--et-pad);
}

.et-up__header {
    display: grid;
    grid-template-columns: 110px 1fr auto;
    gap: 28px;
    align-items: center;
    background: #fff;
    padding: 28px 36px;
    margin-bottom: 18px;
    border-bottom: 4px solid var(--et-harbor);
}
.et-up__avatar-wrap {
    width: 100px; height: 100px;
    overflow: hidden;
    border-radius: 50%;
    border: 3px solid var(--et-harbor-tint);
    box-shadow: 0 0 0 1px var(--et-harbor) inset;
}
.et-up__avatar {
    width: 100%; height: 100%;
    object-fit: cover;
    display: block;
}
.et-up__id { min-width: 0; }
.et-up__kicker {
    font-family: var(--et-mono);
    font-size: 11px; font-weight: 600;
    color: var(--et-harbor);
    letter-spacing: 2.4px;
    display: block;
    margin-bottom: 8px;
}
.et-up__name {
    margin: 0 0 6px;
    font-family: var(--et-font);
    font-size: 36px; font-weight: 700;
    line-height: 1.05; letter-spacing: -0.6px;
    color: var(--et-ink);
}
.et-up__role {
    font-size: 13.5px;
    color: var(--et-ink3);
}
.et-up__btn-ghost {
    padding: 10px 18px;
    background: #fff;
    border: 1px solid var(--et-line-hi);
    color: var(--et-ink2);
    font-size: 12px; font-weight: 600;
    text-decoration: none;
    transition: all 0.2s;
}
.et-up__btn-ghost:hover {
    border-color: var(--et-harbor);
    color: var(--et-harbor);
}

.et-up__notice {
    background: var(--et-harbor);
    color: #fff;
    padding: 12px 18px;
    margin-bottom: 18px;
    font-size: 13px; font-weight: 600;
    letter-spacing: 0.3px;
}

/* Stats */
.et-up__stats {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 0;
    background: #fff;
    margin-bottom: 28px;
}
.et-up__stat {
    padding: 24px 28px;
    border-right: 1px solid var(--et-line);
    display: flex;
    flex-direction: column;
}
.et-up__stat:last-child { border-right: 0; }
.et-up__stat-label {
    font-size: 10.5px; font-weight: 700;
    color: var(--et-ink3);
    letter-spacing: 1.5px;
    text-transform: uppercase;
    margin-bottom: 8px;
}
.et-up__stat-num {
    font-family: var(--et-font);
    font-size: 32px; font-weight: 700;
    color: var(--et-harbor);
    line-height: 1;
    letter-spacing: -0.5px;
}
.et-up__stat-num--small {
    font-size: 18px;
    margin-top: 8px;
}

/* Grid */
.et-up__grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 24px;
}
.et-up__card {
    background: #fff;
    padding: 28px 32px;
}
.et-up__card--wide { grid-column: span 2; }
.et-up__card-head {
    display: flex;
    align-items: baseline;
    justify-content: space-between;
    padding-bottom: 16px;
    margin-bottom: 18px;
    border-bottom: 1px solid var(--et-line-dk);
}
.et-up__card-title {
    margin: 0;
    font-family: var(--et-font);
    font-size: 22px; font-weight: 700;
    letter-spacing: -0.3px;
    color: var(--et-ink);
}
.et-up__card-sub {
    font-size: 12px;
    color: var(--et-ink3);
    font-weight: 500;
}

.et-up__list {
    list-style: none; margin: 0; padding: 0;
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 18px;
}
.et-up__list-link {
    display: grid;
    grid-template-columns: 110px 1fr;
    gap: 16px;
    text-decoration: none;
    color: inherit;
}
.et-up__list-thumb {
    border-radius: 5px;
    overflow: hidden;
    aspect-ratio: 4/3;
    background-size: cover; background-position: center;
}
.et-up__list-cat {
    font-size: 9.5px; font-weight: 700;
    color: var(--et-harbor);
    letter-spacing: 1.6px;
    display: block;
    margin-bottom: 6px;
}
.et-up__list-title {
    margin: 0 0 6px;
    font-family: var(--et-font);
    font-size: 14.5px; font-weight: 700;
    line-height: 1.25;
    color: var(--et-ink);
    transition: color 0.2s;
}
.et-up__list-link:hover .et-up__list-title { color: var(--et-harbor); }
.et-up__list-meta {
    font-size: 11px;
    color: var(--et-ink3);
}

.et-up__comments {
    list-style: none; margin: 0; padding: 0;
}
.et-up__comment {
    border-bottom: 1px solid var(--et-line);
    padding: 14px 0;
}
.et-up__comment:last-child { border-bottom: 0; }
.et-up__comment a {
    text-decoration: none; color: inherit;
    display: block;
}
.et-up__comment-on {
    font-size: 11px;
    color: var(--et-harbor);
    font-weight: 600;
    letter-spacing: 0.3px;
    text-transform: uppercase;
    display: block;
    margin-bottom: 6px;
}
.et-up__comment-on strong { color: var(--et-ink); font-weight: 700; }
.et-up__comment-body {
    margin: 0 0 6px;
    font-size: 13.5px; line-height: 1.5;
    color: var(--et-ink2);
    font-family: var(--et-font);
    font-style: italic;
}
.et-up__comment-date {
    font-family: var(--et-mono);
    font-size: 10.5px;
    color: var(--et-ink4);
    letter-spacing: 0.3px;
}

.et-up__empty {
    color: var(--et-ink3);
    font-size: 13.5px;
    line-height: 1.55;
    margin: 0;
    font-style: italic;
}

.et-up__form { display: block; }
.et-up__field {
    display: block;
    margin-bottom: 18px;
}
.et-up__field-label {
    font-size: 11px; font-weight: 700;
    color: var(--et-ink3);
    letter-spacing: 0.5px;
    text-transform: uppercase;
    display: block;
    margin-bottom: 8px;
}
.et-up__input {
    width: 100%;
    padding: 12px 14px;
    border: 1px solid var(--et-line-hi);
    background: var(--et-bg);
    font-family: var(--et-font);
    font-size: 14px;
    color: var(--et-ink);
    box-sizing: border-box;
    transition: border-color 0.2s;
}
.et-up__input:focus {
    outline: none;
    border-color: var(--et-harbor);
    box-shadow: 0 0 0 3px var(--et-harbor-tint);
}
.et-up__textarea {
    min-height: 80px;
    resize: vertical;
}
.et-up__field-hint {
    font-size: 11.5px;
    color: var(--et-ink3);
    margin-top: 6px;
    display: block;
    font-style: italic;
}
.et-up__form-actions {
    display: flex;
    justify-content: flex-end;
}
.et-up__btn {
    padding: 12px 28px;
    background: var(--et-harbor);
    color: #fff;
    border: 0;
    font-size: 12px; font-weight: 700;
    letter-spacing: 0.6px;
    text-transform: uppercase;
    cursor: pointer;
    transition: background 0.2s;
}
.et-up__btn:hover {
    background: var(--et-harbor-deep);
}

.et-up__quick-links {
    list-style: none; margin: 0; padding: 0;
}
.et-up__quick-links li {
    border-bottom: 1px solid var(--et-line);
}
.et-up__quick-links li:last-child { border-bottom: 0; }
.et-up__quick-links a {
    display: block;
    padding: 14px 0;
    color: var(--et-ink2);
    font-size: 13.5px;
    text-decoration: none;
    transition: color 0.2s, padding 0.2s;
}
.et-up__quick-links a:hover {
    color: var(--et-harbor);
    padding-left: 6px;
}

@media (max-width: 900px) {
    .et-up__header { grid-template-columns: 80px 1fr; }
    .et-up__actions { grid-column: 1 / -1; justify-self: start; }
    .et-up__name { font-size: 26px; }
    .et-up__stats { grid-template-columns: 1fr 1fr; }
    .et-up__stat:nth-child(2) { border-right: 0; }
    .et-up__stat:nth-child(1), .et-up__stat:nth-child(2) { border-bottom: 1px solid var(--et-line); }
    .et-up__grid { grid-template-columns: 1fr; }
    .et-up__card--wide { grid-column: auto; }
    .et-up__list { grid-template-columns: 1fr; }
}

/* ═══════════════════════════════════════════════════════════════════
   v3 — KICKER, ROUNDED PHOTOS, LIVE BLOG, NEW ECONOMY, CLEAN HEADERS
═══════════════════════════════════════════════════════════════════ */

/* KICKER — el antetítulo en azul harbor */
/* Image rounding — subtle premium */
.et-hero__photo,
.et-hero__sec-photo,
.et-canarias__lead-photo,
.et-tnf__card-photo,
.et-cul__photo,
.et-eco-lead__photo,
.et-eco-list__thumb,
.et-sp__photo,
.et-weather__news-photo,
.et-seismic__news-photo,
.et-mh__photo,
.et-mh-sec__photo {
    border-radius: 6px;
}

/* Remove section number (was used) — now hidden */
.et-section-head__num { display: none !important; }

/* Section head — harbor accent at the bottom rule */
.et-section-head {
    border-bottom: 2px solid var(--et-harbor);
}

/* Author + city meta */
.et-hero__lead-meta .city,
.et-hero__sec-meta .city,
.et-canarias__lead-meta .city,
.et-mh__meta .city {
    color: var(--et-ink3);
    font-weight: 500;
}

/* SECONDARY HERO CARDS — Reuters-style premium redesign */
.et-hero__secondary {
    grid-template-columns: 1fr 1fr;
}
.et-hero__sec-card {
    grid-template-columns: 1fr;
    gap: 0;
    background: #fff;
    border: 1px solid var(--et-line);
    border-radius: 6px;
    overflow: hidden;
    transition: border-color 0.2s ease, transform 0.25s ease, box-shadow 0.25s ease;
}
.et-hero__sec-card:hover {
    border-color: var(--et-harbor);
    transform: translateY(-2px);
    box-shadow: 0 12px 32px rgba(14, 47, 70, 0.08);
}
.et-hero__sec-photo {
    aspect-ratio: 16/9;
    border-radius: 0;
    border-bottom-left-radius: 0;
    border-bottom-right-radius: 0;
    border-top-left-radius: 6px;
    border-top-right-radius: 6px;
}
.et-hero__sec-text {
    padding: 22px 24px 24px;
}
.et-hero__sec-title {
    font-size: 22px;
    line-height: 1.18;
    font-weight: 700;
    margin-bottom: 12px;
}
.et-hero__sec-sub {
    margin: 0 0 14px;
    font-size: 14px;
    line-height: 1.5;
    color: var(--et-ink3);
}

/* ═══ ECONOMY v3 — Light premium FT-inspired ═══════════════════════ */
.et-eco { background: #fff; }

/* Ticker strip (top of section) */
.et-eco-ticker {
    display: grid;
    grid-template-columns: 130px 1fr;
    align-items: center;
    background: var(--et-harbor-tint);
    border: 1px solid var(--et-line);
    border-radius: 6px;
    padding: 14px 18px;
    margin-bottom: 36px;
    overflow: hidden;
}
.et-eco-ticker__label {
    font-family: var(--et-mono);
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 1.5px;
    color: var(--et-harbor-deep);
    display: flex;
    align-items: center;
    gap: 8px;
    padding-right: 14px;
    border-right: 1px solid var(--et-line-hi);
}
.et-eco-ticker__items {
    display: flex;
    gap: 26px;
    overflow-x: auto;
    padding-left: 18px;
}
.et-eco-ticker__items::-webkit-scrollbar { display: none; }
.et-eco-ticker__item {
    display: flex;
    align-items: center;
    gap: 10px;
    flex-shrink: 0;
}
.et-eco-ticker__sym {
    font-size: 11px;
    font-weight: 700;
    color: var(--et-ink3);
    letter-spacing: 0.4px;
}
.et-eco-ticker__val {
    font-family: var(--et-mono);
    font-size: 13.5px;
    font-weight: 600;
    color: var(--et-ink);
}
.et-eco-ticker__chg {
    font-size: 12px;
    font-weight: 700;
    letter-spacing: 0.2px;
}
.et-eco-ticker__chg.up { color: #15803D; }
.et-eco-ticker__chg.down { color: var(--et-red); }
.et-eco__spark { width: 60px; height: 22px; }

/* Main grid */
.et-eco-grid {
    display: grid;
    grid-template-columns: 1.6fr 1fr;
    gap: 36px;
}

/* Lead news */
.et-eco-lead {
    display: block;
    text-decoration: none;
    color: inherit;
    margin-bottom: 28px;
}
.et-eco-lead__photo {
    aspect-ratio: 16/9;
    background-size: cover;
    background-position: center;
    margin-bottom: 18px;
    border-radius: 6px;
}
.et-eco-lead__cat {
    font-size: 10px;
    font-weight: 700;
    color: var(--et-harbor);
    letter-spacing: 2px;
    margin-bottom: 10px;
    display: block;
}
.et-eco-lead__title {
    margin: 0 0 12px;
    font-size: 28px;
    font-weight: 700;
    line-height: 1.15;
    color: var(--et-ink);
    letter-spacing: -0.4px;
    transition: color 0.2s;
}
.et-eco-lead:hover .et-eco-lead__title { color: var(--et-harbor); }
.et-eco-lead__sub {
    margin: 0 0 12px;
    font-size: 14.5px;
    line-height: 1.5;
    color: var(--et-ink3);
}
.et-eco-lead__meta {
    font-size: 12px;
    color: var(--et-ink3);
}
.et-eco-lead__meta .by { color: var(--et-ink); font-weight: 600; }

/* Secondary list with thumb */
.et-eco-list {
    list-style: none;
    margin: 0;
    padding: 0;
    border-top: 1px solid var(--et-line);
}
.et-eco-list__item { border-bottom: 1px solid var(--et-line); }
.et-eco-list__link {
    display: grid;
    grid-template-columns: 1fr 110px;
    gap: 16px;
    padding: 16px 0;
    text-decoration: none;
    color: inherit;
}
.et-eco-list__thumb {
    aspect-ratio: 4/3;
    background-size: cover;
    background-position: center;
    order: 2;
    border-radius: 6px;
}
.et-eco-list__text { order: 1; min-width: 0; }
.et-eco-list__title {
    margin: 0 0 6px;
    font-size: 15px;
    font-weight: 600;
    line-height: 1.32;
    color: var(--et-ink);
    transition: color 0.2s;
}
.et-eco-list__link:hover .et-eco-list__title { color: var(--et-harbor); }
.et-eco-list__meta {
    font-size: 11.5px;
    color: var(--et-ink3);
}

/* IBEX detail card */
.et-eco-detail {
    background: var(--et-harbor-tint);
    border: 1px solid var(--et-line);
    border-radius: 6px;
    padding: 20px 22px;
    margin-bottom: 24px;
}
.et-eco-detail__head {
    display: flex;
    justify-content: space-between;
    align-items: baseline;
    margin-bottom: 10px;
}
.et-eco-detail__label {
    font-size: 11px;
    font-weight: 700;
    color: var(--et-harbor-deep);
    letter-spacing: 1.4px;
}
.et-eco-detail__time {
    font-family: var(--et-mono);
    font-size: 10.5px;
    color: var(--et-ink3);
    letter-spacing: 0.5px;
}
.et-eco-detail__value {
    display: flex;
    align-items: baseline;
    gap: 12px;
    margin-bottom: 14px;
}
.et-eco-detail__value strong {
    font-family: var(--et-mono);
    font-size: 32px;
    font-weight: 700;
    color: var(--et-ink);
    letter-spacing: -0.5px;
}
.et-eco-detail__chg {
    font-size: 12.5px;
    font-weight: 700;
}
.et-eco-detail__chg.up { color: #15803D; }
.et-eco-detail__chg.down { color: var(--et-red); }
.et-eco-detail__chart {
    width: 100%;
    height: 80px;
    margin-bottom: 14px;
    display: block;
}
.et-eco-detail__range {
    display: flex;
    justify-content: space-between;
    font-size: 11px;
    color: var(--et-ink3);
    padding-top: 12px;
    border-top: 1px solid rgba(27, 73, 101, 0.15);
}
.et-eco-detail__range strong {
    color: var(--et-ink);
    font-family: var(--et-mono);
    font-weight: 600;
}

/* Sectors heatmap */
.et-eco-sectors {
    background: #fff;
    border: 1px solid var(--et-line);
    border-radius: 6px;
    padding: 20px 22px;
}
.et-eco-sectors h4 {
    margin: 0 0 14px;
    font-size: 13px;
    font-weight: 700;
    color: var(--et-ink);
    letter-spacing: 0.3px;
    padding-bottom: 10px;
    border-bottom: 1px solid var(--et-line);
}
.et-eco-sectors__grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 8px;
}
.et-eco-sectors__cell {
    padding: 12px 14px;
    border-radius: 4px;
    display: flex;
    flex-direction: column;
    gap: 4px;
}
.et-eco-sectors__name {
    font-size: 12px;
    font-weight: 600;
    color: var(--et-ink);
}
.et-eco-sectors__pct {
    font-family: var(--et-mono);
    font-size: 14px;
    font-weight: 700;
    letter-spacing: -0.2px;
}
.et-eco-sectors__pct.up { color: #15803D; }
.et-eco-sectors__pct.down { color: var(--et-red); }

/* ═══ SEISMIC TABLE — premium clean ═══════════════════════════════ */
.et-seismic-table {
    background: #fff;
    border: 1px solid var(--et-line);
    border-radius: 6px;
    overflow: hidden;
    margin-bottom: 36px;
}
.et-seismic-table__head {
    display: grid;
    grid-template-columns: 110px 1fr 130px 140px;
    padding: 14px 22px;
    background: var(--et-harbor-tint);
    border-bottom: 1px solid var(--et-line);
    font-family: var(--et-mono);
    font-size: 10.5px;
    font-weight: 700;
    color: var(--et-harbor-deep);
    letter-spacing: 1.6px;
}
.et-seismic-table__row {
    display: grid;
    grid-template-columns: 110px 1fr 130px 140px;
    padding: 16px 22px;
    align-items: center;
    border-bottom: 1px solid var(--et-line);
    transition: background 0.15s;
}
.et-seismic-table__row:last-child { border-bottom: 0; }
.et-seismic-table__row:hover { background: var(--et-harbor-tint); }
.et-seismic-table__row.is-live { background: rgba(200, 16, 46, 0.04); }
.et-seismic-table__mag {
    font-family: var(--et-mono);
    font-size: 18px;
    font-weight: 700;
    color: var(--et-ink);
    letter-spacing: -0.3px;
    width: 70px;
    padding: 6px 0;
    text-align: center;
    border: 1px solid var(--et-line-hi);
    border-radius: 3px;
}
.et-seismic-table__mag.is-strong {
    background: var(--et-ink);
    color: #fff;
    border-color: var(--et-ink);
}
.et-seismic-table__place {
    font-size: 14px;
    color: var(--et-ink);
    font-weight: 500;
}
.et-seismic-table__depth,
.et-seismic-table__time {
    font-family: var(--et-mono);
    font-size: 12px;
    color: var(--et-ink3);
    letter-spacing: 0.4px;
    display: flex;
    align-items: center;
    gap: 6px;
}

/* ═══ LIVE BOX — sidebar in canarias section ═════════════════════ */
.et-livebox {
    background: #fff;
    border: 1px solid var(--et-line);
    border-radius: 6px;
    overflow: hidden;
    margin-bottom: 24px;
    border-top: 3px solid var(--et-red);
}
.et-livebox__head {
    display: block;
    padding: 18px 20px 16px;
    text-decoration: none;
    color: inherit;
    border-bottom: 1px solid var(--et-line);
}
.et-livebox__badge {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    background: var(--et-red);
    color: #fff;
    padding: 4px 10px;
    font-size: 10px;
    font-weight: 800;
    letter-spacing: 1.5px;
    margin-bottom: 12px;
    border-radius: 3px;
}
.et-livebox__dot {
    display: inline-block;
    width: 7px;
    height: 7px;
    background: #fff;
    border-radius: 50%;
    animation: etPulse 1.6s infinite;
}
.et-livebox__title {
    margin: 0 0 6px;
    font-size: 17px;
    font-weight: 700;
    line-height: 1.25;
    color: var(--et-ink);
}
.et-livebox__sub {
    margin: 0;
    font-size: 12.5px;
    color: var(--et-ink3);
    line-height: 1.4;
}
.et-livebox__feed {
    padding: 4px 20px 8px;
}
.et-livebox__update {
    display: block;
    padding: 14px 0;
    border-bottom: 1px dashed var(--et-line);
    text-decoration: none;
    color: inherit;
    transition: padding 0.2s;
}
.et-livebox__update:last-child { border-bottom: 0; }
.et-livebox__update:hover { padding-left: 4px; }
.et-livebox__update.is-first {
    border-left: 2px solid var(--et-red);
    padding-left: 12px;
    margin-left: -14px;
}
.et-livebox__update.is-first:hover { padding-left: 16px; }
.et-livebox__time {
    font-family: var(--et-mono);
    font-size: 10.5px;
    font-weight: 700;
    color: var(--et-harbor);
    letter-spacing: 0.5px;
    display: block;
    margin-bottom: 4px;
}
.et-livebox__tag {
    display: inline-block;
    background: var(--et-ink);
    color: #fff;
    padding: 1px 6px;
    font-size: 9px;
    font-weight: 800;
    letter-spacing: 1px;
    margin-bottom: 6px;
    margin-right: 6px;
    border-radius: 2px;
}
.et-livebox__update-title {
    display: block;
    font-size: 13.5px;
    font-weight: 600;
    line-height: 1.35;
    color: var(--et-ink);
}
.et-livebox__update:hover .et-livebox__update-title { color: var(--et-harbor); }
.et-livebox__more {
    display: block;
    padding: 14px 20px;
    text-align: center;
    background: var(--et-harbor);
    color: #fff;
    font-size: 12px;
    font-weight: 700;
    letter-spacing: 0.5px;
    text-decoration: none;
    text-transform: uppercase;
    transition: background 0.2s;
}
.et-livebox__more:hover { background: var(--et-harbor-deep); color: #fff; }

/* ═══ LIVE PAGE — /en-vivo/ ═════════════════════════════════════ */
.et-livepage {
    background: var(--et-bg-soft);
    min-height: 70vh;
    padding: 56px 0 96px;
}
.et-livepage__inner {
    max-width: 920px;
    margin: 0 auto;
    padding: 0 var(--et-pad);
}
.et-livepage__empty {
    background: #fff;
    border-radius: 6px;
    padding: 64px 40px;
    text-align: center;
    border-top: 4px solid var(--et-harbor);
}
.et-livepage__empty .et-livepage__kicker {
    font-family: var(--et-mono);
    font-size: 11px;
    color: var(--et-harbor);
    letter-spacing: 2.5px;
    margin-bottom: 16px;
    display: block;
}
.et-livepage__empty h1 {
    font-size: 30px;
    font-weight: 700;
    margin: 0 0 12px;
    letter-spacing: -0.5px;
}
.et-livepage__empty p {
    font-size: 14.5px;
    color: var(--et-ink3);
    margin: 0 0 24px;
    line-height: 1.55;
}
.et-livepage__back {
    display: inline-block;
    padding: 12px 28px;
    background: var(--et-harbor);
    color: #fff;
    font-size: 12px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: 0.6px;
    text-decoration: none;
}

.et-livepage__head {
    background: #fff;
    border-radius: 6px;
    padding: 32px 36px 30px;
    margin-bottom: 32px;
    border-top: 4px solid var(--et-red);
}
.et-livepage__head-top {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 18px;
}
.et-livepage__live-badge {
    display: inline-flex;
    align-items: center;
    gap: 7px;
    background: var(--et-red);
    color: #fff;
    padding: 6px 12px;
    font-size: 11px;
    font-weight: 800;
    letter-spacing: 1.6px;
    border-radius: 3px;
}
.et-livepage__live-dot {
    width: 8px; height: 8px;
    background: #fff;
    border-radius: 50%;
    animation: etPulse 1.6s infinite;
}
.et-livepage__started {
    font-family: var(--et-mono);
    font-size: 11.5px;
    color: var(--et-ink3);
    letter-spacing: 0.4px;
}
.et-livepage__title {
    margin: 0 0 12px;
    font-size: 38px;
    font-weight: 800;
    line-height: 1.1;
    letter-spacing: -0.8px;
    color: var(--et-ink);
}
.et-livepage__sub {
    margin: 0;
    font-size: 16px;
    color: var(--et-ink3);
    line-height: 1.55;
}
.et-livepage__pending {
    background: #fff;
    padding: 32px;
    border-radius: 6px;
    text-align: center;
    color: var(--et-ink3);
    font-style: italic;
}

.et-livepage__feed {
    position: relative;
}
.et-live-card {
    display: grid;
    grid-template-columns: 90px 1fr;
    gap: 24px;
    background: #fff;
    border-radius: 6px;
    padding: 24px 28px;
    margin-bottom: 12px;
    position: relative;
    transition: transform 0.2s;
}
.et-live-card.is-newest {
    border-left: 3px solid var(--et-red);
    box-shadow: 0 6px 24px rgba(200, 16, 46, 0.08);
}
.et-live-card__rail {
    position: relative;
    padding-top: 4px;
}
.et-live-card__time {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 2px;
}
.et-live-card__time strong {
    font-family: var(--et-mono);
    font-size: 18px;
    font-weight: 700;
    color: var(--et-harbor-deep);
    letter-spacing: -0.3px;
}
.et-live-card__time span {
    font-family: var(--et-mono);
    font-size: 11px;
    color: var(--et-ink3);
    text-transform: uppercase;
    letter-spacing: 0.4px;
}
.et-live-card__dot {
    position: absolute;
    top: 28px;
    right: -16px;
    width: 12px;
    height: 12px;
    background: var(--et-harbor);
    border-radius: 50%;
    border: 3px solid #fff;
    box-shadow: 0 0 0 1px var(--et-harbor);
}
.et-live-card__dot[data-pulse="1"] {
    background: var(--et-red);
    box-shadow: 0 0 0 1px var(--et-red);
    animation: etPulse 1.6s infinite;
}
.et-live-card__body {}
.et-live-card__tag {
    display: inline-block;
    background: var(--et-ink);
    color: #fff;
    padding: 3px 8px;
    font-size: 10px;
    font-weight: 800;
    letter-spacing: 1.4px;
    margin-bottom: 10px;
    border-radius: 2px;
}
.et-live-card.is-newest .et-live-card__tag { background: var(--et-red); }
.et-live-card__title {
    margin: 0 0 12px;
    font-size: 22px;
    font-weight: 700;
    line-height: 1.22;
    color: var(--et-ink);
    letter-spacing: -0.3px;
}
.et-live-card__content {
    font-size: 15.5px;
    line-height: 1.62;
    color: var(--et-ink2);
}
.et-live-card__content p { margin: 0 0 12px; }
.et-live-card__content p:last-child { margin-bottom: 0; }
.et-live-card__content img {
    max-width: 100%;
    height: auto;
    border-radius: 6px;
    margin: 12px 0;
    display: block;
}
.et-live-card__content iframe,
.et-live-card__content video {
    max-width: 100%;
    border-radius: 6px;
    margin: 12px 0;
    display: block;
}
.et-live-card__content blockquote {
    margin: 14px 0;
    padding: 12px 18px;
    border-left: 3px solid var(--et-harbor);
    background: var(--et-harbor-tint);
    font-style: italic;
    color: var(--et-ink);
}
.et-live-card__content a {
    color: var(--et-harbor);
    text-decoration: underline;
}
.et-live-card__permalink {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    margin-top: 14px;
    padding: 4px 10px;
    background: var(--et-harbor-tint);
    color: var(--et-harbor);
    font-family: var(--et-mono);
    font-size: 11px;
    font-weight: 600;
    text-decoration: none;
    border-radius: 3px;
    letter-spacing: 0.3px;
}

/* Most-read item — remove number style */
.et-most-read__item {
    grid-template-columns: 1fr;
}
.et-most-read__num { display: none; }

/* ═══════════════════════════════════════════════════════════════════
   BOLETINES — /boletines/ page
═══════════════════════════════════════════════════════════════════ */
.et-bol {
    background: var(--et-harbor-tint);
    min-height: 70vh;
    padding: 64px 0 96px;
}
.et-bol__inner {
    max-width: 1080px;
    margin: 0 auto;
    padding: 0 var(--et-pad);
}
.et-bol__head {
    text-align: center;
    margin-bottom: 48px;
}
.et-bol__kicker {
    display: block;
    font-family: var(--et-mono);
    font-size: 11px;
    color: var(--et-harbor);
    letter-spacing: 2.5px;
    margin-bottom: 16px;
}
.et-bol__head h1 {
    font-size: 42px;
    font-weight: 800;
    margin: 0 0 14px;
    letter-spacing: -1px;
    line-height: 1.1;
}
.et-bol__head p {
    font-size: 16px;
    color: var(--et-ink3);
    line-height: 1.55;
    max-width: 620px;
    margin: 0 auto;
}
.et-bol__grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 24px;
    margin-bottom: 36px;
}
.et-bol__card {
    background: #fff;
    padding: 32px 32px 28px;
    border-radius: 6px;
    border-top: 3px solid var(--et-harbor);
    transition: box-shadow 0.25s, transform 0.25s;
}
.et-bol__card:hover {
    box-shadow: 0 14px 36px rgba(14, 47, 70, 0.10);
    transform: translateY(-2px);
}
.et-bol__icon {
    font-size: 32px;
    margin-bottom: 12px;
    line-height: 1;
}
.et-bol__card h2 {
    margin: 0 0 6px;
    font-size: 22px;
    font-weight: 700;
    letter-spacing: -0.3px;
}
.et-bol__cadence {
    font-family: var(--et-mono);
    font-size: 11px;
    color: var(--et-harbor);
    font-weight: 600;
    letter-spacing: 1px;
    text-transform: uppercase;
    display: block;
    margin-bottom: 14px;
}
.et-bol__card p {
    font-size: 14px;
    color: var(--et-ink2);
    line-height: 1.55;
    margin: 0 0 12px;
}
.et-bol__count {
    font-size: 11.5px;
    color: var(--et-ink3);
    margin-bottom: 18px;
    display: block;
}
.et-bol__form {
    display: grid;
    grid-template-columns: 1fr auto;
    gap: 8px;
}
.et-bol__input {
    padding: 12px 14px;
    border: 1px solid var(--et-line-hi);
    border-radius: 4px;
    font-family: inherit;
    font-size: 14px;
    outline: none;
    transition: border-color 0.2s;
}
.et-bol__input:focus { border-color: var(--et-harbor); }
.et-bol__btn {
    padding: 12px 18px;
    background: var(--et-harbor);
    color: #fff;
    border: 0;
    border-radius: 4px;
    font-weight: 700;
    font-size: 12px;
    text-transform: uppercase;
    letter-spacing: 0.6px;
    cursor: pointer;
    transition: background 0.2s;
}
.et-bol__btn:hover { background: var(--et-harbor-deep); }
.et-bol__msg {
    display: block;
    margin-top: 10px;
    font-size: 12.5px;
    min-height: 18px;
}
.et-bol__msg.is-ok  { color: #15803D; font-weight: 600; }
.et-bol__msg.is-err { color: var(--et-red); font-weight: 600; }

.et-bol__footer {
    text-align: center;
    padding-top: 24px;
    border-top: 1px solid var(--et-line);
}
.et-bol__footer p {
    font-size: 12.5px;
    color: var(--et-ink3);
}
.et-bol__footer a { color: var(--et-harbor); }

@media (max-width: 720px) {
    .et-bol__grid { grid-template-columns: 1fr; }
    .et-bol__head h1 { font-size: 30px; }
}

/* Hide section numbering globally — premium clean look */
.et-section-head__num,
.et-m__section-num { display: none !important; }

/* ═══════════════════════════════════════════════════════════════════
   KICKER (harbor blue prefix on titles) — Reuters-style
═══════════════════════════════════════════════════════════════════ */
/* ═══════════════════════════════════════════════════════════════════
   EN VIVO sidebar — premium live thread
═══════════════════════════════════════════════════════════════════ */
.et-live {
    background: #fff;
    border: 1px solid var(--et-line);
    border-top: 4px solid var(--et-red);
    overflow: hidden;
}
.et-live__head {
    padding: 20px 22px 18px;
    background: linear-gradient(180deg, #fff, #fafafa);
    border-bottom: 1px solid var(--et-line);
}
.et-live__head-top {
    display: flex; align-items: center; gap: 10px;
    margin-bottom: 12px;
}
.et-live__pulse {
    width: 9px; height: 9px;
    border-radius: 50%;
    background: var(--et-red);
    animation: etPulse 1.4s infinite;
    box-shadow: 0 0 0 0 rgba(200, 16, 46, 0.5);
}
.et-live__kicker {
    font-family: var(--et-font);
    font-size: 11px; font-weight: 800;
    color: var(--et-red);
    letter-spacing: 2.4px;
}
.et-live__active-badge {
    margin-left: auto;
    font-size: 10px; font-weight: 700;
    color: #fff;
    background: var(--et-red);
    padding: 3px 8px;
    border-radius: 2px;
    letter-spacing: 1px;
    text-transform: uppercase;
}
.et-live__title {
    margin: 0;
    font-size: 17px; font-weight: 700;
    line-height: 1.25;
    color: var(--et-ink);
    letter-spacing: -0.2px;
}

.et-live__list {
    list-style: none; margin: 0; padding: 0;
    counter-reset: livecount;
}
.et-live__item {
    display: block;
    padding: 16px 22px;
    border-bottom: 1px solid var(--et-line);
    position: relative;
}
.et-live__item:last-of-type { border-bottom: 0; }
.et-live__item--latest {
    background: linear-gradient(90deg, rgba(200,16,46,0.05), transparent 60%);
}
.et-live__time {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    font-family: var(--et-mono);
    font-size: 10.5px;
    color: var(--et-ink3);
    letter-spacing: 0.6px;
    margin-bottom: 8px;
    text-transform: uppercase;
    font-weight: 600;
}
.et-live__item--latest .et-live__time { color: var(--et-red); font-weight: 700; }
.et-live__time-dot {
    display: inline-block;
    width: 6px; height: 6px;
    border-radius: 50%;
    background: var(--et-red);
    flex-shrink: 0;
    animation: etPulse 1.4s infinite;
}
.et-live__body {
    font-size: 13.5px; line-height: 1.55;
    color: var(--et-ink);
}
.et-live__body strong { font-weight: 700; color: var(--et-harbor); }
.et-live__body p { margin: 0 0 8px; }
.et-live__body p:last-child { margin: 0; }
.et-live__body a { color: var(--et-harbor); text-decoration: underline; }

.et-live__media {
    margin-top: 10px;
    border-radius: 4px;
    overflow: hidden;
    background: var(--et-bg-soft);
}
.et-live__media img,
.et-live__media video,
.et-live__media iframe {
    width: 100%;
    display: block;
    max-width: 100%;
    height: auto;
}

.et-live__cta {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    padding: 14px 22px;
    background: var(--et-harbor);
    color: #fff;
    text-decoration: none;
    font-size: 12px; font-weight: 700;
    letter-spacing: 0.4px;
    text-transform: uppercase;
    transition: background 0.2s;
}
.et-live__cta:hover { background: var(--et-harbor-deep); }

@keyframes etPulse {
    0% { box-shadow: 0 0 0 0 rgba(200, 16, 46, 0.5); }
    70% { box-shadow: 0 0 0 8px rgba(200, 16, 46, 0); }
    100% { box-shadow: 0 0 0 0 rgba(200, 16, 46, 0); }
}


/* ═══════════════════════════════════════════════════════════════════
   ECONOMÍA — PREMIUM LIGHT (Reuters/FT integrated)
═══════════════════════════════════════════════════════════════════ */
.et-eco { background: var(--et-harbor-tint); }
.et-eco__board {
    display: grid;
    grid-template-columns: 1fr 380px;
    gap: 32px;
    align-items: start;
}

/* LEFT — News column */
.et-eco__news-col {
    background: #fff;
    border-radius: 4px;
    overflow: hidden;
}
.et-eco__lead {
    display: block;
    text-decoration: none; color: inherit;
}
.et-eco__lead-photo {
    width: 100%;
    aspect-ratio: 16/9;
    background-color: #1B4965;
    background-size: cover; background-position: center;
}
.et-eco__lead-body {
    padding: 28px 32px 24px;
}
.et-eco__lead-cat {
    font-size: 10.5px; font-weight: 700; color: var(--et-harbor);
    letter-spacing: 2px; margin-bottom: 12px; display: block;
}
.et-eco__lead-title {
    margin: 0 0 14px;
    font-size: 28px; font-weight: 700;
    line-height: 1.18; color: var(--et-ink);
    letter-spacing: -0.5px;
    transition: color 0.2s;
}
.et-eco__lead:hover .et-eco__lead-title { color: var(--et-harbor); }
.et-eco__lead-sub {
    margin: 0 0 14px;
    font-size: 15px; line-height: 1.55;
    color: var(--et-ink2);
}
.et-eco__lead-meta { font-size: 12px; color: var(--et-ink3); }

.et-eco__list {
    list-style: none; margin: 0; padding: 0;
    border-top: 1px solid var(--et-line);
}
.et-eco__list-item {
    border-bottom: 1px solid var(--et-line);
}
.et-eco__list-item:last-child { border-bottom: 0; }
.et-eco__list-link {
    display: block;
    padding: 18px 32px;
    text-decoration: none; color: inherit;
    transition: background 0.15s;
}
.et-eco__list-link:hover { background: var(--et-harbor-tint); }
.et-eco__list-cat {
    font-size: 9.5px; font-weight: 700; color: var(--et-harbor);
    letter-spacing: 1.6px; margin-bottom: 6px; display: block;
}
.et-eco__list-title {
    margin: 0 0 6px;
    font-size: 16px; font-weight: 600;
    line-height: 1.32; color: var(--et-ink);
    transition: color 0.2s;
}
.et-eco__list-link:hover .et-eco__list-title { color: var(--et-harbor); }
.et-eco__list-meta { font-size: 11.5px; color: var(--et-ink3); }

/* RIGHT — Markets panel (light) */
.et-eco__markets {
    background: #fff;
    border-radius: 4px;
    border-top: 4px solid var(--et-harbor);
    overflow: hidden;
}
.et-eco__markets-head {
    display: flex;
    justify-content: space-between;
    align-items: flex-end;
    padding: 22px 24px 18px;
    border-bottom: 1px solid var(--et-line);
}
.et-eco__markets-kicker {
    font-family: var(--et-mono);
    font-size: 10.5px; font-weight: 700;
    color: var(--et-harbor);
    letter-spacing: 2px;
    display: block;
    margin-bottom: 4px;
}
.et-eco__markets-head h3 {
    margin: 0;
    font-size: 18px; font-weight: 800;
    color: var(--et-ink);
    letter-spacing: -0.3px;
}
.et-eco__markets-clock {
    font-family: var(--et-mono);
    font-size: 11px; color: var(--et-ink3);
    letter-spacing: 0.4px;
    display: inline-flex; align-items: center; gap: 5px;
    padding-bottom: 2px;
}
.et-eco__markets-time { color: var(--et-ink); font-weight: 700; }

/* Featured IBEX */
.et-eco__market-feat {
    padding: 20px 24px;
    background: linear-gradient(180deg,#fff,#fafafa);
    border-bottom: 1px solid var(--et-line);
}
.et-eco__market-feat-top {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    margin-bottom: 14px;
}
.et-eco__market-feat-sym {
    display: block;
    font-size: 13px; font-weight: 800;
    color: var(--et-ink);
    letter-spacing: 0.5px;
    margin-bottom: 2px;
}
.et-eco__market-feat-tag {
    font-size: 10.5px; color: var(--et-ink3);
    letter-spacing: 0.2px;
}
.et-eco__market-feat-vals { text-align: right; }
.et-eco__market-feat-val {
    display: block;
    font-family: var(--et-mono);
    font-size: 24px; font-weight: 700;
    color: var(--et-ink);
    letter-spacing: -0.5px;
    line-height: 1;
    margin-bottom: 4px;
}
.et-eco__market-feat-chg {
    display: inline-flex; align-items: center; gap: 4px;
    font-size: 12px; font-weight: 700;
}
.et-eco__market-feat-chg.up { color: #16a34a; }
.et-eco__market-feat-chg.down { color: var(--et-red); }

.et-eco__chart { width: 100%; height: 80px; display: block; }

/* Mini market grid */
.et-eco__markets-grid {
    display: grid; grid-template-columns: 1fr 1fr;
    gap: 0;
}
.et-eco__market-mini {
    padding: 14px 24px;
    border-bottom: 1px solid var(--et-line);
    border-right: 1px solid var(--et-line);
}
.et-eco__market-mini:nth-child(2n) { border-right: 0; }
.et-eco__market-mini-sym {
    font-size: 10px; font-weight: 700;
    color: var(--et-ink3);
    letter-spacing: 1.5px;
    margin-bottom: 6px;
}
.et-eco__market-mini-val {
    font-family: var(--et-mono);
    font-size: 17px; font-weight: 700;
    color: var(--et-ink);
    margin-bottom: 4px;
    letter-spacing: -0.2px;
}
.et-eco__market-mini-chg {
    display: inline-flex; align-items: center; gap: 4px;
    font-size: 11.5px; font-weight: 600;
}
.et-eco__market-mini-chg.up { color: #16a34a; }
.et-eco__market-mini-chg.down { color: var(--et-red); }

.et-eco__markets-cta {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    padding: 14px 24px;
    background: var(--et-bg-soft);
    color: var(--et-harbor);
    text-decoration: none;
    font-size: 12px; font-weight: 700;
    letter-spacing: 0.3px;
    text-transform: uppercase;
    transition: background 0.2s;
}
.et-eco__markets-cta:hover { background: var(--et-harbor-tint); }

/* ═══════════════════════════════════════════════════════════════════
   EN VIVO PAGE — /en-vivo/ premium full-screen
═══════════════════════════════════════════════════════════════════ */
.et-envivo {
    background: #fff;
    min-height: 70vh;
    padding: 56px 0 80px;
}
.et-envivo__inner {
    max-width: 880px;
    margin: 0 auto;
    padding: 0 var(--et-pad);
}
.et-envivo__head {
    padding-bottom: 36px;
    margin-bottom: 36px;
    border-bottom: 4px solid var(--et-red);
}
.et-envivo__kicker-row {
    display: flex; align-items: center; gap: 12px;
    margin-bottom: 18px;
}
.et-envivo__pulse {
    width: 12px; height: 12px;
    border-radius: 50%;
    background: var(--et-red);
    animation: etPulse 1.4s infinite;
}
.et-envivo__kicker {
    font-size: 13px; font-weight: 800;
    color: var(--et-red);
    letter-spacing: 3px;
}
.et-envivo__active {
    margin-left: auto;
    font-size: 11px; font-weight: 700;
    color: #fff;
    background: var(--et-red);
    padding: 4px 10px;
    letter-spacing: 1.2px;
    border-radius: 2px;
}
.et-envivo__archived {
    margin-left: auto;
    font-size: 11px; font-weight: 700;
    color: var(--et-ink3);
    background: var(--et-bg-soft);
    padding: 4px 10px;
    letter-spacing: 1.2px;
    border: 1px solid var(--et-line);
    border-radius: 2px;
}
.et-envivo__title {
    margin: 0 0 14px;
    font-size: 44px; font-weight: 800;
    line-height: 1.1; letter-spacing: -1.2px;
    color: var(--et-ink);
}
.et-envivo__lead {
    margin: 0 0 18px;
    font-size: 17px; line-height: 1.55;
    color: var(--et-ink2);
    max-width: 720px;
}
.et-envivo__meta {
    display: flex; align-items: center; gap: 10px;
    font-size: 13px; color: var(--et-ink3);
}
.et-envivo__meta strong { color: var(--et-ink); font-weight: 700; }
.et-envivo__meta .dot {
    width: 3px; height: 3px; border-radius: 50%;
    background: var(--et-ink5);
}

.et-envivo__thread {
    list-style: none; margin: 0; padding: 0;
}
.et-envivo__entry {
    display: grid;
    grid-template-columns: 60px 1fr;
    gap: 18px;
    padding-bottom: 32px;
    margin-bottom: 32px;
    border-bottom: 1px solid var(--et-line);
    position: relative;
}
.et-envivo__entry:last-child { border-bottom: 0; margin-bottom: 0; padding-bottom: 0; }
.et-envivo__entry-rail {
    display: flex; flex-direction: column; align-items: center;
    padding-top: 6px;
}
.et-envivo__entry-dot {
    width: 14px; height: 14px;
    border-radius: 50%;
    background: var(--et-ink);
    border: 3px solid #fff;
    box-shadow: 0 0 0 1px var(--et-line);
    flex-shrink: 0;
}
.et-envivo__entry-dot--latest {
    background: var(--et-red);
    box-shadow: 0 0 0 1px var(--et-red);
    animation: etPulse 1.4s infinite;
}
.et-envivo__entry::before {
    content: '';
    position: absolute;
    left: 30px;
    top: 28px;
    bottom: -32px;
    width: 1px;
    background: var(--et-line);
    z-index: 0;
}
.et-envivo__entry:last-child::before { display: none; }

.et-envivo__entry-body { min-width: 0; }
.et-envivo__entry-time {
    font-family: var(--et-mono);
    font-size: 12px; color: var(--et-ink3);
    letter-spacing: 0.4px;
    margin-bottom: 12px;
    display: flex; align-items: center; gap: 10px;
}
.et-envivo__entry--latest .et-envivo__entry-time { color: var(--et-red); font-weight: 700; }
.et-envivo__entry-now-pill {
    background: var(--et-red);
    color: #fff;
    font-family: var(--et-font);
    font-size: 9px; font-weight: 800;
    letter-spacing: 1.2px;
    padding: 3px 7px;
    border-radius: 2px;
}
.et-envivo__entry-text {
    font-size: 17px; line-height: 1.6;
    color: var(--et-ink);
    margin-bottom: 12px;
}
.et-envivo__entry--latest .et-envivo__entry-text {
    font-size: 19px; font-weight: 500;
}
.et-envivo__entry-text p { margin: 0 0 10px; }
.et-envivo__entry-text p:last-child { margin: 0; }
.et-envivo__entry-text strong { color: var(--et-harbor); font-weight: 700; }
.et-envivo__entry-text a { color: var(--et-harbor); }

.et-envivo__entry-media {
    margin-top: 12px;
    border-radius: 5px;
    overflow: hidden;
    background: var(--et-bg-soft);
    max-width: 600px;
}
.et-envivo__entry-media img,
.et-envivo__entry-media video,
.et-envivo__entry-media iframe {
    width: 100%;
    display: block;
    height: auto;
}

@media (max-width: 720px) {
    .et-envivo__title { font-size: 32px; }
    .et-envivo__entry { grid-template-columns: 36px 1fr; gap: 12px; }
    .et-envivo__entry::before { left: 18px; }
}

/* ═══════════════════════════════════════════════════════════════════
   /boletines/ — premium subscription hub
═══════════════════════════════════════════════════════════════════ */
.et-bol {
    background: var(--et-harbor-tint);
    min-height: 70vh;
    padding: 64px 0 80px;
}
.et-bol__inner {
    max-width: 1180px;
    margin: 0 auto;
    padding: 0 var(--et-pad);
}
.et-bol__head {
    text-align: center;
    margin-bottom: 56px;
}
.et-bol__kicker {
    display: inline-block;
    font-family: var(--et-mono);
    font-size: 11px; font-weight: 700;
    color: var(--et-harbor);
    letter-spacing: 3px;
    margin-bottom: 18px;
}
.et-bol__title {
    margin: 0 0 16px;
    font-size: 48px; font-weight: 800;
    line-height: 1.05; letter-spacing: -1.5px;
    color: var(--et-ink);
}
.et-bol__lead {
    margin: 0 auto 32px;
    max-width: 640px;
    font-size: 17px; line-height: 1.55;
    color: var(--et-ink2);
}
.et-bol__stats {
    display: flex;
    justify-content: center;
    gap: 56px;
    padding-top: 24px;
    border-top: 1px solid var(--et-line);
    max-width: 720px;
    margin: 32px auto 0;
}
.et-bol__stat { text-align: center; }
.et-bol__stat .num {
    display: block;
    font-size: 32px; font-weight: 800;
    color: var(--et-harbor);
    letter-spacing: -1px;
    line-height: 1;
    margin-bottom: 6px;
}
.et-bol__stat .lbl {
    font-size: 11px; color: var(--et-ink3);
    letter-spacing: 1.2px;
    text-transform: uppercase;
}

.et-bol__grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 24px;
    margin-bottom: 56px;
}
.et-bol__card {
    background: #fff;
    padding: 32px 28px;
    border-radius: 6px;
    border: 1px solid var(--et-line);
    transition: all 0.25s ease;
    display: flex;
    flex-direction: column;
}
.et-bol__card:hover {
    border-color: var(--et-harbor);
    transform: translateY(-2px);
    box-shadow: 0 12px 32px rgba(14, 47, 70, 0.08);
}
.et-bol__card-icon {
    width: 48px; height: 48px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--et-harbor-tint);
    color: var(--et-harbor);
    border-radius: 50%;
    margin-bottom: 18px;
}
.et-bol__card-icon svg { width: 22px; height: 22px; }
.et-bol__card-meta {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 12px;
}
.et-bol__card-freq {
    font-size: 10.5px; font-weight: 700;
    color: var(--et-harbor);
    letter-spacing: 1.5px;
    text-transform: uppercase;
}
.et-bol__card-subs {
    font-family: var(--et-mono);
    font-size: 11px;
    color: var(--et-ink3);
}
.et-bol__card-title {
    margin: 0 0 10px;
    font-size: 22px; font-weight: 800;
    color: var(--et-ink);
    letter-spacing: -0.5px;
}
.et-bol__card-desc {
    margin: 0 0 22px;
    font-size: 14px; line-height: 1.55;
    color: var(--et-ink3);
    flex: 1;
}
.et-bol__form {
    display: grid;
    grid-template-columns: 1fr auto;
    gap: 8px;
}
.et-bol__input {
    padding: 11px 14px;
    border: 1px solid var(--et-line-hi);
    background: #fff;
    font-size: 13px;
    font-family: var(--et-font);
    color: var(--et-ink);
    border-radius: 4px;
    outline: none;
    transition: border-color 0.2s;
}
.et-bol__input:focus { border-color: var(--et-harbor); }
.et-bol__submit {
    padding: 11px 18px;
    background: var(--et-harbor);
    color: #fff;
    border: 0;
    border-radius: 4px;
    font-size: 12px; font-weight: 700;
    letter-spacing: 0.4px;
    text-transform: uppercase;
    cursor: pointer;
    transition: background 0.2s;
}
.et-bol__submit:hover { background: var(--et-harbor-deep); }
.et-bol__msg {
    font-size: 12px;
    margin-top: 10px;
    line-height: 1.4;
    min-height: 16px;
}
.et-bol__msg--ok  { color: #16a34a; }
.et-bol__msg--err { color: var(--et-red); }
.et-bol__msg--info { color: var(--et-ink3); }

.et-bol__legal {
    text-align: center;
    color: var(--et-ink3);
    font-size: 12.5px;
    line-height: 1.6;
    max-width: 720px;
    margin: 0 auto;
}
.et-bol__legal a { color: var(--et-harbor); }

@media (max-width: 900px) {
    .et-bol__grid { grid-template-columns: 1fr 1fr; }
    .et-bol__stats { flex-direction: column; gap: 20px; }
}
@media (max-width: 600px) {
    .et-bol__grid { grid-template-columns: 1fr; }
    .et-bol__title { font-size: 34px; }
    .et-bol__form { grid-template-columns: 1fr; }
}

/* ─── EN VIVO live thread additions ──────────────────────────── */
.et-live--empty {
    border-top-color: var(--et-line);
}
.et-live__kicker--off { color: var(--et-ink3) !important; }
.et-live__empty-text {
    margin: 0;
    padding: 24px 22px;
    font-size: 13px; line-height: 1.55;
    color: var(--et-ink3);
    border-bottom: 1px solid var(--et-line);
}
.et-live__cta--ghost {
    background: var(--et-bg-soft);
    color: var(--et-harbor);
}
.et-live__cta--ghost:hover { background: var(--et-harbor-tint); }

.et-live__tag {
    display: inline-block;
    font-size: 9px; font-weight: 800;
    letter-spacing: 1.2px;
    color: #fff;
    background: var(--et-red);
    padding: 2px 6px;
    border-radius: 2px;
    margin-bottom: 6px;
}
.et-live__entry-title {
    display: block;
    font-size: 13px; font-weight: 700;
    color: var(--et-ink);
    margin-bottom: 4px;
    line-height: 1.3;
}
.et-live__entry-text {
    font-size: 13px; line-height: 1.5;
    color: var(--et-ink2);
}
.et-live__entry-text p { margin: 0 0 6px; }
.et-live__entry-text p:last-child { margin: 0; }
.et-live__entry-text strong { color: var(--et-harbor); font-weight: 700; }

/* Side quote (restored) */
.et-side-quote {
    margin-top: 28px;
    background: var(--et-harbor-tint);
    padding: 24px;
    border-left: 3px solid var(--et-harbor);
}
.et-side-quote__kicker {
    font-family: var(--et-mono);
    font-size: 10.5px; font-weight: 600;
    color: var(--et-harbor);
    letter-spacing: 2px;
    display: block;
    margin-bottom: 14px;
}
.et-side-quote__text {
    margin: 0 0 14px;
    font-size: 16px; font-weight: 500;
    line-height: 1.45;
    color: var(--et-ink);
    font-style: italic;
}
.et-side-quote__attr { font-size: 12px; color: var(--et-ink3); }
.et-side-quote__attr strong { color: var(--et-ink); font-weight: 700; }

/* Live page premium full-screen */
.et-livepage {
    background: #fff;
    min-height: 70vh;
    padding: 56px 0 80px;
}
.et-livepage__inner {
    max-width: 880px;
    margin: 0 auto;
    padding: 0 var(--et-pad);
}
.et-livepage__empty {
    text-align: center;
    padding: 80px 20px;
}
.et-livepage__kicker {
    display: inline-block;
    font-family: var(--et-mono);
    font-size: 11px; font-weight: 700;
    color: var(--et-harbor);
    letter-spacing: 3px;
    margin-bottom: 20px;
}
.et-livepage__empty h1 {
    margin: 0 0 14px;
    font-size: 32px; font-weight: 800;
    color: var(--et-ink);
    letter-spacing: -0.6px;
}
.et-livepage__empty p {
    color: var(--et-ink3);
    font-size: 15px; line-height: 1.55;
    max-width: 540px;
    margin: 0 auto 28px;
}
.et-livepage__back {
    display: inline-block;
    padding: 12px 28px;
    background: var(--et-harbor);
    color: #fff;
    text-decoration: none;
    font-size: 12px; font-weight: 700;
    letter-spacing: 0.4px;
    text-transform: uppercase;
    border-radius: 3px;
}
.et-livepage__back:hover { background: var(--et-harbor-deep); }

.et-livepage__head {
    padding-bottom: 36px;
    margin-bottom: 36px;
    border-bottom: 4px solid var(--et-red);
}
.et-livepage__head-top {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 20px;
}
.et-livepage__live-badge {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 6px 12px;
    background: var(--et-red);
    color: #fff;
    font-size: 11px; font-weight: 800;
    letter-spacing: 2px;
    border-radius: 2px;
}
.et-livepage__live-dot {
    width: 8px; height: 8px;
    border-radius: 50%;
    background: #fff;
    animation: etPulse 1.4s infinite;
}
.et-livepage__started {
    font-family: var(--et-mono);
    font-size: 12px;
    color: var(--et-ink3);
    letter-spacing: 0.3px;
}
.et-livepage__title {
    margin: 0 0 14px;
    font-size: 44px; font-weight: 800;
    line-height: 1.08; letter-spacing: -1.2px;
    color: var(--et-ink);
}
.et-livepage__sub {
    margin: 0;
    font-size: 17px; line-height: 1.55;
    color: var(--et-ink2);
}

.et-livepage__feed {
    display: flex; flex-direction: column;
}
.et-live-card {
    display: grid;
    grid-template-columns: 90px 1fr;
    gap: 20px;
    padding-bottom: 32px;
    margin-bottom: 32px;
    border-bottom: 1px solid var(--et-line);
    position: relative;
}
.et-live-card:last-child { border-bottom: 0; }
.et-live-card__rail {
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    padding-top: 4px;
    position: relative;
}
.et-live-card__time {
    text-align: right;
    margin-bottom: 8px;
}
.et-live-card__time strong {
    display: block;
    font-family: var(--et-mono);
    font-size: 22px; font-weight: 700;
    line-height: 1;
    color: var(--et-ink);
    margin-bottom: 4px;
}
.et-live-card__time span {
    font-family: var(--et-mono);
    font-size: 11px; color: var(--et-ink3);
    letter-spacing: 0.4px;
    text-transform: uppercase;
}
.et-live-card.is-newest .et-live-card__time strong { color: var(--et-red); }
.et-live-card__dot {
    width: 12px; height: 12px;
    border-radius: 50%;
    background: var(--et-ink);
    border: 2px solid #fff;
    box-shadow: 0 0 0 1px var(--et-line);
    margin-top: 6px;
    margin-right: -7px;
    z-index: 2;
    position: relative;
}
.et-live-card__dot[data-pulse] {
    background: var(--et-red);
    box-shadow: 0 0 0 1px var(--et-red);
    animation: etPulse 1.4s infinite;
}
.et-live-card__rail::after {
    content: '';
    position: absolute;
    top: 60px;
    bottom: -32px;
    right: -1px;
    width: 1px;
    background: var(--et-line);
    z-index: 1;
}
.et-live-card:last-child .et-live-card__rail::after { display: none; }

.et-live-card__body { min-width: 0; }
.et-live-card__tag {
    display: inline-block;
    font-size: 10px; font-weight: 800;
    letter-spacing: 1.4px;
    color: #fff;
    background: var(--et-red);
    padding: 3px 8px;
    margin-bottom: 10px;
    border-radius: 2px;
}
.et-live-card__title {
    margin: 0 0 12px;
    font-size: 22px; font-weight: 800;
    line-height: 1.2; letter-spacing: -0.4px;
    color: var(--et-ink);
}
.et-live-card.is-newest .et-live-card__title { font-size: 26px; }
.et-live-card__content {
    font-size: 15px; line-height: 1.6;
    color: var(--et-ink);
}
.et-live-card__content p { margin: 0 0 12px; }
.et-live-card__content p:last-child { margin: 0; }
.et-live-card__content strong { color: var(--et-harbor); }
.et-live-card__content a { color: var(--et-harbor); }
.et-live-card__content img,
.et-live-card__content iframe {
    max-width: 100%;
    border-radius: 5px;
    margin: 12px 0;
}
.et-live-card__permalink {
    display: inline-flex;
    align-items: center;
    gap: 5px;
    margin-top: 14px;
    font-family: var(--et-mono);
    font-size: 11px;
    color: var(--et-ink3);
    text-decoration: none;
    letter-spacing: 0.3px;
}
.et-live-card__permalink:hover { color: var(--et-harbor); }

.et-livepage__pending {
    text-align: center;
    color: var(--et-ink3);
    font-size: 15px;
    padding: 40px 20px;
}

@media (max-width: 720px) {
    .et-livepage__title { font-size: 30px; }
    .et-live-card { grid-template-columns: 60px 1fr; gap: 14px; }
    .et-live-card__time strong { font-size: 16px; }
}

/* ═══════════════════════════════════════════════════════════════════
   KICKER — Reuters-style harbor blue prefix on titles
   No gray dot, no extra spacing. Just bold blue + space + title.
═══════════════════════════════════════════════════════════════════ */
.et-kicker {
    color: var(--et-harbor);
    font-weight: 800;
}
.et-kicker::after {
    content: ' ';
}

/* ═══════════════════════════════════════════════════════════════════
   BYLINE — Author + thin harbor bar + city, with clickable author link
═══════════════════════════════════════════════════════════════════ */
.et-byline-author {
    color: var(--et-ink);
    font-weight: 600;
    text-decoration: none;
    transition: color 0.15s;
    position: relative;
    z-index: 2;  /* sits above card overlay link */
}
.et-byline-author:hover { color: var(--et-harbor); }
.et-byline-sep {
    display: inline-block;
    width: 14px;
    height: 1.5px;
    background: var(--et-harbor);
    margin: 0 8px;
    vertical-align: middle;
    border-radius: 1px;
}
.et-byline-city {
    color: var(--et-ink2);
    font-weight: 500;
}

/* Clickable category link — sits above card overlay */
.et-cat-link {
    color: var(--et-harbor);
    font-weight: 700;
    letter-spacing: 2px;
    text-decoration: none;
    transition: color 0.15s;
    position: relative;
    z-index: 2;
}
.et-cat-link:hover { color: var(--et-harbor-deep); }

/* When card has overlay-link pattern, ensure author/cat links bubble above */
.et-card--linked {
    position: relative;
}
.et-card__overlay-link {
    position: absolute;
    inset: 0;
    z-index: 1;
    text-indent: -9999px;
    overflow: hidden;
}

/* ═══════════════════════════════════════════════════════════════════
   HERO REUTERS-STYLE — denser, premium editorial layout
═══════════════════════════════════════════════════════════════════ */
.et-hero-r {
    background: var(--et-bg);
    padding: 24px 0 36px;
    border-bottom: 1px solid var(--et-line);
}
.et-hero-r__inner {
    max-width: var(--et-max);
    margin: 0 auto;
    padding: 0 var(--et-pad);
}

/* Top bar — Reuters thin label */
.et-hero-r__topbar {
    display: flex; align-items: center; gap: 14px;
    padding-bottom: 16px; margin-bottom: 24px;
    border-bottom: 2px solid var(--et-ink);
}
.et-hero-r__top-label {
    font-size: 11px; font-weight: 800;
    letter-spacing: 2.5px;
    color: var(--et-ink);
}
.et-hero-r__top-rule { flex: 1; height: 1px; background: transparent; }
.et-hero-r__top-meta {
    font-size: 12px;
    color: var(--et-ink3);
    font-weight: 500;
    text-transform: capitalize;
}

/* TOP — lead + sidebar */
.et-hero-r__top {
    display: grid;
    grid-template-columns: 1.85fr 1fr;
    gap: 28px;
    margin-bottom: 28px;
}

/* LEAD card */
.et-hero-r__lead {
    display: flex;
    flex-direction: column;
    position: relative;
}
.et-hero-r__lead-photo {
    width: 100%;
    aspect-ratio: 16/9;
    background-color: #1B4965;
    background-size: cover; background-position: center;
    border-radius: 5px;
    overflow: hidden;
    margin-bottom: 18px;
}
.et-hero-r__lead-body { padding: 0; }
.et-hero-r__lead-cat {
    font-size: 11px;
    margin-bottom: 12px;
    display: inline-block;
}
.et-hero-r__lead-title {
    margin: 0 0 12px;
    font-size: 34px; font-weight: 800;
    line-height: 1.12; letter-spacing: -0.8px;
    color: var(--et-ink);
}
.et-hero-r__lead-title a {
    color: inherit;
    text-decoration: none;
    position: relative; z-index: 2;
}
.et-hero-r__lead-title a:hover { color: var(--et-harbor); }
.et-hero-r__lead-sub {
    margin: 0 0 14px;
    font-size: 16px; line-height: 1.5;
    color: var(--et-ink2);
}
.et-hero-r__lead-meta {
    font-size: 13px;
    color: var(--et-ink3);
    display: flex; align-items: center;
}

/* SIDE — 3 stacked secondary */
.et-hero-r__side {
    display: flex;
    flex-direction: column;
    gap: 0;
}
.et-hero-r__sec {
    display: grid;
    grid-template-columns: 100px 1fr;
    gap: 14px;
    padding: 16px 0;
    border-bottom: 1px solid var(--et-line);
    position: relative;
}
.et-hero-r__sec:first-child { padding-top: 0; }
.et-hero-r__sec:last-child { border-bottom: 0; }
.et-hero-r__sec-photo {
    aspect-ratio: 1/1;
    background-color: #1B4965;
    background-size: cover; background-position: center;
    border-radius: 4px;
    overflow: hidden;
}
.et-hero-r__sec-body { min-width: 0; }
.et-hero-r__sec-cat {
    font-size: 9.5px;
    letter-spacing: 1.6px;
    display: inline-block;
    margin-bottom: 6px;
}
.et-hero-r__sec-title {
    margin: 0 0 6px;
    font-size: 15px; font-weight: 700;
    line-height: 1.28;
    color: var(--et-ink);
}
.et-hero-r__sec-title a {
    color: inherit;
    text-decoration: none;
    position: relative; z-index: 2;
}
.et-hero-r__sec-title a:hover { color: var(--et-harbor); }
.et-hero-r__sec-meta {
    font-size: 11.5px;
    color: var(--et-ink3);
    display: flex; align-items: center;
}
.et-hero-r__sec-meta .et-byline-sep { width: 10px; }

/* BOTTOM — 4 cards row */
.et-hero-r__cards {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 24px;
    padding-top: 28px;
    border-top: 1px solid var(--et-line);
}
.et-hero-r__card {
    display: flex; flex-direction: column;
    position: relative;
}
.et-hero-r__card-photo {
    width: 100%;
    aspect-ratio: 16/10;
    background-color: #1B4965;
    background-size: cover; background-position: center;
    border-radius: 4px;
    overflow: hidden;
    margin-bottom: 12px;
}
.et-hero-r__card-cat {
    font-size: 10px;
    letter-spacing: 1.6px;
    display: inline-block;
    margin-bottom: 6px;
}
.et-hero-r__card-title {
    margin: 0 0 6px;
    font-size: 15.5px; font-weight: 700;
    line-height: 1.28;
    color: var(--et-ink);
}
.et-hero-r__card-title a {
    color: inherit;
    text-decoration: none;
    position: relative; z-index: 2;
}
.et-hero-r__card-title a:hover { color: var(--et-harbor); }
.et-hero-r__card-meta {
    font-size: 11px;
    color: var(--et-ink3);
    display: flex; align-items: center;
    margin-top: auto;
}
.et-hero-r__card-meta .et-byline-sep { width: 10px; }

@media (max-width: 1080px) {
    .et-hero-r__top { grid-template-columns: 1fr; }
    .et-hero-r__cards { grid-template-columns: 1fr 1fr; }
    .et-hero-r__lead-title { font-size: 28px; }
}
@media (max-width: 640px) {
    .et-hero-r__cards { grid-template-columns: 1fr; }
}

/* Hide old hero CSS leftover */
.et-hero { display: none; }
.et-hero-r .et-byline-author { font-weight: 700; }

/* ═══════════════════════════════════════════════════════════════════
   SECTION HEAD — tighter Reuters-style with rule
═══════════════════════════════════════════════════════════════════ */
.et-section-head {
    padding-bottom: 14px;
    margin-bottom: 24px;
    border-bottom: 2px solid var(--et-ink);
}
.et-section-head__title {
    font-size: 24px;
    letter-spacing: -0.5px;
}

/* Tighten section padding */
.et-canarias, .et-tnf, .et-op, .et-weather, .et-seismic, .et-eco, .et-cul, .et-sp {
    padding: 40px 0 !important;
}

/* ═══════════════════════════════════════════════════════════════════
   QUOTE BAND — standalone premium quote, sits between hero & Canarias
═══════════════════════════════════════════════════════════════════ */
.et-quote-band {
    background: var(--et-harbor-tint);
    padding: 36px 0;
    border-top: 1px solid var(--et-line);
    border-bottom: 1px solid var(--et-line);
}
.et-quote-band__inner {
    max-width: 920px;
    margin: 0 auto;
    padding: 0 var(--et-pad);
    text-align: center;
}
.et-quote-band__kicker {
    display: inline-block;
    font-family: var(--et-mono);
    font-size: 10.5px; font-weight: 700;
    color: var(--et-harbor);
    letter-spacing: 2.4px;
    margin-bottom: 18px;
}
.et-quote-band__text {
    margin: 0 0 16px;
    font-size: 24px; font-weight: 500;
    line-height: 1.4; letter-spacing: -0.4px;
    color: var(--et-ink);
    font-style: italic;
    position: relative;
    padding: 0 24px;
}
.et-quote-band__mark {
    color: var(--et-harbor);
    font-size: 28px;
    font-style: normal;
    font-weight: 700;
    margin: 0 4px;
    vertical-align: -2px;
}
.et-quote-band__attr {
    font-size: 13px;
    color: var(--et-ink3);
    display: inline-flex; align-items: center;
    justify-content: center;
}
.et-quote-band__attr strong { color: var(--et-ink); font-weight: 700; }

@media (max-width: 720px) {
    .et-quote-band { padding: 28px 0; }
    .et-quote-band__text { font-size: 19px; padding: 0 8px; }
}

/* ═══════════════════════════════════════════════════════════════════
   MOBILE/DESKTOP HARD SEPARATION — fallback CSS rules
   These run AFTER all mobile.css rules and beat any specificity battle.
═══════════════════════════════════════════════════════════════════ */
html body .et-m { display: none !important; }
html body .et-d-only { display: block !important; }

@media screen and (max-width: 1024px) {
    html body .et-m { display: block !important; }
    html body .et-d-only,
    html body .et-canarias,
    html body .et-tnf,
    html body .et-op,
    html body .et-eco,
    html body .et-cul,
    html body .et-news,
    html body .et-footer,
    html body section.et-utility,
    html body header.et-masthead,
    html body nav.et-nav {
        display: none !important;
    }
}

/* ═══════════════════════════════════════════════════════════════════
   v2.25.62 — FUENTE INTER GLOBAL (petición del usuario)
   Aplicar Inter en TODO el sitio, PC y móvil. Solo se preserva
   JetBrains Mono para code/pre/kbd (legibilidad técnica).
═══════════════════════════════════════════════════════════════════ */
html, body,
body *,
h1, h2, h3, h4, h5, h6,
p, a, span, em, strong, small, mark,
button, input, select, textarea, label,
ul, ol, li, dl, dt, dd,
nav, header, footer, main, section, article, aside, figure, figcaption,
blockquote, cite, q,
table, tr, td, th, caption,
.dai-quote p, .dai-quote cite,
.et-pcv2-hero__title, .et-pcv2-hero__title *,
.et-pcv2-csc__head-title, .et-pcv2-econ__head-title,
.et-pcv2-sports__head-title, .et-pcv2-reg__head-title,
.et-pcv2-wqo__head-title, .et-pcv2-live__head-title,
.et-seis__title, .et-weather__title, .et-gas__title,
.et-gas__stat-value, .et-gas__top-rank, .et-gas__top-price-value,
.et-gas__top-title, .et-gas__top-brand, .et-gas__map-title {
    font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif !important;
}
code, pre, kbd, samp, tt,
.dai-mono, .et-pcv2__input--mono, .et-mono {
    font-family: 'JetBrains Mono', 'SF Mono', Menlo, Consolas, monospace !important;
}
