*{margin:0;padding:0;box-sizing:border-box;font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif}
body{min-height:100vh;background:#f5f5f5;position:relative;overflow-x:hidden;display:flex;flex-direction:column}
.contenedor{display:flex;background:#fff;height:calc(100vh - 64px);width:100%;overflow:hidden;align-items:stretch}
.panel-login{width:45%;padding:1.5rem;display:flex;flex-direction:column;justify-content:center;align-items:center;overflow-y:auto;height:100%}
.formulario-contenedor{max-width:28rem;width:100%;margin:0 auto;padding:1.25rem;background:#fff;border-radius:16px;box-shadow:0 5px 7px 4px rgba(0,0,0,.1);position:relative}
h1{font-size:1.5rem;font-weight:600;margin-bottom:.5rem;color:#1f2937;text-align:center}
.subtitulo{color:#6b7280;margin-bottom:1.5rem;font-size:.875rem;text-align:center}
.user-selection-step{display:block;text-align:center}
.user-type-cards{display:flex;flex-direction:column;gap:1rem;margin-bottom:1.5rem}
.user-type-card{padding:2rem;border:2px solid #e1e7ef;border-radius:16px;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);background:linear-gradient(135deg,#fff 0%,#f8fafc 100%);text-align:center;position:relative;overflow:hidden}
.user-type-card::before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,rgba(37,99,235,.03) 0%,rgba(59,130,246,.08) 100%);opacity:0;transition:opacity .3s ease}
.user-type-card:hover{border-color:#2563eb;transform:translateY(-4px);box-shadow:0 10px 25px rgba(37,99,235,.15)}
.user-type-card:hover::before{opacity:1}
.user-type-card i{font-size:3rem;color:#2563eb;margin-bottom:1rem;transition:all .3s ease;position:relative;z-index:1}
.user-type-card:hover i{transform:scale(1.1);color:#1d4ed8}
.user-type-card h3{font-size:1.25rem;font-weight:600;color:#1f2937;margin:0;position:relative;z-index:1}
.login-form-step{display:none}
.back-btn{position:absolute;top:1rem;left:1rem;display:inline-flex;align-items:center;color:#6b7280;text-decoration:none;font-size:.875rem;cursor:pointer;padding:.5rem;border-radius:.5rem;transition:all .2s ease;z-index:10}
.back-btn:hover{color:#2563eb;background:#f3f4f6}
.back-btn i{margin-right:.5rem}
.user-type-indicator{position:absolute;top:1rem;right:1rem;display:inline-flex;align-items:center;background:#f0f9ff;color:#2563eb;padding:.5rem 1rem;border-radius:9999px;font-size:.875rem;font-weight:500;box-shadow:0 2px 8px rgba(37,99,235,.15)}
.user-type-indicator i{margin-right:.5rem}
.grupo-formulario{margin-bottom:1rem;position:relative}
label{display:block;font-size:.8125rem;font-weight:500;color:#374151;margin-bottom:.2rem}
input[type="email"],input[type="password"],input[type="text"]{width:100%;padding:.4rem .6rem;border:1px solid #d1d5db;border-radius:.375rem;font-size:.8125rem;transition:border-color .2s}
input:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 2px rgba(37,99,235,.2)}
.password-input-wrapper{position:relative}
.password-input-wrapper input{padding-right:3rem}
.toggle-password{position:absolute;right:.6rem;top:50%;transform:translateY(-50%);background:none;border:none;color:#6b7280;cursor:pointer;padding:.5rem;display:flex;align-items:center;justify-content:center;transition:color .2s;width:auto;height:auto;line-height:1;font-size:1.1rem}
.toggle-password:hover{color:#2563eb}
.recordar-olvidar{display:flex;justify-content:space-between;align-items:center;margin:.5rem 0;font-size:.8125rem}
.recordar{display:flex;align-items:center}
.recordar input{margin-right:.5rem}
.enlace-olvidar{color:#2563eb;text-decoration:none;cursor:pointer}
.enlace-olvidar:hover{text-decoration:underline}
.boton-ingresar{width:100%;background:#2563eb;color:#fff;padding:.4rem 1rem;border:none;border-radius:.375rem;font-size:.8125rem;cursor:pointer;transition:background-color .2s;margin-top:.5rem}
.boton-ingresar:hover{background:#1d4ed8}
.boton-ingresar:disabled{opacity:.6;cursor:not-allowed}
.divisor{position:relative;text-align:center;margin:.75rem 0;color:#6b7280;font-size:.8125rem}
.boton-social{width:100%;padding:.4rem 1rem;border:1px solid #d1d5db;border-radius:.375rem;background:#fff;display:flex;align-items:center;justify-content:center;margin-bottom:.35rem;cursor:pointer;transition:background-color .2s,transform .2s;font-size:.8125rem}
.boton-social:hover{background:#f9fafb;transform:translateY(-2px)}
.boton-social img{width:20px;height:20px;margin-right:.5rem;object-fit:contain}
#google-login{position:relative;overflow:hidden;min-height:44px;border-radius:.375rem;transition:all .2s ease;margin-bottom:.35rem;display:flex;align-items:center;justify-content:center;border:1px solid #d1d5db}
#google-login:hover{transform:translateY(-2px);background:#f9fafb;border-color:#2563eb}
#google-login>div{display:flex!important;align-items:center!important;justify-content:center!important;width:100%!important}
#apple-login{background:#000;color:#fff;border:none;opacity:.5;cursor:not-allowed}
#apple-login:hover{transform:none}
.panel-testimonios{width:50%;padding:1.5rem;position:relative;background:#fff;overflow:hidden;height:100%;display:flex;flex-direction:column;justify-content:center}
.contenedor-testimonios{position:relative;border-radius:24px;overflow:hidden;box-shadow:0 8px 32px 0 rgba(31,38,135,.18);display:flex;flex-direction:column;height:100%;background:rgba(255,255,255,.18);backdrop-filter:blur(16px) saturate(180%);-webkit-backdrop-filter:blur(16px) saturate(180%);border:1.5px solid rgba(255,255,255,.35)}
.imagen-testimonios{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:1;min-height:100%;min-width:100%}
.contenido-testimonios{position:absolute;bottom:0;left:0;right:0;padding:1rem;background:linear-gradient(to top,rgba(0,0,0,.35),transparent 80%);color:#fff;z-index:2}
.texto-testimonios{font-size:.875rem;margin-bottom:.25rem}
.autor-testimonios{display:flex;justify-content:space-between;align-items:center}
.testimonio{position:absolute;width:100%;height:100%;opacity:0;transition:opacity .5s ease-in-out,transform .5s ease-in-out;display:none;transform:translateX(100%)}
.testimonio.activo{opacity:1;display:block;transform:translateX(0)}
.testimonio.salida{opacity:0;transform:translateX(-100%)}
.info-autor{flex-grow:1}
.nombre-autor{font-weight:500}
.rol-autor{font-size:.875rem;opacity:.8}
.botones-navegacion{position:absolute;bottom:1.5rem;right:1.5rem;display:flex;gap:.5rem;z-index:10}
.boton-nav{width:40px;height:40px;border-radius:50%;background:rgba(255,255,255,.15);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.3);color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .3s ease}
.boton-nav:hover{background:rgba(255,255,255,.25);transform:scale(1.05)}
.boton-nav::before{content:"";width:10px;height:10px;border:2px solid #fff;border-left:0;border-bottom:0;transform:rotate(45deg)}
.boton-nav:first-child::before{transform:rotate(-135deg)}
.error-message,.success-message,.warning-message{text-align:left;margin-top:.25rem;font-size:.75rem;padding:.4rem .6rem;border-radius:.375rem;display:none}
.error-message{color:#ef4444;background:#fef2f2;border:1px solid #fecaca}
.success-message{color:#22c55e;background:#f0fdf4;border:1px solid #bbf7d0}
.warning-message{color:#f59e0b;background:#fefce8;border:1px solid #fde68a}
.general-error-message{text-align:center;margin-bottom:.5rem;font-size:.75rem;padding:.4rem .6rem;border-radius:.375rem;display:none}
.footer-link{text-align:center;margin-top:1rem;font-size:.875rem;color:#6b7280;padding:.5rem 0}
.footer-link a{color:#2563eb;text-decoration:none;font-weight:500}
.footer-link a:hover{text-decoration:underline}

@media (max-width:767px){
  .contenedor{flex-direction:column;height:auto;min-height:calc(100vh - 56px)}
  .panel-login,.panel-testimonios{width:100%;padding:1rem}
  .formulario-contenedor{max-width:100%;padding:1rem;box-shadow:none}
  .imagen-testimonios{height:200px!important}
  .user-type-cards{flex-direction:column;gap:.75rem;margin-bottom:1rem}
  .user-type-card{padding:1.5rem}
  .user-type-card i{font-size:2.5rem}
  .footer-link{margin-top:1.25rem;font-size:.9rem;padding:.75rem 0;border-top:1px solid #e5e7eb;background:#f9fafb;margin-left:-1rem;margin-right:-1rem;margin-bottom:-1rem;border-radius:0 0 16px 16px}
  h1{font-size:1.35rem}
  .subtitulo{font-size:.85rem;margin-bottom:1.25rem}
}

@media (max-width:320px){
  .formulario-contenedor{padding:1rem}
  .user-type-card{padding:1rem .75rem}
  .user-type-card i{font-size:1.75rem}
  .grupo-formulario label{font-size:.75rem}
  input[type="email"],input[type="password"]{font-size:.75rem}
  .footer-link{font-size:.85rem}
}

@media (min-width:768px) and (max-width:1024px){
  .contenedor{flex-direction:column;min-height:auto}
  .panel-login,.panel-testimonios{width:100%;padding:2rem}
  .formulario-contenedor{max-width:24rem;padding:1.5rem}
  .imagen-testimonios{height:250px}
  .boton-social,#google-login{padding:.45rem .85rem;font-size:.85rem}
  .boton-social img{width:19px;height:19px}
  .footer-link{margin-top:1.5rem;font-size:.875rem}
}

@media (min-width:1025px){.panel-testimonios{position:relative}}