/* ============================================================
   EMILIO MAILLO — CV / CURRÍCULUM
   Extiende manual.css (sistema bermellón)
   ============================================================ */

:root {
  /* A4 = 210 × 297 mm. En pantalla usamos 96dpi → 794 × 1123 px.
     Márgenes equivalentes a ~14mm = 53px. */
  --cv-page-w: 794px;
  --cv-page-h: 1123px;
  --cv-pad-x: 56px;
  --cv-pad-y: 52px;
  --cv-rule: 1px solid var(--vm-ink);
  --cv-rule-soft: 1px solid var(--vm-rule-soft);
  --cv-rule-hair: 1px solid var(--vm-rule-hair);
}

html, body { margin: 0; padding: 0; }
body {
  background: #ECECEC;
  color: var(--vm-ink);
  font-family: var(--font-display);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

/* ----- Sheet (A4 estricto, vive sobre fondo gris en pantalla) ----- */
.sheet {
  background: var(--vm-paper);
  width: var(--cv-page-w);
  min-height: var(--cv-page-h);
  margin: 32px auto;
  padding: var(--cv-pad-y) var(--cv-pad-x);
  box-shadow: 0 1px 0 rgba(0,0,0,0.04), 0 24px 60px -20px rgba(0,0,0,0.18);
  box-sizing: border-box;
}

/* ============================================================
   PAGE-HEAD
   ============================================================ */
.cv-head {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  border-bottom: var(--cv-rule);
  padding-bottom: 14px;
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
}
.cv-head .left  { display: flex; gap: 18px; align-items: baseline; color: var(--vm-dim); }
.cv-head .left .doc { color: var(--vm-ink); }
.cv-head .right { color: var(--vm-dim); }
.cv-head .red   { color: var(--vm-red); }

/* ============================================================
   HERO
   ============================================================ */
.cv-hero {
  padding: 36px 0 28px;
  border-bottom: var(--cv-rule);
}

.cv-name {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: 64px;
  line-height: 0.94;
  letter-spacing: -0.045em;
  margin: 0;
}
.cv-name .dot { color: var(--vm-red); }

.cv-role {
  margin: 18px 0 0;
  font-family: var(--font-display);
  font-weight: 400;
  font-size: 20px;
  line-height: 1.3;
  letter-spacing: -0.012em;
  max-width: 32ch;
  text-wrap: balance;
}
.cv-role .red { color: var(--vm-red); }

.cv-contact {
  margin-top: 28px;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 20px;
}
.cv-contact .row { display: flex; flex-direction: column; gap: 4px; }
.cv-contact .lbl {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--vm-dim);
}
.cv-contact .val {
  font-family: var(--font-display);
  font-size: 15px;
  font-weight: 400;
  letter-spacing: -0.005em;
  color: var(--vm-ink);
  line-height: 1.3;
}
.cv-contact .val.red { color: var(--vm-red); }
a.val { color: var(--vm-ink); text-decoration: none; border-bottom: 1px solid transparent; transition: border-color .15s ease; }
a.val:hover { border-bottom-color: currentColor; }
a.val.red { color: var(--vm-red); }

/* ============================================================
   KPI BAND — Datos clave
   ============================================================ */
.kpi-band {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  border-bottom: var(--cv-rule);
}
.kpi-heading {
  padding: 28px 0 0;
}
.kpi-heading .cv-sec-title {
  margin: 0 0 18px;
}
  border-bottom: var(--cv-rule);
}
.kpi {
  padding: 24px 20px 24px 0;
  border-right: var(--cv-rule-soft);
  display: flex;
  flex-direction: column;
  gap: 6px;
  min-height: 134px;
}
.kpi:nth-child(2) { padding-left: 20px; padding-right: 20px; }
.kpi:last-child   { padding-left: 20px; padding-right: 0; border-right: none; }

.kpi .tag {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--vm-dim);
  display: flex;
  gap: 8px;
  align-items: baseline;
}
.kpi .tag .red { color: var(--vm-red); }
.kpi .big {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: 24px;
  line-height: 1.06;
  letter-spacing: -0.025em;
  margin: 6px 0 0;
  text-wrap: balance;
}
.kpi .big .red { color: var(--vm-red); }
.kpi .sub {
  margin-top: auto;
  padding-top: 10px;
  font-family: var(--font-display);
  font-size: 12.5px;
  line-height: 1.45;
  color: var(--vm-dim);
  letter-spacing: -0.005em;
  text-wrap: pretty;
  max-width: 22ch;
}

