/*//////////////////////////////////////////////////////////////////
[ FONT ]*/
:root {
    --xmas-red: #B71C1C;
    --xmas-green: #0F3D3E;
    --xmas-gold: #C5A000;
    --xmas-blue: #1D76D2;
    --xmas-silver: #C0C0C0;
    --xmas-gold-2: #D4AF37;
    --xmas-black: #4A4A4A;
    --xmas-silver-2: #B0B0B0;
    --xmas-blue-2: #1C355E;
    --cinzel-font: 'Cinzel', serif;
    --newyear-script-font: "Playwrite NO", cursive;
}


@font-face {
  font-family: Poppins-Regular;
  src: url('../fonts/poppins/Poppins-Regular.ttf'); 
}

@font-face {
  font-family: Poppins-Medium;
  src: url('../fonts/poppins/Poppins-Medium.ttf'); 
}

@font-face {
  font-family: Poppins-Bold;
  src: url('../fonts/poppins/Poppins-Bold.ttf'); 
}

@font-face {
  font-family: Poppins-SemiBold;
  src: url('../fonts/poppins/Poppins-SemiBold.ttf'); 
}
/*
@font-face {
  font-family: Montserrat-Bold;
  src: url('../fonts/montserrat/Montserrat-Bold.ttf'); 
}

@font-face {
  font-family: Montserrat-SemiBold;
  src: url('../fonts/montserrat/Montserrat-SemiBold.ttf'); 
}

@font-face {
  font-family: Montserrat-Regular;
  src: url('../fonts/montserrat/Montserrat-Regular.ttf'); 
}
*/

/*//////////////////////////////////////////////////////////////////
[ RESTYLE TAG ]*/

* {
	margin: 0px; 
	padding: 0px; 
	box-sizing: border-box;
}

html {
	height: 100%;
	font-family: Poppins-Regular, sans-serif;
}

