/* ══════════════════════════════════════════════
   AUTH.CSS — Login & Registro
   CyberChip Purple · Design Reyes
   ══════════════════════════════════════════════ */

/* ── RESET ── */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{font-size:16px;scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:"Poppins",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif;min-height:100vh;line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none}
input,select,textarea{font-family:inherit}
ul{list-style:none}

/* ── VARIABLES ── */
:root{
  --bg:#0d0620;
  --surface:rgba(18,8,42,0.6);
  --surface-2:rgba(24,12,54,0.5);
  --surface-3:rgba(34,16,68,0.45);
  --glass:rgba(22,10,50,0.65);
  --border:rgba(138,11,210,0.18);
  --border-h:rgba(178,75,240,0.38);
  --accent:#8A0BD2;
  --accent-soft:#b44bf0;
  --accent-bright:#9b2de0;
  --accent-glow:rgba(138,11,210,0.4);
  --orange:#f97316;
  --green:#22c55e;
  --green-soft:#4ade80;
  --text:#f0eaff;
  --text-soft:#d4c8f0;
  --muted:#9b8ec4;
  --panel:rgba(18,8,42,0.7);
  --radius:16px;
  --radius-sm:12px;
  --radius-lg:24px;
  --ease:cubic-bezier(.4,0,.2,1);
}

/* ── BODY ── */
body{
  background:var(--bg);
  background-image:
    radial-gradient(ellipse 90% 70% at 12% 18%,rgba(138,11,210,0.5) 0%,transparent 55%),
    radial-gradient(ellipse 75% 55% at 88% 22%,rgba(155,45,224,0.4) 0%,transparent 52%),
    radial-gradient(ellipse 100% 80% at 50% 85%,rgba(138,11,210,0.35) 0%,transparent 58%),
    radial-gradient(ellipse 65% 45% at 72% 68%,rgba(180,75,240,0.3) 0%,transparent 48%),
    radial-gradient(ellipse 55% 50% at 25% 55%,rgba(120,20,200,0.25) 0%,transparent 45%),
    linear-gradient(155deg,#24085a 0%,#180845 25%,#110630 50%,#0d0620 100%);
  background-attachment:fixed;
  color:var(--text);
  overflow-x:hidden;
}

/* ── ANIMATIONS ── */
@keyframes spin{to{transform:rotate(360deg)}}
@keyframes fadeUp{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.55}}
@keyframes shimmer{0%{background-position:-200% 0}100%{background-position:200% 0}}

/* ============================================
   INFO BAR (marquee)
   ============================================ */