/* ============================================================
   SECCIÓN GENÉRICA
   ============================================================ */
.cv-sec {
  padding: 32px 0 4px;
  border-bottom: var(--cv-rule-soft);
}
.cv-sec:last-of-type { border-bottom: none; }

.cv-sec-marker {
  display: flex;
  align-items: baseline;
  gap: 12px;
  font-family: var(--font-mono);
  font-size: 10.5px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--vm-dim);
  margin-bottom: 18px;
}
.cv-sec-marker .num { color: var(--vm-ink); }
.cv-sec-marker .red { color: var(--vm-red); }

.cv-sec-title {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: 22px;
  letter-spacing: -0.02em;
  line-height: 1.1;
  margin: 0 0 22px;
  max-width: 28ch;
  text-wrap: balance;
}
.cv-sec-sub {
  margin: -14px 0 22px;
  font-family: var(--font-display);
  font-size: 14px;
  letter-spacing: -0.005em;
  line-height: 1.35;
  color: var(--vm-dim);
}
.cv-sec-sub .red { color: var(--vm-red); }
.cv-sec-title .red { color: var(--vm-red); }

/* ============================================================
   §01 PERFIL / RESUMEN
   ============================================================ */
.perfil {
  display: grid;
  grid-template-columns: 160px 1fr;
  gap: 36px;
  align-items: start;
  padding-bottom: 24px;
}
.perfil .meta {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--vm-dim);
  display: grid;
  gap: 6px;
}
.perfil .meta .red { color: var(--vm-red); }

.perfil .body {
  display: grid;
  gap: 14px;
  max-width: 56ch;
}
.perfil .body p {
  margin: 0;
  font-family: var(--font-display);
  font-size: 14px;
  line-height: 1.5;
  letter-spacing: -0.005em;
  text-wrap: pretty;
}
.perfil .body p.lead {
  font-size: 16px;
  line-height: 1.4;
  letter-spacing: -0.012em;
  font-weight: 500;
}
.perfil .body p .red { color: var(--vm-red); }

/* ============================================================
   §02 EXPERIENCIA
   ============================================================ */
.exp-list {
  display: grid;
  gap: 0;
  border-top: var(--cv-rule);
  margin-bottom: 24px;
}
.exp {
  display: grid;
  grid-template-columns: 170px 1fr;
  gap: 40px;
  padding: 28px 0;
  border-bottom: var(--cv-rule-soft);
  align-items: start;
}
.exp:last-child { border-bottom: var(--cv-rule); }

.exp .when {
  display: flex;
  flex-direction: column;
  gap: 4px;
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--vm-dim);
  padding-top: 4px;
}
.exp .when .dates { color: var(--vm-ink); font-variant-numeric: tabular-nums; white-space: nowrap; }
.exp .when .dur { color: var(--vm-dim); }
.exp .when .red { color: var(--vm-red); }

.exp .body { display: grid; gap: 8px; }
.exp .role {
  margin: 0;
  font-family: var(--font-display);
  font-weight: 500;
  font-size: 18px;
  letter-spacing: -0.018em;
  line-height: 1.2;
  text-wrap: balance;
}
.exp .role .red { color: var(--vm-red); }

.exp .org {
  font-family: var(--font-display);
  font-size: 13.5px;
  letter-spacing: -0.005em;
  color: var(--vm-dim);
  margin: 0;
  display: flex;
  gap: 10px;
  align-items: baseline;
  flex-wrap: wrap;
}
.exp .org .sep { color: var(--vm-rule-soft); }
.exp .org .place { color: var(--vm-dim); }
.exp .org .red { color: var(--vm-red); }

.exp .summary {
  margin: 6px 0 0;
  font-family: var(--font-display);
  font-size: 14.5px;
  line-height: 1.55;
  letter-spacing: -0.005em;
  text-wrap: pretty;
  max-width: 72ch;
  color: var(--vm-ink);
}

