/* ============================================================
   InfoELA · sistema de diseño compartido
   HTML/CSS/JS vanilla · Dirección A2 (portada editorial) + B2 (tipografía)
   Usado por: home + todas las páginas internas y plantillas
   ============================================================ */
:root{
  --ink:#102530; --ink-soft:#43555E; --muted:#7A8A91; --faint:#A9B5BA;
  --petrol:#012C3F; --petrol-2:#0A3A4F; --teal:#1CA5B8; --teal-ink:#0E6171;
  --coral:#FA4D55; --coral-ink:#C0343C; --ice:#D6E9F0;
  --paper:#FFFFFF; --cool:#F5F8F9; --cool2:#EEF3F5;
  --line:#E4EAEC; --line-strong:#CBD6DA;
  --serif:'Newsreader',Georgia,'Times New Roman',serif;
  --sans:'Source Sans 3',system-ui,-apple-system,sans-serif;
  --wrap:1180px; --wrap-narrow:760px; --head-h:68px;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;scroll-padding-top:118px;-webkit-text-size-adjust:100%}
body{font-family:var(--sans);font-size:17px;line-height:1.62;color:var(--ink);background:var(--paper);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
ul{list-style:none}
button{font-family:inherit;cursor:pointer;border:none;background:none}
code{font-family:ui-monospace,Menlo,monospace;font-size:.9em;background:rgba(16,37,48,.06);padding:1px 5px;border-radius:3px}
.wrap{max-width:var(--wrap);margin:0 auto;padding:0 32px}
.wrap-narrow{max-width:var(--wrap-narrow);margin:0 auto;padding:0 32px}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}

