*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

:root {
  --bg-dark:    #080a0c;
  --bg-card:    #0e1014;
  --bg-card2:   #111418;
  --accent:     #ad977f;
  --accent2:    #c9b49a;
  --gold:       #ad977f;
  --text:       #ffffff;
  --muted:      #8a8070;
  --border:     rgba(173,151,127,.15);
  --white-card: #f0ebe4;
}

@font-face {
  font-family:rfont;
  src: url("../fonts/Brother-1816-Regular.ttf");
  
}
@font-face {
  font-family:rfont2;
  src: url("../fonts/AbrilFatface-Regular.ttf") ;
  
}

html { scroll-behavior: smooth; }

body {
  font-family: rfont, sans-serif;
  background: var(--bg-dark);
  color: var(--text);
  overflow-x: hidden;
  user-select: none;
}

#network-canvas {
  position: fixed; inset: 0; z-index: 0;
  width: 100%; height: 100%;
  opacity: .8; pointer-events: none;
}

/* ─── NAV ─── */
nav {
  position: fixed; top: 0; left: 0; right: 0; z-index: 100;
  display: flex; align-items: center; justify-content: space-between;
  padding: 18px 56px;
  
  backdrop-filter: blur(16px);
  
}
.nav-logo { font-family: 'rfont'; font-size: 1.7rem; letter-spacing: .12em; color: var(--text); }
.nav-logo-img { width: 150px; height: auto; }
.nav-logo span { color: var(--accent); }
.nav-links { display: flex; gap: 36px; align-items: center; }
.nav-links a {
  font-family: 'rfont'; font-size: .8rem; font-weight: 600;
  text-transform: uppercase; letter-spacing: .14em;
  color: rgba(255,255,255,.55); text-decoration: none; transition: color .25s;
}
.nav-links a:hover { color: #fff; }
.btn-register {
  font-family: 'rfont' ; font-weight: 700;
  font-size: .78rem; letter-spacing: .14em; text-transform: uppercase;
  padding: 10px 26px;
  border: 1.5px solid var(--text);
  color: var(--text); background: transparent;
  cursor: pointer; transition: all .25s;
  display: flex; align-items: center; gap: 8px;
}
.btn-register::after { content: '↗'; font-size: .85rem; }
.btn-register:hover { background: var(--text); color: var(--bg-dark); }

.nav-hamburger {
  display: none; flex-direction: column; gap: 5px;
  background: none; border: none; cursor: pointer; padding: 4px;
}
.nav-hamburger span { display: block; width: 24px; height: 2px; background: var(--accent); border-radius: 2px; transition: all .3s; }

.mobile-menu {
  position: fixed; top: 64px; left: 0; right: 0; z-index: 99;
  background: rgba(8,10,12,.97);
  backdrop-filter: blur(14px);
  border-bottom: 1px solid var(--border);
  display: flex; flex-direction: column; gap: 0;
  padding: 20px 40px;
}
.mobile-menu a {
  font-family: 'rfont'; font-size: 1.1rem; font-weight: 600;
  text-transform: uppercase; letter-spacing: .1em;
  color: var(--muted); text-decoration: none; padding: 12px 0;
  border-bottom: 1px solid var(--border); transition: color .25s;
}
.mobile-menu a:hover { color: var(--text); }
.mobile-menu .btn-register { margin-top: 16px; width: 100%; text-align: center; }
.hidden { display: none !important; }

/* ─── HERO ─── */
.hero {
  position: relative;
  z-index: 1;
  min-height: 100vh;
  display: grid;
  grid-template-rows: auto auto auto auto;
  padding: 0 72px 80px;
  padding-top: 130px;
}

.cinematic-side {
  max-width: 600px;
}

.cinematic-side > span {
  font-family: 'rfont';
  font-size: .72rem;
  letter-spacing: .22em;
  text-transform: uppercase;
  color: rgba(255,255,255,.45);
  display: block;
  margin-bottom: 22px;
}

.cinematic-side h1 {
  font-family: 'rfont' ;
  font-size: clamp(3.2rem, 5.5vw, 5.2rem);
  font-weight: 400;
  line-height: 1.05;
  letter-spacing: -.01em;
  color: #fff;
}

.cinematic-side h1 span[style*="rfont2"] {
  font-family: 'rfont2' !important;
  color: var(--accent) !important;
}

.line {
  width: 52px;
  height: 1.5px;
  background: rgba(255,255,255,.3);
  margin: 32px 0;
}

.title-hero {
  max-width: 580px;
  margin-top: 0;
  text-align: left;
}

.title-hero p {
  font-family: 'rfont' !important;
  font-size: 1rem;
  line-height: 1.85;
  color: rgba(255,255,255,.55) !important;
  letter-spacing: .02em;
}

/* ─── PILLS ─── */
.hero-pills {
  display: flex; flex-wrap: wrap; gap: 0;
  justify-content: flex-start;
  margin-top: 52px;
  border-top: 1px solid rgba(255,255,255,.1);
  border-left: 1px solid rgba(255,255,255,.1);
  width: fit-content;
}

.img-pill { width: 28px; height: 28px; filter: brightness(0) invert(1); opacity: .7; }

.pill {
  display: flex; align-items: center; gap: 10px;
  padding: 16px 28px;
  border-right: 1px solid rgba(255,255,255,.1);
  border-bottom: 1px solid rgba(255,255,255,.1);
  background: transparent;
  font-family: 'rfont';
  font-size: .72rem;
  font-weight: 700;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: rgba(255,255,255,.55);
  transition: color .25s, background .25s;
}
.pill:hover { color: #fff; background: rgba(173,151,127,.07); }

/* ─── HERO CARDS ─── */
.hero-cards {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0;
  max-width: 700px;
  margin-top: 60px;
  border: 1px solid rgba(255,255,255,.1);
}

.hero-card {
  background: rgba(12,10,8,.6);
  border: none;
  border-right: 1px solid rgba(255,255,255,.1);
  padding: 36px 32px;
  backdrop-filter: blur(10px);
  transition: background .3s;
  cursor: pointer;
  position: relative;
  text-align: left;
  border-radius: 0;
  overflow: hidden;
}
.hero-card:last-child { border-right: none; }
.hero-card:hover { background: rgba(173,151,127,.06); }

.hero-card h3 {
  font-family: 'rfont';
  font-size: .85rem;
  font-weight: 700;
  letter-spacing: .18em;
  text-transform: uppercase;
  color: #fff;
  margin-bottom: 12px;
  margin-top: 10px;
}
.hero-card p {
  font-size: .82rem;
  line-height: 1.7;
  color: rgba(255,255,255,.45);
}

.card-badge {
  display: inline-block;
  font-family: 'rfont';
  font-size: .65rem;
  font-weight: 700;
  letter-spacing: .12em;
  text-transform: uppercase;
  padding: 4px 12px;
  border-radius: 0;
  background: rgba(173,151,127,.1);
  color: var(--accent);
  border: 1px solid rgba(173,151,127,.25);
  margin-bottom: 12px;
  border-radius: 4px;
}
.card-badge.coming {
  background: rgba(255,255,255,.05);
  color: rgba(255,255,255,.4);
  border-color: rgba(255,255,255,.12);
}

.card-cta {
  margin-top: 18px;
  font-family: 'rfont';
  font-size: .78rem;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--accent);
  transition: opacity .2s;
}
.hero-card:hover .card-cta { opacity: .7; }

/* ─── SECTIONS (ecosystem etc) ─── */
.ecosystem { position: relative; z-index: 1; padding: 100px 40px 80px; text-align: center; }
.section-title {
  font-family: 'rfont';
  font-size: clamp(2rem, 4vw, 3rem); letter-spacing: .12em; color: var(--text); margin-bottom: 60px;
}
.section-title em { font-style: normal; color: var(--accent); text-decoration: underline; text-underline-offset: 6px; }
.eco-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; max-width: 1100px; margin: 0 auto; }
.eco-card {
  background: var(--bg-card); border: 1px solid var(--border); padding: 30px 22px; text-align: left;
  cursor: default;
  transition: transform .35s cubic-bezier(.22,1,.36,1), background .35s, border-color .35s, box-shadow .35s;
}
.eco-card:hover { transform: scale(1.07); background: var(--white-card); border-color: var(--accent); box-shadow: 0 12px 40px rgba(173,151,127,.15); }
.eco-card:hover .eco-icon, .eco-card:hover .eco-title, .eco-card:hover .eco-desc { color: #1a1208; }
.eco-icon { font-size: 1.8rem; margin-bottom: 16px; color: var(--accent); transition: color .35s; }
.eco-title { font-family: 'rfont'; font-size: 1rem; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; color: var(--text); margin-bottom: 10px; transition: color .35s; }
.eco-desc { font-size: .82rem; line-height: 1.65; color: var(--muted); transition: color .35s; }
.eco-card:hover .eco-desc { color: #3a2a1a; }

/* ─── BENEFITS ─── */
.benefits { position: relative; z-index: 1; padding: 80px 40px; text-align: center; }
.benefits-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; max-width: 900px; margin: 0 auto; }
.ben-card {
  background: var(--bg-card2); border: 1px solid var(--border); padding: 32px 28px; text-align: left;
  transition: border-color .3s, transform .3s;
}
.ben-card:hover { border-color: var(--accent); transform: translateY(-4px); }
.ben-card.highlight { background: linear-gradient(135deg, rgba(173,151,127,.08) 0%, rgba(13,10,8,1) 100%); border-color: rgba(173,151,127,.3); }
.ben-title { font-family: 'rfont', sans-serif; font-size: 1.1rem; font-weight: 700; letter-spacing: .07em; color: var(--text); margin-bottom: 14px; display: flex; align-items: center; gap: 10px; }
.ben-title .ben-icon { font-size: 1.4rem; color: var(--accent); }
.ben-list { list-style: none; display: flex; flex-direction: column; gap: 7px; }
.ben-list li { font-size: .85rem; color: var(--muted); display: flex; align-items: center; gap: 8px; }
.ben-list li::before { content: '›'; color: var(--accent); font-size: 1.1rem; flex-shrink: 0; }
.ben-highlight-text { font-family: 'rfont', sans-serif; font-size: 1.4rem; font-weight: 600; color: var(--text); line-height: 1.4; }
.ben-highlight-text span { color: var(--accent); }

/* ─── FOOTER ─── */
footer {
  position: relative; z-index: 1;
  background: #040506;
  border-top: 1px solid rgba(255,255,255,.08);
  padding: 50px 60px;
  display: grid;
  grid-template-columns: auto 1fr auto auto;
  gap: 40px;
  align-items: center;
}
.footer-logo { font-family: 'rfont', sans-serif; font-size: 2.2rem; letter-spacing: .1em; line-height: 1; color: var(--text); }
.footer-logo span { color: var(--accent); }
.footer-tagline { font-family: 'rfont', sans-serif; font-size: .8rem; letter-spacing: .18em; text-transform: uppercase; color: var(--muted); margin-top: 4px; }
.footer-social { display: flex; gap: 12px; }
.social-btn {
  width: 34px; height: 34px;
  border: 1px solid rgba(255,255,255,.12);
  display: flex; align-items: center; justify-content: center;
  color: rgba(255,255,255,.4); font-size: .85rem;
  text-decoration: none; border-radius: 50%;
  transition: border-color .25s, color .25s;
}
.social-btn:hover { border-color: var(--accent); color: var(--accent); }
.footer-newsletter label { display: block; font-family: 'rfont', sans-serif; font-size: .85rem; font-weight: 600; letter-spacing: .08em; text-transform: uppercase; color: rgba(255,255,255,.5); margin-bottom: 10px; }
.footer-newsletter label span { color: var(--accent); }
.newsletter-row { display: flex; gap: 0; }
.newsletter-row input {
  background: rgba(255,255,255,.04); border: 1px solid rgba(255,255,255,.1);
  border-right: none;
  color: var(--text); padding: 10px 16px; font-size: .88rem;
  font-family: 'rfont', sans-serif; outline: none; flex: 1;
  transition: border-color .25s;
}
.newsletter-row input:focus { border-color: var(--accent); }
.newsletter-row button {
  font-family: 'rfont', sans-serif; font-weight: 700; font-size: .8rem;
  letter-spacing: .1em; text-transform: uppercase;
  padding: 10px 22px;
  background: var(--accent); color: #080a0c;
  border: none; cursor: pointer; transition: opacity .25s;
}
.newsletter-row button:hover { opacity: .85; }
.footer-slogan { font-family: 'rfont', sans-serif; font-size: clamp(1.3rem, 2.5vw, 2rem); letter-spacing: .06em; text-align: right; line-height: 1.2; color: var(--text); }
.footer-slogan strong { display: block; color: var(--accent2); }
.footer-img { width: 110px; height: 32px; }
.footer-logo-img { width: 200px; height: auto; }

/* ─── ANIMATIONS ─── */
@keyframes fadeUp { from{opacity:0;transform:translateY(30px)} to{opacity:1;transform:translateY(0)} }
.reveal { opacity: 0; transform: translateY(28px); transition: opacity .7s ease, transform .7s ease; }
.reveal.visible { opacity: 1; transform: none; }

/* ─── NEW HERO helpers ─── */
.hero-tag {
  margin-top: 20px; padding: 10px 22px;
  border: 1px solid var(--border); border-radius: 40px;
  background: rgba(173,151,127,.06);
  color: var(--accent); font-size: .78rem; letter-spacing: .12em; font-weight: 700;
  display: inline-flex; align-items: center; justify-content: center;
}

.hero-main {
  max-width: 900px; margin-top: 34px;
  font-size: clamp(3rem, 6vw, 5.8rem); line-height: 1.05;
  font-family: 'rfont', sans-serif; color: var(--text);
  font-weight: 700; letter-spacing: -.02em; text-align: center;
}

.hero-description {
  max-width: 760px; margin-top: 26px;
  font-size: 1.08rem; line-height: 1.9;
  color: var(--muted); text-align: center;
}

.hero-differential { margin-top: 24px; color: var(--accent2); font-size: 1rem; letter-spacing: .08em; }

.hero-actions { display: flex; gap: 18px; margin-top: 40px; flex-wrap: wrap; justify-content: center; }

.btn-primary, .btn-secondary {
  padding: 16px 30px; border: none; cursor: pointer;
  font-weight: 700; letter-spacing: .08em; transition: .3s;
  font-family: 'rfont', sans-serif; font-size: .85rem; text-transform: uppercase;
}
.btn-primary { background: var(--accent); color: #080a0c; }
.btn-primary:hover { transform: translateY(-3px); opacity: .9; }
.btn-secondary { background: transparent; border: 1px solid var(--border); color: var(--text); }
.btn-secondary:hover { border-color: var(--accent); }

.positioning, .ecosystem-block, .fomo-block, .final-cta {
  position: relative; z-index: 1; padding: 100px 20px; text-align: center;
}
.positioning h2, .ecosystem-block h2, .fomo-block h2, .final-cta h2 {
  max-width: 900px; margin: auto;
  font-size: clamp(2rem,4vw,3.5rem); line-height: 1.2;
}
.positioning p, .ecosystem-block p {
  max-width: 900px; margin: 30px auto 0;
  color: var(--muted); line-height: 1.9; font-size: 1.05rem;
}
.card-list { margin-top: 20px; list-style: none; display: flex; flex-direction: column; gap: 10px; }
.card-list li { color: var(--accent2); font-size: .9rem; }
.softlanding-title { font-size: 2rem !important; color: #fff !important; letter-spacing: .12em; }
.fomo-items { margin-top: 40px; display: flex; justify-content: center; gap: 18px; flex-wrap: wrap; }
.fomo-items span {
  padding: 12px 18px; border: 1px solid var(--border);
  background: rgba(173,151,127,.05); color: var(--accent2);
}
.big { margin-top: 40px; font-size: 1rem; padding: 18px 34px; }

/* ─── RESPONSIVE ─── */
@media (max-width: 900px) {
  .eco-grid { grid-template-columns: 1fr 1fr; }
  .benefits-grid { grid-template-columns: 1fr; }
  footer {
    grid-template-columns: 1fr 1fr;
    padding: 36px 28px;
    row-gap: 28px;
  }
  /* imagen del footer ocupa ancho completo centrada */
  .footer-right {
    grid-column: 1 / -1;
    margin-left: 0;
    justify-content: center;
  }
  .footer-text { margin: 0 auto; }
  .hero-cards { grid-template-columns: 1fr; }
  .hero { padding: 110px 28px 60px; }
}
@media (max-width: 600px) {
  .eco-grid { grid-template-columns: 1fr; }
  /* Footer: todo en columna, centrado */
  footer {
    grid-template-columns: 1fr;
    padding: 36px 20px;
    text-align: center;
    gap: 24px;
  }
  footer > div { display: flex; flex-direction: column; align-items: center; }
  .footer-right { grid-column: 1; margin-left: 0; align-items: center; justify-content: center; }
  .footer-logo-img { margin: 0 auto; }
  .footer-social { justify-content: center; }
  .footer-text { width: 160px; margin: 0 auto; display: block; }
  .footer-slogan { text-align: center; }
  nav { padding: 14px 20px; }
  .nav-links { display: none; }
  .nav-hamburger { display: flex; }
  .hero { padding: 100px 20px 60px; }
  .hero-pills { flex-direction: column; width: 100%; }
  .pill { border-right: 1px solid rgba(255,255,255,.1); }
}

/* ── INLINE OVERRIDES FOR REFERENCE-IMAGE FIDELITY ── */

    /* NAV extra links */
    .nav-links { gap: 32px; }

    /* HERO two-column layout */
    .hero {
      display: grid;
      grid-template-columns: 1fr 1fr;
      grid-template-rows: auto auto auto;
      column-gap: 60px;
      row-gap: 0;
      align-items: start;
      padding-top: 130px;
    }
    .hero-left  { grid-column: 1; grid-row: 1 / 4; display: flex; flex-direction: column; justify-content: center; }
    .hero-right { grid-column: 2; grid-row: 1 / 4; display: flex; align-items: center; justify-content: center; }

    .hero-img-wrap {
      width: 100%; max-width: 520px;
      position: relative;
    }
    .hero-img-wrap img { width: 100%; height: auto; display: block; border-radius: 4px; }

    /* overline tag */
    .hero-overline {
      font-family: rfont;
      font-size: .85rem; letter-spacing: .24em; 
      color: rgba(255,255,255,.38); margin-bottom: 20px; display: block;
    }

    /* main h1 */
    .hero-h1 {
      font-family: rfont;
      font-size: clamp(3rem, 4.9vw, 4.8rem);
      line-height: 1.04; font-weight: 400;
      color: #fff; margin-bottom: 0;
    }
    .hero-h1 .gold { color: #ad977f; }

    .hero-divider { width: 48px; height: 1px; background: rgba(255,255,255,.25); margin: 28px 0; }

    /* description */
    .hero-desc {
      font-family: rfont;
      font-size: .95rem; line-height: 1.85;
      color: rgba(255,255,255,.48); max-width: 460px;
    }

    /* pill row */
    .hero-pill-row {
      display: grid; grid-template-columns: repeat(4,1fr);
      border-left: 1px solid rgba(255,255,255,.08);
      margin-top: 48px;
    }
    .hero-pill-item {
      border-right: 1px solid rgba(255,255,255,.08);
      padding: 20px 16px; display: flex; flex-direction: column;
      gap: 10px; align-items: flex-start;
    }
    .hero-pill-icon { font-size: 1.3rem; color: rgba(255,255,255,.45); }
    .hero-pill-label {
      font-family: rfont;
      font-size: .62rem; letter-spacing: .18em; text-transform: uppercase;
      color: rgba(255,255,255,.42); line-height: 1.4;
    }

    /* CTA buttons */
    .hero-btns { display: flex; align-items: center; gap: 28px; margin-top: 40px; }
    .btn-gold {
      display: inline-flex; align-items: left; gap: 20px;
      background: #ad977f; color: #080a0c;
      font-family: rfont; font-weight: 700;
      font-size: .78rem; letter-spacing: .14em; text-transform: uppercase;
      padding: 14px 28px 14px 28px; border: none; cursor: pointer;
      transition: opacity .25s, transform .25s;
      border-radius: 4px;
    }
    .btn-gold:hover { opacity: .88; transform: translateY(-2px); }
    .btn-ghost-link {
      font-family: 'rfont1', sans-serif; font-size: .90rem;
      letter-spacing: .15em; text-transform: uppercase;
      color: rgba(255,255,255,.5); background: none; border: none;
      transition: color .25s;
      margin-right:40px;

    }
    .btn-ghost-link:hover { color: #fff; }

    /* ── ECOSYSTEM STRIP ── */
    .eco-strip {
      position: relative; z-index: 1;
      border-top: 1px solid rgba(255,255,255,.08);
      border-bottom: 1px solid rgba(255,255,255,.08);
      padding: 36px 72px;
      display: flex; align-items: center; justify-content: center;
    }
    .eco-strip-inner {
      max-width: 1000px; width: 100%;
      display: flex; align-items: center; justify-content: space-between; gap: 0;
    }
    .eco-strip-label {
      font-family: 'rfont', sans-serif;
      font-size: .68rem; letter-spacing: .22em; text-transform: uppercase;
      color: rgba(255,255,255,.35);
    }
    .eco-strip-label em { font-style: normal; color: #ad977f; }
    .eco-strip-steps {
      display: flex; align-items: center; gap: 0;
    }
    .eco-step {
      display: flex; flex-direction: column; align-items: center; gap: 10px;
      padding: 0 32px; position: relative;
    }
    .eco-step:not(:last-child)::after {
      content: ''; position: absolute; right: 0; top: 20px;
      width: 1px; height: 32px; background: rgba(255,255,255,.1);
    }
    .eco-step-icon {
      width: 48px; height: 48px; border: 1px solid rgba(255,255,255,.12);
      border-radius: 50%; display: flex; align-items: center; justify-content: center;
      font-size: 1.2rem; color: rgba(255,255,255,.5);
    }
    .eco-step-icon.center-icon {
      background: #ad977f; border-color: #ad977f; color: #080a0c;
      width: 56px; height: 56px; font-size: 1.3rem; font-weight: 700;
    }
    /* clase que usa el HTML: center-icono (sin guion) */
    .eco-step-icon.center-icono {
      background: transparent;
      border-color: rgba(173,151,127,.4);
      width: 56px; height: 56px;
    }
    .eco-step-label {
      font-family: 'rfont', sans-serif; font-size: .6rem;
      letter-spacing: .16em; text-transform: uppercase;
      color: rgba(255,255,255,.38); text-align: center;
    }

    /* ── MODULES ── */
    .modules-section {
      position: relative; z-index: 1;
      padding: 100px 72px;
    }
    .modules-grid {
      display: grid; grid-template-columns: repeat(4,1fr);
     
      border-left: 1px solid rgba(255,255,255,.08);
      margin-top: 48px;
    }
    .mod-card {
      border-right: 1px solid rgba(255,255,255,.08);
      
      padding: 40px 32px;
    }
    .mod-num {
      font-family: 'rfont', sans-serif; font-size: 2.2rem;
      color: rgba(173,151,127,.25); letter-spacing: .02em;
      margin-bottom: 22px; display: block;
    }
    .mod-title {
      font-family: 'rfont', sans-serif; font-size: .82rem;
      letter-spacing: .18em; text-transform: uppercase;
      color: #fff; font-weight: 700; margin-bottom: 14px;
    }
    .mod-desc {
      font-family: 'rfont', sans-serif; font-size: .82rem;
      line-height: 1.75; color: rgba(255,255,255,.42);
    }
    .mod-arrow {
      display: block; margin-top: 24px;
      font-size: .9rem; color: #ad977f;
      cursor: pointer;
      user-select: none;
      color: white;
      transition: .3s ease
    }
    .mod-arrow:hover { color: #ad977f; opacity: .8; }

    .section-overline {
      font-family: 'rfont', sans-serif; font-size: .80rem;
      letter-spacing: .22em; text-transform: uppercase;
      color: rgba(255,255,255,.35); display: block; margin-bottom: 16px;
    }
    .section-heading {
      font-family: 'rfont', sans-serif;
      font-size: clamp(2rem, 3.5vw, 3.2rem);
      color: #fff; font-weight: 400; line-height: 1.1;
    }
    .section-heading .gold { color: #ad977f; }

    /* ── FINAL CTA ── */
    .final-cta-section {
      position: relative; z-index: 1;
      margin: 0 72px 100px;
      border: 1px solid rgba(255,255,255,.08);
      padding: 64px 72px;
      display: flex; align-items: center; justify-content: space-between; gap: 40px;
      background: #f5ece3;
      border-radius: 20px;
    }
    .final-cta-text .cta-over {
      font-family: 'rfont', sans-serif; font-size: .68rem;
      letter-spacing: .2em; text-transform: uppercase;
      color: #29323b; display: block; margin-bottom: 14px;
    }
    .final-cta-text h2 {
      font-family: 'rfont', sans-serif;
      font-size: clamp(1.8rem, 3vw, 2.8rem); font-weight: 400;
      color: #fff; line-height: 1.15;
    }
    .final-cta-text h2 .gold { color: #ad977f; }

    /* RESPONSIVE overrides */
    @media (max-width: 960px) {
      .hero { grid-template-columns: 1fr; }
      .hero-right { display: none; }
      .hero-left { grid-row: 1; }
      /* eco-strip: label arriba, pasos abajo en fila wrappable */
      .eco-strip { padding: 28px 20px; flex-direction: column; gap: 20px; align-items: center; }
      .eco-strip-inner { flex-direction: column; gap: 20px; align-items: center; text-align: center; }
      .eco-strip-label { max-width: 260px; text-align: center; }
      /* 5 pasos en wrap: 2 | R centrada | 2 */
      .eco-strip-steps { flex-wrap: wrap; justify-content: center; gap: 0; }
      .eco-step { padding: 12px 20px; width: 40%; justify-content: center; }
      /* R (3er paso) sola en su fila, centrada */
      .eco-step:nth-child(3) { width: 100%; align-items: center; order: 0; }
      .eco-step:not(:last-child)::after { display: none; }
      .modules-section { padding: 60px 24px; }
      .modules-grid { grid-template-columns: 1fr 1fr; }
      .final-cta-section { margin: 0 24px 60px; flex-direction: column; text-align: center; padding: 40px 28px; }
    }
    @media (max-width: 600px) {
      .hero-pill-row { grid-template-columns: 1fr 1fr; }
      .modules-grid { grid-template-columns: 1fr; }
      /* eco-step más compacto en pantallas pequeñas */
      .eco-step { padding: 8px 10px; }
      .eco-step-icon { width: 40px; height: 40px; }
      .imgicon { width: 32px; }
    }
    .imgpill {
  width: 28px; height: auto;
    }
    .imgicon{
  width: 47px; height: auto;
    }
    .uparrow{
      display:flex; 
      justify-content:right;
      margin-right:40px;
      margin-bottom:20px;
    }
    .arrow{
  font-size: 1.75rem; color: var(--accent); 
  border-right: 1px solid rgba(255,255,255,.08);
  border-bottom: 1px solid rgba(255,255,255,.08);
  padding: 0.0002px 8px 0.2px 8px;
  border-left: 1px solid rgba(255,255,255,.08);
  border-top: 1px solid rgba(255,255,255,.08);   
  display: inline-flex; 
    }
    
    .footer-text{
      width:220px;
  height:auto;
  display:block;
    }

    /* Footer columna derecha — desktop: empujada a la derecha */
    .footer-right {
      margin-left: auto;
      display: flex;
      align-items: center;
      justify-content: flex-end;
      
    }
    .footer-right { margin-left: 0; justify-content: center; }
    
/* ════════════════════════════════════════════════
   RESPONSIVE ADICIONAL — sin tocar el diseño original
   Agrega soporte para: tablet, celulares pequeños, TV
════════════════════════════════════════════════ */

/* ── Tablet y móvil — nav y extras ── */
@media (max-width: 960px) {
  nav { padding: 14px 28px; }
  .nav-logo-img { width: 120px; }
}

@media (max-width: 600px) {
  .hero-h1 { font-size: clamp(2rem, 8vw, 3rem); }
  .hero-desc { font-size: .85rem; }
  .hero-divider { margin: 18px 0; }
  .hero-pill-row { margin-top: 28px; }
  .hero-pill-item { padding: 12px 10px; }
  .btn-gold { font-size: .72rem; padding: 12px 18px; }
  .modules-section { padding: 48px 16px; }
  .mod-card { padding: 24px 16px; }
  .final-cta-section { margin: 0 16px 48px; padding: 32px 20px; text-align: center; flex-direction: column; }
  .final-cta-text h2 { font-size: 1.6rem; }
  .uparrow { margin-right: 16px; }
}

/* ── Móvil pequeño (≤ 400px) ── */
@media (max-width: 400px) {
  .hero-h1 { font-size: 1.9rem; }
  .hero-pill-row { grid-template-columns: 1fr 1fr; }
  .eco-step-icon { width: 36px; height: 36px; }
  .imgicon { width: 30px; }
}

/* ── TV / Pantalla grande (≥ 1920px) ── */
@media (min-width: 1920px) {
  nav { padding: 20px 120px; }
  .nav-logo-img { width: 180px; }
  .hero { padding: 160px 120px 100px; }
  .hero-h1 { font-size: 5.5rem; }
  .hero-desc { font-size: 1.1rem; max-width: 560px; }
  .eco-strip { padding: 48px 120px; }
  .modules-section { padding: 120px; }
  .final-cta-section { margin: 0 120px 120px; }
  footer { padding: 60px 120px; }
}

/* ── Accesibilidad: sin animaciones si el usuario lo prefiere ── */
@media (prefers-reduced-motion: reduce) {
  .reveal { transition: none; opacity: 1; transform: none; }
}

/* ════════════════════════════════════════════════
   FLECHA FLOTANTE "volver al inicio"
   Reemplaza el .uparrow estático — aparece al bajar
════════════════════════════════════════════════ */
.scroll-top-btn {
  position: fixed;
  bottom: 32px;
  right: 32px;
  z-index: 200;
  width: 44px; height: 44px;
  display: flex; align-items: center; justify-content: center;
  font-size: 1.5rem;
  color: var(--accent);
  text-decoration: none;
  border-top:    1px solid rgba(255,255,255,.08);
  border-left:   1px solid rgba(255,255,255,.08);
  border-right:  1px solid rgba(255,255,255,.08);
  border-bottom: 1px solid rgba(255,255,255,.08);
  background: rgba(8,10,12,.75);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  /* oculto por defecto */
  opacity: 0;
  pointer-events: none;
  transform: translateY(10px);
  transition: opacity .35s ease, transform .35s ease, border-color .25s;
}
.scroll-top-btn.visible {
  opacity: 1;
  pointer-events: auto;
  transform: translateY(0);
}
.scroll-top-btn:hover { border-color: var(--accent); }

@media (max-width: 600px) {
  .scroll-top-btn { bottom: 20px; right: 16px; }
}
/* Copyright bar — siempre al final, ancho completo */
.footer-copy {
  position: relative; z-index: 1;
  background: #040506;
  border-top: 1px solid rgba(255,255,255,.05);
  padding: 14px 60px;
  font-size: .65rem;
  letter-spacing: .1em;
  color: rgba(255,255,255,.2);
  text-align: center;
}
@media (max-width: 600px) {
  .footer-copy { padding: 12px 20px; }
}