:root {

  /* =========================
     PALETA AZUL OSCURO
  ========================= */

  --bg: #06111f;
  --bg-secondary: #0b1b31;
  --card: rgba(15, 35, 65, 0.72);
  --text: #ffffff;
  --muted: #9fb3d1;
  --primary: #2f6bff;
  --secondary: #4f8cff;
  --border: rgba(120, 170, 255, 0.16);
  --glow:
    0 0 40px rgba(47,107,255,.28),
    0 0 80px rgba(79,140,255,.18);
  --shadow:
    0 15px 50px rgba(0,0,0,.45);
  --radius: 24px;
}

*{
  margin:0;
  padding:0;
  box-sizing:border-box;
}

html{
  scroll-behavior:smooth;
}

body{
  font-family:'Inter',sans-serif;
  background:
    linear-gradient(
      180deg,
      #06111f 0%,
      #08192d 40%,
      #0b2038 100%
    );

  color:var(--text);
  overflow-x:hidden;
}

/* =========================
   AMBIENT BACKGROUND
========================= */

.ambient-bg{

  position:fixed;
  inset:0;

  background:
    radial-gradient(
      circle at top left,
      rgba(47,107,255,.25),
      transparent 35%
    ),

    radial-gradient(
      circle at bottom right,
      rgba(79,140,255,.18),
      transparent 35%
    ),

    radial-gradient(
      circle at center,
      rgba(17,65,130,.18),
      transparent 45%
    );

  z-index:-2;
}

.noise{
  position:fixed;
  inset:0;
  background-image:url('assets/texture-noise.png');
  opacity:.025;
  z-index:-1;
}

/* =========================
   NAVBAR
========================= */

.navbar{

  position:fixed;
  top:0;
  width:100%;
  z-index:1000;
  backdrop-filter:blur(18px);
  background:
    rgba(4,15,30,.72);
  border-bottom:
    1px solid rgba(120,170,255,.08);
}

.nav-container{
  max-width:1400px;
  margin:auto;
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:1.3rem 2rem;
}

.logo{
  display:flex;
  align-items:center;
  text-decoration:none;
}

.logo img{
  height:42px;
  width:auto;
  object-fit:contain;
  filter:
    drop-shadow(0 0 20px rgba(47,107,255,.45));
  transition:.4s;
}

.logo img:hover{
  transform:scale(1.04);
  filter:
    drop-shadow(0 0 35px rgba(47,107,255,.7));
}

/* FOOTER LOGO */

.footer-logo img{
  width:140px;
  margin-bottom:1rem;
  filter:
    drop-shadow(0 0 30px rgba(79,140,255,.28));
}

/* =========================
   MOBILE MENU
========================= */

.menu-toggle{

  width:52px;
  height:52px;

  display:none;

  flex-direction:column;
  justify-content:center;
  align-items:center;

  gap:6px;

  border-radius:18px;

  border:
    1px solid rgba(120,170,255,.15);

  background:
    rgba(16,35,65,.65);

  backdrop-filter:blur(18px);

  cursor:pointer;

  transition:.4s;
}

.menu-toggle:hover{

  box-shadow:
    0 0 30px rgba(47,107,255,.2);
}

.menu-toggle span{

  width:24px;
  height:2px;

  border-radius:20px;

  background:white;

  transition:.4s;
}

.menu-toggle.active span:nth-child(1){

  transform:
    translateY(8px)
    rotate(45deg);
}

.menu-toggle.active span:nth-child(2){

  opacity:0;
}

.menu-toggle.active span:nth-child(3){

  transform:
    translateY(-8px)
    rotate(-45deg);
}

/* =========================
   NAV LINKS
========================= */

.nav-links{

  display:flex;
  gap:2rem;

  list-style:none;
}

.nav-links a{

  color:var(--muted);

  text-decoration:none;

  transition:.3s;
}

.nav-links a:hover{

  color:white;
}

/* =========================
   BUTTONS
========================= */

.primary-btn,
.secondary-btn{

  padding:1rem 1.8rem;

  border-radius:999px;

  border:none;

  cursor:pointer;

  font-weight:600;

  transition:.4s;
}

.primary-btn{

  background:
    linear-gradient(
      135deg,
      #2f6bff,
      #4f8cff
    );

  color:white;

  box-shadow:var(--glow);
}

.primary-btn:hover{

  transform:
    translateY(-3px)
    scale(1.02);

  box-shadow:
    0 0 40px rgba(47,107,255,.35);
}

.secondary-btn{

  background:
    rgba(255,255,255,.04);

  color:white;

  border:
    1px solid rgba(120,170,255,.12);

  backdrop-filter:blur(10px);
}

.secondary-btn:hover{

  background:
    rgba(255,255,255,.08);
}

/* =========================
   HERO
========================= */

.hero{
  min-height:100vh;
  display:flex;
  align-items:center;
  position:relative;
  padding:0 8%;
  overflow:hidden;
}

.hero::before{
  content:'';
  position:absolute;
  inset:0;
  background:
    linear-gradient(
      to bottom,
      rgba(4,12,24,.25),
      rgba(4,12,24,.82)
    );
  z-index:1;
}

.hero-content{
  position:relative;
  z-index:5;
  max-width:760px;
}

.hero-tag{
  display:inline-block;
  padding:.6rem 1rem;
  border-radius:999px;
  background:
    rgba(47,107,255,.12);
  border:
    1px solid rgba(120,170,255,.15);
  margin-bottom:2rem;
  color:#d8e5ff;
}

.hero h1{
  font-size:clamp(4rem,8vw,7rem);
  line-height:.95;
  font-weight:900;
  letter-spacing:-4px;
  margin-bottom:2rem;
}

.hero-content h1{
  font-size:52px;
  line-height:1.05;
  margin:24px 0;
}

.hero-content h1 span{
  background:
    linear-gradient(
      90deg,
      #ffffff,
      #73a9ff,
      #9bc0ff
    );

  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
}

.hero p{
  font-size:1.15rem;
  line-height:1.8;
  color:var(--muted);
  max-width:650px;
  margin-bottom:3rem;
}

