/* ── MAPA HERO ── */
.mapa-hero { padding:140px 80px 80px; max-width:1080px; margin:0 auto; display:grid; grid-template-columns:1fr 1fr; gap:80px; align-items:center; }
.hero-tag { display:flex; align-items:center; gap:10px; font-size:10px; font-weight:500; letter-spacing:2.5px; text-transform:uppercase; color:var(--gold); margin-bottom:24px; opacity:0; animation:fadeUp 0.6s ease 0.1s forwards; }
.tag-line { width:28px; height:0.5px; background:var(--cream-border); }
.mapa-h1 { font-family:var(--font-display); font-size:clamp(38px,5vw,64px); font-weight:300; line-height:1.1; color:var(--olive-text); margin-bottom:20px; opacity:0; animation:fadeUp 0.8s ease 0.2s forwards; }
.mapa-h1 em { font-style:italic; color:var(--olive); }
.mapa-sub { font-size:15px; font-weight:300; color:var(--olive-mid); line-height:1.85; margin-bottom:36px; opacity:0; animation:fadeUp 0.8s ease 0.35s forwards; }
.mapa-cta-btn { display:inline-flex; align-items:center; gap:8px; font-size:14px; font-weight:500; color:var(--cream); background:var(--olive); padding:14px 28px; border-radius:var(--radius-sm); cursor:pointer; transition:background 0.2s,transform 0.15s,box-shadow 0.2s; opacity:0; animation:fadeUp 0.8s ease 0.48s forwards; }
.mapa-cta-btn:hover { background:var(--olive-text); transform:translateY(-2px); box-shadow:0 8px 28px rgba(42,49,32,0.15); }
.mapa-cta-btn svg { transition:transform 0.2s; }
.mapa-cta-btn:hover svg { transform:translateX(3px); }

/* ── MINIMAP ── */
.hero-minimap { opacity:0; animation:fadeIn 1s ease 0.4s forwards; }
.minimap-track { position:relative; padding-left:40px; }
.minimap-track::before { content:''; position:absolute; left:12px; top:16px; bottom:16px; width:0.5px; background:linear-gradient(to bottom,var(--gold),var(--olive-light),var(--olive)); }
.minimap-paso { display:flex; align-items:flex-start; gap:16px; padding:12px 0; cursor:pointer; transition:transform 0.2s; }
.minimap-paso:hover { transform:translateX(4px); }
.minimap-paso:hover .mh-name { color:var(--olive-text); }
.mh-dot { position:absolute; left:6px; width:14px; height:14px; border-radius:50%; background:var(--cream); border:1.5px solid var(--cream-border); margin-top:3px; transition:border-color 0.2s,background 0.2s; flex-shrink:0; }
.minimap-paso:hover .mh-dot { border-color:var(--gold); background:var(--gold-light); }
.mh-dot.gold { border-color:var(--gold); background:var(--gold-light); }
.mh-num { font-family:var(--font-display); font-size:13px; font-weight:300; color:var(--gold); min-width:16px; line-height:1.6; }
.mh-name { font-size:13px; font-weight:500; color:var(--olive-text); transition:color 0.2s; }
.mh-label { font-size:11px; color:var(--olive-mid); line-height:1.4; margin-top:1px; }

