:root{
    --logos-blue: #220E7A;
    --logos-turq: #13E8A5;
    --logos-gold: #F5A608;
    --gray-900: #0f172a;
    --gray-600: #475569;
    --gray-300: #cbd5e1;
    --bg-soft: #f8fafc;
}

*{
    box-sizing: border-box;
}

body{
    margin: 0;
    font-family: system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
    background-color: var(--bg-soft);
    color: var(--gray-900);
    min-height: 100vh;
    display: flex;
    align-items: center;
    justify-content: center;
}

main{
    width: 100%;
    max-width: 1100px;
    padding: 2rem;
}

.login-layout{
    display: grid;
    grid-template-columns: 1.1fr 0.9fr;
    gap: 4rem;
    align-items: center;
}

/* COLUMNA IZQUIERDA */
.login-info{
    display: flex;
    flex-direction: column;
    gap: 1.5rem;
}

.login-info img{
    width: 380px;
}

.login-info h1{
    font-size: 2.5rem;
    line-height: 1.2;
    margin: 0;
}

.login-info p{
    font-size: 1.05rem;
    color: var(--gray-600);
    max-width: 420px;
}

/* CARD LOGIN */
.login-card{
    background: #fff;
    border-radius: 24px;
    padding: 2.5rem;
    box-shadow: 0 20px 40px rgba(0,0,0,0.08);
}

.login-card h2{
    margin: 0 0 .5rem 0;
    font-size: 1.6rem;
}

.login-card .subtitle{
    font-size: .9rem;
    color: var(--gray-600);
    margin-bottom: 2rem;
}

form{
    display: flex;
    flex-direction: column;
    gap: 1.4rem;
}

label{
    font-size: .85rem;
    font-weight: 600;
    margin-bottom: .4rem;
}

input{
    width: 100%;
    padding: .75rem .9rem;
    border-radius: 12px;
    border: 1px solid var(--gray-300);
    font-size: .9rem;
}

input:focus{
    outline: none;
    border-color: var(--logos-turq);
    box-shadow: 0 0 0 2px rgba(19,232,165,.25);
}

button{
    margin-top: .5rem;
    padding: .85rem;
    border-radius: 999px;
    border: none;
    background-color: var(--logos-blue);
    color: #fff;
    font-weight: 600;
    font-size: .95rem;
    cursor: pointer;
    transition: background-color .2s ease;
}

button:hover{
    background-color: #000;
}

.login-footer{
    display: flex;
    justify-content: space-between;
    margin-top: 1.2rem;
    font-size: .75rem;
    color: var(--gray-600);
}

.login-footer a{
    color: var(--logos-blue);
    text-decoration: none;
}

.login-footer a:hover{
    text-decoration: underline;
}

.legal{
    margin-top: 2rem;
    text-align: center;
    font-size: .7rem;
    color: var(--gray-600);
}

/* RESPONSIVE */
@media (max-width: 900px){
    .login-layout{
        grid-template-columns: 1fr;
        gap: 2rem;
    }

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

    .login-info p{
        max-width: none;
    }
}



/* ===============================
   MOBILE FIX – LOGIN ACADEMIA
   SOLO MÓVIL
================================ */
@media (max-width: 576px){

  /* 1️⃣ Body deja de centrar verticalmente */
  body{
    align-items: flex-start;
    justify-content: flex-start;
  }

  main{
    padding: 1.5rem;
  }

  /* 2️⃣ Layout 100% vertical */
  .login-layout{
    gap: 2.5rem;
  }

  /* 3️⃣ Info superior limpia */
  .login-info{
    text-align: center;
    align-items: center;
  }

  .login-info img{
    width: 220px;
    margin-bottom: .5rem;
  }

  .login-info h1{
    font-size: 2rem;
  }

  .login-info p{
    font-size: 1rem;
  }

  /* 4️⃣ Card bien contenida */
  .login-card{
    padding: 2rem 1.5rem;
  }

  .login-card h2{
    text-align: center;
  }

  .login-card .subtitle{
    text-align: center;
  }

  /* 5️⃣ Footer del form en columna */
  .login-footer{
    flex-direction: column;
    gap: .6rem;
    text-align: center;
  }

  .login-footer span{
    font-size: .7rem;
  }

  /* 6️⃣ Legal bien separado */
  .legal{
    margin-top: 1.6rem;
    padding-bottom: 1rem;
  }
}