/* ============================================================
   WPA · _program-page.css
   Iris · 2026-05-08 · estilos específicos de página de programa
   Extiende _page-base.css (no duplica tokens ni componentes base)
   ============================================================ */

/* ========== PROGRAM HERO ========== */
.program-hero {
  position:relative;
  min-height:88vh;
  padding:160px 0 100px;
  overflow:hidden;
  background:var(--black);
}
.program-hero-bg {
  position:absolute; inset:0;
  background-size:cover;
  background-position:center;
  opacity:.55;
  z-index:1;
  filter:saturate(.85) contrast(1.05);
}
.program-hero-bg::after {
  content:""; position:absolute; inset:0;
  background:
    linear-gradient(180deg, rgba(0,0,0,.55) 0%, rgba(0,0,0,.85) 70%, rgba(0,0,0,1) 100%),
    radial-gradient(ellipse at 80% 30%, rgba(201,168,76,.18), transparent 60%);
}
.program-hero .wrap { position:relative; z-index:2; }
.program-hero-grid {
  display:grid;
  grid-template-columns:1.1fr 1fr;
  gap:80px;
  align-items:center;
}
.program-hero-text { max-width:680px; }
.program-tag {
  display:inline-block;
  font-family:'DM Mono', monospace;
  font-size:11px; letter-spacing:.28em;
  text-transform:uppercase; color:var(--gold);
  padding:8px 14px;
  border:1px solid var(--gold);
  border-radius:4px;
  margin-bottom:24px;
}
.program-hero h1 {
  font-family:'Oswald', sans-serif;
  font-weight:600;
  font-size:clamp(38px, 5vw, 68px);
  line-height:1.05;
  letter-spacing:-.005em;
  color:var(--cream);
  text-transform:uppercase;
  margin-bottom:28px;
}
.program-hero h1 em {
  font-family:'Playfair Display', serif;
  font-style:italic;
  font-weight:400;
  text-transform:none;
  color:var(--gold);
}
.program-hero p.lead {
  font-size:clamp(16px, 1.3vw, 19px);
  color:var(--cream-72);
  font-weight:400;
  line-height:1.7;
  margin-bottom:36px;
  max-width:580px;
}
.program-hero-meta {
  display:grid;
  grid-template-columns:1fr 1fr 1fr;
  gap:24px;
  padding:24px 0;
  margin:32px 0 36px;
  border-top:1px solid var(--rule);
  border-bottom:1px solid var(--rule);
}
.program-hero-meta .item {
  display:flex; flex-direction:column; gap:4px;
}
.program-hero-meta .label {
  font-family:'DM Mono', monospace;
  font-size:10px; letter-spacing:.20em;
  color:var(--gold);
  text-transform:uppercase;
}
.program-hero-meta .value {
  font-family:'Oswald', sans-serif;
  font-size:18px; font-weight:500;
  color:var(--cream);
  letter-spacing:.02em;
}
.program-hero-cta { display:flex; gap:16px; flex-wrap:wrap; }
.program-hero-portrait {
  position:relative;
  border-radius:8px;
  overflow:hidden;
  aspect-ratio:4/5;
  border:1px solid var(--rule);
  box-shadow:0 30px 80px rgba(0,0,0,.55);
  background:linear-gradient(135deg, var(--navy-3), var(--navy-2));
}
.program-hero-portrait img {
  width:100%; height:100%; object-fit:cover;
}
@media (max-width:980px) {
  .program-hero-grid { grid-template-columns:1fr; gap:48px; }
  .program-hero-meta { grid-template-columns:1fr; gap:16px; }
}