/* ── PASOS ── */
.pasos-section { padding:0 80px 120px; }
.section-divider { max-width:1080px; margin:0 auto 80px; display:flex; align-items:center; gap:20px; }
.divider-line { flex:1; height:0.5px; background:var(--cream-border); }
.divider-label { font-size:10px; letter-spacing:2px; text-transform:uppercase; color:var(--olive-mid); white-space:nowrap; }
.paso-bloque { max-width:1080px; margin:0 auto 16px; display:grid; grid-template-columns:280px 1fr; border:0.5px solid var(--cream-border); border-radius:var(--radius-lg); overflow:hidden; opacity:0; transform:translateY(16px); transition:opacity 0.7s ease,transform 0.7s ease; scroll-margin-top:88px; }
.paso-bloque.visible { opacity:1; transform:translateY(0); }
.paso-bloque:hover { border-color:rgba(168,196,138,0.5); }
.paso-bloque-meta { background:var(--cream-dark); }
.paso-bloque-meta .paso-sidebar { background:var(--cream-dark); }
.paso-bloque-meta .paso-sidebar::before { display:none; }
.paso-bloque-meta .paso-big-num { color:rgba(74,94,56,0.1); }
.paso-bloque-meta .paso-nombre { color:var(--olive-text); }
.paso-bloque-meta .paso-tagline { color:var(--olive-mid); }
.paso-sidebar { background:var(--olive-night); padding:44px 36px; display:flex; flex-direction:column; justify-content:space-between; position:relative; overflow:hidden; }
.paso-sidebar::before { content:''; position:absolute; inset:0; background:radial-gradient(ellipse 120% 80% at 0% 100%,rgba(168,196,138,0.08) 0%,transparent 60%); }
.paso-big-num { font-family:var(--font-display); font-size:88px; font-weight:300; line-height:1; color:rgba(168,196,138,0.1); position:absolute; top:16px; right:20px; z-index:0; }
.paso-sidebar-content { position:relative; z-index:1; }
.paso-badge { display:inline-flex; align-items:center; gap:6px; font-size:9px; letter-spacing:2px; text-transform:uppercase; color:var(--gold); margin-bottom:16px; }
.paso-badge-dot { width:4px; height:4px; border-radius:50%; background:var(--gold); }
.paso-nombre { font-family:var(--font-display); font-size:26px; font-weight:300; color:#D4E4B8; line-height:1.2; margin-bottom:12px; }
.paso-tagline { font-size:12px; color:rgba(168,196,138,0.45); line-height:1.6; font-style:italic; }
.paso-sidebar-cta { display:inline-flex; align-items:center; gap:6px; font-size:11px; color:rgba(168,196,138,0.4); margin-top:28px; transition:color 0.2s; position:relative; z-index:1; border-bottom:0.5px solid rgba(168,196,138,0.15); padding-bottom:2px; width:fit-content; cursor:pointer; }
.paso-bloque:hover .paso-sidebar-cta { color:var(--olive-light); border-color:rgba(168,196,138,0.35); }
.paso-content { background:var(--cream-dark); padding:44px 48px; }
.paso-desc-text { font-size:15px; color:var(--olive-mid); line-height:1.85; margin-bottom:28px; }
.paso-desc-text strong { color:var(--olive-text); font-weight:500; }
.paso-checklist { list-style:none; display:flex; flex-direction:column; gap:10px; margin-bottom:28px; }
.paso-checklist li { display:flex; align-items:flex-start; gap:12px; font-size:13px; color:var(--olive-mid); line-height:1.6; }
.check-icon { width:18px; height:18px; border-radius:50%; background:rgba(74,94,56,0.08); border:0.5px solid var(--olive-light); display:flex; align-items:center; justify-content:center; flex-shrink:0; margin-top:1px; }
.paso-checklist strong { color:var(--olive-text); font-weight:500; }
.paso-recurso { display:inline-flex; align-items:center; gap:8px; font-size:12px; color:var(--olive); border:0.5px solid var(--olive-light); padding:8px 16px; border-radius:20px; cursor:pointer; transition:background 0.2s,border-color 0.2s; }
.paso-recurso:hover { background:rgba(74,94,56,0.06); border-color:var(--olive); }
.paso-conector { max-width:1080px; margin:0 auto; padding:0 0 0 139px; height:16px; }
.conector-line { width:0.5px; height:16px; background:linear-gradient(to bottom,var(--cream-border),rgba(212,206,188,0.3)); }

/* ── MAPA CTA ── */
.mapa-cta-section { background:var(--cream); padding:120px 80px; text-align:center; position:relative; overflow:hidden; }
.mapa-cta-section::before { content:''; position:absolute; inset:0; pointer-events:none; background-image:radial-gradient(ellipse 60% 50% at 50% 0%,rgba(168,196,138,0.09) 0%,transparent 65%); }
.mapa-cta-inner { position:relative; z-index:1; }
.mapa-cta-tag { font-size:10px; letter-spacing:2.5px; text-transform:uppercase; color:var(--gold); margin-bottom:18px; }
.mapa-cta-h2 { font-family:var(--font-display); font-size:clamp(32px,4.5vw,54px); font-weight:300; color:var(--olive-text); line-height:1.15; max-width:540px; margin:0 auto 16px; }
.mapa-cta-sub { font-size:15px; color:var(--olive-mid); max-width:380px; margin:0 auto 44px; line-height:1.8; }
.cta-box { display:inline-flex; align-items:center; justify-content:space-between; gap:32px; background:var(--olive-night); border:0.5px solid rgba(168,196,138,0.15); border-radius:var(--radius-lg); padding:28px 36px; max-width:560px; width:100%; text-align:left; }
.cta-box-left { display:flex; align-items:center; gap:16px; }
.cta-box-icon { width:48px; height:48px; border-radius:var(--radius-md); background:rgba(168,196,138,0.08); border:0.5px solid rgba(168,196,138,0.15); display:flex; align-items:center; justify-content:center; flex-shrink:0; }
.cta-box-title { font-size:15px; font-weight:500; color:#D4E4B8; margin-bottom:3px; }
.cta-box-desc { font-size:11px; color:rgba(168,196,138,0.4); }
.cta-box-btn { display:inline-flex; align-items:center; gap:8px; flex-shrink:0; font-size:13px; font-weight:500; color:var(--olive-night); background:var(--olive-light); padding:12px 22px; border-radius:var(--radius-sm); cursor:pointer; transition:background 0.2s,transform 0.15s; white-space:nowrap; }
.cta-box-btn:hover { background:#BDD89E; transform:translateY(-1px); }
.cta-box-btn svg { transition:transform 0.2s; }
.cta-box-btn:hover svg { transform:translateX(3px); }