/* ---------- primitivas tipográficas ---------- */
.kicker{font:700 .72rem/1 var(--sans);letter-spacing:.15em;text-transform:uppercase;color:var(--teal-ink);display:inline-flex;align-items:center;gap:9px;white-space:nowrap}
.kicker::before{content:"";width:20px;height:2px;background:currentColor;opacity:.9}
.kicker.bare::before{display:none}
.kicker.on-dark{color:#7FD3E0}
.serif{font-family:var(--serif)}
.lede{color:var(--ink-soft);line-height:1.6}
.meta{font:600 .8rem/1 var(--sans);letter-spacing:.02em;color:var(--muted);display:inline-flex;align-items:center;gap:9px;white-space:nowrap}
.meta time{font-variant-numeric:tabular-nums}
.meta .dot{width:3px;height:3px;border-radius:50%;background:var(--faint)}

/* badge por categoría (par tonal) */
.badge{display:inline-flex;align-items:center;gap:6px;font:700 .67rem/1 var(--sans);letter-spacing:.08em;text-transform:uppercase;color:var(--catink,var(--teal-ink));padding:5px 10px;background:var(--tint,var(--cool));border-radius:2px;white-space:nowrap}
.badge::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--catdot,var(--teal))}
.badge.bare{background:none;padding:0}
.cat-inv{--tint:#E9F3F7;--tint2:#DCEDF3;--catink:#0E5366;--catdot:#1C85A8}
.cat-cui{--tint:#E1F3F3;--tint2:#D2EDEC;--catink:#0E6171;--catdot:#1CA5B8}
.cat-rec{--tint:#FCECEC;--tint2:#FAE0E1;--catink:#C0343C;--catdot:#FA4D55}
.cat-nov{--tint:#EAEFF1;--tint2:#DFE7EA;--catink:#1C3A47;--catdot:#3D5A66}
.cat-tra{--tint:#E7EEF4;--tint2:#DAE6EF;--catink:#16455F;--catdot:#2A6E8C}
.cat-tec{--tint:#E8EFF0;--tint2:#DCE7E9;--catink:#234A56;--catdot:#3E707C}
.cat-pac{--tint:#EAF1F2;--tint2:#DEE9EB;--catink:#1B4A52;--catdot:#2E8390}
.cat-pro{--tint:#E7EEF1;--tint2:#DAE6EA;--catink:#274B58;--catdot:#41707E}
.cat-org{--tint:#EDEEEA;--tint2:#E2E5DE;--catink:#3D4A36;--catdot:#6B7A5C}

/* link "leer" */
.read{display:inline-flex;align-items:center;gap:6px;font:700 .85rem/1 var(--sans);color:var(--teal-ink);white-space:nowrap}
.read::after{content:"→";transition:transform .15s}
.read:hover::after{transform:translateX(3px)}
.read.on-dark{color:#9BDCE7}

/* botones */
.btn{display:inline-flex;align-items:center;gap:8px;font:700 .9rem/1 var(--sans);padding:13px 22px;border-radius:3px;background:var(--petrol);color:#fff;transition:background .18s,transform .1s}
.btn:hover{background:var(--petrol-2);transform:translateY(-1px)}
.btn.teal{background:var(--teal)} .btn.teal:hover{background:var(--teal-ink)}
.btn.ghost{background:transparent;color:var(--petrol);box-shadow:inset 0 0 0 1.5px var(--line-strong)}
.btn.ghost:hover{background:var(--cool);transform:none}
.btn.on-dark{background:#fff;color:var(--petrol)} .btn.on-dark:hover{background:var(--ice)}
.btn.on-dark.ghost{background:transparent;color:#fff;box-shadow:inset 0 0 0 1.5px rgba(255,255,255,.32)}
.btn.sm{padding:9px 16px;font-size:.82rem}

/* ---------- media: sistema imagen-opcional ---------- */
.media{position:relative;overflow:hidden;border-radius:4px}
.media.photo{background:repeating-linear-gradient(135deg,rgba(16,37,48,.045) 0 11px,rgba(16,37,48,.075) 11px 22px);display:flex;align-items:flex-end}
.media.photo .tag{font:600 .62rem/1 ui-monospace,Menlo,monospace;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);background:rgba(255,255,255,.8);padding:5px 8px;margin:10px;border-radius:2px}
.media.nophoto{background:linear-gradient(150deg,var(--tint,var(--cool)) 0%,var(--tint2,var(--cool2)) 100%);display:flex;flex-direction:column;justify-content:space-between;padding:18px;color:var(--catink,var(--teal-ink))}
.media.nophoto .topcat{font:700 .7rem/1 var(--sans);letter-spacing:.14em;text-transform:uppercase}
.media.nophoto .glyph{font-family:var(--serif);font-weight:600;font-size:5rem;line-height:.8;opacity:.24;align-self:flex-end;margin-top:auto}
.media.nophoto.lines::after{content:"";position:absolute;inset:0;background-image:repeating-linear-gradient(0deg,color-mix(in oklab,var(--catink) 12%,transparent) 0 1px,transparent 1px 13px);opacity:.5;pointer-events:none}

/* ============================================================
   TOP-BAR  (utilidad institucional, no sticky)
   ============================================================ */
.topbar{background:#00131E;color:rgba(255,255,255,.62);font:600 .78rem/1 var(--sans)}
.topbar-in{display:flex;align-items:center;justify-content:space-between;gap:16px;height:38px}
.topbar .tagline{letter-spacing:.02em;color:rgba(255,255,255,.5)}
.topbar nav ul{display:flex;align-items:center;gap:22px}
.topbar nav a{color:rgba(255,255,255,.66);transition:color .15s;white-space:nowrap}
.topbar nav a:hover{color:#fff}

/* ============================================================
   HEADER  (sticky)
   ============================================================ */
.site-header{position:sticky;top:0;z-index:60;background:rgba(255,255,255,.94);backdrop-filter:blur(8px);border-bottom:1px solid var(--line);transition:box-shadow .2s}
.site-header.scrolled{box-shadow:0 2px 14px rgba(16,37,48,.07)}
.header-in{display:flex;align-items:center;gap:24px;height:var(--head-h)}
.logo img{height:30px;width:auto}
.main-nav{flex:1;display:flex}
.main-nav ul{display:flex;gap:2px}
.main-nav a{font:600 .87rem/1 var(--sans);color:var(--ink-soft);padding:8px 10px;border-radius:5px;transition:color .15s,background .15s;white-space:nowrap}
.main-nav a:hover{color:var(--teal-ink);background:var(--cool)}
.main-nav a.active{color:var(--teal-ink)}
.header-actions{display:flex;align-items:center;gap:12px}
.search{display:flex;align-items:center;gap:8px;height:38px;padding:0 14px;background:var(--cool);border:1px solid var(--line);border-radius:100px;transition:border-color .18s}
.search:focus-within{border-color:var(--teal)}
.search svg{color:var(--muted);flex-shrink:0}
.search input{border:none;background:none;outline:none;font:400 .9rem/1 var(--sans);color:var(--ink);width:108px}
.menu-btn{display:none;flex-direction:column;gap:5px;padding:8px}
.menu-btn span{width:22px;height:2px;background:var(--ink);border-radius:2px;transition:.2s}
.mobile-menu{display:none;border-top:1px solid var(--line);background:#fff}
.mobile-menu.open{display:block}
.mobile-menu ul{padding:8px 0}
.mobile-menu a{display:block;padding:12px 32px;font-weight:600;color:var(--ink-soft)}
.mobile-menu a:hover{background:var(--cool);color:var(--teal-ink)}
.mobile-menu .group{padding:14px 32px 6px;font:700 .68rem/1 var(--sans);letter-spacing:.12em;text-transform:uppercase;color:var(--faint)}

/* ============================================================
   SECCIONES genéricas
   ============================================================ */
.section{padding:78px 0}
.section.cool{background:var(--cool)}
.section.tight{padding:56px 0}
.sec-head{display:flex;align-items:flex-end;justify-content:space-between;gap:24px;margin-bottom:44px}
.sec-head .ht{max-width:46em}
.sec-head h2{font-family:var(--serif);font-weight:560;font-size:clamp(1.6rem,2.4vw,2.05rem);line-height:1.1;letter-spacing:-.01em;margin-top:12px}
.sec-head p{color:var(--ink-soft);font-size:1.02rem;margin-top:12px}
.sec-head .read{flex-shrink:0;padding-bottom:6px}

/* ============================================================
   MASTHEAD de página interna (encabezado editorial)
   ============================================================ */
.page-masthead{border-bottom:1px solid var(--line)}
.page-masthead.cool{background:var(--cool)}
.masthead-top{display:flex;align-items:center;justify-content:space-between;gap:20px;padding:20px 0 16px;border-bottom:2px solid var(--ink)}
.crumb{display:flex;align-items:center;gap:9px;font:600 .78rem/1 var(--sans);color:var(--muted);flex-wrap:wrap}
.crumb a{transition:color .15s}
.crumb a:hover{color:var(--teal-ink)}
.crumb .sep{color:var(--faint)}
.crumb .cur{color:var(--ink)}
.masthead-date{font:600 .78rem/1 var(--sans);letter-spacing:.05em;text-transform:uppercase;color:var(--muted);white-space:nowrap}
.masthead-body{display:grid;grid-template-columns:1.55fr 1fr;gap:56px;align-items:end;padding:42px 0 46px}
.masthead-body.solo{grid-template-columns:1fr;max-width:50em}
.masthead-body h1{font-family:var(--serif);font-weight:500;font-size:clamp(2rem,3.3vw,2.95rem);line-height:1.05;letter-spacing:-.018em;margin-bottom:18px;text-wrap:balance}
.masthead-body h1 em{font-style:italic}
.masthead-body .lede{font-size:1.14rem;max-width:30em}
.masthead-aside{padding-bottom:6px}
.masthead-aside p{color:var(--ink-soft);font-size:.98rem;line-height:1.6}
.masthead-aside p+p{margin-top:12px}

/* ============================================================
   GRID de cards de entrada (listados dinámicos)
   ============================================================ */
.post-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:30px 28px}
.post-grid.two{grid-template-columns:repeat(2,1fr)}
.post-card{display:flex;flex-direction:column;gap:14px;background:var(--paper);border:1px solid var(--line);border-radius:8px;overflow:hidden;transition:box-shadow .2s,transform .2s,border-color .2s}
.post-card:hover{box-shadow:0 12px 32px rgba(16,37,48,.08);transform:translateY(-2px);border-color:transparent}
.post-card .media{height:172px;border-radius:0}
.post-card .pc-body{display:flex;flex-direction:column;gap:11px;padding:6px 24px 26px}
.post-card h3{font-family:var(--serif);font-weight:560;font-size:1.28rem;line-height:1.2}
.post-card h3 a{transition:color .15s}
.post-card:hover h3 a{color:var(--teal-ink)}
.post-card p{color:var(--ink-soft);font-size:.95rem;line-height:1.5;flex:1}
.post-card .pc-foot{display:flex;align-items:center;justify-content:space-between;gap:12px;padding-top:4px}

/* ---------- Últimas novedades · lista numerada B2 ---------- */
.news-list{display:grid}
.news-item{display:grid;grid-template-columns:120px 1fr auto;gap:32px;align-items:start;padding:30px 0;border-top:1px solid var(--line-strong)}
.news-item:first-child{border-top:none;padding-top:0}
.news-item:last-child{border-bottom:1px solid var(--line-strong)}
.news-item .num{font-family:var(--serif);font-weight:400;font-size:4.4rem;line-height:.78;color:var(--catink);letter-spacing:-.02em;font-variant-numeric:lining-nums}
.news-item .c{display:grid;gap:11px;max-width:46em}
.news-item h3{font-family:var(--serif);font-weight:560;font-size:1.5rem;line-height:1.16}
.news-item.lead h3{font-size:2rem}
.news-item h3 a{transition:color .15s}
.news-item h3 a:hover{color:var(--teal-ink)}
.news-item .c p{color:var(--ink-soft);font-size:.98rem;line-height:1.55}
.news-item .side{display:grid;gap:12px;justify-items:end;text-align:right;min-width:140px}

/* ---------- cards de recurso / tema (ícono) ---------- */
.res-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}
.res-grid.three{grid-template-columns:repeat(3,1fr)}
.res-card{display:flex;flex-direction:column;gap:14px;background:var(--paper);border:1px solid var(--line);border-radius:8px;padding:26px 24px;transition:box-shadow .2s,transform .2s,border-color .2s}
.res-card:hover{box-shadow:0 10px 30px rgba(16,37,48,.08);transform:translateY(-2px);border-color:transparent}
.res-ico{width:46px;height:46px;border-radius:9px;display:grid;place-items:center;background:var(--tint);color:var(--catink)}
.res-ico svg{width:23px;height:23px}
.res-card h3{font-family:var(--serif);font-weight:600;font-size:1.16rem;line-height:1.25}
.res-card p{color:var(--ink-soft);font-size:.93rem;line-height:1.5;flex:1}

/* ---------- índice tipográfico por tema ---------- */
.topic-index{display:grid;grid-template-columns:1fr 1fr;column-gap:56px}
.topic-row{display:flex;align-items:center;gap:20px;padding:22px 4px;border-top:1px solid var(--line-strong);transition:padding .18s}
.topic-row:hover{padding-left:12px}
.topic-row .tn{font-family:var(--serif);font-size:1rem;color:var(--faint);font-variant-numeric:tabular-nums;width:30px;flex-shrink:0}
.topic-row .tt{flex:1}
.topic-row h3{font-family:var(--serif);font-weight:500;font-size:1.7rem;line-height:1.1;letter-spacing:-.01em;transition:color .15s}
.topic-row:hover h3{color:var(--teal-ink)}
.topic-row p{color:var(--muted);font-size:.9rem;margin-top:3px}
.topic-row .arr{color:var(--line-strong);font-size:1.3rem;transition:color .15s,transform .18s}
.topic-row:hover .arr{color:var(--teal);transform:translateX(4px)}

/* ---------- bloque por categoría (cards numeradas) ---------- */
.catrow{padding-top:8px}
.catrow+.catrow{margin-top:56px;padding-top:56px;border-top:1px solid var(--line)}
.cat-head{display:flex;align-items:baseline;justify-content:space-between;gap:20px;margin-bottom:28px}
.cat-head h2{font-family:var(--serif);font-weight:560;font-size:1.55rem}
.cat-grid{display:grid;grid-template-columns:1fr 1fr;gap:28px}
.cat-card{display:grid;grid-template-columns:auto 1fr;gap:22px;align-items:start;padding:26px;border:1px solid var(--line);border-radius:8px;background:var(--paper);transition:box-shadow .2s,border-color .2s}
.cat-card:hover{box-shadow:0 10px 30px rgba(16,37,48,.07);border-color:transparent}
.cat-card .num{font-family:var(--serif);font-weight:600;font-size:2.6rem;line-height:.8;color:var(--catink);opacity:.85;min-width:36px}
.cat-card .c{display:grid;gap:10px}
.cat-card h3{font-family:var(--serif);font-weight:560;font-size:1.25rem;line-height:1.22}
.cat-card h3 a:hover{color:var(--teal-ink)}
.cat-card p{color:var(--ink-soft);font-size:.94rem;line-height:1.5}

/* ---------- guía editorial (card con número + flecha) ---------- */
.guide-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.guide-card{position:relative;display:flex;flex-direction:column;gap:12px;padding:30px 26px;border:1px solid var(--line);border-radius:8px;background:var(--paper);transition:box-shadow .2s,transform .2s,border-color .2s}
.guide-card:hover{box-shadow:0 12px 32px rgba(16,37,48,.08);transform:translateY(-2px);border-color:transparent}
.guide-card .gnum{font-family:var(--serif);font-weight:500;font-size:1rem;color:var(--catink);font-variant-numeric:tabular-nums}
.guide-card h3{font-family:var(--serif);font-weight:600;font-size:1.32rem;line-height:1.2}
.guide-card p{color:var(--ink-soft);font-size:.95rem;line-height:1.55;flex:1}
.guide-card .read{margin-top:4px}

/* ---------- chips / filtros ---------- */
.chips{display:flex;flex-wrap:wrap;gap:10px}
.chip{display:inline-flex;align-items:center;gap:7px;font:600 .85rem/1 var(--sans);color:var(--ink-soft);padding:9px 15px;border:1px solid var(--line-strong);border-radius:100px;background:var(--paper);transition:color .15s,border-color .15s,background .15s}
.chip:hover{border-color:var(--teal);color:var(--teal-ink)}
.chip.active{background:var(--petrol);color:#fff;border-color:var(--petrol)}
.chip .count{font-size:.78rem;opacity:.6}

/* ---------- toolbar de listado (filtros + buscador) ---------- */
.list-toolbar{display:flex;align-items:center;justify-content:space-between;gap:24px;flex-wrap:wrap;margin-bottom:40px}
.inline-search{display:flex;align-items:center;gap:10px;height:46px;padding:0 18px;background:var(--paper);border:1px solid var(--line-strong);border-radius:100px;min-width:300px;transition:border-color .18s}
.inline-search:focus-within{border-color:var(--teal)}
.inline-search svg{color:var(--muted);flex-shrink:0}
.inline-search input{flex:1;border:none;background:none;outline:none;font:400 .95rem/1 var(--sans);color:var(--ink)}

/* ---------- paginación ---------- */
.pager{display:flex;align-items:center;justify-content:center;gap:8px;margin-top:54px}
.pager a,.pager span{display:inline-flex;align-items:center;justify-content:center;min-width:42px;height:42px;padding:0 14px;font:600 .9rem/1 var(--sans);color:var(--ink-soft);border:1px solid var(--line);border-radius:6px;background:var(--paper);transition:.15s}
.pager a:hover{border-color:var(--teal);color:var(--teal-ink)}
.pager .cur{background:var(--petrol);color:#fff;border-color:var(--petrol)}
.pager .ends{font-weight:700}
.pager .gap{border:none;background:none;min-width:24px}

/* ---------- estado vacío ---------- */
.empty{text-align:center;max-width:40em;margin:0 auto;padding:60px 0}
.empty .ico{width:54px;height:54px;border-radius:50%;background:var(--cool);display:grid;place-items:center;margin:0 auto 20px;color:var(--muted)}
.empty h3{font-family:var(--serif);font-weight:560;font-size:1.4rem;margin-bottom:10px}
.empty p{color:var(--ink-soft);font-size:1rem}

/* ============================================================
   BLOQUES institucionales reutilizables
   ============================================================ */
/* banda petróleo (qué es / mirada) */
.about{background:radial-gradient(120% 130% at 92% -10%,rgba(28,165,184,.18) 0%,transparent 48%),var(--petrol);color:#fff;padding:84px 0}
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center}
.about h2{font-family:var(--serif);font-weight:500;font-size:1.9rem;margin:14px 0 18px;color:#fff}
.about p{color:rgba(255,255,255,.74);font-size:1.04rem;line-height:1.7;margin-bottom:16px;max-width:34em}
.about .btn{margin-top:10px}
.about-quote{border-left:3px solid var(--teal);padding:6px 0 6px 30px}
.about-quote q{quotes:none;display:block;font-family:var(--serif);font-style:italic;font-weight:400;font-size:1.85rem;line-height:1.34;color:#EAF6F8}
.about-quote .by{margin-top:18px;font:600 .82rem/1 var(--sans);letter-spacing:.04em;color:#7FD3E0}

/* statement · banda petróleo centrada */
.statement{background:radial-gradient(120% 130% at 50% -20%,rgba(28,165,184,.16) 0%,transparent 52%),var(--petrol);color:#fff;padding:84px 0}
.statement .in{max-width:740px;margin:0 auto;text-align:center}
.statement .kicker{justify-content:center;margin-bottom:18px}
.statement h2{font-family:var(--serif);font-weight:500;font-size:clamp(1.7rem,2.6vw,2.25rem);line-height:1.18;color:#fff;letter-spacing:-.01em;margin-bottom:18px;text-wrap:balance}
.statement p{color:rgba(255,255,255,.76);font-size:1.08rem;line-height:1.7;max-width:60ch;margin:0 auto 14px}
.statement .btn{margin-top:14px}

/* aviso importante · coral */
.notice{background:linear-gradient(180deg,#FFF2F2,#FCEAEB);border-top:3px solid var(--coral);padding:56px 0}
.notice-in{display:grid;grid-template-columns:auto 1fr;gap:26px;align-items:start;max-width:920px}
.notice-ico{width:50px;height:50px;border-radius:50%;background:#fff;border:1.5px solid #F4B9BC;display:grid;place-items:center;color:var(--coral);flex-shrink:0}
.notice h2{font-family:var(--serif);font-weight:600;font-size:1.35rem;color:#8A1119;margin-bottom:12px;line-height:1.22}
.notice p{color:#8A1119;opacity:.86;font-size:.98rem;line-height:1.6;margin-bottom:8px;max-width:54em}
.notice .read{color:#8A1119;margin-top:6px}.notice .read:hover{color:var(--coral)}

/* callout médico compacto (en línea) */
.med-callout{display:grid;grid-template-columns:auto 1fr;gap:18px;align-items:start;padding:24px 26px;background:#FFF4F4;border:1px solid #F6CDCF;border-left:3px solid var(--coral);border-radius:8px}
.med-callout .mc-ico{width:36px;height:36px;border-radius:50%;background:#fff;border:1.5px solid #F4B9BC;display:grid;place-items:center;color:var(--coral);flex-shrink:0}
.med-callout p{color:#8A1119;font-size:.94rem;line-height:1.58;margin:0}
.med-callout p strong{font-weight:700}
.med-callout a{color:var(--coral-ink);font-weight:700;text-decoration:underline;text-underline-offset:2px}

/* newsletter */
.news-cta{background:var(--petrol);padding:78px 0;text-align:center}
.news-cta .in{max-width:560px;margin:0 auto}
.news-cta h2{font-family:var(--serif);font-weight:500;font-size:1.9rem;color:#fff;margin-bottom:12px}
.news-cta p{color:rgba(255,255,255,.72);font-size:1.04rem;margin-bottom:28px}
.nl-form{display:flex;gap:10px;max-width:480px;margin:0 auto}
.nl-form input{flex:1;padding:14px 18px;border:1.5px solid rgba(255,255,255,.22);border-radius:4px;background:rgba(255,255,255,.06);color:#fff;font:400 1rem/1 var(--sans);outline:none}
.nl-form input::placeholder{color:rgba(255,255,255,.5)}
.nl-form input:focus{border-color:var(--teal)}
.nl-note{margin-top:14px;font-size:.82rem;color:rgba(255,255,255,.45)}

/* ============================================================
   PROSA (páginas legales / cuerpo de entrada)
   ============================================================ */
.prose{font-size:1.06rem;line-height:1.72;color:var(--ink-soft)}
.prose>*+*{margin-top:1.1em}
.prose h2{font-family:var(--serif);font-weight:560;font-size:1.55rem;line-height:1.2;color:var(--ink);margin-top:2em;letter-spacing:-.01em}
.prose h2:first-child{margin-top:0}
.prose h3{font-family:var(--serif);font-weight:600;font-size:1.22rem;color:var(--ink);margin-top:1.6em}
.prose p{text-wrap:pretty}
.prose a{color:var(--teal-ink);font-weight:600;text-decoration:underline;text-underline-offset:2px;text-decoration-color:var(--line-strong)}
.prose a:hover{text-decoration-color:var(--teal)}
.prose strong{color:var(--ink);font-weight:700}
.prose ul.bullets{padding-left:0;display:grid;gap:11px}
.prose ul.bullets li{position:relative;padding-left:26px;color:var(--ink-soft)}
.prose ul.bullets li::before{content:"";position:absolute;left:4px;top:11px;width:7px;height:7px;border-radius:50%;background:var(--teal)}
.prose blockquote{border-left:3px solid var(--teal);padding:4px 0 4px 26px;margin:1.4em 0;font-family:var(--serif);font-style:italic;font-size:1.3rem;line-height:1.4;color:var(--ink)}

/* índice lateral (legales largos) */
.split{display:grid;grid-template-columns:1.45fr 1fr;gap:56px;align-items:start}
@media(max-width:980px){.split{grid-template-columns:1fr;gap:36px}}
.doc-grid{display:grid;grid-template-columns:240px 1fr;gap:64px;align-items:start}
.doc-toc{position:sticky;top:120px}
.doc-toc .lbl{font:700 .7rem/1 var(--sans);letter-spacing:.13em;text-transform:uppercase;color:var(--faint);margin-bottom:16px}
.doc-toc ul{display:grid;gap:2px}
.doc-toc a{display:block;padding:8px 12px;font-size:.9rem;color:var(--ink-soft);border-left:2px solid var(--line);border-radius:0 4px 4px 0;transition:.15s}
.doc-toc a:hover{color:var(--teal-ink);background:var(--cool);border-color:var(--teal)}
.doc-toc a.active{color:var(--teal-ink);border-color:var(--teal);font-weight:600}

/* ============================================================
   ARTÍCULO (entrada individual)
   ============================================================ */
.article-head{padding:42px 0 36px;border-bottom:1px solid var(--line)}
.article-head .badge{margin-bottom:18px}
.article-head h1{font-family:var(--serif);font-weight:500;font-size:clamp(2rem,3.4vw,2.85rem);line-height:1.08;letter-spacing:-.018em;margin-bottom:18px;text-wrap:balance}
.article-head .lede{font-size:1.2rem;color:var(--ink-soft);max-width:38em;margin-bottom:24px}
.article-meta{display:flex;align-items:center;gap:14px;flex-wrap:wrap;font:600 .85rem/1 var(--sans);color:var(--muted)}
.article-meta .dot{width:3px;height:3px;border-radius:50%;background:var(--faint)}
.article-figure{margin:36px 0}
.article-figure .media{height:380px}
.article-figure figcaption{margin-top:10px;font:600 .8rem/1.4 var(--sans);color:var(--muted)}
.article-body{padding:40px 0}

/* ---------- formularios ---------- */
.form{display:grid;gap:22px}
.form-row{display:grid;gap:8px}
.form-row label{font:600 .88rem/1 var(--sans);color:var(--ink)}
.form-row .req{color:var(--coral-ink)}
.form-row input,.form-row select,.form-row textarea{width:100%;padding:13px 16px;border:1.5px solid var(--line-strong);border-radius:6px;background:var(--paper);font:400 1rem/1.4 var(--sans);color:var(--ink);outline:none;transition:border-color .18s}
.form-row textarea{min-height:148px;resize:vertical;line-height:1.6}
.form-row input:focus,.form-row select:focus,.form-row textarea:focus{border-color:var(--teal)}
.form-row select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%237A8A91' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 16px center;padding-right:42px}
/* El captcha matemático es type=number: ocultar las flechas del spinner para que el campo quede idéntico al de email (con el que ya comparte .form-row input) */
.math-captcha-input{-moz-appearance:textfield;appearance:textfield}
.math-captcha-input::-webkit-outer-spin-button,.math-captcha-input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}
/* Captcha del newsletter (barra oscura): se inyecta fuera del .nl-form, así que
   replicamos aquí el mismo estilo que el campo de email (.nl-form input). El wrap
   tiene el mismo ancho/centrado que el .nl-form; la pregunta (mc-q) crece como
   relleno flexible y el .mc-spacer (ancho = botón, fijado por JS) deja el borde
   derecho del input alineado con el del campo de email. */
.math-captcha-nl{display:flex;align-items:center;gap:10px;max-width:480px;margin:10px auto 0}
.math-captcha-nl .mc-q{flex:1;text-align:right;color:#fff;font-size:.875rem;white-space:nowrap}
.math-captcha-nl .mc-spacer{flex:0 0 auto}
.math-captcha-nl .math-captcha-input{flex:0 0 auto;width:130px;padding:14px 18px;border:1.5px solid rgba(255,255,255,.22);border-radius:4px;background:rgba(255,255,255,.06);color:#fff;font:400 1rem/1 var(--sans);outline:none}
.math-captcha-nl .math-captcha-input::placeholder{color:rgba(255,255,255,.5)}
.math-captcha-nl .math-captcha-input:focus{border-color:var(--teal)}
@media(max-width:620px){.math-captcha-nl{flex-wrap:wrap;justify-content:center}.math-captcha-nl .mc-q{flex:0 0 auto;text-align:center}.math-captcha-nl .mc-spacer{display:none}}
.check-row{display:flex;align-items:flex-start;gap:12px}
.check-row input{width:19px;height:19px;margin-top:2px;accent-color:var(--teal);flex-shrink:0}
.check-row label{font-size:.94rem;color:var(--ink-soft);font-weight:400;line-height:1.5}
.form-note{font-size:.88rem;color:var(--muted);line-height:1.55}
.form-msg{display:none;padding:16px 18px;border-radius:8px;font-size:.95rem;line-height:1.5}
.form-msg.ok{display:block;background:#E8F5F0;border:1px solid #B8DECB;color:#16654A}
.form-msg.err{display:block;background:#FCECEC;border:1px solid #F4C4C7;color:#8A1119}

/* ---------- caja de contacto/aside ---------- */
.aside-card{padding:28px;border:1px solid var(--line);border-radius:10px;background:var(--cool)}
.aside-card h3{font-family:var(--serif);font-weight:560;font-size:1.2rem;margin-bottom:12px}
.aside-card p{color:var(--ink-soft);font-size:.95rem;line-height:1.6;margin-bottom:10px}
.aside-card .reasons{display:grid;gap:12px;margin-top:4px}
.aside-card .reason{display:grid;grid-template-columns:auto 1fr;gap:12px;align-items:start;font-size:.95rem;color:var(--ink-soft);line-height:1.45}
.aside-card .reason .b{width:7px;height:7px;border-radius:50%;background:var(--teal);margin-top:8px}

/* ---------- audiencia (sobre info ela) ---------- */
.aud-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:22px}
.aud-card{padding:28px;border:1px solid var(--line);border-radius:10px;background:var(--paper)}
.aud-card .ac-ico{width:42px;height:42px;border-radius:9px;background:var(--tint,var(--cool));color:var(--catink,var(--teal-ink));display:grid;place-items:center;margin-bottom:16px}
.aud-card h3{font-family:var(--serif);font-weight:600;font-size:1.18rem;margin-bottom:8px}
.aud-card p{color:var(--ink-soft);font-size:.95rem;line-height:1.55}

/* ---------- resultados de búsqueda ---------- */
.result-list{display:grid}
.result-item{display:grid;gap:9px;padding:28px 0;border-top:1px solid var(--line)}
.result-item:first-child{border-top:none}
.result-top{display:flex;align-items:center;gap:12px;flex-wrap:wrap}
.type-tag{font:700 .64rem/1 var(--sans);letter-spacing:.1em;text-transform:uppercase;color:var(--muted);padding:4px 9px;border:1px solid var(--line-strong);border-radius:3px}
.result-item h3{font-family:var(--serif);font-weight:560;font-size:1.42rem;line-height:1.18}
.result-item h3 a:hover{color:var(--teal-ink)}
.result-item p{color:var(--ink-soft);font-size:.98rem;line-height:1.55;max-width:54em}
.result-item .r-foot{display:flex;align-items:center;gap:14px;flex-wrap:wrap;margin-top:2px}
mark{background:rgba(28,165,184,.2);color:inherit;padding:0 2px;border-radius:2px}

/* ============================================================
   FOOTER
   ============================================================ */
.footer{background:#00131E;color:rgba(255,255,255,.58);padding:60px 0 30px}
.footer-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr;gap:48px;margin-bottom:44px}
.footer-brand img{height:30px;margin-bottom:16px}
.footer-brand p{font-size:.92rem;line-height:1.6;max-width:30em}
.footer-col h4{font:700 .72rem/1 var(--sans);letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.4);margin-bottom:16px}
.footer-col li{margin-bottom:9px}
.footer-col a{font-size:.92rem;color:rgba(255,255,255,.6);transition:color .15s}
.footer-col a:hover{color:#fff}
.footer-bottom{display:grid;grid-template-columns:1fr auto 1fr;grid-auto-flow:dense;align-items:center;gap:14px;padding-top:24px;border-top:1px solid rgba(255,255,255,.08);font-size:.82rem}
.footer-bottom .fl{display:flex;gap:20px;grid-column:3;justify-self:end}
.footer-bottom a:hover{color:#fff}
/* Crédito "Creado por Sitio Plus": en la misma línea que el copyright (izq.) y
   los enlaces legales (der.), centrado en el ancho real de la página.
   Hereda fuente/tamaño/color del .footer-bottom; el enlace usa el acento celeste */
.footer-credit{grid-column:2;margin:0;text-align:center}
.footer-credit a{color:var(--teal);font-weight:700;text-decoration:none}
.footer-credit a:hover{color:#fff}
@media(max-width:620px){.footer-bottom{grid-template-columns:1fr;justify-items:center;text-align:center}.footer-bottom .fl,.footer-credit{grid-column:auto;justify-self:center}}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media(max-width:1040px){
  .main-nav a{padding:8px 8px;font-size:.84rem}
  .header-in{gap:16px}
}
@media(max-width:980px){
  .topbar{display:none}
  .main-nav,.search{display:none}
  .menu-btn{display:flex}
  .masthead-body{grid-template-columns:1fr;gap:26px}
  .about-grid{grid-template-columns:1fr;gap:36px}
  .res-grid,.res-grid.three{grid-template-columns:1fr 1fr}
  .post-grid{grid-template-columns:1fr 1fr}
  .guide-grid{grid-template-columns:1fr 1fr}
  .topic-index{grid-template-columns:1fr}
  .cat-grid{grid-template-columns:1fr}
  .doc-grid{grid-template-columns:1fr;gap:36px}
  .doc-toc{display:none}
  .aud-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:620px){
  body{font-size:16px}
  .wrap,.wrap-narrow{padding:0 20px}
  .section{padding:54px 0}
  .news-item{grid-template-columns:1fr;gap:14px;padding:24px 0}
  .news-item .num{font-size:3rem}
  .news-item.lead h3,.news-item h3{font-size:1.4rem}
  .news-item .side{justify-items:start;text-align:left;min-width:0}
  .post-grid,.post-grid.two,.res-grid,.res-grid.three,.guide-grid,.cat-grid,.aud-grid{grid-template-columns:1fr}
  .notice-in,.med-callout{grid-template-columns:1fr}
  .notice-ico{display:none}
  .nl-form{flex-direction:column}
  .footer-grid{grid-template-columns:1fr;gap:30px}
  .sec-head{flex-direction:column;align-items:flex-start}
  .list-toolbar{flex-direction:column;align-items:stretch}
  .inline-search{min-width:0}
  .masthead-body h1{font-size:2rem}
  .article-figure .media{height:230px}
}