@keyframes scrollInfoBar{
  0%{transform:translateX(0)}
  100%{transform:translateX(-50%)}
}
.info-bar{
  overflow:hidden;white-space:nowrap;
  background:linear-gradient(90deg,#1a0535 0%,rgba(138,11,210,0.35) 30%,rgba(249,115,22,0.18) 70%,#1a0535 100%);
  border-bottom:1px solid rgba(138,11,210,0.25);
  position:relative;
}
.info-bar::before{
  content:'';position:absolute;inset:0;
  background:linear-gradient(90deg,transparent 0%,rgba(138,11,210,0.08) 50%,transparent 100%);
  pointer-events:none;
}
.info-bar-content{
  display:inline-block;
  padding:.55rem 0;
  font-size:.85rem;
  color:rgba(255,255,255,0.88);
  animation:scrollInfoBar 20s linear infinite;
}
.info-bar-content:hover{animation-play-state:paused}
.info-bar-text{display:inline-block;padding:0 2rem}
.info-bar-text strong{color:#f59e0b;font-weight:700}

/* ============================================
   NAVBAR
   ============================================ */
.nav{
  position:sticky;top:0;z-index:100;
  background:linear-gradient(135deg,rgba(26,5,53,0.92) 0%,rgba(48,12,90,0.88) 50%,rgba(26,5,53,0.92) 100%);
  backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);
  border-bottom:1px solid rgba(138,11,210,0.25);
  box-shadow:0 4px 24px rgba(138,11,210,0.1),0 1px 0 rgba(138,11,210,0.15) inset;
}
.nav-inner{
  width:95%;max-width:1600px;margin:0 auto;
  padding:.85rem 0;
  display:flex;align-items:center;justify-content:space-between;gap:1.5rem;
  flex-wrap:wrap;
}
.nav-brand{
  display:flex;align-items:center;gap:.6rem;
  font-weight:600;font-size:1.1rem;color:var(--text);
  text-decoration:none;transition:all .3s;
}
.nav-brand:hover{opacity:.9}
.nav-brand img{width:40px;height:40px}

.nav-links{display:flex;align-items:center;gap:1rem;font-size:.95rem}
.nav-links a{
  padding:.35rem .9rem;border-radius:999px;
  color:var(--muted);font-weight:500;
  transition:all .25s;text-decoration:none;
}
.nav-links a:hover,
.nav-links a.is-active{
  background:rgba(124,58,237,0.28);color:var(--text);
}

.nav-toggle{
  display:none;
  padding:.35rem .8rem;border-radius:999px;
  border:1px solid var(--border);
  color:var(--text);font-size:1.1rem;
  transition:all .3s;background:transparent;cursor:pointer;
}
.nav-toggle:hover{background:rgba(138,11,210,.12);border-color:var(--accent)}

/* ── Botones genéricos ── */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.35rem;
  padding:.55rem 1.25rem;border:none;border-radius:999px;
  font-size:.95rem;font-weight:600;cursor:pointer;
  transition:all .25s;white-space:nowrap;
  position:relative;overflow:hidden;
}
.btn-primary{
  background:linear-gradient(135deg,var(--accent),var(--accent-soft));
  color:#fff;
  box-shadow:0 4px 16px rgba(138,11,210,0.15);
}
.btn-primary:hover{
  transform:translateY(-2px);
  box-shadow:0 8px 32px rgba(124,58,237,0.35),0 4px 12px rgba(124,58,237,0.2);
}

/* loop-glow */
@keyframes glowLoop{
  0%{box-shadow:0 4px 16px rgba(124,58,237,0.2)}
  50%{box-shadow:0 4px 24px rgba(167,139,250,0.45),0 0 60px rgba(124,58,237,0.15)}
  100%{box-shadow:0 4px 16px rgba(124,58,237,0.2)}
}
.loop-glow{animation:glowLoop 4s ease-in-out infinite}

