/*
Theme Name: Solimplax
Theme URI: https://solimplax.es
Author: Grupo DeKeVa
Author URI: https://grupodekeva.es
Description: Tema a medida para Solimplax — limpieza y mantenimiento profesional de placas solares en Jaen. Identidad amarillo solar + azul marino, Poppins. Diseno DeKeVa.
Version: 1.4.1
License: GNU General Public License v2 or later
Text Domain: solimplax
*/

:root{
  --bg:#FFFFFF; --bg-soft:#F6F7FB; --bg-dark:#2C3B7A; --bg-deep:#1E2A5C;
  --ink:#1A2147; --ink-soft:#5A6492; --ink-mute:#9CA3C2; --ink-on-dark:#FFFFFF;
  --accent:#F4B82F; --accent-dark:#DBA01E; --accent-soft:#FCEAB3;
  --hairline:rgba(26,33,71,0.08);
  --hairline-on-dark:rgba(255,255,255,0.14);
  --shadow-card:0 1px 2px rgba(26,33,71,0.04), 0 12px 32px -8px rgba(26,33,71,0.08);
  --shadow-card-hover:0 4px 8px rgba(26,33,71,0.06), 0 20px 48px -12px rgba(26,33,71,0.16);
  --r-pill:999px; --r-card:14px; --r-md:8px;
  --ease:cubic-bezier(0.22, 1, 0.36, 1);
}
*{box-sizing:border-box; margin:0; padding:0}
html{scroll-behavior:smooth}
body{
  font-family:'Poppins', system-ui, sans-serif;
  background:var(--bg); color:var(--ink);
  font-size:16px; line-height:1.55;
  -webkit-font-smoothing:antialiased; -moz-osx-font-smoothing:grayscale;
  overflow-x:hidden;
}
img{max-width:100%; display:block}
a{color:inherit; text-decoration:none}
.wrap{max-width:1320px; margin:0 auto; padding:0 32px}
.eyebrow{font-size:12px; font-weight:600; text-transform:uppercase; letter-spacing:0.22em; color:var(--ink-soft)}
.eyebrow--accent{color:var(--accent-dark)}
.eyebrow--on-dark{color:var(--accent)}

/* ============================ HEADER ============================ */
.header{
  position:sticky; top:0; z-index:50;
  background:var(--bg);
  border-bottom:1px solid var(--hairline);
  height:96px;
  display:flex; align-items:center;
}
.header-inner{display:flex; align-items:center; justify-content:space-between; gap:32px; width:100%}
.brand{display:flex; flex-direction:column; align-items:flex-start; line-height:1; gap:2px}
.brand-mark{
  font-weight:800; font-size:34px; letter-spacing:-0.02em;
  color:var(--accent); position:relative;
}
.brand-mark .b-mid{color:var(--bg-dark)}
.brand-mark .b-trail{color:var(--accent)}
.brand-sub{
  font-size:9px; font-weight:600; letter-spacing:0.24em; color:var(--bg-dark);
  text-transform:uppercase; margin-top:2px;
}
.nav{display:flex; align-items:center; gap:48px}
.nav-item{
  display:flex; flex-direction:column; align-items:center; gap:6px;
  font-size:14px; font-weight:600; letter-spacing:0.06em;
  color:var(--ink); cursor:pointer; padding:8px 4px;
  text-transform:uppercase;
  position:relative; transition:color .2s var(--ease);
}
.nav-item .nav-icon{width:34px; height:34px; display:flex; align-items:center; justify-content:center}
.nav-item .nav-label{font-size:12px; letter-spacing:0.12em}
.nav-item.is-active{color:var(--bg-dark)}
.nav-item.is-active::after{
  content:""; position:absolute; bottom:-2px; left:50%; transform:translateX(-50%);
  width:42px; height:3px; background:var(--accent); border-radius:2px;
}
.nav-item:hover{color:var(--bg-dark)}
/* INICIO: solo texto, sin icono — alineado con los labels de los demás */
.nav-item--text{justify-content:center; min-height:34px}
.nav-label--lg{font-size:15px; letter-spacing:0.08em; font-weight:700}
.nav-item--text.is-active::after{bottom:-8px; width:100%}

/* Hamburger button (solo visible en mobile) */
.hamburger{
  display:none; width:48px; height:48px;
  border:0; background:transparent; cursor:pointer;
  position:relative; z-index:60;
  padding:0; margin-left:auto;
}
.hamburger-bar{
  position:absolute; left:10px; right:10px; height:2.5px;
  background:var(--ink); border-radius:2px;
  transition:transform .3s var(--ease), opacity .2s var(--ease), top .3s var(--ease);
}
.hamburger-bar:nth-child(1){top:15px}
.hamburger-bar:nth-child(2){top:23px}
.hamburger-bar:nth-child(3){top:31px}
body.is-nav-open .hamburger-bar{background:var(--ink)}
body.is-nav-open .hamburger-bar:nth-child(1){top:23px; transform:rotate(45deg)}
body.is-nav-open .hamburger-bar:nth-child(2){opacity:0}
body.is-nav-open .hamburger-bar:nth-child(3){top:23px; transform:rotate(-45deg)}

/* Scrim del drawer */
.nav-scrim{
  display:none;
  position:fixed; inset:0; z-index:45;
  background:rgba(14,18,40,0.4);
  opacity:0; transition:opacity .35s var(--ease);
}
body.is-nav-open .nav-scrim{opacity:1}