.hero-actions{
  display:flex;
  gap:1rem;
}

.hero-visual img{
  width:100%;
  border-radius:30px;
  object-fit:cover;
  box-shadow:
    0 40px 100px rgba(0,0,0,.45);
}

/* =========================
   GENERAL SECTIONS
========================= */

.section-padding{
  padding:120px 8%;
}

.section-header{
  margin-bottom:4rem;
}

.section-label{
  display:inline-block;
  color:#8fb7ff;
  margin-bottom:1rem;
  letter-spacing:2px;
  font-size:.8rem;
}

.section-header h2,
.showcase-text h2,
.cta h2{
  font-size:clamp(1.5rem,4vw,3rem);
  line-height:1.05;
  max-width:700px;
}


.showcaseHero-text h2,
.cta h2{
  font-size:clamp(1.5rem,4vw,3rem);
  line-height:1.05;
  max-width:700px;
}


/* =========================
   STATS
========================= */

.stats-grid{
  display:grid;
  grid-template-columns:
    repeat(auto-fit,minmax(220px,1fr));

  gap:2rem;
}

.stat-card{
  background:
    rgba(9,25,45,.78);

  border:
    1px solid rgba(120,170,255,.12);

  backdrop-filter:blur(18px);
  border-radius:var(--radius);
  padding:2rem;
  box-shadow:var(--shadow);
}

.stat-card h2{
  font-size:2rem;
  margin-bottom:1rem;
  color:#8bb4ff;
}

/* =========================
   SHOWCASE
========================= */

.showcase-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:4rem;
  align-items:center;
}

.showcase-image img{
  width:100%;
  border-radius:28px;
  box-shadow:var(--shadow);
}



.showcase-content h1{
  font-size:52px;
  line-height:1.05;
  margin:24px 0;
}

.showcase-content h1 span{
  background:
    linear-gradient(
      90deg,
      #ffffff,
      #73a9ff,
      #9bc0ff
    );

  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
}

.showcase p{
  font-size:1.15rem;
  line-height:1.8;
  color:var(--muted);
  max-width:650px;
  margin-bottom:3rem;
}



/* =========================
   SHOWCASE HERO
========================= */


.showcaseHero{
  min-height:100vh;
  display:flex;
  align-items:center;
  position:relative;
  padding:0 8%;
  overflow:hidden;
}

.showcaseHero::before{
  content:'';
  position:absolute;
  inset:0;
  background:
    linear-gradient(
      to bottom,
      rgba(4,12,24,.25),
      rgba(4,12,24,.82)
    );
  z-index:1;
}

.showcaseHero-content{
  position:relative;
  z-index:5;
  max-width:760px;
}


.showcaseHero-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:4rem;
  align-items:center;
}

.showcaseHero-image img{
  width:100%;
  border-radius:28px;
  box-shadow:var(--shadow);
}


.showcaseHero-tag{
  display:inline-block;
  padding:.6rem 1rem;
  border-radius:999px;
  background:
    rgba(47,107,255,.12);
  border:
    1px solid rgba(120,170,255,.15);
  margin-bottom:2rem;
  color:#d8e5ff;
}

.showcaseHero-content h1{
  font-size:52px;
  line-height:1.05;
  margin:24px 0;
}

.showcaseHero-content h1 span{
  background:
    linear-gradient(
      90deg,
      #ffffff,
      #73a9ff,
      #9bc0ff
    );

  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
}

.showcaseHero p{
  font-size:1.15rem;
  line-height:1.8;
  color:var(--muted);
  max-width:650px;
  margin-bottom:3rem;
}

.showcaseHero-actions{
  display:flex;
  gap:1rem;
}



/* =========================
   FEATURES
========================= */

.features-grid{

  display:grid;

  grid-template-columns:
    repeat(auto-fit,minmax(280px,1fr));

  gap:2rem;
}

.feature-card{

  position:relative;

  overflow:hidden;

  padding:2.5rem;

  border-radius:var(--radius);

  background:
    rgba(10,28,52,.72);

  border:
    1px solid rgba(120,170,255,.12);

  backdrop-filter:blur(20px);

  transition:.5s;
}

.feature-card:hover{

  transform:translateY(-8px);

  border-color:
    rgba(47,107,255,.32);

  box-shadow:
    0 0 35px rgba(47,107,255,.12);
}

.card-glow{

  position:absolute;

  width:250px;
  height:250px;

  background:
    radial-gradient(
      circle,
      rgba(47,107,255,.22),
      transparent 70%
    );

  top:-100px;
  right:-100px;
}

/* =========================
   CTA
========================= */

.cta-box{

  position:relative;

  overflow:hidden;

  border-radius:32px;

  padding:6rem;

  background:
    linear-gradient(
      135deg,
      rgba(10,30,55,.82),
      rgba(8,22,42,.72)
    );

  border:
    1px solid rgba(120,170,255,.12);

  backdrop-filter:blur(24px);
}

.cta-gradient{

  position:absolute;

  inset:0;

  background:
    radial-gradient(
      circle at top right,
      rgba(47,107,255,.2),
      transparent 35%
    );
}

/* =========================
   FOOTER
========================= */

.footer{

  padding:5rem 8%;

  border-top:
    1px solid rgba(120,170,255,.08);
}

.footer-grid{

  display:grid;

  grid-template-columns:
    repeat(auto-fit,minmax(220px,1fr));

  gap:3rem;
}

.footer h4{

  margin-bottom:1rem;
}

.footer ul{

  list-style:none;
}

.footer a{

  color:var(--muted);

  text-decoration:none;

  line-height:2;
}

/* =========================
   REVEAL
========================= */

.reveal{

  opacity:0;

  transform:translateY(40px);

  transition:
    opacity 1s ease,
    transform 1s ease;
}

.reveal.active{

  opacity:1;

  transform:translateY(0);
}

/* =========================
   LOGIN SECTION
========================= */

.login-section{

  position:relative;

  z-index:5;
}

.login-container{

  display:grid;

  grid-template-columns:4fr 8fr;

  gap:4rem;

  align-items:start;
}

