/* ============================================================
   ivanro.com — shared design system
   Used by: index.html (historia) + programa.html (oferta)
   ============================================================ */
*{margin:0;padding:0;box-sizing:border-box}
:root{
  --navy:#0f1629;
  --navy-soft:#161e38;
  --gold:#f0b429;
  --purple:#8b5cf6;
  --green:#22c55e;
  --green-dark:#16a34a;
  --cream:#f0ede7;
  --card:#ffffff;
  --text:#1c1917;
  --muted:#78716c;
  --border:#e5ddd6;
  --font-head:'Barlow Condensed',sans-serif;
  --font-body:'Inter',system-ui,-apple-system,sans-serif;
  /* Unified type: labels, nav, buttons all use the condensed display face (no more monospace) */
  --font-mono:'Barlow Condensed',sans-serif;
}
html{scroll-behavior:smooth}
body{background:var(--cream);color:var(--text);font-family:var(--font-body);font-size:16px;line-height:1.7}
a{color:inherit;text-decoration:none}

/* NAV */
nav{
  position:sticky;top:0;z-index:100;
  background:var(--navy);
  display:flex;align-items:center;justify-content:space-between;
  padding:.7rem 1.5rem;
  border-bottom:1px solid rgba(255,255,255,.06);
}
.nav-brand{font-family:var(--font-head);font-weight:700;font-size:.82rem;letter-spacing:.13em;text-transform:uppercase;color:rgba(255,255,255,.78)}
.nav-brand span{color:var(--gold)}
.nav-right{display:flex;align-items:center;gap:1.25rem}
.nav-link{font-family:var(--font-head);font-weight:700;font-size:.82rem;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.72);transition:color .2s}
.nav-link:hover{color:#fff}
.nav-cta{
  background:var(--green);color:#fff;
  font-family:var(--font-head);font-weight:700;font-size:.84rem;letter-spacing:.09em;text-transform:uppercase;
  padding:.42rem 1.05rem;white-space:nowrap;transition:background .2s;
}
.nav-cta:hover{background:var(--green-dark)}
.nav-cta.gold{background:var(--gold);color:#0f1629;font-weight:700}
.nav-cta.gold:hover{background:var(--gold);opacity:.88}

/* HERO */
.hero{
  background:var(--navy);
  padding:5rem 1.5rem 4.5rem;
  text-align:center;
}
.hero-eyebrow{
  font-family:var(--font-head);font-weight:700;font-size:.85rem;letter-spacing:.2em;text-transform:uppercase;
  color:rgba(255,255,255,.72);margin-bottom:2rem;
}
.hero-headline{
  font-family:var(--font-head);font-weight:900;
  font-size:clamp(2.8rem,11vw,6.5rem);
  line-height:.93;letter-spacing:.01em;text-transform:uppercase;
  margin-bottom:2rem;
}
.hero-headline .line1{color:#ffffff;display:block}
.hero-headline .line2{color:var(--gold);display:block}
.hero-headline .line3{color:#c4b5fd;display:block}
.hero-sub{
  max-width:560px;margin:0 auto 2.75rem;
  color:rgba(255,255,255,.6);font-size:.95rem;line-height:1.8;
}
.hero-sub strong{color:rgba(255,255,255,.92);font-weight:600}

/* HERO PORTRAIT (story page) */
.hero-portrait{
  width:160px;height:160px;border-radius:50%;margin:0 auto 2rem;overflow:hidden;
  border:2px solid rgba(255,255,255,.12);
  background:linear-gradient(150deg,#1c2748,#0b1120);
  position:relative;display:flex;align-items:center;justify-content:center;
}
.hero-portrait img{width:100%;height:100%;object-fit:cover;display:block}
.hero-portrait .ph{display:none}
.hero-portrait.noimg .ph{
  display:flex;flex-direction:column;align-items:center;gap:.3rem;
  color:rgba(255,255,255,.4);font-family:var(--font-mono);font-size:.52rem;
  letter-spacing:.1em;text-transform:uppercase;text-align:center;padding:.5rem;line-height:1.5;
}

/* BUTTONS */
.btn-group{display:flex;gap:.75rem;justify-content:center;flex-wrap:wrap}
.btn-wa{
  display:inline-flex;align-items:center;gap:.5rem;
  background:var(--green);color:#fff;
  font-family:var(--font-head);font-size:.95rem;letter-spacing:.1em;text-transform:uppercase;
  padding:.75rem 1.6rem;font-weight:700;transition:background .2s;
}
.btn-wa:hover{background:var(--green-dark)}
.btn-gold{
  display:inline-flex;align-items:center;gap:.5rem;
  background:var(--gold);color:#0f1629;
  font-family:var(--font-head);font-size:.95rem;letter-spacing:.1em;text-transform:uppercase;
  padding:.75rem 1.6rem;font-weight:700;transition:opacity .2s;
}
.btn-gold:hover{opacity:.88}
.btn-ghost{
  display:inline-flex;align-items:center;gap:.5rem;
  background:transparent;color:#fff;border:1px solid rgba(255,255,255,.25);
  font-family:var(--font-head);font-size:.95rem;letter-spacing:.1em;text-transform:uppercase;
  padding:.75rem 1.6rem;font-weight:700;transition:border-color .2s,background .2s;
}
.btn-ghost:hover{border-color:#fff;background:rgba(255,255,255,.05)}
.hero-trust{
  margin-top:2.5rem;
  font-family:var(--font-head);font-weight:700;font-size:.8rem;letter-spacing:.14em;text-transform:uppercase;
  color:rgba(255,255,255,.55);
}

/* SECTION LABEL */
.sec-label{
  display:flex;align-items:center;gap:1rem;
  padding:3rem 1.5rem 0;max-width:880px;margin:0 auto;
}
.sec-label::before,.sec-label::after{content:'';flex:1;height:1px;background:var(--border)}
.sec-label span{
  font-family:var(--font-mono);font-size:.62rem;letter-spacing:.16em;text-transform:uppercase;
  color:var(--muted);white-space:nowrap;
}
.sec-label.dark-lbl::before,.sec-label.dark-lbl::after{background:rgba(255,255,255,.09)}
.sec-label.dark-lbl span{color:rgba(255,255,255,.28)}

/* SECTIONS */
.sec{padding:2.5rem 1.5rem 1rem;max-width:880px;margin:0 auto}
h2.title{
  font-family:var(--font-head);font-weight:900;
  font-size:clamp(1.75rem,5vw,2.6rem);
  text-transform:uppercase;line-height:1;margin-bottom:1.25rem;letter-spacing:.02em;
}
h2.title .hash{color:var(--gold);margin-right:.25rem}
p{margin:.65rem 0;color:#44403c}
strong{color:var(--text)}

/* IS / IS NOT */
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-top:1.25rem}
.card{background:var(--card);border:1px solid var(--border);padding:1.5rem}
.card-lbl{font-family:var(--font-mono);font-size:.62rem;letter-spacing:.16em;text-transform:uppercase;margin-bottom:.7rem}
.card-lbl.yes{color:#059669}.card-lbl.no{color:#dc2626}
.card p{font-size:.9rem;margin:0}

/* BULLET LIST */
.blist{list-style:none;margin-top:1rem}
.blist li{
  display:flex;align-items:flex-start;gap:.75rem;
  padding:.55rem 0;border-bottom:1px solid var(--border);
  font-size:.93rem;color:#44403c;
}
.blist li::before{content:'›';color:var(--gold);font-size:1.1rem;flex-shrink:0;margin-top:.1rem;font-weight:700}
.blist li.x::before{content:'×';color:#dc2626;font-size:1rem}

/* QUOTE */
.quote{
  background:var(--navy);
  padding:2rem 2rem;margin:2rem 0;
  border-left:3px solid var(--purple);
}
.quote blockquote{
  font-family:var(--font-head);font-weight:900;
  font-size:clamp(1.15rem,4vw,1.75rem);
  text-transform:uppercase;letter-spacing:.04em;line-height:1.2;color:#fff;
}
.quote-foot{
  margin-top:.75rem;
  font-family:var(--font-mono);font-size:.61rem;letter-spacing:.13em;text-transform:uppercase;
  color:rgba(255,255,255,.35);
}

/* STEPS */
.steps{margin-top:1.5rem;display:flex;flex-direction:column;gap:.5rem}
.step{
  display:grid;grid-template-columns:3.5rem 1fr;
  background:var(--card);border:1px solid var(--border);padding:1.25rem 1.5rem;
}
.step-n{
  font-family:var(--font-head);font-weight:900;font-size:2rem;
  color:var(--border);line-height:1;padding-top:.1rem;
}
.step-t{font-weight:600;color:var(--text);margin-bottom:.25rem;font-size:.95rem}
.step p{font-size:.88rem;margin:0}

/* 4-GRID */
.four-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-top:1.25rem}
.feat{background:var(--card);border:1px solid var(--border);padding:1.5rem}
.feat-lbl{font-family:var(--font-mono);font-size:.62rem;letter-spacing:.16em;text-transform:uppercase;color:var(--purple);margin-bottom:.6rem}
.feat p{font-size:.88rem;margin:0}

/* SPLIT (text + photo) */
.split{display:grid;grid-template-columns:1fr 1fr;gap:2rem;align-items:center;margin-top:.5rem}
.split.rev .split-text{order:2}
.split.rev .split-media{order:1}
.split-text p:first-child{margin-top:0}

/* PHOTO BLOCK */
.photo{
  position:relative;width:100%;aspect-ratio:4/5;overflow:hidden;
  border:1px solid var(--border);
  background:linear-gradient(150deg,#e9e3db,#d6cdc1);
}
.photo img{width:100%;height:100%;object-fit:cover;display:block}
.photo-tag{
  position:absolute;top:.85rem;left:.85rem;z-index:2;
  font-family:var(--font-head);font-weight:700;font-size:.8rem;letter-spacing:.16em;text-transform:uppercase;
  padding:.3rem .75rem;background:var(--navy);color:rgba(255,255,255,.85);
}
.photo-tag.now{background:var(--gold);color:var(--navy)}
.photo .ph{display:none}
.photo.noimg .ph{
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.4rem;
  position:absolute;inset:0;color:var(--muted);font-family:var(--font-mono);font-size:.6rem;
  letter-spacing:.12em;text-transform:uppercase;text-align:center;padding:1rem;line-height:1.6;
}
.photo .ph svg{opacity:.4}

/* FIND ME (social cards) */
.find-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem;margin-top:1.25rem}
.find-card{
  display:block;background:var(--card);border:1px solid var(--border);padding:1.25rem 1.5rem;
  transition:border-color .2s,transform .2s;
}
.find-card:hover{border-color:var(--gold);transform:translateY(-2px)}
.fc-plat{font-family:var(--font-mono);font-size:.6rem;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);margin-bottom:.35rem}
.fc-handle{font-weight:600;color:var(--text);font-size:1.02rem}
.fc-desc{font-size:.82rem;color:var(--muted);margin-top:.25rem}

/* LEVELS — rutas ascendentes (Trabajador / Operador / Creador) */
.levels{display:flex;flex-direction:column;gap:1rem;margin-top:1.25rem}
.level{background:var(--card);border:1px solid var(--border);border-left:4px solid var(--border);padding:1.5rem 1.6rem}
.level.l1{border-left-color:var(--green)}
.level.l2{border-left-color:var(--gold)}
.level.l3{border-left-color:var(--purple)}
.level-head{display:flex;align-items:baseline;gap:.85rem;flex-wrap:wrap}
.level-n{font-family:var(--font-mono);font-weight:700;font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;color:var(--muted)}
.level-name{font-family:var(--font-head);font-weight:900;font-size:1.6rem;text-transform:uppercase;letter-spacing:.02em;line-height:1}
.level.l1 .level-name{color:var(--green-dark)}
.level.l2 .level-name{color:#b9831a}
.level.l3 .level-name{color:#6d4bd0}
.level-goal{color:#3a352f;font-size:.96rem;margin:.55rem 0 1rem}
.level-meters{display:flex;gap:1.5rem;flex-wrap:wrap;margin-bottom:1.1rem}
.meter{font-family:var(--font-mono);font-weight:700;font-size:.58rem;letter-spacing:.1em;text-transform:uppercase;color:var(--muted)}
.meter .dots{letter-spacing:.2em;margin-left:.4rem;color:var(--text);font-size:.7rem}
.level h4{font-family:var(--font-mono);font-weight:700;font-size:.62rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);margin:.4rem 0 .45rem}
.level ul{list-style:none;margin:0}
.level li{display:flex;gap:.6rem;font-size:.9rem;color:#3a352f;padding:.22rem 0}
.level li::before{content:'›';color:var(--gold);font-weight:700;flex-shrink:0}
.level-fit{font-size:.85rem;color:var(--muted);border-top:1px solid var(--border);margin-top:1rem;padding-top:.8rem}
.level-fit b{color:var(--text);font-weight:600}

/* POSSIBILITIES (lo que puede abrir — no promesas) */
.poss{list-style:none;margin-top:1rem;display:grid;grid-template-columns:1fr 1fr;gap:.45rem 1.5rem}
.poss li{display:flex;gap:.6rem;font-size:.9rem;color:#3a352f}
.poss li::before{content:'+';color:var(--green-dark);font-weight:700;flex-shrink:0}
@media(max-width:640px){.poss{grid-template-columns:1fr}}

/* RETO OASIS — free on-ramp box */
.reto{background:var(--card);border:1px dashed #cbb9a3;padding:1.5rem 1.6rem;margin-top:1.25rem}
.reto .feat-lbl{color:var(--green-dark)}
.reto p{font-size:.92rem;margin:.3rem 0 0}

/* DARK ABOUT / TRUST */
.dark-sec{background:var(--navy);padding:3rem 1.5rem 2rem}
.dark-inner{max-width:880px;margin:0 auto}
.dark-inner h2.title{color:#fff}
.dark-inner p{color:rgba(255,255,255,.65)}
.dark-inner strong{color:#fff}
.trust-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-top:1.5rem}
.trust-card{background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.1);padding:1.25rem}
.trust-card .feat-lbl{color:var(--gold)}
.trust-card p{color:rgba(255,255,255,.6);font-size:.88rem;margin:0}
.trust-card strong{color:#fff}

/* PRICING */
.price-sec{background:var(--navy-soft);padding:3rem 1.5rem 2.5rem}
.price-inner{max-width:880px;margin:0 auto}
.price-amt{
  font-family:var(--font-head);font-weight:900;
  font-size:clamp(3rem,10vw,5.5rem);color:var(--gold);line-height:1;
}
.price-sub{
  font-family:var(--font-head);font-weight:700;font-size:.9rem;letter-spacing:.12em;text-transform:uppercase;
  color:rgba(255,255,255,.62);margin-left:.5rem;
}
.price-list{list-style:none;margin:1.25rem 0 0}
.price-list li{
  display:flex;align-items:flex-start;gap:.6rem;
  color:rgba(255,255,255,.65);font-size:.92rem;padding:.4rem 0;
}
.price-list li::before{content:'›';color:var(--gold);flex-shrink:0;font-weight:700}
.price-list li>span{flex:1}
.price-list strong{color:#fff}
.price-btns{display:flex;gap:.75rem;flex-wrap:wrap;margin-top:2rem}
.contact-row{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-top:2rem}
.contact-card{border:1px solid rgba(255,255,255,.12);padding:1rem}
.contact-lbl{font-family:var(--font-head);font-weight:700;font-size:.74rem;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.6);margin-bottom:.4rem}
.contact-card a{font-family:var(--font-head);font-weight:700;font-size:.98rem;letter-spacing:.04em;color:#fff;display:block;transition:color .2s}
.contact-card a:hover{color:var(--gold)}

/* FINAL CTA */
.final{background:var(--navy);text-align:center;padding:4.5rem 1.5rem 4rem;border-top:1px solid rgba(255,255,255,.06)}
.final-eye{
  font-family:var(--font-head);font-weight:700;font-size:.82rem;letter-spacing:.2em;text-transform:uppercase;
  color:rgba(255,255,255,.6);margin-bottom:1.75rem;
}
.final-hl{
  font-family:var(--font-head);font-weight:900;
  font-size:clamp(2.5rem,9vw,5.5rem);
  text-transform:uppercase;line-height:.93;color:#fff;margin-bottom:1.25rem;
}
.final-hl span{color:var(--gold)}
.final-sub{max-width:520px;margin:0 auto 2.75rem;color:rgba(255,255,255,.5);font-size:.92rem;line-height:1.75}
.final-sub strong{color:rgba(255,255,255,.88)}

/* DOC / ARTICLE PAGES (knowledge base) */
.doc{max-width:760px;margin:0 auto;padding:2.75rem 1.5rem 1rem}
.doc .crumb{font-family:var(--font-mono);font-size:.65rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);margin-bottom:1.5rem}
.doc .crumb a{color:var(--muted)}
.doc .crumb a:hover{color:var(--navy)}
.doc h1{font-family:var(--font-head);font-weight:900;font-size:clamp(2rem,6vw,3rem);line-height:1.03;text-transform:uppercase;letter-spacing:.01em;margin-bottom:.6rem}
.doc .lede{font-size:1.08rem;color:#3a352f;margin:.6rem 0 1rem;line-height:1.7}
.doc .byline{font-family:var(--font-mono);font-size:.64rem;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);padding-bottom:1.25rem;border-bottom:1px solid var(--border);margin-bottom:1.5rem}
.doc h2{font-family:var(--font-head);font-weight:900;font-size:1.55rem;text-transform:uppercase;letter-spacing:.02em;margin:2.1rem 0 .6rem;line-height:1.05}
.doc h2 .hash{color:var(--gold);margin-right:.2rem}
.doc h3{font-weight:600;font-size:1.05rem;color:var(--navy);margin:1.35rem 0 .35rem}
.doc p{margin:.7rem 0;color:#3a352f}
.doc ul,.doc ol{padding-left:1.25rem;margin:.7rem 0;color:#3a352f}
.doc li{margin:.4rem 0}
.doc strong{color:var(--text)}
.doc blockquote{border-left:3px solid var(--purple);background:#fff;padding:1rem 1.25rem;margin:1.25rem 0;font-style:italic;color:#52493d}
.doc table{width:100%;border-collapse:collapse;font-size:.9rem;margin:1rem 0}
.doc th{text-align:left;font-family:var(--font-mono);font-size:.6rem;letter-spacing:.08em;text-transform:uppercase;color:var(--muted);padding:.55rem .7rem;border-bottom:1px solid var(--border)}
.doc td{padding:.55rem .7rem;border-bottom:1px solid var(--border);vertical-align:top}
.doc-cta{background:var(--navy);padding:1.6rem 1.5rem;margin:2rem 0;border-left:3px solid var(--gold)}
.doc-cta .dc-lbl{font-family:var(--font-mono);font-size:.62rem;letter-spacing:.15em;text-transform:uppercase;color:var(--gold);margin-bottom:.5rem}
.doc-cta p{color:rgba(255,255,255,.72);margin:.3rem 0 1rem;font-size:.95rem}
.doc-cta .btn-gold,.doc-cta .btn-ghost{margin-top:.25rem}
.faq{margin-top:.5rem}
.faq dt{font-weight:600;color:var(--navy);margin-top:1.15rem}
.faq dd{margin:.3rem 0 0;color:#3a352f}
.related{margin:2rem 0 0;padding-top:1.25rem;border-top:1px solid var(--border)}
.related .rel-lbl{font-family:var(--font-mono);font-size:.62rem;letter-spacing:.15em;text-transform:uppercase;color:var(--muted);margin-bottom:.6rem}
.related a{display:block;color:var(--navy);font-weight:500;padding:.3rem 0;border-bottom:1px solid var(--border)}
.related a:hover{color:var(--gold)}

/* FOOTER */
footer{
  background:#070c17;
  padding:1.6rem 1.5rem;
  font-family:var(--font-head);font-weight:700;font-size:.78rem;letter-spacing:.09em;text-transform:uppercase;
  color:rgba(255,255,255,.45);
}
.foot-inner{
  max-width:880px;margin:0 auto;
  display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:.75rem;
}
.foot-links{display:flex;gap:1.5rem;flex-wrap:wrap}
.foot-links a{color:rgba(255,255,255,.45);transition:color .2s}
.foot-links a:hover{color:var(--gold)}

/* RESPONSIVE */
@media(max-width:640px){
  .hero{padding:3rem 1.25rem 3.5rem}
  .btn-group{flex-direction:column;align-items:center}
  .btn-wa,.btn-gold,.btn-ghost{width:100%;max-width:320px;justify-content:center}
  .two-col,.four-grid,.trust-grid,.contact-row,.split,.find-grid{grid-template-columns:1fr}
  .split.rev .split-text,.split.rev .split-media{order:0}
  .price-btns{flex-direction:column}
  .price-btns .btn-wa,.price-btns .btn-gold{justify-content:center;width:100%;max-width:320px}
  .foot-inner{flex-direction:column;text-align:center}
  nav{padding:.6rem 1rem}
  .nav-brand{font-size:.58rem}
  .nav-right{gap:.85rem}
  .nav-link{font-size:.6rem}
}
