:root{
      --primary:#074280;
      --primary-dark:#052f5c;
      --primary-soft:#eaf2fb;
      --primary-soft-2:rgba(7,66,128,.08);
      --primary-border:rgba(7,66,128,.18);
      --text:#111111;
      --muted:rgba(17,17,17,.72);
      --muted-2:rgba(17,17,17,.58);
      --line:rgba(0,0,0,.08);
      --bg:#f4f7fb;
      --white:#ffffff;
      --shadow:0 20px 60px rgba(0,0,0,.06);
      --radius-xl:32px;
      --radius-lg:28px;
      --radius-md:22px;
      --radius-sm:18px;
    }

    *{box-sizing:border-box}
    html{scroll-behavior:smooth}
    body{
      margin:0;
      font-family:Arial, Helvetica, sans-serif;
      color:var(--text);
      background:
        radial-gradient(circle at top left, rgba(7,66,128,.06), transparent 28%),
        var(--bg);
      line-height:1.6;
    }

    a{text-decoration:none}
    img{max-width:100%;display:block}
    h1,h2,h3,p{margin:0}

    .wrap{
      width:100%;
      max-width:1200px;
      margin:0 auto;
      padding:0 24px;
    }

    .topbar{
      position:sticky;
      top:0;
      z-index:40;
      backdrop-filter:blur(10px);
      background:rgba(255,255,255,.9);
      border-bottom:1px solid var(--line);
    }

    .topbar-inner{
      display:flex;
      align-items:center;
      justify-content:space-between;
      gap:20px;
      padding:16px 0;
    }

    .logos{
      display:flex;
      align-items:center;
      gap:22px;
      flex-wrap:wrap;
    }

    .logo-box img{
      max-height:42px;
      width:auto;
      height:auto;
    }

    .nav-cta{
      display:flex;
      align-items:center;
      gap:12px;
      flex-wrap:wrap;
    }

    .btn{
      display:inline-flex;
      align-items:center;
      justify-content:center;
      gap:10px;
      padding:15px 24px;
      border-radius:999px;
      font-weight:900;
      font-size:14px;
      letter-spacing:.3px;
      transition:.2s ease;
      border:1px solid transparent;
      white-space:nowrap;
      cursor:pointer;
    }

    .btn-primary{
      background:var(--primary);
      color:#ffffff;
      border-color:var(--primary);
      box-shadow:0 10px 24px rgba(7,66,128,.18);
    }

    .btn-primary:hover{
      transform:translateY(-1px);
      box-shadow:0 14px 28px rgba(7,66,128,.24);
      background:var(--primary-dark);
      border-color:var(--primary-dark);
    }

    .btn-secondary{
      background:#ffffff;
      color:var(--primary);
      border-color:var(--primary-border);
    }

    .btn-secondary:hover{
      background:var(--primary-soft);
    }

    .btn-ghost{
      background:#ffffff;
      color:#111111;
      border-color:var(--line);
    }

    .hero{
      padding:28px 0 24px;
    }

    .hero-card{
      position:relative;
      overflow:hidden;
      border-radius:var(--radius-xl);
      border:1px solid var(--line);
      background:#ffffff;
      box-shadow:var(--shadow);
    }

    .hero-grid{
      display:grid;
      grid-template-columns:1.05fr .95fr;
      min-height:650px;
    }

    .hero-copy{
      padding:56px 52px 46px;
      position:relative;
      z-index:2;
    }

    .eyebrow{
      display:inline-block;
      padding:8px 13px;
      border-radius:999px;
      font-size:11px;
      font-weight:800;
      letter-spacing:.8px;
      color:var(--primary);
      background:var(--primary-soft-2);
      border:1px solid var(--primary-border);
    }

    .hero h1{
      margin-top:18px;
      font-size:48px;
      line-height:.98;
      letter-spacing:-1.4px;
      font-weight:900;
      max-width:640px;
    }

    .hero-lead{
      margin-top:20px;
      font-size:18px;
      line-height:1.9;
      color:rgba(17,17,17,.74);
      max-width:610px;
    }

    .hero-benefit{
      margin-top:26px;
      background:linear-gradient(180deg, rgba(7,66,128,.09) 0%, rgba(7,66,128,.04) 100%);
      border:1px solid var(--primary-border);
      border-radius:24px;
      padding:24px;
      max-width:620px;
    }

    .hero-benefit-kicker{
      font-size:12px;
      line-height:1.4;
      text-transform:uppercase;
      letter-spacing:.8px;
      font-weight:900;
      color:var(--primary);
      margin-bottom:10px;
    }

    .hero-benefit-main{
      font-size:28px;
      line-height:1.1;
      letter-spacing:-.7px;
      font-weight:900;
      color:#111111;
      margin-bottom:10px;
    }

    .hero-benefit-sub{
      font-size:15px;
      line-height:1.8;
      color:rgba(17,17,17,.68);
    }

    .hero-actions{
      margin-top:28px;
      display:flex;
      gap:14px;
      flex-wrap:wrap;
    }

    .hero-mini{
      margin-top:24px;
      display:flex;
      flex-wrap:wrap;
      gap:12px;
    }

    .hero-mini-item{
      padding:10px 14px;
      border-radius:999px;
      border:1px solid var(--line);
      background:#ffffff;
      font-size:13px;
      font-weight:700;
      color:rgba(17,17,17,.78);
    }

    .hero-visual{
      position:relative;
      min-height:100%;
      background:
        linear-gradient(180deg, rgba(0,0,0,.10) 0%, rgba(0,0,0,.20) 100%),
        url('https://assets.cdn.filesafe.space/MDfbz3VvUHsQzzBd9JDv/media/69bd3c710e1bdb0fa87ad586.png') center/cover no-repeat;
    }

    .hero-floating-card{
      position:absolute;
      right:26px;
      bottom:26px;
      width:300px;
      background:rgba(255,255,255,.95);
      border:1px solid var(--line);
      border-radius:24px;
      padding:22px;
      box-shadow:0 18px 40px rgba(0,0,0,.12);
    }

    .hero-floating-card h3{
      font-size:16px;
      font-weight:900;
      margin-bottom:8px;
      line-height:1.3;
    }

    .hero-floating-card p{
      font-size:14px;
      line-height:1.75;
      color:rgba(17,17,17,.68);
    }

    .section{
      padding:24px 0;
    }

    .section-card{
      background:#ffffff;
      border:1px solid var(--line);
      border-radius:var(--radius-lg);
      padding:38px;
      box-shadow:0 14px 40px rgba(0,0,0,.04);
    }

    .section-top{
      display:flex;
      justify-content:space-between;
      align-items:end;
      gap:18px;
      flex-wrap:wrap;
      margin-bottom:22px;
    }

    .section-title{
      font-size:36px;
      line-height:1.06;
      letter-spacing:-.8px;
      font-weight:900;
      max-width:760px;
    }

    .section-text{
      font-size:16px;
      line-height:1.9;
      color:var(--muted);
    }

    .benefit-grid{
      display:grid;
      grid-template-columns:repeat(4,1fr);
      gap:16px;
    }

    .benefit-item{
      background:#ffffff;
      border:1px solid var(--line);
      border-radius:22px;
      padding:24px;
      transition:.2s ease;
    }

    .benefit-item:hover{
      transform:translateY(-2px);
      box-shadow:0 14px 30px rgba(0,0,0,.05);
    }

    .check{
      width:40px;
      height:40px;
      border-radius:999px;
      display:flex;
      align-items:center;
      justify-content:center;
      background:rgba(7,66,128,.10);
      color:var(--primary);
      font-weight:900;
      margin-bottom:14px;
      font-size:18px;
    }

    .benefit-item h3{
      font-size:19px;
      line-height:1.25;
      font-weight:900;
      margin-bottom:8px;
    }

    .benefit-item p{
      font-size:14px;
      line-height:1.85;
      color:rgba(17,17,17,.68);
    }

    .band{
      margin-top:22px;
      border-radius:24px;
      padding:28px;
      background:
        linear-gradient(135deg, rgba(7,66,128,.10) 0%, rgba(7,66,128,.04) 100%);
      border:1px solid var(--primary-border);
    }

    .band-grid{
      display:grid;
      grid-template-columns:1.1fr .9fr;
      gap:24px;
      align-items:center;
    }

    .band h3{
      font-size:32px;
      line-height:1.08;
      letter-spacing:-.7px;
      font-weight:900;
      margin-bottom:10px;
    }

    .band p{
      font-size:16px;
      line-height:1.9;
      color:var(--muted);
    }

    .band-box{
      background:#ffffff;
      border:1px solid var(--line);
      border-radius:22px;
      padding:22px;
    }

    .band-price{
      font-size:46px;
      font-weight:900;
      line-height:1;
      letter-spacing:-1.2px;
      color:var(--primary);
      margin-bottom:8px;
    }

    .band-price-sub{
      font-size:15px;
      line-height:1.8;
      color:rgba(17,17,17,.68);
    }

    .steps{
      display:grid;
      grid-template-columns:repeat(3,1fr);
      gap:16px;
      margin-top:8px;
    }

    .step{
      background:#f8fafc;
      border:1px solid var(--line);
      border-radius:22px;
      padding:24px;
    }

    .step-num{
      width:40px;
      height:40px;
      border-radius:999px;
      background:var(--primary);
      color:#fff;
      display:flex;
      align-items:center;
      justify-content:center;
      font-weight:900;
      margin-bottom:14px;
    }

    .step h3{
      font-size:18px;
      margin-bottom:8px;
      font-weight:900;
    }

    .step p{
      font-size:14px;
      line-height:1.85;
      color:rgba(17,17,17,.68);
    }

    .conditions-box{
      margin-top:20px;
      background:#f8fafc;
      border:1px solid var(--line);
      border-radius:22px;
      padding:26px;
    }

    .conditions-box p + p{
      margin-top:12px;
    }

    .faq{
      display:grid;
      grid-template-columns:1fr 1fr;
      gap:16px;
      margin-top:6px;
    }

    .faq-item{
      background:#f8fafc;
      border:1px solid var(--line);
      border-radius:22px;
      padding:24px;
    }

    .faq-item h3{
      font-size:17px;
      font-weight:900;
      margin-bottom:8px;
      line-height:1.35;
    }

    .faq-item p{
      font-size:14px;
      line-height:1.85;
      color:rgba(17,17,17,.68);
    }

    .cta-band{
      padding:26px 0 54px;
    }

    .cta-band-card{
      background:#ffffff;
      border:1px solid var(--line);
      border-radius:28px;
      padding:40px;
      text-align:center;
      box-shadow:0 16px 40px rgba(0,0,0,.04);
    }

    .cta-band-card h2{
      font-size:38px;
      line-height:1.08;
      letter-spacing:-.8px;
      font-weight:900;
      margin-bottom:12px;
    }

    .cta-band-card p{
      max-width:760px;
      margin:0 auto;
      font-size:16px;
      line-height:1.9;
      color:var(--muted);
    }

    .cta-band-actions{
      margin-top:24px;
      display:flex;
      justify-content:center;
      gap:14px;
      flex-wrap:wrap;
    }

    .footer{
      background:#ffffff;
      border-top:1px solid var(--line);
      padding:24px 0 40px;
    }

    .footer-inner{
      display:flex;
      justify-content:space-between;
      gap:20px;
      align-items:center;
      flex-wrap:wrap;
    }

    .footer-left img{
      max-height:34px;
      width:auto;
    }

    .footer-right{
      text-align:right;
      font-size:12px;
      line-height:1.8;
      color:#66706b;
    }

    .small-note{
      margin-top:14px;
      font-size:12px;
      line-height:1.8;
      color:rgba(17,17,17,.44);
    }

    .footer-links{
      margin-top:14px;
      display:flex;
      gap:10px;
      flex-wrap:wrap;
    }

    .footer-link-btn{
      display:inline-flex;
      align-items:center;
      justify-content:center;
      min-height:42px;
      padding:10px 16px;
      border-radius:999px;
      font-size:13px;
      font-weight:800;
      border:1px solid var(--line);
      background:#ffffff;
      color:var(--primary);
      transition:.2s ease;
    }

    .footer-link-btn:hover{
      background:var(--primary-soft);
      border-color:var(--primary-border);
    }

    @media (max-width:1024px){
      .hero-grid{grid-template-columns:1fr}
      .hero-visual{min-height:360px}
      .hero h1{font-size:46px}
      .benefit-grid{grid-template-columns:repeat(2,1fr)}
      .band-grid{grid-template-columns:1fr}
      .steps{grid-template-columns:1fr}
      .faq{grid-template-columns:1fr}
      .hero-floating-card{
        right:18px;
        bottom:18px;
        width:260px;
      }
    }

    @media (max-width:640px){
      .wrap{padding:0 16px}
      .topbar-inner{padding:14px 0}
      .hero-copy{padding:30px 22px}
      .hero h1{font-size:36px;line-height:1.02}
      .hero-benefit-main{font-size:28px}
      .section-card{padding:26px 20px}
      .section-title{font-size:28px}
      .benefit-grid{grid-template-columns:1fr}
      .band{padding:20px}
      .band h3{font-size:26px}
      .band-price{font-size:38px}
      .cta-band-card{padding:28px 20px}
      .cta-band-card h2{font-size:30px}
      .footer-right{text-align:left}
      .hero-floating-card{
        position:static;
        width:auto;
        margin:18px;
      }
      .nav-cta{display:none}
      
    }