.login-info{

  position:relative;
}

.login-info h2{

  font-size:clamp(1.5rem,4vw,3.5rem);

  line-height:1.05;

  margin-bottom:1.5rem;
}

.login-info p{

  color:var(--muted);

  max-width:500px;

  line-height:1.8;
}

.login-glow{

  position:absolute;

  width:400px;
  height:400px;

  background:
    radial-gradient(
      circle,
      rgba(47,107,255,.2),
      transparent 70%
    );

  top:-100px;
  left:-100px;

  filter:blur(100px);

  z-index:-1;
}

.login-card{

  background:
    rgba(8,24,46,.82);

  border:
    1px solid rgba(120,170,255,.12);

  backdrop-filter:blur(24px);

  padding:3rem;

  border-radius:32px;

  box-shadow:
    0 20px 80px rgba(0,0,0,.35);

  position:relative;

  overflow:hidden;
}

.login-card::before{

  content:'';

  position:absolute;

  inset:0;

  background:
    linear-gradient(
      135deg,
      rgba(47,107,255,.12),
      rgba(79,140,255,.04)
    );

  pointer-events:none;
}

.input-group{

  margin-bottom:1.5rem;
}

.input-group label{

  display:block;

  margin-bottom:.7rem;

  color:#d8e5ff;

  font-size:.95rem;
}

.input-group input,
.input-group textarea{

  width:100%;

  padding:1rem 1.2rem;

  border-radius:18px;

  border:
    1px solid rgba(120,170,255,.12);

  background:
    rgba(255,255,255,.03);

  color:white;

  outline:none;

  transition:.3s;
}

.input-group input:focus,
.input-group textarea:focus{

  border-color:
    rgba(47,107,255,.5);

  box-shadow:
    0 0 20px rgba(47,107,255,.2);
}

.login-btn{

  width:100%;

  margin-top:1rem;
}







/* =========================
   CONTACT SECTION
========================= */

.contact-section{
  position:relative;
  z-index:5;
}

.contact-container{
  display:grid;
  grid-template-columns:4fr 8fr;
  gap:4rem;
  align-items:start;
}

.contact-info{
  position:relative;
}

.contact-info h2{
  font-size:clamp(1.5rem,4vw,3.5rem);
  line-height:1.05;
  margin-bottom:1.5rem;
}

.contact-info p{
  color:var(--muted);
  max-width:500px;
  line-height:1.8;
}

.contact-glow{
  position:absolute;
  width:400px;
  height:400px;
  background:
    radial-gradient(
      circle,
      rgba(47,107,255,.2),
      transparent 70%
    );

  top:-100px;
  left:-100px;
  filter:blur(100px);
  z-index:-1;
}

.contact-card{
  background:
    rgba(8,24,46,.82);
  border:
    1px solid rgba(120,170,255,.12);

  backdrop-filter:blur(24px);
  padding:3rem;
  border-radius:32px;
  box-shadow:
    0 20px 80px rgba(0,0,0,.35);
  position:relative;
  overflow:hidden;
}

.contact-card::before{
  content:'';
  position:absolute;
  inset:0;
  background:
    linear-gradient(
      135deg,
      rgba(47,107,255,.12),
      rgba(79,140,255,.04)
    );

  pointer-events:none;
}

.input-group{

  margin-bottom:1.5rem;
}

.input-group label{

  display:block;

  margin-bottom:.7rem;

  color:#d8e5ff;

  font-size:.95rem;
}

.input-group input,
.input-group textarea{

  width:100%;

  padding:1rem 1.2rem;

  border-radius:18px;

  border:
    1px solid rgba(120,170,255,.12);

  background:
    rgba(255,255,255,.03);

  color:white;

  outline:none;

  transition:.3s;
}

.input-group input:focus,
.input-group textarea:focus{

  border-color:
    rgba(47,107,255,.5);

  box-shadow:
    0 0 20px rgba(47,107,255,.2);
}

.contact-btn{

  width:100%;

  margin-top:1rem;
}



/* =========================
   FORM ROW
========================= */

.form-row{

  display:flex;

  gap:20px;
}

.form-row .input-group{

  flex:1;
}

/* =========================
   CONTACT CARDS
========================= */



.contact-cards{

    display:grid;

    grid-template-columns:1fr;

    gap:14px;

    margin-top:2rem;
}

.contact-card{

  position:relative;
  display:flex;
  align-items:center;
  gap:1rem;
  padding:1.1rem 1.2rem;
  border-radius:22px;
  text-decoration:none;
  overflow:hidden;

  background:    rgba(10,28,52,.72);
  border:    1px solid rgba(120,170,255,.12);
  backdrop-filter:blur(20px);
  transition:.45s;
  box-shadow:    0 10px 40px rgba(0,0,0,.22);
  
  flex: 1 1 220px;
  min-width: 220px;
  
}

.contact-card:hover{

  transform:translateY(-4px);

  border-color:
    rgba(47,107,255,.28);

  box-shadow:
    0 0 35px rgba(47,107,255,.12);
}

.contact-icon{

  min-width:54px;
  height:54px;

  display:flex;
  align-items:center;
  justify-content:center;

  border-radius:18px;

  font-size:1.3rem;

  color:white;

  background:
    linear-gradient(
      135deg,
      rgba(47,107,255,.3),
      rgba(79,140,255,.22)
    );
}

.contact-content{

  display:flex;

  flex-direction:column;
}

.contact-content span{

  font-size:.78rem;

  letter-spacing:1px;

  text-transform:uppercase;

  color:#8fb7ff;

  margin-bottom:.3rem;
}

.contact-content strong{

  color:white;

  font-size:.98rem;

  font-weight:600;
}

/* =========================
   PROJECTS
========================= */

.projects{

  position:relative;

  overflow:hidden;
}

.projects-slider{

  display:grid;

  grid-template-columns:
    repeat(auto-fit,minmax(300px,1fr));

  gap:2rem;

  margin-top:2rem;
}