.exp ul.bullets {
  margin: 8px 0 0;
  padding: 0;
  list-style: none;
  display: grid;
  gap: 6px;
}
.exp ul.bullets li {
  display: grid;
  grid-template-columns: 16px 1fr;
  font-family: var(--font-display);
  font-size: 13.5px;
  line-height: 1.48;
  letter-spacing: -0.005em;
  max-width: 62ch;
}
.exp ul.bullets li::before {
  content: "—";
  color: var(--vm-red);
}
.exp ul.bullets li strong {
  font-weight: 600;
  color: var(--vm-ink);
}

/* placeholder rows */
.exp.is-placeholder .body .role { color: var(--vm-dim-2); }
.exp .ph-fill {
  border: 1px dashed var(--vm-rule-soft);
  background:
    repeating-linear-gradient(
      135deg,
      transparent 0 11px,
      var(--vm-rule-hair) 11px 12px
    );
  padding: 14px 16px;
  margin-top: 8px;
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--vm-dim);
}

/* ============================================================
   §03 FORMACIÓN
   ============================================================ */
.formacion {
  display: grid;
  grid-template-columns: 130px 1fr;
  gap: 28px;
  border-top: var(--cv-rule);
  margin-bottom: 24px;
}
.formacion .head-meta {
  padding-top: 22px;
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--vm-dim);
}
.formacion .head-meta .red { color: var(--vm-red); }

.formacion .list { display: grid; }
.edu {
  display: grid;
  grid-template-columns: 1fr 100px;
  gap: 20px;
  padding: 16px 0;
  border-bottom: var(--cv-rule-soft);
  align-items: baseline;
}
.edu:last-child { border-bottom: none; }
.edu .name {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: 15.5px;
  letter-spacing: -0.012em;
  line-height: 1.2;
  margin: 0;
}
.edu .name .red { color: var(--vm-red); }
.edu .where {
  margin: 3px 0 0;
  font-family: var(--font-display);
  font-size: 13px;
  letter-spacing: -0.005em;
  color: var(--vm-dim);
}
.edu .year {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--vm-ink);
  text-align: right;
  font-variant-numeric: tabular-nums;
}

/* ============================================================
   §02 ÁREAS OPERATIVAS
   ============================================================ */
.areas-list {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  border-top: var(--cv-rule);
  border-bottom: var(--cv-rule);
  margin-bottom: 24px;
}
.area {
  display: flex;
  flex-direction: column;
  gap: 10px;
  padding: 22px 22px 24px 0;
  border-right: var(--cv-rule-soft);
  align-items: start;
}
.area:nth-child(2) { padding-left: 22px; padding-right: 22px; }
.area:last-child   { padding-left: 22px; padding-right: 0; border-right: none; }

.area .tag {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--vm-dim);
}
.area .body { display: grid; gap: 8px; }
.area .title {
  margin: 0;
  font-family: var(--font-display);
  font-weight: 500;
  font-size: 16px;
  letter-spacing: -0.012em;
  line-height: 1.2;
  text-wrap: balance;
}
.area .title .red { color: var(--vm-red); }
.area .desc {
  margin: 0;
  font-family: var(--font-display);
  font-size: 12.5px;
  line-height: 1.55;
  letter-spacing: -0.003em;
  text-wrap: pretty;
  color: var(--vm-ink);
}

/* ============================================================
   §04 COMPETENCIAS
   ============================================================ */
.skills {
  display: grid;
  grid-template-columns: 130px 1fr;
  gap: 28px;
  border-top: var(--cv-rule);
  padding: 18px 0 24px;
}
.skills .head-meta {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--vm-dim);
}
.skills .head-meta .red { color: var(--vm-red); }

.skills .grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 20px 32px;
}
.skill-group .gname {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--vm-dim);
  margin-bottom: 10px;
  display: flex;
  gap: 8px;
  align-items: baseline;
}
.skill-group .gname .red { color: var(--vm-red); }
.skill-group ul {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: 4px;
}
.skill-group ul li {
  font-family: var(--font-display);
  font-size: 13.5px;
  line-height: 1.45;
  letter-spacing: -0.005em;
}

/* ============================================================
   §05 IDIOMAS / EXTRA
   ============================================================ */