body { font-family: 'Lato', sans-serif; background-color: #f8f9fa; }
.cinzel-font { font-family: var(--cinzel-font); }
.cinzel-font.navidad { font-family: var(--cinzel-font); }
.cinzel-font.anuevo { font-family: var(--newyear-script-font); }
.text-xmas-red { color: var(--xmas-red) !important; }
.text-xmas-green { color: var(--xmas-green) !important; }

/*---------------------------------------------*/
a {
	font-family: Poppins-Regular;
	font-size: 14px;
	line-height: 1.7;
	color: #666666;
	margin: 0px;
	transition: all 0.4s;
	-webkit-transition: all 0.4s;
  -o-transition: all 0.4s;
  -moz-transition: all 0.4s;
}

a:focus {
	outline: none !important;
}

a:hover {
	text-decoration: none;
  color: #17a2b8;
}

/*---------------------------------------------*/
h1,h2,h3,h4,h5,h6 {
	margin: 0px;
}

p {
	font-family: Poppins-Regular;
	font-size: 14px;
	line-height: 1.7;
	color: #666666;
	margin: 0px;
}

ul, li {
	margin: 0px;
	list-style-type: none;
}


/*---------------------------------------------*/
input {
	outline: none;
	border: none;
}

textarea {
  outline: none;
  border: none;
}

textarea:focus, input:focus {
  border-color: transparent !important;
}

input:focus::-webkit-input-placeholder { color:transparent; }
input:focus:-moz-placeholder { color:transparent; }
input:focus::-moz-placeholder { color:transparent; }
input:focus:-ms-input-placeholder { color:transparent; }

textarea:focus::-webkit-input-placeholder { color:transparent; }
textarea:focus:-moz-placeholder { color:transparent; }
textarea:focus::-moz-placeholder { color:transparent; }
textarea:focus:-ms-input-placeholder { color:transparent; }

input::-webkit-input-placeholder { color: #999999;}
input:-moz-placeholder { color: #999999;}
input::-moz-placeholder { color: #999999;}
input:-ms-input-placeholder { color: #999999;}

textarea::-webkit-input-placeholder { color: #999999;}
textarea:-moz-placeholder { color: #999999;}
textarea::-moz-placeholder { color: #999999;}
textarea:-ms-input-placeholder { color: #999999;}


label {
  display: block;
  margin: 0;
}

/*---------------------------------------------*/
button {
	outline: none !important;
	border: none;
	background: transparent;
}

button:hover {
	cursor: pointer;
}

iframe {
	border: none !important;
}

/*//////////////////////////////////////////////////////////////////
[ utility ]*/

/*==================================================================
[ Text ]*/
.txt1 {
  font-family: Poppins-Regular;
  font-size: 13px;
  line-height: 1.4;
  color: #555555;
}

.txt2 {
  font-family: Poppins-Regular;
  font-size: 13px;
  line-height: 1.4;
  color: #999999;
}


/*==================================================================
[ Size ]*/
.size1 {
  width: 355px;
  max-width: 100%;
}

.size2 {
  width: calc(100% - 43px);
}

/*==================================================================
[ Background ]*/
.bg1 {background: #3b5998;}
.bg2 {background: #1da1f2;}
.bg3 {background: #cd201f;}


/*//////////////////////////////////////////////////////////////////
[ login ]*/
.limiter {
  width: 100%;
  margin: 0 auto;
}

.container-login100 {
  width: 100%;  
  min-height: 100vh;
  display: -webkit-box;
  display: -webkit-flex;
  display: -moz-box;
  display: -ms-flexbox;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
  background: #f2f2f2;
}


.wrap-login100 {
  width: 100%;
  background: #fff;
  overflow: hidden;
  display: -webkit-box;
  display: -webkit-flex;
  display: -moz-box;
  display: -ms-flexbox;
  display: flex;
  flex-wrap: wrap;
  align-items: stretch;
  flex-direction: row-reverse;

}

/*==================================================================
[ login more ]*/
.login100-more {
  width: calc(100% - 500px);
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center;
  position: relative;
  z-index: 1;
}

.login100-more::before {
  content: "";
  display: block;
  position: absolute;
  z-index: -1;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  background: rgba(0,0,0,0.1);
}


.img-logo-cliente {

  max-width: 90%;
  max-height: 100px;
}

.img-logo-taqini {

  max-width: 400px;
  max-height: 150px;
}
/*==================================================================
[ Form ]*/

.login100-form {
  width: 500px;
  min-height: 100vh;
  display: block;
  /*background-color: #f7f7f7;*/
  padding: 50px 55px 20px 55px;
}

.login100-form-title {
  width: 100%;
  display: block;
  font-family: Poppins-Regular;
  font-size: 30px;
  color: #333333;
  line-height: 1.2;
  text-align: center;
}



/*------------------------------------------------------------------
[ Input ]*/

.wrap-input100 {
  display: -webkit-box;
  display: -webkit-flex;
  display: -moz-box;
  display: -ms-flexbox;
  display: flex;
  flex-wrap: wrap;
  align-items: flex-end;
  width: 100%;
  height: 80px;
  position: relative;
  border: 1px solid #e6e6e6;
  border-radius: 10px;
  margin-bottom: 10px;
}

.label-input100 {
  font-family: Poppins-Regular;
  font-size: 18px;
  color: #999999;
  line-height: 1.2;

  display: block;
  position: absolute;
  pointer-events: none;
  width: 100%;
  padding-left: 24px;
  left: 0;
  top: 30px;

  -webkit-transition: all 0.4s;
  -o-transition: all 0.4s;
  -moz-transition: all 0.4s;
  transition: all 0.4s;
}

.input100 {
  display: block;
  width: 100%;
  background: transparent;
  font-family: Poppins-Regular;
  font-size: 18px;
  color: #555555;
  line-height: 1.2;
  padding: 0 26px;
}

input.input100 {
  height: 100%;
  -webkit-transition: all 0.4s;
  -o-transition: all 0.4s;
  -moz-transition: all 0.4s;
  transition: all 0.4s;
}

/*---------------------------------------------*/

.focus-input100 {
  position: absolute;
  display: block;
  width: calc(100% + 2px);
  height: calc(100% + 2px);
  top: -1px;
  left: -1px;
  pointer-events: none;
  border: 1px solid var(--xmas-blue);
  border-radius: 10px;

  visibility: hidden;
  opacity: 0;

  -webkit-transition: all 0.4s;
  -o-transition: all 0.4s;
  -moz-transition: all 0.4s;
  transition: all 0.4s;

  -webkit-transform: scaleX(1.1) scaleY(1.3);
  -moz-transform: scaleX(1.1) scaleY(1.3);
  -ms-transform: scaleX(1.1) scaleY(1.3);
  -o-transform: scaleX(1.1) scaleY(1.3);
  transform: scaleX(1.1) scaleY(1.3);
}

.focus-input100.navidad{
  border: 1px solid var(--xmas-red) !important;
}

.focus-input100.anuevo{
  border: 1px solid var(--xmas-black) !important;
}

.input100:focus + .focus-input100 {
  visibility: visible;
  opacity: 1;

  -webkit-transform: scale(1);
  -moz-transform: scale(1);
  -ms-transform: scale(1);
  -o-transform: scale(1);
  transform: scale(1);
}

.eff-focus-selection {
  visibility: visible;
  opacity: 1;

  -webkit-transform: scale(1);
  -moz-transform: scale(1);
  -ms-transform: scale(1);
  -o-transform: scale(1);
  transform: scale(1);
}

.input100:focus {
  height: 48px;
}

.input100:focus + .focus-input100 + .label-input100 {
  top: 14px;
  font-size: 13px;
}

.has-val {
  height: 48px !important;
}

.has-val + .focus-input100 + .label-input100 {
  top: 14px;
  font-size: 13px;
}

/*==================================================================
[ Restyle Checkbox ]*/

.input-checkbox100 {
  display: none;
}

.label-checkbox100 {
  font-family: Poppins-Regular;
  font-size: 13px;
  color: #999999;
  line-height: 1.4;

  display: block;
  position: relative;
  padding-left: 26px;
  cursor: pointer;
}

.label-checkbox100::before {
  content: "\f00c";
  font-family: FontAwesome;
  font-size: 13px;
  color: transparent;

  display: -webkit-box;
  display: -webkit-flex;
  display: -moz-box;
  display: -ms-flexbox;
  display: flex;
  justify-content: center;
  align-items: center;
  position: absolute;
  width: 18px;
  height: 18px;
  border-radius: 2px;
  background: #fff;
  border: 1px solid #17a2b8;
  left: 0;
  top: 50%;
  -webkit-transform: translateY(-50%);
  -moz-transform: translateY(-50%);
  -ms-transform: translateY(-50%);
  -o-transform: translateY(-50%);
  transform: translateY(-50%);
}

.input-checkbox100:checked + .label-checkbox100::before {
  color: #17a2b8;
}


/*------------------------------------------------------------------
[ Button ]*/
.container-login100-form-btn {
  width: 100%;
  display: -webkit-box;
  display: -webkit-flex;
  display: -moz-box;
  display: -ms-flexbox;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
}

.login100-form-btn {
  display: -webkit-box;
  display: -webkit-flex;
  display: -moz-box;
  display: -ms-flexbox;
  display: flex;
  justify-content: center;
  align-items: center;
  padding: 0 20px;
  width: 100%;
  height: 50px;
  border-radius: 10px;
  background: #17a2b8;

  font-family: Poppins-Bold;
  font-size: 12px;
  color: #fff;
  line-height: 1.2;
  text-transform: uppercase;
  letter-spacing: 1px;

  -webkit-transition: all 0.4s;
  -o-transition: all 0.4s;
  -moz-transition: all 0.4s;
  transition: all 0.4s;
}

.login100-form-btn:hover {
  background: #333333;
}



/*------------------------------------------------------------------
[ Responsive ]*/

@media (max-width: 992px) {
  .login100-form {
    width: 50%;
    padding-left: 30px;
    padding-right: 30px;
  }

  .login100-more {
    width: 50%;
  }
}

@media (max-width: 768px) {
  .login100-form {
    width: 100%;
  }

  .login100-more {
    display: none;
  }
}

@media (max-width: 576px) {
  .login100-form {
    padding-left: 15px;
    padding-right: 15px;
    padding-top: 40px;
  }
}


/*------------------------------------------------------------------
[ Alert validate ]*/

.validate-input {
  position: relative;
}

.alert-validate::before {
  content: attr(data-validate);
  position: absolute;
  z-index: 100;
  max-width: 70%;
  background-color: #fff;
  border: 1px solid #c80000;
  border-radius: 2px;
  padding: 4px 25px 4px 10px;
  top: 50%;
  -webkit-transform: translateY(-50%);
  -moz-transform: translateY(-50%);
  -ms-transform: translateY(-50%);
  -o-transform: translateY(-50%);
  transform: translateY(-50%);
  right: 12px;
  pointer-events: none;

  font-family: Poppins-Regular;
  color: #c80000;
  font-size: 13px;
  line-height: 1.4;
  text-align: left;

  visibility: hidden;
  opacity: 0;

  -webkit-transition: opacity 0.4s;
  -o-transition: opacity 0.4s;
  -moz-transition: opacity 0.4s;
  transition: opacity 0.4s;
}

.alert-validate::after {
  content: "\f12a";
  font-family: FontAwesome;
  display: block;
  position: absolute;
  z-index: 110;
  color: #c80000;
  font-size: 16px;
  top: 50%;
  -webkit-transform: translateY(-50%);
  -moz-transform: translateY(-50%);
  -ms-transform: translateY(-50%);
  -o-transform: translateY(-50%);
  transform: translateY(-50%);
  right: 18px;
}

.alert-validate:hover:before {
  visibility: visible;
  opacity: 1;
}

@media (max-width: 992px) {
  .alert-validate::before {
    visibility: visible;
    opacity: 1;
  }
}



/*==================================================================
[ Social ]*/
.login100-form-social-item {
  width: 36px;
  height: 36px;
  font-size: 18px;
  color: #fff;
  border-radius: 50%;
}

.login100-form-social-item:hover {
  background: #333333;
  color: #fff;
}


/* TOMADO DE NAVIDAD- AHORA COM BASE */

.xmas-bg-image {
    background: url('../../files/imagenes/fondo_login.jpg') no-repeat center center;
    background-size: cover;
    position: relative;
}

.xmas-bg-image.navidad {
    background: url('fondo_navidad.jpg') no-repeat center center;
    background-size: cover;
    position: relative;
}

.xmas-bg-image.anuevo {
    background: url('fondo_anuevo.jpg') no-repeat center center;
    background-size: cover;
    position: relative;
}

.xmas-bg-image::before {
    content: ''; position: absolute; top: 0; left: 0; right: 0; bottom: 0;
    /*background: rgba(15, 61, 62, 0.5);*/
    background: rgba(0, 0, 0, 0.5);
}
.xmas-overlay-text { position: relative; z-index: 2; text-shadow: 2px 2px 4px rgba(0,0,0,0.5); }


/* --- NUEVO: Decoraciones CSS en la parte blanca --- */

/* El "hilo" del adorno */
.ornament {
    position: absolute;
    top: 0;
    width: 2px; /* Grosor del hilo */
    background-color: #e0e0e0; /* Color del hilo (gris claro) */
    z-index: 10;
    /* Animación suave de balanceo (opcional, da un toque premium) */
    animation: swing 3s ease-in-out infinite alternate;
    transform-origin: top center;
}

/* La "bola" del adorno (usando ::after) */
.ornament::after {
    content: '';
    position: absolute;
    bottom: -18px; /* Posición relativa al final del hilo */
    left: -9px; /* Centrar la bola respecto al hilo */
    width: 20px;
    height: 20px;
    border-radius: 50%;
    box-shadow: inset -2px -2px 6px rgba(0,0,0,0.3); /* Sombra interna para efecto 3D */
}

/* Colores específicos para las bolas */
.ornament-red::after { background-color: var(--xmas-red); }
.ornament-green::after { background-color: var(--xmas-green); }
.ornament-gold::after { background-color: var(--xmas-gold); }
.ornament-gold-2::after { background-color: var(--xmas-gold); }
.ornament-silver::after { background-color: var(--xmas-silver); }
.ornament-silver-2::after { background-color: var(--xmas-silver); }
.ornament-black::after { background-color: var(--xmas-black); }
.ornament-blue-2::after { background-color: var(--xmas-blue-2); }
/* Variación en la velocidad de animación para que no se muevan igual */
.ornament-red, .ornament-blue-2 { animation-duration: 2.8s; }
.ornament-silver, .ornament-silver-2 { animation-duration: 4.0s; }
.ornament-green, .ornament-black { animation-duration: 3.5s; }
.ornament-gold, .ornament-gold-2  { animation-duration: 2.2s; }

/* Animación Keyframes */
@keyframes swing {
    0% { transform: rotate(10deg); }
    100% { transform: rotate(-10deg); }
}



/* --- Rama de Pino Realista (Reemplazo) --- */
.pine-branch-corner {
    /* Usamos una imagen real con transparencia para evitar el efecto "triángulo" */
    /*background-image: url('corner.png');*/      
    /* Filtros para integración */
    opacity: 0.85; /* Un poco transparente para que sea suave */
    filter: drop-shadow(2px 4px 6px rgba(0,0,0,0.1)); /* Sombra suave para realismo */
    
    z-index: 5; /* Detrás del formulario */
    pointer-events: none; /* Para que no moleste al hacer clic */
}

.pine-branch-corner.navidad {
    position: absolute;
    top: -10px;    /* Ajustado para que salga desde el borde */
    right: -10px;  /* Ajustado para la esquina */
    width: 400px;  /* Hacemos la imagen GRANDE para que se vean las hojas */
    height: 250px;  
    background-image: url('corner_navidad.png');
    background-size: contain;   /* Ajusta la imagen al contenedor */
    background-repeat: no-repeat;    
    background-position: top right;
}

.pine-branch-corner.anuevo {
    position: absolute;
    top: -10px;    /* Ajustado para que salga desde el borde */
    right: -10px;  /* Ajustado para la esquina */
    width: 100%;  /* Hacemos la imagen GRANDE para que se vean las hojas */
    height: 300px;  
    background-image: url('corner_anuevo.png');
    background-position: top;
    background-size: contain;   /* Ajusta la imagen al contenedor */
    background-repeat: repeat;    
}

/* Opcional: Ajuste para móviles para que no tape el input */
@media (max-width: 768px) {
    .pine-branch-corner.navidad {
        width: 250px;
        height: 180px;
        opacity: 0.6; /* Más suave en celular */
    }
    .pine-branch-corner.anuevo {
        width: 100%;
        height: 250px;
        opacity: 0.6; /* Más suave en celular */
    }    
}

/* Aseguramos que el formulario esté por encima de las decoraciones */
.z-2 { z-index: 2; }

/* --- Estilos del Formulario (Inputs Limpios) --- */

/* Input Base */
.form-control {
    border: 1px solid #e0e0e0; /* Borde más fino y claro */
    border-radius: 8px; /* Bordes suaves */
    padding: 10px 15px; /* Más espacio interno */
    transition: all 0.3s ease;
}

/* El cuadro del ícono */
.input-group-text { 
    background-color: transparent; /* ELIMINA el color gris */
    border: 1px solid #e0e0e0; /* Un borde sutil para que coincida */
    border-right: none; /* Quitamos el borde derecho para que se fusione con el input */
    border-radius: 8px 0 0 8px; /* Ajustamos el borde izquierdo */
}

.form-control {
    border-left: none; /* Quitamos el borde izquierdo del input */
    border-radius: 0 8px 8px 0; /* Ajustamos el borde derecho del input */
}

/* Estado Focus: Usamos el rojo navideño */
.form-control:focus,
.input-group-text:focus-within { /* Aplicamos el foco al icono también */
    border-color: var(--xmas-red); /* Borde rojo fuerte */
    
    /* Box-shadow moderno: Eliminamos el "glow" azul/verde viejo y usamos un anillo más sutil y limpio */
    box-shadow: 0 0 0 2px rgba(183, 28, 28, 0.2); 
}

/* Estado de foco: Pintamos el icono de rojo */
.input-group:focus-within .input-group-text {
    border-color: var(--xmas-red);
    color: var(--xmas-red); /* Icono se pone rojo */
}

.btn-xmas {
    background-color: var(--xmas-blue) !important; border: none; color: white;
    border-radius: 50px; transition: all 0.3s ease;
}

.btn-xmas.navidad {
    background-color: var(--xmas-red) !important; border: none; color: white;
    border-radius: 50px; transition: all 0.3s ease;
}

.btn-xmas.navidad:hover { background-color: #D32F2F !important; color: white; transform: translateY(-2px); }

.btn-xmas.anuevo {
    background-color: #000000 !important; border: none; color: white;
    border-radius: 50px; transition: all 0.3s ease;
}

.btn-xmas.anuevo:hover { background-color: var(--xmas-black) !important; color: white; transform: translateY(-2px); }


.login-form-wrapper { 
    z-index: 7 !important; 
}

.xmas-absolute-bottom {
    position: absolute;
    bottom: 40px; /* Separación del borde inferior */
    width: 100%; /* Asegura que abarque todo el ancho de la columna padre */
    text-align: center; /* Centra el texto horizontalmente */
    padding: 0 40px; /* Padding horizontal para que no se pegue a los lados */
    z-index: 5; /* Asegura que flote sobre la capa oscura de la imagen */
}

.lead.anuevo{
  font-size: 1.25rem;
    font-weight: 300;
    font-family: 'Playwrite NO';
    margin-top: 10px;
}