.project-card{

  position:relative;

  width:100%;

  padding:2rem;

  border-radius:30px;

  overflow:hidden;

  text-decoration:none;

  background:
    rgba(10,28,52,.72);

  border:
    1px solid rgba(120,170,255,.12);

  backdrop-filter:blur(24px);

  transition:.5s;

  box-shadow:
    0 10px 40px rgba(0,0,0,.28);
}

.project-card:hover{

  transform:translateY(-8px);

  border-color:
    rgba(47,107,255,.28);

  box-shadow:
    0 0 45px rgba(47,107,255,.12);
}

.project-icon{

  width:72px;
  height:72px;

  display:flex;
  align-items:center;
  justify-content:center;

  margin-bottom:1.8rem;

  border-radius:24px;

  font-size:1.6rem;

  color:white;

  background:
    linear-gradient(
      135deg,
      rgba(47,107,255,.32),
      rgba(79,140,255,.24)
    );

  box-shadow:
    0 0 30px rgba(47,107,255,.15);
}

.project-card h3{

  font-size:1.3rem;

  line-height:1.3;

  margin-bottom:1rem;

  color:white;
}

.project-card p{

  color:var(--muted);

  line-height:1.7;

  font-size:.98rem;
}

/* =========================
   BTN SESION
========================= */

.btnSesion{

  padding:.68rem 1.25rem;

  font-size:.92rem;

  text-decoration:none;

  display:inline-flex;
  align-items:center;
  justify-content:center;

  border-radius:999px;

  color:white;

  transition:.4s;
}

.btnSesion:hover{

  text-decoration:none;
}

/* =========================
   ALERTAS FORMULARIO
========================= */

.form-message{

  margin-top:2rem;

  padding:1.2rem 1.5rem;

  border-radius:22px;

  backdrop-filter:blur(20px);

  border:1px solid rgba(255,255,255,.08);

  position:relative;

  overflow:hidden;

  font-size:.95rem;

  line-height:1.6;

  animation:fadeUp .5s ease;
}

.form-message.success{

  background:
    linear-gradient(
      135deg,
      rgba(52,152,219,.18),
      rgba(52,152,219,.06)
    );

  border-color:
    rgba(52,152,219,.35);

  color:#dcefff;

  box-shadow:
    0 0 30px rgba(52,152,219,.12);
}

.form-message.error{

  background:
    linear-gradient(
      135deg,
      rgba(255,90,90,.12),
      rgba(255,90,90,.04)
    );

  border-color:
    rgba(255,90,90,.25);

  color:#ffe2e2;

  box-shadow:
    0 0 30px rgba(255,90,90,.08);
}

@keyframes fadeUp{

  from{

    opacity:0;
    transform:translateY(20px);
  }

  to{

    opacity:1;
    transform:translateY(0);
  }
}

.divider{

  display: flex;
  align-items: center;

  margin: 2rem 0;

  color: #8b8b97;

  gap: 1rem;
}

.divider::before,
.divider::after{

  content: '';

  flex: 1;

  height: 1px;

  background:
    rgba(255,255,255,.08);
}



.google-btn{
    display:flex;
    align-items:center;
    justify-content:center;

	/* =========================
	gap:1px;
    width:100%;
    padding:12px 16px;
    background:#fff;
    border:1px solid #dadce0;
    border-radius:8px;
    text-decoration:none;
    color:#3c4043;
    font-weight:500;
    font-size:15px;

    cursor:pointer;
    transition:all .2s ease;	
========================= */

  gap: 1rem;
  padding: 1rem;
  border-radius: 18px;
  border: 1px solid rgba(255,255,255,.08);
  background:
    rgba(255,255,255,.04);
  color: white;
  cursor: pointer;
  transition: .4s;
  font-weight: 600;    

}

.google-btn:hover{
	/* =========================
    background:#f8f9fa;
    border-color:#c6c6c6;
	
========================= */
   	transform: translateY(-2px);
  background:
    rgba(255,255,255,.07);
  box-shadow:
    0 0 30px rgba(91,124,255,.15);
}







/* =========================
   RESPONSIVE
========================= */

@media(max-width:980px){

  .showcase-grid{
    grid-template-columns:1fr;
  }

  .showcaseHero-grid{
    grid-template-columns:1fr;
  }

  .menu-toggle{

    display:flex;
  }

  .nav-menu{

    position:absolute;

    top:100%;
    left:50%;

    transform:
      translateX(-50%)
      translateY(-30px);

    width:calc(100% - 40px);

    opacity:0;
    visibility:hidden;

    transition:.4s ease;

    padding:2rem;

    border-radius:28px;

    background:
      rgba(6,18,34,.96);

    backdrop-filter:blur(30px);

    border:
      1px solid rgba(120,170,255,.12);
  }

  .nav-menu.active{

    opacity:1;
    visibility:visible;

    transform:
      translateX(-50%)
      translateY(15px);
  }

  .nav-links{

    flex-direction:column;

    align-items:center;
  }

  .login-container{
    grid-template-columns:1fr;
    gap:2rem;
  }

  .login-info{
    text-align:center;
  }

  .login-info p{
    margin:auto;
  }

.contact-container{
    grid-template-columns:1fr;
    gap:2rem;
  }

  .contact-info{
    text-align:center;
  }

  .contact-info p{
    margin:auto;
  }


  
   .contact-cards{
    flex-direction: column;
    margin: 2.5rem auto 0 auto;
  }

  .contact-card{
    width: 100%;
  }
  
  
}

@media(max-width:768px){

  .form-row{

    flex-direction:column;

    gap:0;
  }
}

@media(max-width:680px){

  .hero{
    padding-top:120px;
  }

  .hero-actions{
    flex-direction:column;
  }

  .showcaseHero-actions{
    flex-direction:column;
  }


  .cta-box{

    padding:3rem 2rem;
  }

  .project-card{

    min-width:280px;
  }
}




/* =========================
   FUTURISTIC FEATURE LISTS
========================= */

.feature-card ul{

  list-style:none;

  margin-top:1.8rem;

  display:flex;
  flex-direction:column;

  gap:1rem;

  position:relative;

  z-index:2;
}