/* ========== PARA QUIÉN ES ========== */
.for-whom-section { padding:120px 0; background:#030710; }
.for-whom-grid {
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:24px;
  margin-top:48px;
}
.for-whom-card {
  padding:32px 28px;
  background:linear-gradient(180deg, rgba(14,29,53,.50), rgba(6,16,31,.30));
  border:1px solid var(--rule-soft);
  border-radius:8px;
}
.for-whom-card.yes { border-left:3px solid var(--gold); }
.for-whom-card.no { border-left:3px solid rgba(237,232,220,.20); opacity:.85; }
.for-whom-card .head {
  display:flex; align-items:center; gap:12px;
  margin-bottom:18px;
  font-family:'DM Mono', monospace;
  font-size:11px; letter-spacing:.24em;
  text-transform:uppercase; color:var(--gold);
}
.for-whom-card.no .head { color:rgba(237,232,220,.50); }
.for-whom-card .head .icon {
  width:24px; height:24px; border-radius:50%;
  display:inline-flex; align-items:center; justify-content:center;
  font-size:12px;
  background:rgba(201,168,76,.15);
}
.for-whom-card.no .head .icon { background:rgba(237,232,220,.10); }
.for-whom-card ul li {
  font-family:'DM Sans', sans-serif;
  font-size:15px;
  color:var(--cream-85);
  line-height:1.6;
  padding:10px 0;
  border-bottom:1px solid rgba(237,232,220,.05);
}
.for-whom-card ul li:last-child { border-bottom:none; }
.for-whom-card.no ul li { color:rgba(237,232,220,.55); }
@media (max-width:780px) { .for-whom-grid { grid-template-columns:1fr; } }

/* ========== INCLUYE ========== */
.includes-section { padding:120px 0; background:var(--black); }
.includes-grid {
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:24px;
  margin-top:48px;
}
.includes-cell {
  padding:28px 24px;
  background:linear-gradient(180deg, rgba(20,37,64,.40), rgba(6,16,31,.20));
  border:1px solid var(--rule-soft);
  border-radius:6px;
}
.includes-cell .num {
  font-family:'Oswald', sans-serif;
  font-size:42px;
  font-weight:600;
  color:var(--gold);
  line-height:1;
  margin-bottom:14px;
  letter-spacing:-.02em;
}
.includes-cell .title {
  font-family:'Oswald', sans-serif;
  font-size:18px;
  font-weight:600;
  letter-spacing:.04em;
  text-transform:uppercase;
  color:var(--cream);
  margin-bottom:12px;
  line-height:1.3;
}
.includes-cell .desc {
  font-family:'DM Sans', sans-serif;
  font-size:14px;
  color:var(--cream-72);
  line-height:1.6;
}
@media (max-width:980px) { .includes-grid { grid-template-columns:1fr 1fr; } }
@media (max-width:600px) { .includes-grid { grid-template-columns:1fr; } }

/* ========== HOW IT WORKS ========== */
.how-section { padding:120px 0; background:#030710; }
.how-list {
  margin-top:48px;
  display:flex;
  flex-direction:column;
}
.how-step {
  display:grid;
  grid-template-columns:80px 1fr;
  gap:32px;
  padding:32px 0;
  border-bottom:1px solid var(--rule-soft);
  align-items:start;
}
.how-step:last-child { border-bottom:none; }
.how-step .num {
  font-family:'Oswald', sans-serif;
  font-size:48px;
  font-weight:600;
  color:var(--gold);
  line-height:.9;
  letter-spacing:-.02em;
}
.how-step .body .title {
  font-family:'Oswald', sans-serif;
  font-size:24px;
  font-weight:600;
  letter-spacing:.02em;
  text-transform:uppercase;
  color:var(--cream);
  margin-bottom:10px;
}
.how-step .body .desc {
  font-family:'DM Sans', sans-serif;
  font-size:15px;
  color:var(--cream-72);
  line-height:1.7;
  max-width:760px;
}

/* ========== RESULTS ========== */
.results-section { padding:120px 0; background:var(--black); }
.results-grid {
  display:grid;
  grid-template-columns:repeat(2, 1fr);
  gap:32px;
  margin-top:48px;
}
.result-cell {
  padding:32px 28px;
  background:linear-gradient(135deg, rgba(201,168,76,.05), transparent 60%);
  border:1px solid var(--rule);
  border-radius:8px;
}
.result-cell .icon {
  width:48px; height:48px;
  border:1px solid var(--gold);
  border-radius:8px;
  display:flex; align-items:center; justify-content:center;
  color:var(--gold); font-size:20px;
  margin-bottom:18px;
}
.result-cell .title {
  font-family:'Oswald', sans-serif;
  font-size:20px;
  font-weight:600;
  letter-spacing:.02em;
  text-transform:uppercase;
  color:var(--cream);
  margin-bottom:10px;
}
.result-cell .desc {
  font-family:'DM Sans', sans-serif;
  font-size:14.5px;
  color:var(--cream-72);
  line-height:1.65;
}
@media (max-width:780px) { .results-grid { grid-template-columns:1fr; } }

/* ========== AUTHOR MINI ========== */
.author-mini-section {
  padding:100px 0;
  background:#030710;
  border-top:1px solid var(--rule-soft);
  border-bottom:1px solid var(--rule-soft);
}
.author-mini-grid {
  display:grid;
  grid-template-columns:200px 1fr;
  gap:48px;
  align-items:center;
  max-width:920px;
  margin:0 auto;
}
.author-mini-photo {
  width:200px; height:200px;
  border-radius:50%;
  overflow:hidden;
  border:2px solid var(--gold);
  box-shadow:0 0 0 6px rgba(201,168,76,.10);
}
.author-mini-photo img { width:100%; height:100%; object-fit:cover; }
.author-mini .role {
  font-family:'DM Mono', monospace;
  font-size:11px; letter-spacing:.28em;
  color:var(--gold); text-transform:uppercase;
  margin-bottom:10px;
}
.author-mini .name {
  font-family:'Oswald', sans-serif;
  font-size:32px; font-weight:600;
  color:var(--cream);
  letter-spacing:-.005em;
  margin-bottom:14px;
}
.author-mini .credentials {
  font-family:'DM Mono', monospace;
  font-size:12px; letter-spacing:.16em;
  color:var(--gold);
  margin-bottom:18px;
  text-transform:uppercase;
}
.author-mini .bio {
  font-family:'DM Sans', sans-serif;
  font-size:15px;
  color:var(--cream-72);
  line-height:1.7;
}
@media (max-width:780px) {
  .author-mini-grid { grid-template-columns:1fr; text-align:center; gap:24px; }
  .author-mini-photo { margin:0 auto; }
}

/* ========== FAQ ========== */
.faq-section { padding:120px 0; background:var(--black); }
.faq-list { max-width:880px; margin:48px auto 0; }
.faq-item {
  border-bottom:1px solid var(--rule-soft);
  padding:24px 0;
}
.faq-item summary {
  font-family:'Oswald', sans-serif;
  font-size:clamp(16px, 1.4vw, 20px);
  font-weight:600;
  letter-spacing:.02em;
  color:var(--cream);
  cursor:pointer;
  list-style:none;
  display:flex; justify-content:space-between; align-items:center;
}
.faq-item summary::-webkit-details-marker { display:none; }
.faq-item summary::after {
  content:'+';
  color:var(--gold);
  font-size:24px;
  font-family:'DM Mono', monospace;
  transition:transform .35s;
}
.faq-item[open] summary::after { transform:rotate(45deg); }
.faq-item p {
  margin-top:18px;
  font-family:'DM Sans', sans-serif;
  font-size:15px;
  color:var(--cream-72);
  line-height:1.7;
  padding-right:48px;
}

/* ========== PROGRAM CTA FINAL ========== */
.program-cta {
  padding:140px 0;
  background:
    radial-gradient(ellipse at 50% 30%, rgba(201,168,76,.12), transparent 60%),
    var(--black);
}
.program-cta .container { text-align:center; max-width:780px; margin:0 auto; }
.program-cta h2 {
  font-family:'Oswald', sans-serif;
  font-size:clamp(32px, 4vw, 52px);
  font-weight:600;
  text-transform:uppercase;
  color:var(--cream);
  line-height:1.1;
  margin-bottom:18px;
}
.program-cta h2 em {
  font-family:'Playfair Display', serif;
  font-style:italic;
  font-weight:400;
  text-transform:none;
  color:var(--gold);
}
.program-cta p {
  font-family:'DM Sans', sans-serif;
  font-size:17px;
  color:var(--cream-72);
  line-height:1.7;
  margin-bottom:36px;
}
.program-cta .btn { padding:22px 44px; font-size:14px; }

/* ========== BREADCRUMB ========== */
.breadcrumb {
  padding:24px 0;
  background:var(--black);
  border-bottom:1px solid var(--rule-soft);
  margin-top:78px; /* compensa header sticky */
}
.breadcrumb ol {
  display:flex; align-items:center; gap:12px;
  font-family:'DM Mono', monospace;
  font-size:11px; letter-spacing:.16em;
  text-transform:uppercase;
  color:var(--cream-50);
}
.breadcrumb a {
  color:var(--cream-72);
  transition:color .25s;
}
.breadcrumb a:hover { color:var(--gold); }
.breadcrumb .sep { color:var(--gold); opacity:.45; }
.breadcrumb .current { color:var(--gold); }
