.main_login{
	grid-area: main;
	display: grid;
    grid-template-areas: 
        "presentacion acceder";
    grid-template-columns:1fr 1fr;
    grid-template-rows: auto 1fr auto;
	height:100vh;
	background:
		radial-gradient(120% 90% at 8% 12%, color-mix(in srgb, var(--accent-100) 12%, transparent) 0%, transparent 62%),
		linear-gradient(150deg, color-mix(in srgb, var(--bg-100) 96%, var(--accent-100) 4%), color-mix(in srgb, var(--bg-100) 94%, var(--accent-200) 6%));
}
.presentacion{
	grid-area: presentacion;
    overflow-y: auto;
    height:100vh;
    display:flex;
    justify-content:center;
    align-items:center;
    background:var(--bg-100);
    flex-direction:column;
    user-select:none;
    width:100%;
    opacity:1;
    transition:opacity .8s;
}

.presentacion.register-presentacion{
	position: relative;
	background:
		radial-gradient(120% 90% at 8% 12%, color-mix(in srgb, var(--accent-100) 16%, transparent) 0%, transparent 62%),
		radial-gradient(130% 92% at 94% 90%, color-mix(in srgb, var(--accent-200) 14%, transparent) 0%, transparent 66%),
		linear-gradient(155deg, color-mix(in srgb, var(--bg-100) 94%, var(--accent-100) 6%), color-mix(in srgb, var(--bg-100) 96%, var(--accent-200) 4%));
}
.presentacion h1{
	margin-bottom:10px;
	color:var(--primary-100);
}
.presentacion p{
	color:var(--text-100);
	display:block;
	width:100%;
	max-width:400px;
	text-align:center;
}
.presentacion svg{
	user-select:none;
	display:block;
	width:100%;
	position:relative;
	max-width:400px;
}
.acceder {
    user-select: none;
    display: grid;
    place-items: center;
    background: linear-gradient(180deg, color-mix(in srgb, var(--bg-200) 92%, var(--bg-100) 8%), color-mix(in srgb, var(--bg-200) 86%, var(--bg-300) 14%));
    height:100vh;
    padding:20px;
    overflow-y:auto;
}
.acceder > .acceder_content {
	display:flex;
	justify-content:center;
	align-items:center;
	flex-wrap:wrap;
    max-width:90vw;
    max-height:90vh;
    width:100%;
    height:auto;
    padding: 20px;
}
.text_mensaje{
	display:flex;
	flex-direction:column;
	gap:1rem;
	width:100%;
	text-align:center;
	padding:10px;
	color:var(--text-100);
}
.selected_users{
	cursor:pointer;
	transition:all .5s;
}
.selected_users:hover{
	padding:2px;
}
.selected_users:active{
	padding:5px;
}
.pin_acceso{
	display:flex;
	gap:1.2rem;
	margin:15px auto;
}
.teclado_acceso{
	width:100%;
	display:flex;
	flex-direction:column;
}
.teclado_acceso .group{
	display:flex;
	gap:1.8rem;
	margin:10px auto;
}
.teclado_acceso .group span{
	user-select:none;
	cursor:pointer;
	height:65px;
	width:65px;
	display:flex;
	justify-content:center;
	align-items:center;
	background:var(--bg-100);
	border-radius:100px;
	padding:10px;
	transition:all .3s;
}
.teclado_acceso .group span:active{
	background:var(--bg-200);
}
.borrar_cc svg{
	rotate:180deg;
}
@keyframes vibrar {
  0% { transform: translateX(0); }
  25% { transform: translateX(-2px); }
  50% { transform: translateX(2px); }
  75% { transform: translateX(-2px); }
  100% { transform: translateX(0); }
}
.error-pin circle {
	color:red;
	animation: vibrar 0.3s ease-in-out 3;
}

@media ( max-width: 720px ){
	.acceder{width:100vw;}
	.presentacion{width:0;opacity:0;}
}