.feature-card ul li{

  position:relative;

  padding:
    1rem 1rem 1rem 3.4rem;

  border-radius:20px;

  overflow:hidden;

  color:#dce9ff;

  font-size:.96rem;

  line-height:1.6;

  background:
    linear-gradient(
      135deg,
      rgba(255,255,255,.045),
      rgba(255,255,255,.015)
    );

  border:
    1px solid rgba(120,170,255,.12);

  backdrop-filter:blur(18px);

  box-shadow:
    0 10px 30px rgba(0,0,0,.22);

  transition:
    transform .45s ease,
    border-color .45s ease,
    box-shadow .45s ease,
    background .45s ease;
}

/* =========================
   LIGHT EFFECT
========================= */

.feature-card ul li::before{

  content:'';

  position:absolute;

  inset:0;

  background:
    radial-gradient(
      circle at left center,
      rgba(47,107,255,.18),
      transparent 65%
    );

  opacity:.9;

  pointer-events:none;

  transition:.5s;
}

/* =========================
   FUTURISTIC BULLET
========================= */

.feature-card ul li::after{

  content:'';

  position:absolute;

  top:50%;
  left:1.2rem;

  transform:
    translateY(-50%);

  width:12px;
  height:12px;

  border-radius:50%;

  background:
    radial-gradient(
      circle,
      #ffffff 0%,
      #7fb1ff 25%,
      #2f6bff 55%,
      rgba(47,107,255,.1) 100%
    );

  box-shadow:
    0 0 12px rgba(255,255,255,.4),
    0 0 24px rgba(47,107,255,.55),
    0 0 40px rgba(79,140,255,.35);

  animation:
    futuristicPulse 4.5s ease-in-out infinite;
}

/* =========================
   HOVER
========================= */

.feature-card ul li:hover{

  transform:
    translateX(8px)
    scale(1.01);

  border-color:
    rgba(79,140,255,.28);

  background:
    linear-gradient(
      135deg,
      rgba(47,107,255,.12),
      rgba(79,140,255,.03)
    );

  box-shadow:
    0 0 30px rgba(47,107,255,.18),
    0 18px 40px rgba(0,0,0,.35);
}

.feature-card ul li:hover::before{

  background:
    radial-gradient(
      circle at left center,
      rgba(79,140,255,.24),
      transparent 70%
    );

  opacity:1;
}

/* =========================
   ANIMATION
========================= */

@keyframes futuristicPulse{

  0%{

    transform:
      translateY(-50%)
      scale(.75);

    opacity:.45;
  }

  25%{

    transform:
      translateY(-50%)
      scale(1);

    opacity:.85;
  }

  50%{

    transform:
      translateY(-50%)
      scale(1.22);

    opacity:1;
  }

  75%{

    transform:
      translateY(-50%)
      scale(.95);

    opacity:.75;
  }

  100%{

    transform:
      translateY(-50%)
      scale(.75);

    opacity:.45;
  }
}



.footer-social{
    display:flex;
    align-items:center;
    gap:14px;
    margin-top:22px;
}

.social-icon{
    width:42px;
    height:42px;

    display:flex;
    align-items:center;
    justify-content:center;

    border-radius:14px;

    background:rgba(255,255,255,0.04);

    border:1px solid rgba(255,255,255,0.08);

    backdrop-filter:blur(12px);

    color:#d7e2ff;

    font-size:16px;

    text-decoration:none;

    transition:all .25s ease;
}

.social-icon:hover{

    transform:translateY(-3px);

    border-color:rgba(120,160,255,.35);

    background:rgba(120,160,255,.08);

    box-shadow:
      0 0 18px rgba(120,160,255,.18),
      0 0 40px rgba(120,160,255,.08);

    color:#ffffff;
}

.footer{
    position:relative;
    overflow:hidden;
}

.footer::before{
    content:'';

    position:absolute;
    inset:0;

    background:
      radial-gradient(circle at top left,
      rgba(90,120,255,.12),
      transparent 35%);

    pointer-events:none;
}
.social-icon i{
    color:#d7e2ff;
    font-size:18px;
    transition:.25s;
}

.social-icon:hover i{
    color:white;
}





/* =========================
   LOGIN ALERT
========================= */

.login-alert{

    display:flex;
    align-items:center;
    gap:12px;

    margin-top:1.5rem;
    padding:1rem 1.2rem;

    border-radius:18px;

    background:
      linear-gradient(
        135deg,
        rgba(255,90,90,.10),
        rgba(255,90,90,.04)
      );

    border:
      1px solid rgba(255,90,90,.18);

    backdrop-filter:blur(18px);

    color:#ffe7e7;

    box-shadow:
      0 0 30px rgba(255,90,90,.06);

    animation:fadeUp .4s ease;
}

.login-alert i{

    color:#ff7d7d;

    font-size:1rem;
}

/* =========================
   LOGIN FOOTER
========================= */

.login-footer{

    display:flex;
    justify-content:center;

    margin-top:2rem;
}

/* =========================
   FORGOT PASSWORD
========================= */

.forgot-link{

    display:inline-flex;
    align-items:center;
    gap:10px;

    padding:.9rem 1.2rem;

    border-radius:18px;

    text-decoration:none;

    color:#cfe0ff;

    background:
      rgba(255,255,255,.03);

    border:
      1px solid rgba(120,170,255,.10);

    backdrop-filter:blur(14px);

    transition:.35s ease;
}

.forgot-link:hover{

    transform:translateY(-2px);

    color:#ffffff;

    border-color:
      rgba(120,170,255,.28);

    background:
      rgba(120,170,255,.06);

    box-shadow:
      0 0 25px rgba(47,107,255,.12);
}

.forgot-link i{

    font-size:.9rem;

    color:#8fb7ff;
}




/* =========================
   terminos
========================= */


.glass-container{
  position: relative;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 60px;
  align-items: center;
  max-width: 1300px;
  margin: 0 auto;
  padding: 60px;
  border-radius: 32px;
  background: rgba(255,255,255,0.03);
  border: 1px solid rgba(255,255,255,0.08);
  backdrop-filter: blur(14px);
  overflow: hidden;
}