/* =========================
   MODAL CUOTA DINÁMICO SAE
   ========================= */

.modal-overlay{
  position:fixed;
  inset:0;
  z-index:200;
  display:none;
  align-items:center;
  justify-content:center;
  padding:20px;
  background:rgba(4,16,33,.55);
  backdrop-filter:blur(6px);
}

.modal-overlay.active{
  display:flex;
}

.modal{
  position:relative;
  width:100%;
  max-width:980px;
  max-height:90vh;
  overflow:auto;
  background:#ffffff;
  border:1px solid rgba(255,255,255,.18);
  border-radius:28px;
  box-shadow:0 24px 70px rgba(0,0,0,.22);
}

.modal-head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  padding:24px 28px 0;
}

.modal-title{
  font-size:34px;
  line-height:1.06;
  letter-spacing:-.9px;
  font-weight:900;
  color:var(--text);
}

.modal-close{
  width:42px;
  height:42px;
  min-width:42px;
  border:none;
  border-radius:999px;
  background:#f4f7fb;
  color:#111111;
  font-size:22px;
  cursor:pointer;
  display:flex;
  align-items:center;
  justify-content:center;
  transition:.2s ease;
}

.modal-close:hover{
  background:var(--primary-soft);
  color:var(--primary);
}

.modal-body{
  padding:18px 28px 28px;
}