/* CTA dentro del drawer (solo mobile, oculto en desktop) */
.nav-cta-mobile{display:none}
.cta{
  display:inline-flex; align-items:center; gap:10px;
  padding:14px 28px; border-radius:var(--r-pill);
  font-weight:700; font-size:13px; letter-spacing:0.1em;
  text-transform:uppercase;
  cursor:pointer; border:none; transition:all .25s var(--ease);
  font-family:inherit; white-space:nowrap;
}
.cta-primary{background:var(--accent); color:var(--ink)}
.cta-primary:hover{background:var(--accent-dark); transform:translateY(-1px); box-shadow:0 8px 24px -6px rgba(244,184,47,0.5)}
.cta-outline{background:transparent; color:var(--ink); border:1.5px solid var(--ink)}
.cta-outline:hover{background:var(--ink); color:#fff}
.cta-on-dark{background:var(--accent); color:var(--ink)}
.cta-ghost-on-dark{background:transparent; color:#fff; border:1.5px solid rgba(255,255,255,0.4)}
.cta-ghost-on-dark:hover{background:#fff; color:var(--ink); border-color:#fff}

/* ============================ HERO (home) ============================ */
.hero{
  position:relative;
  min-height:clamp(440px, 56vh, 600px);
  display:flex; align-items:stretch;
  color:#fff; overflow:hidden;
  padding:56px 0;
}
.hero-bg{
  position:absolute; inset:0;
  background-image:url('assets/img/banner_superior.webp');
  background-size:cover; background-position:center 45%;
  z-index:0;
}
.hero-overlay{
  position:absolute; inset:0; z-index:1;
  background:
    linear-gradient(to bottom, transparent 72%, rgba(44,59,122,0.85) 92%, #2C3B7A 100%),
    linear-gradient(100deg, rgba(34,42,88,0.42) 0%, rgba(48,56,108,0.18) 42%, transparent 60%);
}
.hero-inner{position:relative; z-index:2; width:100%; display:flex; flex-direction:column; justify-content:space-between; gap:40px}
.hero-grid{display:grid; grid-template-columns: 1fr; gap:32px}
.hero-title{
  font-weight:800; font-size:clamp(40px, 5.6vw, 76px); line-height:0.98;
  letter-spacing:-0.005em; text-transform:uppercase;
  max-width:1100px; margin-left:auto;
  text-shadow:0 2px 24px rgba(20,26,60,0.35);
}
.hero-title-line{display:block; text-align:right}
.hero-sub{
  font-weight:500; font-style:italic; font-size:clamp(19px, 1.9vw, 27px);
  text-align:right; margin-top:10px; color:#D7DCF2;
}
.hero-foot{
  display:grid; grid-template-columns: 1fr auto; gap:48px; align-items:center;
}
.hero-desc{font-size:clamp(17px, 1.4vw, 21px); font-weight:600; max-width:680px; text-shadow:0 2px 16px rgba(20,26,60,0.4)}

/* ============================ PAGE HERO (páginas internas) ============================ */
.page-hero{
  position:relative; overflow:hidden; color:#fff;
  padding:140px 0 72px; min-height:340px;
  display:flex; align-items:flex-end;
}
.page-hero-bg{
  position:absolute; inset:0; z-index:0;
  background-image:url('assets/img/banner_superior.webp');
  background-size:cover; background-position:center 40%;
}
.page-hero-overlay{
  position:absolute; inset:0; z-index:1;
  background:linear-gradient(95deg, rgba(30,42,92,0.92) 0%, rgba(44,59,122,0.7) 50%, rgba(120,90,70,0.35) 100%);
}
.page-hero-inner{position:relative; z-index:2; width:100%}
.breadcrumb{font-size:12px; font-weight:600; letter-spacing:0.18em; text-transform:uppercase; color:var(--accent); margin-bottom:18px}
.breadcrumb a{color:#C9CFE2}
.breadcrumb a:hover{color:#fff}
.page-hero h1{
  font-weight:800; font-size:clamp(40px, 6vw, 80px); line-height:0.98;
  letter-spacing:-0.01em; text-transform:uppercase;
}
.page-hero h1 em{font-style:italic; font-weight:600; color:var(--accent)}
.page-hero p{font-size:18px; color:#D7DCEC; max-width:560px; margin-top:20px; line-height:1.6}

/* ============================ DUAL CARD (potencia + map) ============================ */
.dual{
  background:var(--bg-dark);
  position:relative;
  padding:32px 0 0;
  margin-top:-1px;
}
.dual-grid{display:grid; grid-template-columns:1.6fr 1fr; gap:24px; padding:0 32px 32px}
.dual-card-img{
  position:relative; border-radius:12px; overflow:hidden;
  background-image:url('assets/img/banner_inferior.webp');
  background-size:cover; background-position:center; background-repeat:no-repeat;
  background-color:#2C3B7A;
  aspect-ratio:1331 / 319;
}
.dual-card-map{
  position:relative; border-radius:12px; overflow:hidden; background:#E8EEF6;
  min-height:100%;
}
.dual-card-map iframe{position:absolute; inset:0; width:100%; height:100%; border:0; display:block}
.map-cta{
  position:absolute; top:14px; left:14px; z-index:2;
  background:#fff; color:var(--ink);
  font-size:11px; font-weight:600; padding:6px 12px; border-radius:6px;
  display:inline-flex; align-items:center; gap:6px;
  box-shadow:0 2px 8px rgba(0,0,0,0.08);
}
.map-pin{position:absolute; right:24%; top:40%; z-index:2}

/* ============================ FOOTER BAND (replicado del cliente) ============================ */
.foot-band{
  background:var(--bg-dark); color:#fff;
  padding:28px 0;
}
.foot-band-inner{display:flex; justify-content:space-between; align-items:center; gap:24px}
.foot-band-info{font-size:14px; line-height:1.7; color:#fff}
.foot-band-info a{color:#fff}
.foot-band-rrss{display:flex; gap:16px; margin-top:10px}
.foot-band-rrss a{
  width:30px; height:30px; border-radius:50%; background:#fff; color:var(--bg-dark);
  display:flex; align-items:center; justify-content:center; transition:all .2s;
}
.foot-band-rrss a:hover{background:var(--accent); color:var(--ink)}
.foot-band-logo{display:flex; flex-direction:column; align-items:flex-end; line-height:1; gap:2px}
.foot-band-logo .brand-mark{color:#fff}
.foot-band-logo .brand-mark .b-mid{color:var(--accent)}
.foot-band-logo .brand-sub{color:#fff}

/* ============================ SECCIÓN / MANIFESTO ============================ */
.section{padding:120px 0; position:relative}
.section--soft{background:var(--bg-soft)}
.section--dark{background:var(--bg-dark); color:#fff}
.section-head{display:grid; grid-template-columns: 1fr 1.5fr; gap:64px; align-items:end; margin-bottom:64px}
.section-head h2{
  font-weight:800; font-size:clamp(34px, 4.5vw, 56px); line-height:1.0;
  letter-spacing:-0.01em; text-transform:uppercase;
}
.section-head h2 em{font-style:italic; font-weight:600; color:var(--accent-dark)}
.section--dark .section-head h2 em{color:var(--accent)}
.section-head p{font-size:18px; color:var(--ink-soft); max-width:520px}
.section--dark .section-head p{color:#C9CFE2}

.manifesto-grid{display:grid; grid-template-columns:1.4fr 1fr; gap:80px; align-items:start}
.manifesto-body p{font-size:20px; line-height:1.6; color:var(--ink-soft); margin-bottom:20px}
.manifesto-body p strong{color:var(--ink); font-weight:600}
.manifesto-body p em{font-style:italic; color:var(--accent-dark); font-weight:500}
.manifesto-stat{
  background:#fff; border:1px solid var(--hairline);
  padding:48px 40px; border-radius:18px;
  box-shadow:var(--shadow-card); position:sticky; top:120px;
}
.manifesto-stat .stat-eyebrow{
  font-size:11px; font-weight:600; letter-spacing:0.24em; text-transform:uppercase;
  color:var(--ink-soft); margin-bottom:16px;
}
.manifesto-stat .stat-value{
  font-size:clamp(72px, 9vw, 112px); font-weight:800; line-height:1;
  color:var(--bg-dark); letter-spacing:-0.03em;
}
.manifesto-stat .stat-value sup{font-size:0.4em; color:var(--accent-dark); top:-0.6em; position:relative; font-weight:700}
.manifesto-stat .stat-label{font-size:14px; color:var(--ink-soft); margin-top:12px; line-height:1.5}
.manifesto-stat .stat-source{font-size:11px; color:var(--ink-mute); margin-top:24px; padding-top:16px; border-top:1px dashed var(--hairline)}

/* ============================ SERVICIOS (cards) ============================ */
.svc-grid{display:grid; grid-template-columns:repeat(2, 1fr); gap:24px}
.svc-card{
  position:relative; padding:48px 40px; border-radius:18px;
  background:#fff; border:1px solid var(--hairline);
  box-shadow:var(--shadow-card); transition:all .35s var(--ease);
  display:flex; flex-direction:column; min-height:340px;
}
.svc-card:hover{transform:translateY(-4px); box-shadow:var(--shadow-card-hover); border-color:var(--accent)}
.svc-card .svc-icon{
  width:64px; height:64px; border-radius:16px;
  background:var(--accent-soft); display:flex; align-items:center; justify-content:center;
  margin-bottom:32px; transition:transform .35s var(--ease);
}
.svc-card:hover .svc-icon{transform:scale(1.05) rotate(-3deg)}
.svc-card h3{font-size:24px; font-weight:700; text-transform:uppercase; letter-spacing:0.01em; margin-bottom:14px; color:var(--ink)}
.svc-card p{font-size:15px; color:var(--ink-soft); line-height:1.6; margin-bottom:20px}
.svc-card ul{list-style:none; margin-bottom:auto; padding-bottom:24px}
.svc-card li{
  font-size:13px; color:var(--ink-soft); padding:6px 0 6px 22px;
  position:relative; border-bottom:1px dashed var(--hairline);
}
.svc-card li:last-child{border-bottom:0}
.svc-card li::before{
  content:""; position:absolute; left:0; top:13px; width:10px; height:10px; border-radius:50%;
  background:var(--accent); box-shadow:0 0 0 3px var(--accent-soft);
}
.svc-card .svc-link{
  display:inline-flex; align-items:center; gap:10px;
  font-size:12px; font-weight:700; text-transform:uppercase; letter-spacing:0.14em;
  color:var(--bg-dark); border-top:1px solid var(--hairline); padding-top:20px;
}
.svc-card .svc-link svg{transition:transform .25s var(--ease)}
.svc-card:hover .svc-link svg{transform:translateX(4px)}

/* ============================ EDITORIAL ROW (servicio detalle / nosotros) ============================ */
.edit-row{display:grid; grid-template-columns:1fr 1fr; gap:80px; align-items:center; margin-bottom:120px}
.edit-row:last-child{margin-bottom:0}
.edit-row--rev .edit-media{order:2}
.edit-media{
  position:relative; border-radius:18px; overflow:hidden; aspect-ratio:4/3;
  background-size:cover; background-position:center; box-shadow:var(--shadow-card);
}
.edit-media .edit-tag{
  position:absolute; left:20px; bottom:20px; z-index:2;
  background:var(--accent); color:var(--ink); font-size:11px; font-weight:700;
  letter-spacing:0.16em; text-transform:uppercase; padding:8px 14px; border-radius:var(--r-pill);
}
.edit-num{font-size:14px; font-weight:700; letter-spacing:0.22em; color:var(--accent-dark); margin-bottom:16px}
.edit-body h3{font-weight:800; font-size:clamp(28px, 3.5vw, 44px); line-height:1.05; text-transform:uppercase; margin-bottom:20px}
.edit-body h3 em{font-style:italic; font-weight:600; color:var(--accent-dark)}
.edit-body p{font-size:17px; color:var(--ink-soft); line-height:1.65; margin-bottom:20px}
.edit-body ul{list-style:none; margin:24px 0}
.edit-body li{position:relative; padding:10px 0 10px 28px; font-size:15px; color:var(--ink); border-bottom:1px solid var(--hairline)}
.edit-body li::before{content:""; position:absolute; left:0; top:17px; width:10px; height:10px; border-radius:50%; background:var(--accent); box-shadow:0 0 0 3px var(--accent-soft)}

/* ============================ PROCESO ============================ */
.proc-grid{display:grid; grid-template-columns:repeat(4, 1fr); gap:8px; position:relative}
.proc-step{padding:48px 32px; position:relative}
.proc-step:not(:last-child)::after{
  content:""; position:absolute; right:-4px; top:88px; width:8px; height:8px; border-radius:50%;
  background:var(--accent);
}
.proc-num{
  font-size:80px; font-weight:800; line-height:1;
  color:var(--accent); margin-bottom:20px; letter-spacing:-0.04em;
  font-feature-settings: "tnum";
}
.proc-step h4{font-size:20px; font-weight:700; text-transform:uppercase; letter-spacing:0.02em; margin-bottom:14px}
.proc-step p{font-size:14px; color:var(--ink-soft); line-height:1.6}
.section--dark .proc-step p{color:#C9CFE2}
.proc-line{
  position:absolute; top:118px; left:48px; right:48px; height:1px;
  background:repeating-linear-gradient(to right, var(--accent) 0, var(--accent) 6px, transparent 6px, transparent 12px);
  z-index:0;
}

/* ============================ ANTES / DESPUÉS ============================ */
.ba-block{display:grid; grid-template-columns:1.2fr 1fr; gap:64px; align-items:center}
.ba-vis{
  position:relative; border-radius:18px; overflow:hidden;
  aspect-ratio:4/3; background:#000;
}
.ba-vis-before, .ba-vis-after{
  position:absolute; inset:0; background-size:cover; background-position:center;
}
.ba-vis-before{
  background-image:url('assets/fotos/panel-02.webp'); filter:brightness(0.55) saturate(0.7);
}
.ba-vis-after{
  background-image:url('assets/fotos/panel-03.webp');
  clip-path:polygon(50% 0, 100% 0, 100% 100%, 50% 100%);
}
.ba-handle{
  position:absolute; top:0; bottom:0; left:50%; width:3px; background:var(--accent);
  transform:translateX(-50%); z-index:2;
}
.ba-handle::before, .ba-handle::after{
  content:""; position:absolute; left:50%; transform:translateX(-50%);
  width:44px; height:44px; border-radius:50%; background:var(--accent);
  top:50%; margin-top:-22px;
  display:flex; align-items:center; justify-content:center;
}
.ba-handle::after{
  content:"◀ ▶"; color:var(--ink); font-size:11px; font-weight:700;
  letter-spacing:-1px; line-height:44px; text-align:center;
}
.ba-label{
  position:absolute; top:20px;
  padding:6px 14px; border-radius:var(--r-pill);
  font-size:11px; font-weight:700; letter-spacing:0.18em; text-transform:uppercase;
  z-index:3;
}
.ba-label-before{left:20px; background:rgba(0,0,0,0.7); color:#fff}
.ba-label-after{right:20px; background:var(--accent); color:var(--ink)}
.ba-delta{position:absolute; bottom:24px; right:24px; z-index:3; color:#fff; text-align:right}
.ba-delta-num{
  font-size:80px; font-weight:800; line-height:1; color:var(--accent);
  letter-spacing:-0.03em; text-shadow:0 4px 24px rgba(0,0,0,0.3);
}
.ba-delta-num sup{font-size:0.4em; vertical-align:0.65em; margin-left:4px}
.ba-delta-label{font-size:12px; text-transform:uppercase; letter-spacing:0.22em; font-weight:600; margin-top:4px}

.ba-info h3{
  font-weight:800; font-size:clamp(28px, 3.5vw, 44px); line-height:1.05;
  text-transform:uppercase; margin-bottom:24px;
}
.ba-info h3 em{font-style:italic; font-weight:600; color:var(--accent-dark)}
.ba-info p{font-size:17px; color:var(--ink-soft); line-height:1.6; margin-bottom:28px}
.ba-meta{display:grid; grid-template-columns:1fr 1fr; gap:24px; padding-top:24px; border-top:1px solid var(--hairline)}
.ba-meta div span{display:block; font-size:10px; text-transform:uppercase; letter-spacing:0.22em; color:var(--ink-mute); margin-bottom:6px}
.ba-meta div strong{font-size:16px; color:var(--ink); font-weight:600}

/* ============================ CIFRAS / KPIs ============================ */
.kpi-grid{display:grid; grid-template-columns:repeat(4, 1fr); gap:0}
.kpi-cell{padding:8px 0 8px 40px; border-left:1px solid var(--hairline-on-dark)}
.kpi-cell:first-child{border-left:0; padding-left:0}
.kpi-value{
  font-size:clamp(56px, 7vw, 96px); font-weight:800; line-height:1;
  color:#fff; letter-spacing:-0.03em; font-feature-settings:"tnum";
}
.kpi-value .kpi-unit{font-size:0.42em; color:var(--accent); margin-left:6px; font-weight:700; letter-spacing:0; vertical-align:0.45em}
.kpi-label{font-size:12px; font-weight:600; letter-spacing:0.22em; text-transform:uppercase; color:#C9CFE2; margin-top:16px}

/* ============================ TIPOS DE CLIENTE ============================ */
.audience-grid{display:grid; grid-template-columns:repeat(3, 1fr); gap:24px}
.audience-card{
  position:relative; border-radius:18px; overflow:hidden;
  aspect-ratio:3/4; color:#fff; display:flex; flex-direction:column; justify-content:flex-end;
  padding:36px; background-size:cover; background-position:center;
  transition:transform .4s var(--ease);
}
.audience-card:hover{transform:translateY(-6px)}
.audience-card::after{content:""; position:absolute; inset:0; background:linear-gradient(to top, rgba(30,42,92,0.96) 0%, rgba(30,42,92,0.3) 50%, transparent 100%)}
.audience-card > *{position:relative; z-index:1}
.audience-card .aud-eyebrow{
  font-size:10px; font-weight:600; letter-spacing:0.28em; text-transform:uppercase; color:var(--accent); margin-bottom:10px;
}
.audience-card h3{font-size:30px; font-weight:800; text-transform:uppercase; line-height:1.05; margin-bottom:14px}
.audience-card p{font-size:14px; color:#D7DCEC; line-height:1.55; margin-bottom:20px}
.audience-card ul{list-style:none; font-size:13px}
.audience-card ul li{padding:5px 0 5px 18px; position:relative; color:#fff; border-top:1px solid rgba(255,255,255,0.12)}
.audience-card ul li:first-child{border-top:0}
.audience-card ul li::before{content:""; position:absolute; left:0; top:13px; width:8px; height:8px; background:var(--accent); border-radius:50%}
.audience-1{background-image:linear-gradient(rgba(30,42,92,0.25), rgba(30,42,92,0.25)), url('assets/fotos/panel-01.webp')}
.audience-2{background-image:linear-gradient(rgba(30,42,92,0.25), rgba(30,42,92,0.25)), url('assets/fotos/panel-02.webp')}
.audience-3{background-image:linear-gradient(rgba(30,42,92,0.25), rgba(30,42,92,0.25)), url('assets/fotos/panel-03.webp')}

/* ============================ VALORES (nosotros) ============================ */
.value-grid{display:grid; grid-template-columns:repeat(3, 1fr); gap:24px}
.value-card{background:#fff; border:1px solid var(--hairline); border-radius:18px; padding:40px; box-shadow:var(--shadow-card)}
.value-card .value-num{font-size:14px; font-weight:700; letter-spacing:0.22em; color:var(--accent-dark); margin-bottom:20px}
.value-card h4{font-size:22px; font-weight:700; text-transform:uppercase; letter-spacing:0.01em; margin-bottom:14px}
.value-card p{font-size:15px; color:var(--ink-soft); line-height:1.65}

/* ============================ EQUIPO (nosotros) ============================ */
.team-grid{display:grid; grid-template-columns:repeat(3, 1fr); gap:24px}
.team-card{position:relative; border-radius:18px; overflow:hidden; aspect-ratio:3/4; background:var(--bg-dark); display:flex; flex-direction:column; justify-content:flex-end; padding:32px; color:#fff}
.team-card::after{content:""; position:absolute; inset:0; background:linear-gradient(to top, rgba(30,42,92,0.95), rgba(30,42,92,0.15) 60%, transparent)}
.team-card.team-ph{background-image:linear-gradient(135deg, #34427e, #1e2a5c)}
.team-card > *{position:relative; z-index:1}
.team-card .team-role{font-size:10px; font-weight:600; letter-spacing:0.24em; text-transform:uppercase; color:var(--accent); margin-bottom:8px}
.team-card h4{font-size:24px; font-weight:700}
.team-card p{font-size:13px; color:#D7DCEC; margin-top:8px; line-height:1.5}

/* ============================ CONTACTO ============================ */
.contact-grid{display:grid; grid-template-columns:1fr 1fr; gap:64px; align-items:start}
.contact-info .ci-item{display:flex; gap:18px; padding:24px 0; border-bottom:1px solid var(--hairline)}
.contact-info .ci-item:first-child{padding-top:0}
.contact-icon{
  width:48px; height:48px; flex-shrink:0; border-radius:12px; background:var(--accent-soft);
  display:flex; align-items:center; justify-content:center;
}
.ci-text .ci-label{font-size:11px; font-weight:600; letter-spacing:0.22em; text-transform:uppercase; color:var(--ink-soft); margin-bottom:6px}
.ci-text strong{font-size:18px; font-weight:600; color:var(--ink); display:block}
.ci-text span{font-size:14px; color:var(--ink-soft)}
.contact-map{position:relative; border-radius:18px; overflow:hidden; min-height:420px; background:#E8EEF6}
.contact-map iframe{position:absolute; inset:0; width:100%; height:100%; border:0}

/* ============================ TESTIMONIOS ============================ */
.testi-grid{display:grid; grid-template-columns:repeat(3, 1fr); gap:24px}
.testi-card{
  background:#fff; padding:40px; border-radius:18px;
  border:1px solid var(--hairline); position:relative;
}
.testi-card::before{
  content:"\201C"; font-family: Georgia, serif; font-size:120px; line-height:1;
  color:var(--accent); position:absolute; top:-12px; left:32px;
}
.testi-card p{font-size:16px; color:var(--ink); line-height:1.6; margin:32px 0 24px; font-weight:500}
.testi-author{display:flex; align-items:center; gap:14px; padding-top:20px; border-top:1px solid var(--hairline)}
.testi-avatar{
  width:48px; height:48px; border-radius:50%; background:var(--bg-dark); color:#fff;
  display:flex; align-items:center; justify-content:center; font-weight:700; font-size:16px;
}
.testi-meta strong{display:block; font-size:14px; font-weight:600}
.testi-meta span{display:block; font-size:12px; color:var(--ink-soft); margin-top:2px}
.testi-stars{margin-bottom:4px; color:var(--accent); font-size:12px; letter-spacing:2px}

/* ============================ MARQUEE ============================ */
.marquee{background:var(--bg-dark); color:#fff; padding:24px 0; overflow:hidden; border-top:1px solid var(--hairline-on-dark); border-bottom:1px solid var(--hairline-on-dark)}
.marquee-track{display:flex; gap:64px; white-space:nowrap; animation:marquee 38s linear infinite}
.marquee-item{font-size:36px; font-weight:800; text-transform:uppercase; letter-spacing:-0.005em; display:flex; align-items:center; gap:64px}
.marquee-item::after{content:"·"; color:var(--accent); font-size:48px; line-height:1}
@keyframes marquee{from{transform:translateX(0)} to{transform:translateX(-50%)}}

/* ============================ FAQ ============================ */
.faq-block{display:grid; grid-template-columns:1fr 1.6fr; gap:80px; align-items:start}
.faq-side h2{
  font-weight:800; font-size:clamp(32px, 4vw, 48px); line-height:1; text-transform:uppercase; letter-spacing:-0.005em;
  margin-bottom:24px;
}
.faq-side h2 em{font-style:italic; font-weight:600; color:var(--accent-dark)}
.faq-side p{color:var(--ink-soft); line-height:1.6; margin-bottom:28px}
.faq-list{list-style:none}
.faq-item{border-top:1px solid var(--hairline); cursor:pointer; transition:background .2s}
.faq-item:last-child{border-bottom:1px solid var(--hairline)}
.faq-item summary{
  list-style:none; padding:24px 0; display:flex; justify-content:space-between; align-items:center;
  gap:24px; cursor:pointer; font-size:17px; font-weight:600; color:var(--ink);
}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::after{
  content:"+"; font-size:28px; font-weight:300; color:var(--accent-dark); transition:transform .3s var(--ease);
  line-height:1; flex-shrink:0;
}
.faq-item[open] summary::after{content:"−"}
.faq-item[open] summary{color:var(--bg-dark)}
.faq-body{padding:0 0 28px; color:var(--ink-soft); font-size:15px; line-height:1.65; max-width:780px}

/* ============================ CTA FINAL ============================ */
.cta-final{
  position:relative; padding:140px 0; color:#fff; overflow:hidden;
  background:var(--bg-deep);
}
.cta-final::before{
  content:""; position:absolute; inset:0;
  background-image:url('assets/fotos/panel-03.webp');
  background-size:cover; background-position:center;
  opacity:0.22; filter:blur(2px);
}
.cta-final::after{
  content:""; position:absolute; inset:0;
  background:radial-gradient(ellipse 80% 60% at 80% 0%, rgba(244,184,47,0.2), transparent 60%);
}
.cta-final-inner{position:relative; z-index:1; display:grid; grid-template-columns:1.4fr 1fr; gap:80px; align-items:center}
.cta-final-text h2{
  font-weight:800; font-size:clamp(40px, 6vw, 80px); line-height:0.95; text-transform:uppercase; letter-spacing:-0.005em;
}
.cta-final-text h2 em{font-style:italic; font-weight:600; color:var(--accent)}
.cta-final-text p{font-size:18px; color:#D7DCEC; max-width:480px; margin-top:24px; line-height:1.6}
.cta-form{
  background:#fff; color:var(--ink); padding:40px; border-radius:20px;
  box-shadow:0 30px 80px -20px rgba(0,0,0,0.5);
}
.cta-form h3{font-size:18px; font-weight:700; text-transform:uppercase; letter-spacing:0.08em; margin-bottom:8px}
.cta-form .form-meta{font-size:13px; color:var(--ink-soft); margin-bottom:24px}
.field{margin-bottom:14px}
.field label{font-size:11px; font-weight:600; letter-spacing:0.22em; text-transform:uppercase; color:var(--ink-soft); margin-bottom:6px; display:block}
.field input, .field select, .field textarea{
  width:100%; padding:14px 16px; border:1px solid var(--hairline); border-radius:10px;
  font-family:inherit; font-size:15px; color:var(--ink); background:#fff;
  transition:border .2s, box-shadow .2s;
}
.field textarea{resize:vertical; min-height:120px}
.field input:focus, .field select:focus, .field textarea:focus{outline:none; border-color:var(--bg-dark); box-shadow:0 0 0 4px rgba(44,59,122,0.1)}
.cta-form .cta{width:100%; justify-content:center; margin-top:12px}
.form-foot{font-size:11px; color:var(--ink-mute); margin-top:16px; text-align:center}
.form-card{background:#fff; border:1px solid var(--hairline); border-radius:20px; padding:48px; box-shadow:var(--shadow-card)}
.form-grid{display:grid; grid-template-columns:1fr 1fr; gap:14px}
.form-grid .field--full{grid-column:1 / -1}

/* ============================ FOOTER COMPLETO ============================ */
.footer{background:var(--bg-deep); color:#fff; padding-top:96px; overflow:hidden}
.footer-grid{display:grid; grid-template-columns:1.4fr 1fr 1fr 1fr; gap:64px; padding-bottom:80px}
.footer-brand .brand-mark{color:#fff; font-size:42px}
.footer-brand .brand-mark .b-mid{color:var(--accent)}
.footer-brand .brand-sub{color:#C9CFE2; margin-top:6px}
.footer-brand p{margin-top:24px; color:#C9CFE2; line-height:1.7; max-width:380px; font-size:14px}
.footer-col h5{
  font-size:11px; font-weight:700; letter-spacing:0.28em; text-transform:uppercase;
  color:var(--accent); margin-bottom:24px;
}
.footer-col ul{list-style:none}
.footer-col li{padding:6px 0}
.footer-col a{color:#D7DCEC; font-size:14px; transition:color .2s}
.footer-col a:hover{color:#fff}
.footer-watermark{
  width:100vw; margin-left:50%; transform:translateX(-50%);
  font-size:clamp(80px, 18vw, 280px); font-weight:800; text-align:center; line-height:0.85;
  color:rgba(255,255,255,0.04); letter-spacing:-0.04em; text-transform:uppercase;
  white-space:nowrap; padding-bottom:24px; user-select:none; pointer-events:none;
}
.footer-base{
  border-top:1px solid rgba(255,255,255,0.12); padding:32px 0;
  display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:16px;
}
.footer-base-meta{font-size:12px; color:#9CA3C2; letter-spacing:0.04em}
.footer-base-meta a{color:#9CA3C2}
.footer-base-meta a:hover{color:#fff}

/* Anchors helper */
.section-anchor{display:block; height:0; visibility:hidden}

/* ============================ LOGO IMAGEN ============================ */
.brand-logo{display:block; height:54px; width:auto}
.brand-chip{display:inline-block; background:#fff; border-radius:12px; padding:12px 18px; line-height:0}
.brand-chip .brand-logo{height:38px}

/* ============================================================
   RESPONSIVE — 3 breakpoints
   - desktop:  >1024px  (default arriba)
   - tablet:   <=1024px (hamburger + grids 1 col + spacing menor)
   - mobile:   <=640px  (typography compacta, paddings mínimos)
============================================================ */

/* ---------- TABLET / SMALL DESKTOP (<= 1024px) ---------- */
@media (max-width:1024px){

  /* HEADER: nav horizontal → drawer overlay desde la derecha */
  .header{height:72px}
  .wrap{padding:0 24px}
  .brand-logo{height:40px}
  .brand-chip{padding:10px 14px}
  .brand-chip .brand-logo{height:32px}

  .header-inner > .cta-primary{display:none}  /* el CTA fuera del nav se oculta; el del drawer se mantiene */
  .hamburger{display:block}
  .nav-scrim{display:block}

  .nav{
    position:fixed; top:0; right:0; bottom:0;
    width:min(86vw, 380px);
    background:#fff;
    flex-direction:column; align-items:stretch; gap:0;
    padding:88px 28px 32px;
    z-index:55;
    box-shadow:-30px 0 80px -20px rgba(14,18,40,0.4);
    transform:translateX(100%);
    transition:transform .4s var(--ease);
    overflow-y:auto;
    -webkit-overflow-scrolling:touch;
  }
  body.is-nav-open .nav{transform:translateX(0)}
  body.is-nav-open{overflow:hidden}

  .nav-item{
    flex-direction:row; align-items:center; justify-content:flex-start;
    gap:18px; padding:18px 4px;
    border-bottom:1px solid var(--hairline);
    text-transform:uppercase;
  }
  .nav-item:last-of-type{border-bottom:0}
  .nav-item .nav-icon{width:28px; height:28px}
  .nav-item .nav-icon svg{width:100%; height:100%}
  .nav-item .nav-label{
    display:inline-block; font-size:17px; font-weight:600;
    letter-spacing:0.06em; color:var(--ink);
  }
  .nav-item.is-active .nav-label{color:var(--bg-dark)}
  .nav-item.is-active::after{
    left:auto; right:0; bottom:50%; transform:translateY(50%);
    width:3px; height:24px; border-radius:2px;
  }
  /* CTA dentro del drawer */
  .nav-cta-mobile{
    display:flex; margin-top:28px; padding:0 0;
  }
  .nav-cta-mobile .cta{width:100%; justify-content:center; padding:18px 24px; font-size:13px}

  /* SECTIONS spacing */
  .section{padding:72px 0}
  .section-head{margin-bottom:48px}
  .section-head, .manifesto-grid, .ba-block, .cta-final-inner, .faq-block, .footer-grid,
  .edit-row, .edit-row--rev, .contact-grid{grid-template-columns:1fr; gap:40px}
  .edit-row{margin-bottom:64px}
  .edit-row--rev .edit-media{order:0}

  /* GRIDS varias */
  .svc-grid, .form-grid{grid-template-columns:1fr}
  .audience-grid, .testi-grid, .value-grid, .team-grid{grid-template-columns:repeat(2, 1fr); gap:20px}
  .proc-grid{grid-template-columns:repeat(2, 1fr); gap:16px}
  .proc-line{display:none}
  .proc-step:not(:last-child)::after{display:none}
  .kpi-grid{grid-template-columns:repeat(2, 1fr); row-gap:48px}
  .kpi-cell:nth-child(odd){border-left:0; padding-left:0}
  /* DUAL (banner + mapa): full-bleed sin trucos.
     Quitamos paddings de la cadena .wrap > .dual-grid para que ocupe 100% real, y
     reponemos padding lateral solo donde lo necesitamos (mapa + foot-band). */
  .dual > .wrap{padding:0}
  .dual-grid{grid-template-columns:1fr; gap:0; padding:0}
  .dual-card-img{
    width:100%;
    margin:0; transform:none;
    border-radius:0;
  }
  .dual-card-map{margin:16px 18px 0; min-height:280px}

  /* HERO home */
  .hero{min-height:clamp(420px, 70vh, 560px); padding:40px 0}
  .hero-title, .hero-title-line, .hero-sub{text-align:left}
  .hero-foot{grid-template-columns:1fr; gap:24px}

  /* Banda de contacto (foot-band): la metemos dentro de .wrap propio para que recupere padding lateral */
  .dual > .wrap > .foot-band-inner{padding-left:18px; padding-right:18px}
  .foot-band-inner{flex-direction:column; align-items:flex-start; gap:18px}
  .foot-band-logo{align-items:flex-start}

  /* Page hero */
  .page-hero{padding:110px 0 56px; min-height:280px}

  /* Footer watermark + grid */
  .footer{padding-top:64px}
  .footer-grid{padding-bottom:56px; gap:40px}
  .footer-watermark{font-size:80px}
  .footer-base{flex-direction:column; align-items:flex-start; text-align:left}

  /* Manifesto stat */
  .manifesto-stat{padding:32px}
  .manifesto-stat .stat-value{font-size:64px}

  /* Antes / después */
  .ba-block{gap:40px}
  .ba-handle::after{content:"◀▶"; font-size:9px; line-height:36px}
  .ba-handle::before, .ba-handle::after{width:36px; height:36px; margin-top:-18px}
  .ba-delta-num{font-size:56px}

  /* Marquee */
  .marquee-item{font-size:24px; gap:40px}
  .marquee-item::after{font-size:32px}
  .marquee-track{gap:40px}

  /* CTA final */
  .cta-final{padding:88px 0}
  .cta-form, .form-card{padding:28px}

  /* FAQ */
  .faq-block{gap:48px}
  .faq-item summary{font-size:16px; padding:20px 0}

  /* Contact map */
  .contact-map{min-height:320px}

  /* Single hero */
  .single-hero{min-height:380px; padding:110px 0 48px}
  .single-meta{gap:14px; font-size:12px}

  /* Audience cards: aspect menos vertical */
  .audience-card{aspect-ratio:4/5; padding:28px}
  .audience-card h3{font-size:24px}

  /* Team */
  .team-card{aspect-ratio:4/5; padding:24px}

  /* Marquee y secciones dark del index nosotros */
  .section--dark .wrap[style]{padding-left:24px !important; padding-right:24px !important}
}

/* ---------- MOBILE (<= 640px) ---------- */
@media (max-width:640px){
  .wrap{padding:0 18px}
  .header{height:64px}
  .brand-logo{height:34px}
  .hamburger{width:42px; height:42px}

  /* Spacing global más comprimido */
  .section{padding:56px 0}
  .section-head{margin-bottom:36px}

  /* Tipografías display: bajar techo del clamp */
  .hero-title{font-size:clamp(34px, 9vw, 48px)}
  .hero-sub{font-size:clamp(16px, 4.6vw, 20px)}
  .hero-desc{font-size:15px}
  .page-hero h1{font-size:clamp(34px, 9vw, 52px)}
  .page-hero p{font-size:15px; max-width:none}
  .cta-final-text h2{font-size:clamp(34px, 9vw, 48px)}
  .cta-final-text p{font-size:16px}
  .ba-info h3, .edit-body h3{font-size:clamp(24px, 7.5vw, 32px)}
  .blog-hero h1{font-size:clamp(34px, 9vw, 48px)}
  .blog-hero .blog-hero-lead{font-size:16px}
  .single-hero h1{font-size:clamp(28px, 8vw, 40px)}

  /* Grids varias → 1 columna */
  .audience-grid, .testi-grid, .value-grid, .team-grid,
  .proc-grid, .post-grid{grid-template-columns:1fr; gap:16px}
  .kpi-grid{grid-template-columns:1fr; row-gap:32px}
  .kpi-cell{border-left:0; padding-left:0; padding-top:24px; border-top:1px solid var(--hairline-on-dark)}
  .kpi-cell:first-child{border-top:0; padding-top:8px}

  /* Service card */
  .svc-card{padding:32px 24px; min-height:auto}
  .svc-card h3{font-size:20px}

  /* Editorial row: imagen ratio 16/10 menos cuadrada en mobile */
  .edit-media{aspect-ratio:16/10}

  /* Audience / team cards */
  .audience-card{aspect-ratio:3/4; padding:24px}
  .audience-card h3{font-size:22px}
  .audience-card p{font-size:13px}
  .team-card{aspect-ratio:3/4; padding:22px}
  .team-card h4{font-size:20px}

  /* KPIs */
  .kpi-value{font-size:clamp(48px, 14vw, 64px)}
  .kpi-label{font-size:11px; margin-top:10px}

  /* Antes / después: handle más fino */
  .ba-handle{width:2px}
  .ba-handle::before, .ba-handle::after{width:32px; height:32px; margin-top:-16px}
  .ba-handle::after{font-size:8px; line-height:32px}
  .ba-delta-num{font-size:44px}
  .ba-delta{bottom:16px; right:16px}
  .ba-label{font-size:10px; padding:5px 10px; letter-spacing:0.14em}
  .ba-meta{grid-template-columns:1fr; gap:14px}

  /* Marquee */
  .marquee-item{font-size:18px; gap:24px}
  .marquee-item::after{font-size:22px}
  .marquee-track{gap:24px}
  .marquee{padding:16px 0}

  /* Form / contact */
  .cta-form, .form-card{padding:22px; border-radius:14px}
  .field input, .field select, .field textarea{padding:12px 14px; font-size:14px}
  .contact-info .ci-item{gap:14px; padding:18px 0}
  .contact-icon{width:42px; height:42px}
  .ci-text strong{font-size:16px}
  .contact-map{min-height:260px}

  /* FAQ */
  .faq-block{gap:32px}
  .faq-side h2{font-size:30px; margin-bottom:16px}
  .faq-item summary{font-size:15px; padding:18px 0; gap:16px}
  .faq-item summary::after{font-size:24px}
  .faq-body{font-size:14px; padding-bottom:20px}

  /* Page hero */
  .page-hero{padding:88px 0 40px; min-height:240px}
  .single-hero{min-height:320px; padding:88px 0 36px}
  .blog-hero{padding:88px 0 40px; min-height:280px}

  /* Manifesto stat */
  .manifesto-stat{padding:24px}
  .manifesto-stat .stat-value{font-size:48px}

  /* CTA final */
  .cta-final{padding:64px 0}

  /* Footer */
  .footer{padding-top:48px}
  .footer-grid{grid-template-columns:1fr; gap:32px; padding-bottom:40px}
  .footer-watermark{font-size:60px}
  .footer-base{padding:24px 0; font-size:11px}
  .footer-base-meta{font-size:11px}

  /* Blog cards / single */
  .post-card-body{padding:22px}
  .post-card-title{font-size:19px}
  .post-card-cat{font-size:10px; padding:5px 10px}
  .single-body{padding:48px 0 40px}
  .prose{font-size:16px}
  .prose p{font-size:16px}
  .prose h2{font-size:24px}
  .prose blockquote, .prose blockquote p{font-size:18px}
  .post-author{padding:24px; gap:18px}
  .post-author-avatar{width:60px; height:60px; font-size:22px}
  .related{padding:64px 0}

  /* Pagination */
  .pagination .page-numbers{min-width:38px; height:38px; font-size:12px; padding:0 10px}
  .pagination .page-numbers.prev, .pagination .page-numbers.next{padding:0 14px}

  /* Drawer items: padding más cómodo */
  .nav-item{padding:16px 4px}
  .nav-item .nav-label{font-size:16px}

  /* Section--dark wrap inline padding */
  .section--dark > .wrap[style]{padding-left:18px !important; padding-right:18px !important; padding-top:64px !important; padding-bottom:32px !important}
  .section--dark > .wrap[style]:last-child{padding-bottom:64px !important}
}

/* ---------- XS (<= 380px) — pulido para iPhone SE ---------- */
@media (max-width:380px){
  .wrap{padding:0 14px}
  .hero-title{font-size:30px; line-height:1.04}
  .hero-sub{font-size:15px}
  .nav{width:100vw}
  .nav-item .nav-label{font-size:15px}
  .marquee-item{font-size:16px}
}

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

/* --- Index del blog: cabecera editorial --- */
.blog-hero{
  position:relative; overflow:hidden; color:#fff;
  padding:140px 0 84px; min-height:360px;
  background:var(--bg-dark);
  display:flex; align-items:flex-end;
}
.blog-hero::before{
  content:""; position:absolute; inset:0;
  background:
    radial-gradient(ellipse at 80% 0%, rgba(244,184,47,0.18), transparent 55%),
    linear-gradient(180deg, rgba(30,42,92,0) 0%, rgba(30,42,92,0.95) 100%);
  z-index:0;
}
.blog-hero-inner{position:relative; z-index:1; width:100%}
.blog-hero .eyebrow{color:var(--accent); margin-bottom:18px}
.blog-hero h1{
  font-weight:800; font-size:clamp(40px, 6vw, 80px); line-height:0.98;
  letter-spacing:-0.01em; text-transform:uppercase;
}
.blog-hero h1 em{font-style:italic; font-weight:600; color:var(--accent)}
.blog-hero .blog-hero-lead{
  font-size:18px; color:#D7DCEC; max-width:620px; margin-top:22px; line-height:1.6;
}

/* --- Grid de cards --- */
.post-grid{
  display:grid; grid-template-columns:repeat(3, 1fr); gap:32px;
}
.post-card{
  display:flex; flex-direction:column;
  background:#fff; border:1px solid var(--hairline); border-radius:18px;
  overflow:hidden; box-shadow:var(--shadow-card);
  transition:transform .35s var(--ease), box-shadow .35s var(--ease);
}
.post-card:hover{transform:translateY(-4px); box-shadow:var(--shadow-card-hover)}
.post-card-cover{
  display:block; position:relative;
  aspect-ratio:16/10; overflow:hidden;
  background:var(--bg-soft);
}
.post-card-cover img,
.post-card-cover .post-card-cover-img{
  width:100%; height:100%; object-fit:cover; display:block;
  transition:transform .6s var(--ease);
}
.post-card:hover .post-card-cover img{transform:scale(1.04)}
.post-card-cover-fallback{
  position:absolute; inset:0;
  background:
    linear-gradient(135deg, var(--bg-dark) 0%, var(--bg-deep) 100%);
  display:flex; align-items:center; justify-content:center;
}
.post-card-cover-fallback::after{
  content:""; width:64px; height:64px; border-radius:50%;
  background:var(--accent); opacity:0.85;
  box-shadow:0 0 0 14px rgba(244,184,47,0.18);
}
.post-card-cat{
  position:absolute; top:16px; left:16px; z-index:2;
  font-size:11px; font-weight:700; letter-spacing:0.18em; text-transform:uppercase;
  color:var(--ink); background:var(--accent);
  padding:6px 12px; border-radius:var(--r-pill);
}
.post-card-body{padding:28px; display:flex; flex-direction:column; gap:14px; flex:1}
.post-card-meta{
  font-size:11px; font-weight:600; letter-spacing:0.18em; text-transform:uppercase;
  color:var(--ink-mute); display:flex; gap:12px; align-items:center;
}
.post-card-meta .dot{width:3px; height:3px; border-radius:50%; background:var(--ink-mute)}
.post-card-title{
  font-size:22px; font-weight:700; line-height:1.2; letter-spacing:-0.005em;
  color:var(--ink);
}
.post-card-title a{color:inherit}
.post-card-title a:hover{color:var(--bg-dark)}
.post-card-excerpt{font-size:14.5px; color:var(--ink-soft); line-height:1.6; flex:1}
.post-card-more{
  margin-top:8px; font-size:12px; font-weight:700; letter-spacing:0.18em;
  text-transform:uppercase; color:var(--bg-dark);
  display:inline-flex; align-items:center; gap:8px;
}
.post-card-more::after{
  content:""; width:24px; height:1.5px; background:var(--accent);
  transition:width .25s var(--ease);
}
.post-card:hover .post-card-more::after{width:40px}

/* --- Featured / destacado (primer post del index) --- */
.post-featured{
  grid-column:1 / -1;
  display:grid; grid-template-columns:1.2fr 1fr; gap:0;
  border-radius:18px; overflow:hidden;
  background:#fff; border:1px solid var(--hairline); box-shadow:var(--shadow-card);
}
.post-featured .post-card-cover{aspect-ratio:auto; height:100%; min-height:380px}
.post-featured .post-card-body{padding:56px; justify-content:center; gap:18px}
.post-featured .post-card-title{font-size:clamp(28px, 3vw, 40px); line-height:1.05}
.post-featured .post-card-excerpt{font-size:16px}

/* --- Single post --- */
.single-hero{
  position:relative; overflow:hidden; color:#fff;
  padding:160px 0 80px; min-height:520px;
  display:flex; align-items:flex-end;
  background:var(--bg-deep);
}
.single-hero-bg{
  position:absolute; inset:0; z-index:0;
  background-size:cover; background-position:center;
  filter:saturate(1.05);
}
.single-hero-overlay{
  position:absolute; inset:0; z-index:1;
  background:
    linear-gradient(180deg, rgba(30,42,92,0.45) 0%, rgba(30,42,92,0.85) 70%, var(--bg-deep) 100%);
}
.single-hero-inner{position:relative; z-index:2; width:100%; max-width:920px}
.single-hero .breadcrumb{margin-bottom:22px}
.single-hero .post-cat-tag{
  display:inline-block; background:var(--accent); color:var(--ink);
  font-size:11px; font-weight:700; letter-spacing:0.18em; text-transform:uppercase;
  padding:8px 16px; border-radius:var(--r-pill); margin-bottom:24px;
}
.single-hero h1{
  font-weight:800; font-size:clamp(34px, 5.4vw, 68px); line-height:1.03;
  letter-spacing:-0.01em; text-transform:uppercase;
}
.single-hero h1 em{font-style:italic; font-weight:600; color:var(--accent)}
.single-meta{
  display:flex; gap:24px; flex-wrap:wrap; align-items:center;
  margin-top:28px; padding-top:24px;
  border-top:1px solid rgba(255,255,255,0.18);
  font-size:13px; color:#D7DCEC; letter-spacing:0.04em;
}
.single-meta strong{color:#fff; font-weight:600; letter-spacing:0.04em}
.single-meta .dot{width:3px; height:3px; border-radius:50%; background:#9CA3C2; display:inline-block}

/* --- Cuerpo del post (typography) --- */
.single-body{padding:96px 0 80px}
.prose{
  max-width:760px; margin:0 auto;
  font-size:18px; line-height:1.75; color:var(--ink);
}
.prose > * + *{margin-top:1.4em}
.prose p{font-size:18px; line-height:1.75; color:#2A3060}
.prose h2{
  font-size:clamp(26px, 2.6vw, 34px); font-weight:800; text-transform:uppercase;
  letter-spacing:-0.005em; line-height:1.15; margin-top:2.2em;
}
.prose h2 em{font-style:italic; font-weight:600; color:var(--accent-dark)}
.prose h3{
  font-size:clamp(20px, 2vw, 24px); font-weight:700;
  letter-spacing:0.01em; line-height:1.25; margin-top:1.8em;
}
.prose h4{font-size:18px; font-weight:700; margin-top:1.6em}
.prose ul, .prose ol{padding-left:0; list-style:none}
.prose ul li,
.prose ol li{position:relative; padding:6px 0 6px 28px; border-bottom:1px solid var(--hairline)}
.prose ul li::before{
  content:""; position:absolute; left:0; top:16px;
  width:10px; height:10px; border-radius:50%;
  background:var(--accent); box-shadow:0 0 0 3px var(--accent-soft);
}
.prose ol{counter-reset:item}
.prose ol li::before{
  content:counter(item, decimal-leading-zero); counter-increment:item;
  position:absolute; left:0; top:6px;
  font-size:13px; font-weight:700; color:var(--accent-dark); letter-spacing:0.08em;
}
.prose blockquote{
  border-left:3px solid var(--accent);
  padding:8px 0 8px 28px; margin:2em 0;
  font-style:italic; font-size:22px; color:var(--ink);
  line-height:1.5;
}
.prose blockquote p{font-size:22px}
.prose a{color:var(--bg-dark); border-bottom:1px solid var(--accent); transition:color .2s var(--ease)}
.prose a:hover{color:var(--accent-dark)}
.prose img,
.prose .wp-block-image img{
  border-radius:12px; box-shadow:var(--shadow-card);
  width:100%; height:auto;
}
.prose figure{margin:2.4em 0}
.prose figcaption{
  font-size:13px; color:var(--ink-mute); text-align:center;
  margin-top:12px; font-style:italic;
}
.prose code{
  background:var(--bg-soft); padding:2px 8px; border-radius:4px;
  font-family:'SF Mono', Menlo, Consolas, monospace; font-size:0.92em; color:var(--bg-deep);
}
.prose pre{
  background:var(--bg-deep); color:#E6EAF6; padding:24px;
  border-radius:12px; overflow-x:auto; font-size:14px; line-height:1.6;
}
.prose pre code{background:transparent; color:inherit; padding:0}
.prose hr{
  border:0; height:1px; background:var(--hairline); margin:3em 0;
}
.prose table{
  width:100%; border-collapse:collapse; font-size:15px;
  border-top:2px solid var(--ink); border-bottom:2px solid var(--ink);
}
.prose th, .prose td{padding:14px 12px; text-align:left; border-bottom:1px solid var(--hairline)}
.prose th{font-weight:700; text-transform:uppercase; font-size:12px; letter-spacing:0.12em}

/* --- Tags + share + autor (post footer) --- */
.post-foot{
  max-width:760px; margin:72px auto 0;
  padding-top:48px; border-top:1px solid var(--hairline);
  display:flex; flex-wrap:wrap; gap:32px; justify-content:space-between; align-items:flex-start;
}
.post-tags{display:flex; flex-wrap:wrap; gap:10px}
.post-tag{
  font-size:11px; font-weight:700; letter-spacing:0.16em; text-transform:uppercase;
  color:var(--ink-soft); background:var(--bg-soft);
  padding:8px 14px; border-radius:var(--r-pill);
  border:1px solid var(--hairline);
}
.post-tag:hover{background:var(--accent-soft); color:var(--ink)}
.post-share{display:flex; gap:10px; align-items:center; font-size:12px; font-weight:600; letter-spacing:0.12em; text-transform:uppercase; color:var(--ink-soft)}
.post-share a{
  width:36px; height:36px; border-radius:50%;
  display:inline-flex; align-items:center; justify-content:center;
  background:var(--bg-soft); border:1px solid var(--hairline);
  transition:all .25s var(--ease);
}
.post-share a:hover{background:var(--accent); border-color:var(--accent); transform:translateY(-2px)}
.post-share svg{width:16px; height:16px; fill:var(--ink)}

.post-author{
  max-width:760px; margin:48px auto 0;
  display:grid; grid-template-columns:auto 1fr; gap:24px; align-items:center;
  padding:32px; background:var(--bg-soft); border-radius:18px;
}
.post-author-avatar{
  width:72px; height:72px; border-radius:50%;
  background:linear-gradient(135deg, var(--accent) 0%, var(--accent-dark) 100%);
  display:flex; align-items:center; justify-content:center;
  font-size:26px; font-weight:800; color:var(--ink);
}
.post-author-name{font-size:16px; font-weight:700; text-transform:uppercase; letter-spacing:0.04em; margin-bottom:4px}
.post-author-bio{font-size:14px; color:var(--ink-soft); line-height:1.55}

/* --- Posts relacionados --- */
.related{
  background:var(--bg-soft); padding:96px 0;
}
.related .section-head{margin-bottom:48px}
.related .post-grid{grid-template-columns:repeat(3, 1fr); gap:24px}
.related .post-card{box-shadow:none; border:1px solid var(--hairline)}

/* --- Paginación --- */
.pagination{
  margin-top:64px; display:flex; justify-content:center; gap:8px; flex-wrap:wrap;
}
.pagination .page-numbers{
  min-width:44px; height:44px; padding:0 14px;
  display:inline-flex; align-items:center; justify-content:center;
  font-size:13px; font-weight:700; letter-spacing:0.08em;
  border:1px solid var(--hairline); border-radius:var(--r-pill);
  color:var(--ink); background:#fff; transition:all .2s var(--ease);
}
.pagination .page-numbers:hover{border-color:var(--bg-dark); color:var(--bg-dark)}
.pagination .page-numbers.current{background:var(--bg-dark); color:#fff; border-color:var(--bg-dark)}
.pagination .page-numbers.prev,
.pagination .page-numbers.next{padding:0 20px}
.pagination .dots{border:0; background:transparent}

/* --- Search form + no-results --- */
.search-bar{
  max-width:680px; margin:0 auto 64px;
  display:flex; gap:8px;
  background:#fff; padding:8px; border-radius:var(--r-pill);
  border:1px solid var(--hairline); box-shadow:var(--shadow-card);
}
.search-bar input[type="search"]{
  flex:1; padding:14px 22px; border:0; outline:0;
  font-family:inherit; font-size:15px; color:var(--ink);
  background:transparent;
}
.search-bar input[type="search"]::placeholder{color:var(--ink-mute)}
.search-bar button{
  padding:14px 28px; border:0; cursor:pointer;
  border-radius:var(--r-pill); background:var(--bg-dark); color:#fff;
  font-family:inherit; font-size:13px; font-weight:700; letter-spacing:0.12em; text-transform:uppercase;
  transition:background .25s var(--ease);
}
.search-bar button:hover{background:var(--bg-deep)}

.no-results{
  max-width:560px; margin:0 auto; text-align:center;
  padding:64px 32px;
}
.no-results h3{font-size:24px; font-weight:700; text-transform:uppercase; margin-bottom:16px}
.no-results p{color:var(--ink-soft); margin-bottom:32px}

/* --- Responsive blog --- */
@media (max-width:1024px){
  .post-grid{grid-template-columns:1fr; gap:24px}
  .related .post-grid{grid-template-columns:1fr}
  .post-featured{grid-template-columns:1fr}
  .post-featured .post-card-cover{min-height:240px; aspect-ratio:16/10}
  .post-featured .post-card-body{padding:32px}
  .single-hero{padding:120px 0 56px; min-height:420px}
  .single-body{padding:64px 0 56px}
  .prose{font-size:17px}
  .prose p{font-size:17px}
  .post-foot{flex-direction:column; gap:24px}
  .post-author{grid-template-columns:1fr; text-align:center; justify-items:center}
  .blog-hero{padding:120px 0 56px}
  .search-bar{flex-direction:column; border-radius:18px; padding:12px}
  .search-bar input[type="search"]{padding:12px 16px}
  .search-bar button{padding:14px 24px}
}