.reverse-grid{
  grid-template-columns: 1fr 1fr;
}

.terms-image{
  width: 100%;
  height: 420px;
  object-fit: cover;
  border-radius: 24px;
}

.terms-content h2{
  font-size: 3rem;
  margin-bottom: 24px;
  line-height: 1.1;
}

.terms-content p{
  font-size: 1rem;
  line-height: 1.8;
  color: rgba(255,255,255,0.72);
  margin-bottom: 20px;
}

.legal-box{
  max-width: 900px;
  margin: 0 auto;
  text-align: center;
  padding: 80px 40px;
  border-radius: 32px;
  background: rgba(255,255,255,0.03);
  border: 1px solid rgba(255,255,255,0.08);
}

.legal-box h2{
  font-size: 2.5rem;
  margin-bottom: 24px;
}

.legal-box p{
  color: rgba(255,255,255,0.72);
  line-height: 1.8;
}

@media(max-width: 900px){

  .glass-container,
  .reverse-grid{
    grid-template-columns: 1fr;
    padding: 30px;
  }

  .terms-content h2{
    font-size: 2rem;
  }

  .terms-image{
    height: 280px;
  }

}






/* =========================
   FUTURISTIC CAROUSEL
========================= */

.stats-carrousel{

  position:relative;

  margin-top:4rem;

  width:100%;

  overflow:hidden;

  border-radius:32px;

  border:
    1px solid rgba(120,170,255,.12);

  background:
    rgba(10,28,52,.55);

  backdrop-filter:blur(24px);

  box-shadow:
    0 20px 60px rgba(0,0,0,.35);

}

.carousel-track{

  position:relative;

  width:100%;

  height:560px;
}

.carousel-slide{

  position:absolute;

  inset:0;

  opacity:0;

  transform:scale(1.04);

  transition:
    opacity .9s ease,
    transform 1.2s ease;
}

.carousel-slide.active{

  opacity:1;

  transform:scale(1);
}

.carousel-slide img{

  width:100%;
  height:100%;

  object-fit:cover;

  display:block;
}

.carousel-slide::before{

  content:'';

  position:absolute;

  inset:0;

  background:
    linear-gradient(
      to top,
      rgba(3,10,20,.92),
      rgba(3,10,20,.25),
      rgba(3,10,20,.08)
    );
}

.carousel-overlay{

  position:absolute;

  left:60px;
  bottom:60px;

  z-index:5;

  max-width:600px;
}

.carousel-overlay h3{

  font-size:clamp(2rem,4vw,3.5rem);

  margin-bottom:1rem;

  color:white;

  text-shadow:
    0 0 30px rgba(47,107,255,.45);
}

.carousel-overlay p{

  font-size:1.05rem;

  color:#dce7ff;

  line-height:1.8;

  max-width:520px;
}

.carousel-controls{

  position:absolute;

  inset:0;

  display:flex;

  align-items:center;

  justify-content:space-between;

  padding:0 24px;

  pointer-events:none;
}

.carousel-btn{

  width:58px;
  height:58px;

  border:none;

  border-radius:20px;

  cursor:pointer;

  font-size:1.4rem;

  color:white;

  pointer-events:auto;

  background:
    rgba(8,24,46,.65);

  border:
    1px solid rgba(120,170,255,.18);

  backdrop-filter:blur(16px);

  transition:.35s;
}

.carousel-btn:hover{

  transform:scale(1.08);

  background:
    rgba(47,107,255,.22);

  box-shadow:
    0 0 30px rgba(47,107,255,.25);
}

/* GLOW */

.stats-carrousel::after{

  content:'';

  position:absolute;

  width:500px;
  height:500px;

  background:
    radial-gradient(
      circle,
      rgba(47,107,255,.16),
      transparent 70%
    );

  top:-180px;
  right:-180px;

  pointer-events:none;
}

/* RESPONSIVE */

@media(max-width:980px){

  .carousel-track{

    height:420px;
  }

  .carousel-overlay{

    left:30px;
    right:30px;
    bottom:30px;
  }

  .carousel-overlay h3{

    font-size:2rem;
  }

}

@media(max-width:680px){

  .carousel-track{

    height:320px;
  }

  .carousel-btn{

    width:46px;
    height:46px;

    font-size:1rem;
  }

  .carousel-overlay h3{

    font-size:1.5rem;
  }

  .carousel-overlay p{

    font-size:.92rem;
    line-height:1.6;
  }

}


/* COMO FUNCIONA SECTION */

.workflow-grid{
    display:flex;
    justify-content:center;
    align-items:stretch;
    gap:20px;
    flex-wrap:wrap;
    margin-top:60px;
}

.workflow-card{
    width:260px;
    padding:25px;
    border-radius:20px;
    text-align:center;

    background:rgba(255,255,255,0.03);
    backdrop-filter:blur(12px);

    border:1px solid rgba(255,255,255,0.08);

    transition:.3s;
}

.workflow-card:hover{
    transform:translateY(-6px);
}

.workflow-number{

    width:60px;
    height:60px;

    margin:auto;
    margin-bottom:20px;

    border-radius:50%;

    display:flex;
    align-items:center;
    justify-content:center;

    font-size:24px;
    font-weight:700;

    background:linear-gradient(
        135deg,
        #00c6ff,
        #0072ff
    );
}

.workflow-image{

    margin-bottom:20px;
}

.workflow-image img{

    width:100%;
    height:130px;

    object-fit:cover;

    border-radius:12px;

    border:1px solid rgba(
        255,
        255,
        255,
        0.08
    );

    transition:.3s;
}

.workflow-card:hover .workflow-image img{

    transform:scale(1.03);
}

.workflow-card h3{

    margin-bottom:15px;
}

.workflow-arrow{

    display:flex;
    align-items:center;

    font-size:32px;
    opacity:.4;
}

@media(max-width:1200px){

    .workflow-arrow{
        display:none;
    }

}





/* ==================================================
   BENEFICIOS OPERATIVOS
================================================== */