.modal-text{
  font-size:15px;
  line-height:1.85;
  color:var(--muted);
  margin-bottom:22px;
}

.quote-controls{
  display:flex;
  gap:14px;
  align-items:end;
  flex-wrap:wrap;
  margin-bottom:22px;
}

.field{
  flex:1 1 320px;
}

.field label{
  display:block;
  margin-bottom:8px;
  font-size:13px;
  font-weight:800;
  color:var(--primary);
  letter-spacing:.2px;
}

.field select{
  width:100%;
  height:54px;
  border-radius:16px;
  border:1px solid var(--line);
  background:#ffffff;
  padding:0 16px;
  font-size:15px;
  color:var(--text);
  outline:none;
  transition:.2s ease;
}

.field select:focus{
  border-color:var(--primary);
  box-shadow:0 0 0 4px rgba(7,66,128,.08);
}

.quote-result{
  margin-top:6px;
}

.quote-empty{
  padding:22px;
  border:1px dashed var(--primary-border);
  background:linear-gradient(180deg, rgba(7,66,128,.05), rgba(7,66,128,.02));
  border-radius:20px;
  font-size:14px;
  line-height:1.8;
  color:var(--muted);
}

.quote-center{
  display:inline-flex;
  align-items:center;
  gap:10px;
  padding:10px 14px;
  border-radius:999px;
  background:var(--primary-soft-2);
  border:1px solid var(--primary-border);
  color:var(--primary);
  font-size:13px;
  font-weight:800;
}

