 :root {
     --cn-dark: #0f172a;
     --cn-gold: #d4af37;
     --cn-cream: #f4f1ea;
 }

 html {
     scroll-behavior: smooth;
     /* Para que el salto al presionar "Ver servicios" sea elegante */
 }

 body {
     font-family: 'Plus Jakarta Sans', sans-serif;
     background-color: var(--cn-dark);
     margin: 0;
     padding: 0;
 }

 .login-container {
     display: flex;
     min-height: 100vh;
 }

 /* --- SECCIÓN DE LOGIN (IZQUIERDA / ARRIBA EN MÓVIL) --- */
 .login-form-section {
     background-color: var(--cn-cream);
     width: 50%;
     display: flex;
     flex-direction: column;
     align-items: center;
     justify-content: center;
     padding: 3rem;
     position: relative;
 }

 .login-box {
     width: 100%;
     max-width: 400px;
 }

 .login-box h2 {
     font-family: 'Playfair Display', serif;
     color: var(--cn-dark);
     font-size: 2.5rem;
     margin-bottom: 0.5rem;
 }

 .form-control {
     border: 1px solid #ddd;
     padding: 0.8rem;
     border-radius: 10px;
     margin-bottom: 1rem;
 }

 .btn-access {
     background-color: var(--cn-dark);
     color: white;
     width: 100%;
     padding: 1rem;
     border-radius: 10px;
     border: none;
     font-weight: 600;
     transition: 0.3s;
 }

 .btn-access:hover {
     background-color: #1e293b;
     color: var(--cn-gold);
 }

 /* --- INDICADOR DE SCROLL PARA MÓVIL --- */
 .scroll-hint {
     display: none;
     /* Se activa solo en móvil vía Media Query */
     text-align: center;
     margin-top: 2rem;
     color: var(--cn-dark);
     opacity: 0.7;
 }

 @keyframes bounce {

     0%,
     20%,
     50%,
     80%,
     100% {
         transform: translateY(0);
     }

     40% {
         transform: translateY(-8px);
     }

     60% {
         transform: translateY(-4px);
     }
 }

 .bounce-icon {
     display: inline-block;
     animation: bounce 2s infinite;
     font-size: 1.5rem;
     color: var(--cn-gold);
 }

 /* --- SECCIÓN PROMO (DERECHA / ABAJO EN MÓVIL) --- */
 .promo-section {
     background-color: var(--cn-dark);
     width: 50%;
     display: flex;
     flex-direction: column;
     align-items: center;
     justify-content: center;
     color: var(--cn-cream);
     padding: 4rem;
     text-align: center;
     border-left: 1px solid rgba(212, 175, 55, 0.2);
 }

 .promo-content h1 {
     font-family: 'Playfair Display', serif;
     font-size: 3.5rem;
     margin-bottom: 1rem;
 }

 .btn-outline-gold {
     border: 2px solid var(--cn-gold);
     color: var(--cn-gold);
     padding: 1rem 2.5rem;
     border-radius: 50px;
     text-decoration: none;
     font-weight: 600;
     display: inline-block;
     transition: 0.3s;
 }

 .btn-outline-gold:hover {
     background-color: var(--cn-gold);
     color: var(--cn-dark);
 }

 /* --- RESPONSIVIDAD (MOBILE FIRST) --- */
 @media (max-width: 992px) {
     .login-container {
         flex-direction: column;
     }

     .login-form-section {
         width: 100%;
         min-height: 100vh;
         /* Ocupa toda la pantalla inicial */
         padding: 2rem;
     }

     .promo-section {
         width: 100%;
         min-height: 80vh;
         /* Sección de venta abajo */
         padding: 4rem 2rem;
     }

     .scroll-hint {
         display: block;
         /* Aparece solo en móvil */
     }

     .promo-content h1 {
         font-size: 2.5rem;
     }
 }