.idiomas {
  display: block;
  border-top: var(--cv-rule);
  padding: 18px 0 24px;
}
.idiomas .head-meta {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--vm-dim);
}
.idiomas .head-meta .red { color: var(--vm-red); }

.idiomas .row {
  display: flex;
  flex-wrap: wrap;
  gap: 28px 48px;
}
.idiomas .lang {
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.idiomas .lang .l {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: 18px;
  letter-spacing: -0.018em;
  line-height: 1.2;
}
.idiomas .lang .lvl {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--vm-dim);
}

/* ============================================================
   FOOTER
   ============================================================ */
.cv-foot {
  margin-top: 24px;
  padding-top: 14px;
  border-top: var(--cv-rule);
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  font-family: var(--font-mono);
  font-size: 9.5px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--vm-dim);
}
.cv-foot .red { color: var(--vm-red); }
.cv-foot .ink { color: var(--vm-ink); }

/* ============================================================
   PRINT
   ============================================================ */
@page {
  size: A4;
  margin: 14mm;
}
@media print {
  body { background: #fff; }
  .sheet {
    width: 100%;
    min-height: 0;
    margin: 0;
    padding: 0;
    box-shadow: none;
  }
  /* Mantener cada entrada/fila íntegra, pero dejar fluir las secciones
     largas (Trayectoria supera una página): si .cv-sec llevara
     break-inside:avoid, empujaría la sección entera a la página
     siguiente y dejaría media página 1 en blanco. */
  .exp, .edu, .area { break-inside: avoid; page-break-inside: avoid; }
  /* No dejar un título de sección huérfano al pie de página. */
  .cv-sec-title, .cv-sec-sub, .kpi-heading { break-after: avoid; page-break-after: avoid; }
}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 820px) {
  :root { --cv-pad-x: 28px; --cv-pad-y: 32px; }
  .sheet { width: 100%; min-height: 0; }
  .cv-name { font-size: 48px; }
  .cv-contact { grid-template-columns: 1fr 1fr; gap: 20px; }
  .kpi-band { grid-template-columns: 1fr; }
  .kpi { border-right: none; border-bottom: var(--cv-rule-soft); padding: 24px 0 !important; min-height: 0; }
  .kpi:last-child { border-bottom: none; }
  .perfil, .exp, .formacion, .skills, .idiomas { grid-template-columns: 1fr; gap: 16px; }
  .skills .grid { grid-template-columns: 1fr; }
  .edu { grid-template-columns: 1fr; gap: 6px; }
  .edu .year { text-align: left; }
}

/* ============================================================
   PRINT / PDF — forzar el layout de ESCRITORIO
   Una página A4 mide ~793px CSS (< 820px), así que al imprimir se
   dispararía el breakpoint responsive y el CV colapsaría a la versión
   móvil (columnas apiladas). Reafirmamos aquí las rejillas de
   escritorio para que el PDF salga "tal cual el diseño".
   Solo afecta a @media print; la web responsive queda intacta.
   ============================================================ */
@media print {
  .cv-name      { font-size: 64px !important; }
  .cv-contact   { grid-template-columns: repeat(4, 1fr) !important; gap: 20px !important; }
  .kpi-band     { grid-template-columns: repeat(3, 1fr) !important; }
  .kpi {
    border-right: var(--cv-rule-soft) !important;
    border-bottom: none !important;
    padding: 24px 20px 24px 0 !important;
    min-height: 134px !important;
  }
  .kpi:nth-child(2) { padding-left: 20px !important; padding-right: 20px !important; }
  .kpi:last-child   { padding-left: 20px !important; padding-right: 0 !important; border-right: none !important; }
  .perfil    { grid-template-columns: 160px 1fr !important; gap: 36px !important; }
  .exp       { grid-template-columns: 170px 1fr  !important; gap: 40px !important; }
  .formacion { grid-template-columns: 130px 1fr  !important; gap: 28px !important; }
  .skills    { grid-template-columns: 130px 1fr  !important; gap: 28px !important; }
  .skills .grid { grid-template-columns: 1fr 1fr !important; }
  .edu       { grid-template-columns: 1fr 100px  !important; gap: 20px !important; }
  .edu .year { text-align: right !important; }
}
