
   @import url('https://fonts.googleapis.com/css2?family=Bebas+Neue&family=Lobster&family=Open+Sans:wght@300;400;600;700&display=swap');

   * {
       margin: 0;
       padding: 0;
       box-sizing: border-box;
   }
   
   /*HTML Y BODY*/
   
   html {
       font-size: 16px;
       font-family: 'Open Sans', sans-serif;
   }
   
   body {
       background: #f0f0f0 
                   url('Inacode/img/Sede.jpg') 
                   no-repeat center center;
       background-size: cover;
       background-attachment: fixed; 
       min-height: 100vh; 
       overflow-x: hidden; 
       color: #333;
       position: relative; 
   }
   
   
   /*ENCABEZADO Y LOGO*/
   
   .header {
       display: flex;
       align-items: center;
       padding: 10px 20px;
       background-color: rgba(255, 255, 255, 0.8);
       backdrop-filter: blur(6px);
       position: relative;
       z-index: 10;
       box-shadow: 0 0 10px rgba(0,0,0,0.2);
       animation: fadeInHeader 1.2s ease forwards;
   }
   
   @keyframes fadeInHeader {
       0%   { opacity: 0; transform: translateY(-20px); }
       100% { opacity: 1; transform: translateY(0); }
   }
   
   .logo img {
       width: 140px;
       height: auto;
       animation: slideDownLogo 1.5s ease forwards;
   }
   
   @keyframes slideDownLogo {
       0%   { transform: translateY(-50px); opacity: 0; }
       100% { transform: translateY(0);     opacity: 1; }
   }
   

   .divider {
       height: 2px;
       background-color: #000;
       width: 100%;
       animation: dividerGrow 1s ease forwards;
       margin-bottom: 20px;
   }
   
   @keyframes dividerGrow {
       0%   { width: 0; }
       100% { width: 100%; }
   }
   
   /*CONTENEDOR PRINCIPAL DEL LOGIN*/
    
   .login-container {
       width: 90%;
       max-width: 450px;
       margin: 40px auto;
       padding: 30px 20px;
       background-color: rgba(255, 255, 255, 0.85);
       backdrop-filter: blur(8px);
       border-radius: 12px;
       box-shadow: 0 8px 32px rgba(31, 38, 135, 0.37);
       text-align: center;
       color: #333;
       position: relative;
       animation: popUpLogin 1.2s ease forwards;
   }
   
   @keyframes popUpLogin {
       0%   { transform: scale(0.7) translateY(50px); opacity: 0; }
       100% { transform: scale(1)   translateY(0);    opacity: 1; }
   }
   
   .login-container h2 {
       font-family: "Bebas Neue", sans-serif;
       font-size: 2rem;
       letter-spacing: 2px;
       margin-bottom: 20px;
       text-transform: uppercase;
       position: relative;
       color: #333;
   }
   
   .login-container h2::after {
       content: "";
       display: block;
       width: 60px;
       height: 3px;
       background-color: #333;
       margin: 8px auto 0;
       border-radius: 2px;
   }
   
   /*FORMULARIO LOGIN*/
   
   form#loginForm {
       display: flex;
       flex-direction: column;
       align-items: center;
   }
   
   /* Inputs generales */
   .login-container input,
   .password-container input {
       width: 75%;
       padding: 12px 15px;
       margin: 14px 0;
       border: 2px solid #ccc;
       border-radius: 20px;
       font-size: 1rem;
       color: #333;
       transition: border-color 0.3s, background-color 0.3s;
       background-color: #fff;
   }
   
   .login-container input:focus,
   .password-container input:focus {
       outline: none;
       border-color: #aaa; 
       background-color: #fff;
   }
   
   /* Contenedor para la contraseña ICONO*/
   .password-container {
       position: relative;
       width: 75%;
       margin: 15px auto; 
   }
   
   .password-container input {
       width: 100%; 
       padding-right: 46px; 
   }
   
   .password-container .toggle-password {
       position: absolute;
       top: 50%; 
       right: 8px; 
       transform: translateY(-50%);
       background: none;
       border: none;
       cursor: pointer;
       font-size: 22px;
       color: #666; 
       transition: transform 0.3s ease, color 0.3s ease;
   }
   
   .password-container .toggle-password i {
       font-size: 26px;
   }
   
   .password-container .toggle-password:hover i {
       transform: scale(1.15);
       color: #333;
   }
   
   /*BOTÓN DE INICIAR SESIÓN*/
   
   .login-container .login-btn {
       display: inline-block;
       background-color: #b40000;
       color: #fff;
       padding: 12px 28px;
       border: none;
       border-radius: 20px;
       cursor: pointer;
       font-size: 1rem;
       margin-top: 20px;
       text-transform: uppercase;
       letter-spacing: 1px;
       transition: background-color 0.3s ease, transform 0.3s ease,
                   box-shadow 0.3s ease;
   }
   
   .login-container .login-btn:hover {
       background-color: #8f0000;
       transform: translateY(-2px);
       box-shadow: 0 6px 14px rgba(0, 0, 0, 0.3);
   }
   
   .login-container .login-btn:active {
       transform: translateY(0);
       box-shadow: none;
   }
   
   /*TEXTO SECUNDARIO: OLVIDÉ CONTRASEÑA, REGISTRO,*/
   
   .login-container p {
       margin-top: 20px;
       font-size: 0.95rem;
       color: #555; 
   }
   
   .login-container a {
       color: #b40000;
       text-decoration: none;
       display: inline-block;
       margin-top: 10px;
       transition: color 0.3s ease;
   }
   
   .login-container a:hover {
       color: #8f0000;
       text-decoration: underline;
   }
   
   /*RESPONSIVE DESIGN*/
   
   @media screen and (max-width: 768px) {
       .login-container {
           margin: 30px auto;
           padding: 25px 15px;
       }
   
       .login-container h2 {
           font-size: 1.8rem;
       }
       
       .login-container .login-btn {
           font-size: 0.9rem;
           padding: 10px 20px;
       }
   }
   
   @media screen and (max-width: 480px) {
       .login-container {
           margin: 20px auto;
           padding: 20px 10px;
       }
       .login-container h2 {
           font-size: 1.5rem;
       }
   }
   
   /*DECORACIONES*/
   
   /* Ejemplo de círculos flotantes */
   .bg-circle {
       position: absolute;
       border-radius: 50%;
       opacity: 0.6;
       animation: floatCircle 10s linear infinite alternate;
       pointer-events: none; 
   }
   
   .bg-circle-1 {
       width: 150px;
       height: 150px;
       top: 10%;
       left: 10%;
       background-color: rgba(255, 255, 255, 0.2);
   }
   
   .bg-circle-2 {
       width: 100px;
       height: 100px;
       bottom: 8%;
       right: 5%;
       background-color: rgba(255, 255, 255, 0.3);
   }
   
   /* Animación de subida y bajada */
   @keyframes floatCircle {
       0%   { transform: translateY(0)   translateX(0); }
       100% { transform: translateY(-30px) translateX(30px); }
   }
   
   
   .wave {
       position: absolute;
       width: 100%;
       height: 120px;
       bottom: 0;
       left: 0;
       background: url('https://raw.githubusercontent.com/bedimcode/responsive-wavy-login/main/img/wave.png')
                   repeat-x;
       background-size: 50% 120px;
       animation: waveAnimation 4s linear infinite;
       opacity: 0.7;
   }
   
   @keyframes waveAnimation {
       0%   { background-position-x: 0; }
       100% { background-position-x: 800px; }
   }
   
   /*SCROLLBAR PERSONALIZADO*/
   
   ::-webkit-scrollbar {
       width: 8px;
   }
   
   ::-webkit-scrollbar-track {
       background-color: #333;
   }
   
   ::-webkit-scrollbar-thumb {
       background-color: #b40000;
       border-radius: 4px;
   }
   
   ::-webkit-scrollbar-thumb:hover {
       background-color: #8f0000;
   }
   
   /* Animación de rotación lenta */
   @keyframes slowRotate {
       0%   { transform: rotate(0deg); }
       100% { transform: rotate(360deg); }
   }
   
   /* Animación de parpadeo */
   @keyframes blink {
       0%, 100% { opacity: 1; }
       50%      { opacity: 0; }
   }
   
   /*CLASES ADICIONALES DE UTILIDAD*/
   
   .hide {
       display: none !important;
   }
   
   .show {
       display: block !important;
   }
   
   .text-center {
       text-align: center !important;
   }
   
   .mb-20 {
       margin-bottom: 20px !important;
   }
   
   .mt-20 {
       margin-top: 20px !important;
   }
   
   /*EFECTOS HOVER AVANZADOS*/
   
   /* Efecto “glow” en hover */
   .hover-glow:hover {
       box-shadow: 0 0 8px #ffd700, 0 0 15px #ffd700;
       transition: box-shadow 0.3s ease;
   }
   
   /* Efecto “tilt” en hover */
   .hover-tilt {
       transition: transform 0.3s ease;
   }
   
   .hover-tilt:hover {
       transform: perspective(300px) rotateX(5deg) rotateY(-5deg);
   }
   
   /*ANIMACIÓN DE TEXTO CON SOMBRA MOVIL*/
   
   .animated-text-shadow {
       color: #fff;
       position: relative;
       animation: shadowPulse 2s infinite ease-in-out;
   }
   
   /* Ocultar la casita y la barra lateral */
   .Home {
       display: none !important;  
   }
   
   #sidebar {
       display: none !important;  
   }
   
   @keyframes shadowPulse {
       0%   { text-shadow: 0 0 5px #ffd700; }
       50%  { text-shadow: 0 0 15px #ffd700; }
       100% { text-shadow: 0 0 5px #ffd700; }
   }
   
   
   
   @keyframes floatLeftRight {
       0%   { transform: translateX(0); }
       50%  { transform: translateX(20px); }
       100% { transform: translateX(0); }
   }
   
   @keyframes floatUpDown {
       0%   { transform: translateY(0); }
       50%  { transform: translateY(-20px); }
       100% { transform: translateY(0); }
   }
   
   @keyframes floatLeftRight2 {
       0%   { transform: translateX(0); }
       50%  { transform: translateX(-15px); }
       100% { transform: translateX(0); }
   }
   
   @keyframes floatUpDown2 {
       0%   { transform: translateY(0); }
       50%  { transform: translateY(15px); }
       100% { transform: translateY(0); }
   }
   
   @keyframes floatLeftRight3 {
       0%   { transform: translateX(0); }
       50%  { transform: translateX(10px); }
       100% { transform: translateX(0); }
   }
   
   @keyframes floatUpDown3 {
       0%   { transform: translateY(0); }
       50%  { transform: translateY(-10px); }
       100% { transform: translateY(0); }
   }
   
   
   /* Clase con borde animado */
   .border-animated {
       position: relative;
       z-index: 1;
       overflow: hidden;
   }
   
   .border-animated::before {
       content: "";
       position: absolute;
       top: 0;
       left: -100%;
       width: 100%;
       height: 2px;
       background-color: #ffd700;
       animation: borderSlide 2s infinite linear;
   }
   
   @keyframes borderSlide {
       0%   { left: -100%; }
       100% { left: 100%; }
   }
   

   /* Animación swirl */
   @keyframes swirl {
       0%   { transform: rotate(0) scale(1);   }
       50%  { transform: rotate(180deg) scale(1.2); }
       100% { transform: rotate(360deg) scale(1);   }
   }
   
   /* Variaciones */
   @keyframes swirl2 {
       0%   { transform: rotate(0)   scale(1);   }
       50%  { transform: rotate(-180deg) scale(1.1); }
       100% { transform: rotate(-360deg) scale(1);   }
   }
   
   @keyframes swirl3 {
       0%   { transform: rotate(0)   scale(1);   }
       100% { transform: rotate(720deg) scale(1.5);  }
   }
   
   
   @keyframes floatObject1 {
     0%   { transform: translate(0, 0); }
     25%  { transform: translate(10px, -10px); }
     50%  { transform: translate(-10px, 10px); }
     75%  { transform: translate(15px, -15px); }
     100% { transform: translate(0, 0); }
   }
   
   @keyframes floatObject2 {
     0%   { transform: translate(0, 0); }
     25%  { transform: translate(-10px, 10px); }
     50%  { transform: translate(20px, -20px); }
     75%  { transform: translate(-5px, 5px); }
     100% { transform: translate(0, 0); }
   }
   
  