.quote-grid{
  display:grid;
  grid-template-columns:repeat(2, minmax(0,1fr));
  gap:16px;
}

.quote-card{
  background:#ffffff;
  border:1px solid var(--line);
  border-radius:22px;
  padding:22px;
  box-shadow:0 12px 30px rgba(0,0,0,.04);
}

.quote-plan{
  font-size:20px;
  line-height:1.2;
  font-weight:900;
  color:var(--text);
  margin-bottom:10px;
}

.quote-old{
  font-size:14px;
  color:rgba(17,17,17,.52);
  text-decoration:line-through;
  margin-bottom:6px;
}

.quote-new{
  font-size:38px;
  line-height:1;
  letter-spacing:-1.2px;
  font-weight:900;
  color:var(--primary);
  margin-bottom:8px;
}

.quote-meta{
  font-size:14px;
  line-height:1.8;
  color:var(--muted);
  margin-bottom:16px;
}

.quote-lists{
  display:grid;
  gap:12px;
}

.quote-list-box{
  background:#f8fafc;
  border:1px solid var(--line);
  border-radius:18px;
  padding:14px 14px 12px;
}

.quote-list-title{
  font-size:12px;
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:.7px;
  margin-bottom:10px;
}

.quote-list-title.included{
  color:var(--primary);
}

.quote-list-title.excluded{
  color:#7b8794;
}

.quote-list{
  list-style:none;
  margin:0;
  padding:0;
  display:grid;
  gap:8px;
}

.quote-list li{
  display:flex;
  align-items:flex-start;
  gap:10px;
  font-size:14px;
  line-height:1.7;
  color:#243240;
}

.quote-dot{
  width:20px;
  min-width:20px;
  height:20px;
  border-radius:999px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  font-size:12px;
  font-weight:900;
  margin-top:2px;
}

.quote-dot.included{
  background:rgba(7,66,128,.12);
  color:var(--primary);
}

.quote-dot.excluded{
  background:rgba(0,0,0,.06);
  color:#66707a;
}

@media (max-width:900px){
  .quote-grid{
    grid-template-columns:1fr;
  }
}

@media (max-width:640px){
  .modal-overlay{
    padding:14px;
  }

  .modal{
    max-height:92vh;
    border-radius:22px;
  }

  .modal-head{
    padding:18px 18px 0;
    align-items:flex-start;
  }

  .modal-body{
    padding:16px 18px 20px;
  }

  .modal-title{
    font-size:27px;
  }

  .quote-controls{
    flex-direction:column;
    align-items:stretch;
  }

  .field{
    flex:1 1 auto;
  }

  .quote-new{
    font-size:32px;
  }
}