.login-content{display:flex;width:100%;justify-content:center;}
/* Contenedor del formulario */
.login-content form {
   width: 100%;
   max-width: 360px;
   border-radius: 10px;
}
.login-content .perfil_imagesvg{
	display:block;
	position:relative;
	margin:10px auto;
	color:var(--accent-100);
	fill: var(--bg-100);
}
.login-content .input-div {
   position: relative;
   margin: 20px 0;
   padding: 5px 0;
   border-bottom: 2px solid #d9d9d9;
   display:flex;
   gap:0.3rem;
}

.login-content .input-div::before {
   content: "";
   position: absolute;
   bottom: -2px;
   left: 0;
   width: 0;
   height: 2px;
   background-color: var(--accent-100);
   transition: width 0.4s ease;
}
.login-content .input-div.focus::before {
   width: 100%;
}
.login-content .i {
   display: flex;
   justify-content: center;
   align-items: center;
   color: #d9d9d9;
}
.login-content .i i {
   transition: .3s;
}
.login-content .input-div.focus .i i {
   color: var(--accent-100);
}
.login-content .input-div > .div{display:block;width:100%;}
.login-content .input-div > .div > h5 {
   position: absolute;
   left:30px;
   top: 50%;
   transform: translateY(-50%);
   color: #999;
   font-size: 16px;
   transition: .3s;
   pointer-events:none;
   user-select:none;
}
.login-content .input-div.focus > .div > h5 {
   top: -5px;
   font-size: 14px;
   color: var(--accent-100);
}
.login-content input:not([type="checkbox"]):not([type="radio"]):not([type="hidden"]) {
   width: 100%;
   height: 100%;
   border: none;
   outline: none;
   background: none;
   padding: 0.5rem 0.7rem;
   font-size: 1rem;
   color: #333;
   font-family: 'Poppins', sans-serif;
}
.login-content .btn_log {
   display: inline-flex;
   align-items: center;
   justify-content: center;
   gap: 10px;
   width: 100%;
   height: 50px;
   border-radius: 25px;
   outline: none;
   border: 1px solid transparent;
   background: linear-gradient(120deg, var(--primary-100), var(--primary-200));
   font-size: 1.2rem;
   color: var(--boton-color);
   text-transform: uppercase;
   cursor: pointer;
   transition: transform var(--transition-speed) var(--transition-timing), box-shadow var(--transition-speed) var(--transition-timing), filter var(--transition-speed) var(--transition-timing), background var(--transition-speed) var(--transition-timing);
   box-shadow: var(--shadow-sm);
}

.login-content .btn_log_label {
   letter-spacing: 0.02em;
}

.login-content .btn_log_mascot {
   width: 24px;
   height: 24px;
   display: inline-flex;
   align-items: center;
   justify-content: center;
   color: color-mix(in srgb, var(--boton-color) 88%, var(--bg-100) 12%);
   opacity: 0.98;
   transition: transform var(--transition-speed) var(--transition-timing), opacity var(--transition-speed) var(--transition-timing);
}

.login-content .btn_log_mascot svg {
   width: 100%;
   height: 100%;
   display: block;
}

.login-content .btn_log.btn-loading .btn_log_mascot {
   animation: btnLogMascotPulse .7s ease-in-out infinite;
}

.login-content .btn_log.btn-loading .btn_log_label {
   opacity: 0.9;
}

.login-content .btn_log:hover:not(:disabled) {
   filter: brightness(1.03);
   transform: translateY(-1px);
   box-shadow: var(--shadow-md);
}

.login-content .btn_log:focus-visible {
   border-color: color-mix(in srgb, var(--primary-200) 52%, transparent 48%);
   box-shadow: 0 0 0 3px color-mix(in srgb, var(--primary-200) 26%, transparent 74%);
}