.benefits-section{
    position:relative;
}

.benefits-header{
    text-align:center;
    margin-bottom:4rem;
}

.benefits-header h2{
    font-size:clamp(2rem,4vw,3.2rem);
    line-height:1.1;
    max-width:900px;
    margin:0 auto;
}

/* GRID */

.benefits-grid{
    display:grid;
    grid-template-columns:repeat(3, 1fr);
    gap:24px;
    align-items:stretch;
}

/* CARD */

.benefit-card{
    display:flex;
    flex-direction:column;
    justify-content:flex-start;
    min-height:220px;
    padding:2rem;
    border-radius:28px;
    background:
        rgba(10,28,52,.72);

    border:
        1px solid rgba(120,170,255,.12);

    backdrop-filter:blur(20px);

    box-shadow:
        0 10px 40px rgba(0,0,0,.28);

    transition:.4s ease;
}

.benefit-card:hover{

    transform:translateY(-6px);
    border-color:
        rgba(47,107,255,.28);
    box-shadow:
        0 0 35px rgba(47,107,255,.12);
}

/* TITULO */

.benefit-card h3{
    font-size:2.35rem;
    line-height:1.3;
    color:#8fb7ff;
    margin-bottom:1rem;
    font-weight:700;
}

/* TEXTO */

.benefit-card p{
    color:var(--muted);
    line-height:1.7;
    font-size:.99rem;
}

/* =========================
   TABLET
========================= */

@media(max-width:1024px){

    .benefits-grid{

        grid-template-columns:
            repeat(2,1fr);
    }
}

/* =========================
   MOBILE
========================= */

@media(max-width:680px){

    .benefits-grid{

        grid-template-columns:1fr;
    }

    .benefit-card{

        min-height:auto;

        padding:1.6rem;
    }

    .benefit-card h3{

        font-size:1.15rem;
    }

    .benefit-card p{

        font-size:.92rem;
    }
}







/* ==================================================
   FUNCIONALIDADES BLUXTI
================================================== */

.bluxti-features-section{
    position:relative;
}

.bluxti-features-header{

    text-align:center;

    margin-bottom:4rem;
}

.bluxti-features-label{

    display:inline-block;

    margin-bottom:1rem;

    font-size:.85rem;

    letter-spacing:2px;

    text-transform:uppercase;

    color:#8fb7ff;
}

.bluxti-features-header h2{

    font-size:clamp(2rem,4vw,3.2rem);

    line-height:1.1;

    max-width:900px;

    margin:0 auto;
}

/* GRID */

.bluxti-features-grid{

    display:grid;

    grid-template-columns:
        repeat(3,1fr);

    gap:24px;
}

/* CARD */

.bluxti-feature-card{

    position:relative;

    display:flex;

    flex-direction:column;

    align-items:flex-start;

    justify-content:flex-start;

    min-height:260px;

    padding:2rem;

    border-radius:28px;

    text-decoration:none;

    background:
        rgba(10,28,52,.72);

    border:
        1px solid rgba(120,170,255,.12);

    backdrop-filter:blur(24px);

    box-shadow:
        0 10px 40px rgba(0,0,0,.28);

    transition:.4s ease;
}

.bluxti-feature-card:hover{

    transform:translateY(-8px);

    border-color:
        rgba(47,107,255,.28);

    box-shadow:
        0 0 40px rgba(47,107,255,.12);
}

/* ICONO */

.bluxti-feature-icon{

    width:70px;
    height:70px;

    display:flex;

    align-items:center;
    justify-content:center;

    margin-bottom:1.5rem;

    border-radius:22px;

    font-size:1.8rem;

    background:
        linear-gradient(
            135deg,
            rgba(47,107,255,.32),
            rgba(79,140,255,.24)
        );

    box-shadow:
        0 0 30px rgba(47,107,255,.12);
}

/* TITULO */

.bluxti-feature-card h3{

    font-size:1.25rem;

    line-height:1.3;

    color:white;

    margin-bottom:1rem;
}

/* TEXTO */

.bluxti-feature-card p{

    color:var(--muted);

    line-height:1.7;

    font-size:.96rem;
}

/* HOVER SUAVE DEL ICONO */

.bluxti-feature-card:hover .bluxti-feature-icon{

    transform:scale(1.05);

    transition:.3s;
}

/* ==================================================
   TABLET
================================================== */

@media(max-width:1024px){

    .bluxti-features-grid{

        grid-template-columns:
            repeat(2,1fr);
    }
}

/* ==================================================
   MOBILE
================================================== */

@media(max-width:680px){

    .bluxti-features-grid{

        grid-template-columns:1fr;
    }

    .bluxti-feature-card{

        min-height:auto;

        padding:1.7rem;
    }

    .bluxti-feature-icon{

        width:60px;
        height:60px;

        font-size:1.5rem;
    }

    .bluxti-feature-card h3{

        font-size:1.1rem;
    }

    .bluxti-feature-card p{

        font-size:.92rem;
    }
}






/* ==================================================
   INDUSTRIAS / SEGMENTOS BLUXTI
================================================== */

.bluxti-industries-section{
    position:relative;
}

.bluxti-industries-header{

    text-align:center;

    margin-bottom:4rem;
}

.bluxti-industries-header h2{

    font-size:clamp(2rem,4vw,3.2rem);

    line-height:1.1;

    max-width:900px;

    margin:0 auto;
}

/* GRID */

.bluxti-industries-grid{

    display:grid;

    grid-template-columns:
        repeat(3,1fr);

    gap:24px;

    align-items:stretch;
}

/* CARD */

.bluxti-industry-card{

    position:relative;

    display:flex;

    flex-direction:column;

    justify-content:flex-start;

    min-height:280px;

    padding:2rem;

    border-radius:28px;

    text-decoration:none;

    overflow:hidden;

    background:
        rgba(10,28,52,.72);

    border:
        1px solid rgba(120,170,255,.12);

    backdrop-filter:blur(24px);

    box-shadow:
        0 10px 40px rgba(0,0,0,.28);

    transition:.45s ease;
}

/* GLOW SUPERIOR */