/* ── Botón usuario logueado — naranja ── */
.btn.is-logged-in,
.btn-primary.is-logged-in,
button.is-logged-in,
#loginBtn.is-logged-in,
#loginButton.is-logged-in,
[data-login-btn].is-logged-in{
  background:linear-gradient(135deg,#ff6b00,#ff8f3d)!important;
  box-shadow:0 4px 16px rgba(255,107,0,0.25),0 2px 6px rgba(255,107,0,0.15)!important;
  border-color:transparent!important;
  animation:none!important;
}
.btn.is-logged-in:hover,
.btn-primary.is-logged-in:hover,
button.is-logged-in:hover,
#loginBtn.is-logged-in:hover,
#loginButton.is-logged-in:hover,
[data-login-btn].is-logged-in:hover{
  background:linear-gradient(135deg,#ff8000,#ffa65d)!important;
  box-shadow:0 8px 24px rgba(255,107,0,0.35),0 4px 10px rgba(255,107,0,0.2)!important;
  transform:translateY(-2px);
}
.btn.is-logged-in i,
button.is-logged-in i{margin-right:.35rem}

/* ── Navbar móvil ── */
@media(max-width:768px){
  .nav-toggle{display:block}
  .nav-inner{width:90%;padding:.7rem 0}
  .nav-links{
    position:fixed;top:56px;left:0;right:0;
    background:linear-gradient(135deg,rgba(26,5,53,0.97),rgba(48,12,90,0.94));
    backdrop-filter:blur(28px);-webkit-backdrop-filter:blur(28px);
    flex-direction:column;padding:1.25rem;gap:.6rem;
    border-bottom:1px solid rgba(138,11,210,0.25);
    box-shadow:0 12px 40px rgba(138,11,210,0.12);
    transform:translateY(-110%);opacity:0;visibility:hidden;
    transition:all .35s var(--ease);
  }
  .nav-links.is-open{transform:translateY(0);opacity:1;visibility:visible}
  .nav-links a{width:100%;text-align:center;padding:.75rem 1rem;font-size:1rem}
  .nav-links .btn{width:100%;margin-top:.4rem}
}

/* ============================================
   AUTH PAGE — Shared layout
   ============================================ */
.login-page,
.register-page{
  min-height:0;
  flex:1;
  display:flex;
  flex-direction:column;
}

/* Forzar que body sea flex column para que .login-page tome el espacio restante */
body{
  display:flex;
  flex-direction:column;
  min-height:100vh;
}

.login-main,
.register-main{
  flex:1;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:1rem;
}

.login-wrapper,
.register-wrapper{
  width:100%;
  max-width:900px;
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:0;
  background:var(--panel);
  border-radius:var(--radius-lg);
  border:1px solid var(--border);
  overflow:hidden;
  box-shadow:0 25px 50px -12px rgba(0,0,0,0.5);
}

/* ============================================
   LEFT PANEL — Welcome / Benefits
   ============================================ */
.login-welcome,
.register-benefits{
  background:linear-gradient(135deg,rgba(138,11,210,0.15) 0%,rgba(155,45,224,0.08) 100%);
  padding:3rem 2.5rem;
  display:flex;
  flex-direction:column;
  justify-content:center;
  border-right:1px solid var(--border);
}

/* Login welcome */
.welcome-brand{margin-bottom:2rem}
.welcome-brand img{
  width:64px;height:64px;
  filter:drop-shadow(0 4px 20px rgba(138,11,210,0.4));
}
.welcome-header h2{
  font-size:2rem;font-weight:700;color:var(--text);
  margin-bottom:.75rem;line-height:1.2;
}
.welcome-header p{
  color:var(--muted);font-size:1rem;line-height:1.6;margin-bottom:2rem;
}
.welcome-features{display:flex;flex-direction:column;gap:1rem}
.feature-item{
  display:flex;align-items:center;gap:1rem;
  padding:.75rem 1rem;
  background:rgba(138,11,210,0.08);
  border-radius:var(--radius-sm);
  border:1px solid rgba(138,11,210,0.12);
  transition:all .3s;
}
.feature-item:hover{
  background:rgba(138,11,210,0.12);
  transform:translateX(4px);
}
.feature-item i{
  width:36px;height:36px;border-radius:8px;
  background:linear-gradient(135deg,var(--accent),var(--accent-soft));
  display:flex;align-items:center;justify-content:center;
  color:#fff;font-size:.9rem;flex-shrink:0;
}
.feature-item span{
  font-size:.9rem;color:var(--text-soft);font-weight:500;
}

/* Registro benefits */
.register-benefits{padding:2.5rem}
.benefits-header{margin-bottom:2rem}
.benefits-header h2{
  font-size:1.5rem;font-weight:700;color:var(--text);margin-bottom:.5rem;
}
.benefits-header p{color:var(--muted);font-size:.9rem}

.benefit-list{display:flex;flex-direction:column;gap:1rem}
.benefit-item{
  display:flex;align-items:flex-start;gap:1rem;
  padding:1rem;
  background:rgba(138,11,210,0.08);
  border-radius:var(--radius-sm);
  border:1px solid rgba(138,11,210,0.15);
  transition:all .3s;
}
.benefit-item:hover{
  background:rgba(138,11,210,0.12);
  transform:translateX(4px);
}
.benefit-icon{
  width:40px;height:40px;border-radius:10px;
  background:linear-gradient(135deg,var(--accent),var(--accent-soft));
  display:flex;align-items:center;justify-content:center;
  flex-shrink:0;
}
.benefit-icon i{color:#fff;font-size:1rem}
.benefit-content h3{
  font-size:.95rem;font-weight:600;color:var(--text);margin-bottom:.25rem;
}
.benefit-content p{
  font-size:.8rem;color:var(--muted);line-height:1.4;
}

/* ============================================
   RIGHT PANEL — Form
   ============================================ */
.login-form-side,
.register-form-side{
  padding:3rem 2.5rem;
  display:flex;
  flex-direction:column;
  justify-content:center;
}
.register-form-side{padding:2.5rem}

/* Form brand (registro) */
.form-brand{
  display:flex;align-items:center;gap:.75rem;margin-bottom:1.5rem;
}
.form-brand img{
  width:48px;height:48px;
  filter:drop-shadow(0 4px 12px rgba(138,11,210,0.3));
}
.form-brand span{
  font-size:1.25rem;font-weight:700;color:var(--text);
}

/* Form header */
.form-header{text-align:center;margin-bottom:2rem}
.form-header h1{
  font-size:1.75rem;font-weight:700;color:var(--text);margin-bottom:.5rem;
}
.register-form-side .form-header h1{
  font-size:1.35rem;color:var(--accent-soft);margin-bottom:.25rem;
}
.form-header p{font-size:.9rem;color:var(--muted)}
.register-form-side .form-header p{font-size:.85rem;margin-bottom:1.25rem}

/* Form row (2 cols) */
.form-row{
  display:grid;grid-template-columns:1fr 1fr;gap:.75rem;
}

/* Form groups */
.form-group{margin-bottom:1.25rem}
.register-form-side .form-group{margin-bottom:.9rem}

.form-group label{
  display:block;font-size:.85rem;font-weight:500;
  color:var(--text-soft);margin-bottom:.5rem;
}
.register-form-side .form-group label{
  font-size:.8rem;color:var(--muted);margin-bottom:.35rem;
}

.input-container{position:relative}
.input-container i.input-icon{
  position:absolute;left:1rem;top:50%;transform:translateY(-50%);
  color:var(--muted);font-size:1rem;
  transition:color .3s;pointer-events:none;
}
.register-form-side .input-container i.input-icon{
  left:.9rem;font-size:.9rem;
}

.form-group input{
  width:100%;
  padding:1rem 3rem 1rem 3rem;
  border-radius:var(--radius-sm);
  border:2px solid var(--border);
  background:rgba(7,0,18,0.6);
  color:var(--text);
  font-size:1rem;font-family:inherit;
  outline:none;transition:all .3s;
}
.register-form-side .form-group input{
  padding:.8rem 2.5rem .8rem 2.5rem;
  border-radius:10px;font-size:.9rem;
}
.form-group input:focus{
  border-color:var(--accent);
  box-shadow:0 0 0 4px rgba(138,11,210,0.15);
  background:rgba(7,0,18,0.8);
}
.register-form-side .form-group input:focus{
  box-shadow:0 0 0 3px rgba(138,11,210,0.15);
}
.form-group input:focus ~ i.input-icon{color:var(--accent-soft)}
.form-group input::placeholder{color:var(--muted);opacity:.6}
.register-form-side .form-group input::placeholder{font-size:.85rem}

/* Password toggle */
.toggle-password{
  position:absolute;right:1rem;top:50%;transform:translateY(-50%);
  background:none;border:none;color:var(--muted);
  cursor:pointer;padding:.25rem;transition:color .3s;
}
.register-form-side .toggle-password{right:.75rem}
.toggle-password:hover{color:var(--accent-soft)}

/* Forgot password */
.forgot-password{text-align:right;margin-bottom:1.5rem}
.forgot-password a{
  font-size:.85rem;color:var(--accent-soft);transition:color .3s;
}
.forgot-password a:hover{color:var(--accent)}

/* Submit button */
.btn-submit{
  width:100%;padding:1rem;
  border:none;border-radius:var(--radius-sm);
  background:linear-gradient(135deg,var(--accent),var(--accent-soft));
  color:#fff;font-size:1rem;font-weight:600;font-family:inherit;
  cursor:pointer;
  display:flex;align-items:center;justify-content:center;gap:.5rem;
  transition:all .3s;
  box-shadow:0 4px 20px rgba(138,11,210,0.3);
}
.register-form-side .btn-submit{
  padding:.9rem;font-size:.95rem;border-radius:10px;margin-top:.5rem;
}
.btn-submit:hover{
  transform:translateY(-2px);
  box-shadow:0 8px 28px rgba(138,11,210,0.4);
}
.btn-submit:active{transform:translateY(0)}

/* Divider (login) */
.divider{
  display:flex;align-items:center;
  margin:1.75rem 0;color:var(--muted);font-size:.85rem;
}
.divider::before,
.divider::after{
  content:'';flex:1;height:1px;background:var(--border);
}
.divider span{padding:0 1rem}

/* Form footer */
.form-footer{text-align:center;margin-top:0}
.register-form-side .form-footer{margin-top:1.25rem}
.form-footer p{font-size:.9rem;color:var(--muted);margin-bottom:.5rem}
.register-form-side .form-footer p{font-size:.85rem}
.form-footer a{
  color:var(--accent-soft);font-weight:600;transition:color .3s;
}
.form-footer a:hover{color:var(--accent)}

.form-footer .register-cta{
  display:inline-flex;align-items:center;gap:.5rem;
  padding:.75rem 1.5rem;
  background:rgba(138,11,210,0.1);
  border:1px solid rgba(138,11,210,0.2);
  border-radius:10px;
  color:var(--accent-soft);font-weight:600;
  transition:all .3s;
}
.form-footer .register-cta:hover{
  background:rgba(138,11,210,0.15);
  border-color:rgba(138,11,210,0.3);
  transform:translateY(-2px);
}

/* WhatsApp help button */
.whatsapp-help{
  display:inline-flex;align-items:center;gap:.5rem;
  margin-top:.75rem;
  padding:.5rem 1.2rem;
  border-radius:10px;
  background:rgba(37,211,102,0.1);
  border:1px solid rgba(37,211,102,0.2);
  color:#25D366;font-size:.85rem;font-weight:500;
  transition:all .3s;
}
.whatsapp-help:hover{
  background:rgba(37,211,102,0.18);
  border-color:rgba(37,211,102,0.35);
  transform:translateY(-2px);
  color:#2ee370;
}
.whatsapp-help i{font-size:1.1rem}

/* ============================================
   PAGE FOOTER
   ============================================ */
.page-footer{
  border-top:1px solid var(--border);
  background:rgba(5,0,15,0.5);
  backdrop-filter:blur(20px);
  padding:1rem 0;
  color:var(--muted);font-size:.85rem;text-align:center;
}

/* ============================================
   RESPONSIVE
   ============================================ */
@media(max-width:768px){
  .login-main,
  .register-main{
    padding:1rem;margin-top:60px;
  }
  .login-wrapper,
  .register-wrapper{
    grid-template-columns:1fr;max-width:420px;
  }
  .login-welcome,
  .register-benefits{display:none}
  .login-form-side{padding:2rem 1.5rem}
  .register-form-side{padding:2rem 1.5rem}
  .form-row{grid-template-columns:1fr}
}

@media(max-width:480px){
  .login-form-side,
  .register-form-side{padding:1.5rem 1.25rem}
  .form-header h1{font-size:1.5rem}
  .form-brand img{width:40px;height:40px}
  .form-brand span{font-size:1.1rem}
}