.login-content .btn_log:disabled,
.login-content .btn_log[aria-disabled="true"] {
   cursor: not-allowed;
   background: linear-gradient(
      120deg,
      color-mix(in srgb, var(--primary-100) 16%, var(--bg-300) 84%),
      color-mix(in srgb, var(--primary-200) 14%, var(--bg-300) 86%)
   );
   color: color-mix(in srgb, var(--text-100) 48%, var(--bg-100) 52%);
   box-shadow: none;
   transform: none;
   filter: grayscale(0.18);
   opacity: 0.72;
   border-color: color-mix(in srgb, var(--text-200) 32%, transparent 68%);
}

@keyframes btnLogMascotPulse {
   0%,
   100% {
      transform: translateY(0) scale(1);
   }
   50% {
      transform: translateY(-1px) scale(1.06);
   }
}

.register-page #sign_submit:disabled,
.register-page #sign_submit[aria-disabled="true"] {
   filter: grayscale(0.22);
   opacity: 0.64;
}

@media screen and (max-width: 768px) {
	.acceder_content{
		position: relative;
		padding:0px!important;
	}
}

.register-link {
	margin-top: 15px;
	text-align: center;
	font-size: 14px;
}
.register-link a {
	color: var(--accent-100);
	text-decoration: none;
}
.register-link a:hover {
	text-decoration: underline;
}

.forgot-password {
	text-align: center;
	margin-top: 16px;
}
.forgot-password.forgot-password--links {
	margin-top: 8px;
}
.forgot-password a {
	color: var(--text-200);
	font-size: 13px;
	text-decoration: none;
	transition: color .25s ease;
}
.forgot-password a:hover {
	color: var(--text-100);
	text-decoration: underline;
}

.social-divider {
	display: flex;
	align-items: center;
	text-align: center;
	color: var(--text-300);
	font-size: 13px;
	margin: 30px 0 18px;
}
.social-divider::before,
.social-divider::after {
	content: "";
	flex: 1;
	border-bottom: 1px solid var(--bg-300);
}
.social-divider::before {
	margin-right: 10px;
}
.social-divider::after {
	margin-left: 10px;
}

.social-login {
	display: flex;
	flex-direction: column;
	gap: 10px;
	align-items: center;
}

.social-login-error {
	margin-top: 14px;
	border-radius: 10px;
	padding: 10px 12px;
	font-size: 13px;
	font-weight: 600;
	color: color-mix(in srgb, var(--danger) 84%, #000 16%);
	background: color-mix(in srgb, var(--danger) 10%, transparent 90%);
	border: 1px solid color-mix(in srgb, var(--danger) 30%, transparent 70%);
	text-align: center;
}
.social-btn {
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 10px;
	width: 100%;
	max-width: 260px;
	padding: 10px 14px;
	font-size: 14px;
	font-weight: 500;
	border-radius: 8px;
	text-decoration: none;
	transition: background .3s ease, transform .2s ease;
	border: 1px solid transparent;
}
.social-btn img {
	width: 18px;
	height: 18px;
}
.social-btn.google {
	background: var(--bg-100);
	color: var(--text-100);
	border: 1px solid var(--bg-300);
}
.social-btn.google:hover {
	background: var(--bg-200);
	transform: translateY(-1px);
}
.social-btn.facebook {
	background: #1877f2;
	color: #fff;
}
.social-btn.facebook:hover {
	background: #155ab6;
	transform: translateY(-1px);
}
.social-btn.dark {
	background: #111827;
	color: #fff;
}
.social-btn.dark:hover {
	background: #000;
	transform: translateY(-1px);
}
.social-btn.linkedin {
	background: #0a66c2;
	color: #fff;
}
.social-btn.linkedin:hover {
	background: #084c91;
	transform: translateY(-1px);
}
.social-btn.vk {
	background: #2787f5;
	color: #fff;
}
.social-btn.vk:hover {
	background: #1a67bd;
	transform: translateY(-1px);
}
.social-btn.instagram {
	background: linear-gradient(90deg, #f58529, #dd2a7b, #8134af);
	color: #fff;
}
.social-btn.instagram:hover {
	filter: brightness(.95);
	transform: translateY(-1px);
}