.bluxti-industry-card::before{

    content:'';

    position:absolute;

    top:0;
    left:0;

    width:100%;
    height:2px;

    background:
        linear-gradient(
            90deg,
            transparent,
            rgba(79,140,255,.8),
            transparent
        );

    opacity:0;

    transition:.4s;
}

.bluxti-industry-card:hover{

    transform:translateY(-8px);

    border-color:
        rgba(47,107,255,.28);

    box-shadow:
        0 0 40px rgba(47,107,255,.12);
}

.bluxti-industry-card:hover::before{

    opacity:1;
}

/* ICONO */

.bluxti-industry-icon{

    width:72px;
    height:72px;

    display:flex;

    align-items:center;
    justify-content:center;

    margin-bottom:1.5rem;

    border-radius:22px;

    font-size:1.8rem;

    background:
        linear-gradient(
            135deg,
            rgba(47,107,255,.32),
            rgba(79,140,255,.24)
        );

    box-shadow:
        0 0 30px rgba(47,107,255,.15);

    transition:.3s;
}

.bluxti-industry-card:hover .bluxti-industry-icon{

    transform:scale(1.08);
}

/* TITULO */

.bluxti-industry-card h3{

    font-size:1.2rem;

    line-height:1.4;

    color:white;

    margin-bottom:1rem;

    font-weight:700;
}

/* TEXTO */

.bluxti-industry-card p{

    color:var(--muted);

    line-height:1.75;

    font-size:.95rem;
}

/* ==================================================
   TABLET
================================================== */

@media(max-width:1024px){

    .bluxti-industries-grid{

        grid-template-columns:
            repeat(2,1fr);
    }
}

/* ==================================================
   MOBILE
================================================== */

@media(max-width:680px){

    .bluxti-industries-grid{

        grid-template-columns:1fr;
    }

    .bluxti-industry-card{

        min-height:auto;

        padding:1.7rem;
    }

    .bluxti-industry-icon{

        width:60px;
        height:60px;

        font-size:1.5rem;
    }

    .bluxti-industry-card h3{

        font-size:1.05rem;
    }

    .bluxti-industry-card p{

        font-size:.92rem;
    }
}




/* ==========================================
   DEMO BENEFITS
========================================== */

.demo-benefits{

    display:flex;

    flex-direction:column;

    gap:12px;

    margin-top:2rem;

    margin-bottom:2rem;
}

.demo-benefit{

    display:flex;

    align-items:center;

    padding:14px 18px;

    border-radius:18px;

    background:
        rgba(255,255,255,.03);

    border:
        1px solid rgba(120,170,255,.10);

    backdrop-filter:blur(12px);

    color:#dce9ff;

    font-size:.95rem;

    transition:.3s;
}

.demo-benefit:hover{

    transform:translateX(4px);

    border-color:
        rgba(47,107,255,.25);
}


.demo-form-header{

    margin-bottom:2rem;
}

.demo-form-header h3{

    font-size:1.6rem;

    margin-bottom:.6rem;
}

.demo-form-header p{

    color:var(--muted);

    line-height:1.6;
}





/* ==========================
   CUSTOM SOLUTIONS SECTION
========================== */

.custom-solutions{

    position:relative;

    text-align:center;

    overflow:hidden;
}

.custom-solutions-content{

    max-width:900px;

    margin:0 auto;

    padding:70px 50px;

    border-radius:28px;

    background:rgba(255,255,255,0.03);

    backdrop-filter:blur(16px);

    border:1px solid rgba(
        255,
        255,
        255,
        0.08
    );

    position:relative;

    overflow:hidden;
}

/* efecto glow */

.custom-solutions-content::before{

    content:'';

    position:absolute;

    width:400px;
    height:400px;

    top:-200px;
    left:-150px;

    background:radial-gradient(
        circle,
        rgba(0,198,255,.12),
        transparent 70%
    );

    pointer-events:none;
}

.custom-solutions-content::after{

    content:'';

    position:absolute;

    width:350px;
    height:350px;

    bottom:-180px;
    right:-120px;

    background:radial-gradient(
        circle,
        rgba(0,114,255,.12),
        transparent 70%
    );

    pointer-events:none;
}

.custom-solutions h2{

    margin-top:15px;
    margin-bottom:25px;

    font-size:clamp(
        2rem,
        5vw,
        3.5rem
    );

    line-height:1.1;
}

.custom-solutions p{

    max-width:700px;

    margin:0 auto 35px auto;

    font-size:1.1rem;

    line-height:1.8;

    opacity:.85;
}

.custom-solutions .primary-btn{

    min-width:220px;
}

/* hover */

.custom-solutions-content:hover{

    border-color:rgba(
        0,
        198,
        255,
        .35
    );

    transition:.4s;
}

/* responsive */

@media(max-width:768px){

    .custom-solutions-content{

        padding:50px 25px;
    }

    .custom-solutions h2{

        font-size:2rem;
    }

    .custom-solutions p{

        font-size:1rem;
    }

}





/* ==========================
   LANGUAGE SWITCHER
========================== */

.language-item{

    display:flex;
    align-items:center;
    gap:10px;

    margin-left:10px;
}

.lang-btn{

    width:38px;
    height:38px;

    padding:0;

    display:flex;
    align-items:center;
    justify-content:center;

    border-radius:12px;

    background:rgba(255,255,255,.04);

    border:1px solid rgba(
        255,
        255,
        255,
        .08
    );

    cursor:pointer;

    transition:.25s ease;
}

.lang-btn img{

    width:22px;
    height:16px;

    border-radius:3px;

    object-fit:cover;
}

.lang-btn:hover{

    transform:translateY(-2px);

    border-color:rgba(
        0,
        198,
        255,
        .5
    );

    box-shadow:
    0 0 18px rgba(
        0,
        198,
        255,
        .18
    );
}

.lang-btn.active{

    border-color:#00c6ff;

    background:rgba(
        0,
        198,
        255,
        .12
    );

    box-shadow:
    0 0 18px rgba(
        0,
        198,
        255,
        .25
    );
}
		