/* ============================================================
   OFICIOS MATCH! — style.css
   Sistema de conexión entre clientes y trabajadores
   ============================================================ */

/* ── Google Fonts ── */
@import url('https://fonts.googleapis.com/css2?family=Barlow+Condensed:wght@400;600;700;800&family=DM+Sans:ital,wght@0,300;0,400;0,500;0,600;1,400&display=swap');

/* ── Variables ── */
:root {
  --naranja:          #F97316;
  --naranja-hover:    #EA6C0A;
  --naranja-glow:     rgba(249,115,22,.35);
  --naranja-suave:    rgba(249,115,22,.12);
  --azul-oscuro:      #0F172A;
  --azul-medio:       #1E293B;
  --azul-card:        #1A2744;
  --gris-claro:       #F1F5F9;
  --gris-medio:       #94A3B8;
  --blanco:           #FFFFFF;
  --error:            #EF4444;
  --rosa:             #f59999;
  --exito:            #22C55E;

  --radio-sm:  8px;
  --radio-md:  14px;
  --radio-lg:  22px;
  --sombra-naranja: 0 0 30px rgba(249,115,22,.4);
  --trans:     all .25s ease;
  --trans-md:  all .4s ease;

  --fuente-display: 'Barlow Condensed', sans-serif;
  --fuente-body:    'DM Sans', sans-serif;
}

/* ── Reset ── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html,body{height:100%;font-family:var(--fuente-body);background:var(--azul-oscuro);color:var(--blanco);overflow-x:hidden;overflow-y: auto;}

/* ============================================================
   CARRUSEL DE FONDO
   ============================================================ */
.bg-carousel{position:fixed;inset:0;z-index:0;}

.bg-slide{
  position:absolute;inset:0;opacity:0;
  transition:opacity 1.4s ease-in-out;
  background-size:cover;background-position:center;
}
.bg-slide.activo{opacity:1;}

/* Slides apuntan a las imágenes del proyecto */
.bg-slide:nth-child(1){background-image:url('../imagenes/fondo-1.jpg');}
.bg-slide:nth-child(2){background-image:url('../imagenes/fondo-2.jpg');}
.bg-slide:nth-child(3){background-image:url('../imagenes/fondo-3.jpg');}
.bg-slide:nth-child(4){background-image:url('../imagenes/fondo-4.jpg');}
.bg-slide:nth-child(5){background-image:url('../imagenes/fondo-5.jpg');}
.bg-slide:nth-child(6){background-image:url('../imagenes/fondo-6.jpg');}
.bg-slide:nth-child(7){background-image:url('../imagenes/fondo-7.jpg');}

/* Textura de puntos */
.bg-carousel::before{
  content:'';position:absolute;inset:0;z-index:1;
  background-image:radial-gradient(circle,rgba(255,255,255,.04) 1px,transparent 1px);
  background-size:28px 28px;pointer-events:none;
}
/* Overlay + viñeta naranja */
.bg-carousel::after{
  content:'';position:absolute;inset:0;z-index:2;
  background:
    radial-gradient(ellipse at 70% 50%,rgba(249,115,22,.08) 0%,transparent 60%),
    linear-gradient(to bottom,rgba(15,23,42,.55) 0%,rgba(15,23,42,.8) 100%);
  pointer-events:none;
}

/* Dots */
.carousel-dots{
  position:fixed;bottom:24px;left:50%;transform:translateX(-50%);
  z-index:20;display:flex;gap:10px;
}
.carousel-dot{
  width:8px;height:8px;border-radius:50%;background:rgba(255,255,255,.3);
  border:none;cursor:pointer;transition:var(--trans);padding:0;
}
.carousel-dot.activo{background:var(--naranja);width:22px;border-radius:4px;box-shadow:var(--sombra-naranja);}

/* ============================================================
   LAYOUT
   ============================================================ */
.pagina{
  position:relative;z-index:10;
  min-height:100vh;
  display:flex;align-items:center;justify-content:center;
  padding:20px;
}

/* Panel glassmorphism */
.panel{
  width:100%;max-width:480px;
  background:rgba(62, 90, 150, 0.68);
  backdrop-filter:blur(24px) saturate(1.4);
  -webkit-backdrop-filter:blur(24px) saturate(1.4);
  border:1px solid rgba(255,255,255,.1);
  border-radius:var(--radio-lg);
  padding:40px 38px 34px;
  box-shadow:0 30px 80px rgba(0,0,0,.5),0 0 0 1px rgba(249,115,22,.1) inset;
  animation:slideUp .65s cubic-bezier(.23,1,.32,1) both;
}

/* Panel más ancho para registro */
.panel--wide{max-width:620px;padding:36px 38px 32px;}

@keyframes slideUp{
  from{opacity:0;transform:translateY(32px) scale(.97);}
  to  {opacity:1;transform:translateY(0)    scale(1);}
}

/* ============================================================
   LOGO
   ============================================================ */
.logo-wrap{display:flex;flex-direction:column;align-items:center;gap:12px;margin-bottom:28px;}

.logo-svg-wrap{
  filter:drop-shadow(0 0 18px rgba(249,115,22,.5));
  animation:logoPulse 3.5s ease-in-out infinite;
}
@keyframes logoPulse{
  0%,100%{filter:drop-shadow(0 0 14px rgba(249,115,22,.4));}
  50%    {filter:drop-shadow(0 0 28px rgba(249,115,22,.7));}
}

.logo-titulo{
  font-family:var(--fuente-display);font-size:2rem;font-weight:800;
  letter-spacing:.04em;text-transform:uppercase;line-height:1;
}
.logo-titulo span{color:var(--naranja);}
.logo-subtitulo{font-size:.75rem;color:var(--gris-medio);letter-spacing:.18em;text-transform:uppercase;margin-top:8px;}

/* ============================================================
   FORMULARIOS
   ============================================================ */
.form-titulo{
  font-family:var(--fuente-display);font-size:1.5rem;font-weight:700;
  color:var(--gris-claro);margin-bottom:20px;letter-spacing:.02em;
}

.form-grid{display:grid;gap:14px;}
.form-grid--2{grid-template-columns:1fr 1fr;}

.form-grupo{position:relative;}

.form-label{
  display:block;font-size:.72rem;font-weight:600;
  color:var(--gris-medio);letter-spacing:.1em;
  text-transform:uppercase;margin-bottom:6px;
}

.campo-wrap{position:relative;display:flex;align-items:center;}

.campo-icono{
  position:absolute;left:13px;color:var(--gris-medio);
  display:flex;align-items:center;pointer-events:none;
  transition:var(--trans);z-index:1;
}
.campo-icono svg{width:17px;height:17px;}

.form-input,.form-select{
  width:100%;
  background:rgba(255,255,255,.06);
  border:1.5px solid rgba(255,255,255,.1);
  border-radius:var(--radio-md);
  color:var(--blanco);
  font-family:var(--fuente-body);
  font-size:.9rem;
  padding:11px 14px 11px 42px;
  outline:none;
  transition:var(--trans);
  -webkit-appearance:none;
  -moz-appearance:none;
  appearance:none;
}
.form-input.sin-icono,.form-select.sin-icono{padding-left:14px;}

.form-select option{background:var(--azul-medio);color:var(--blanco);}

.form-input::placeholder{color:rgba(220, 235, 255, 0.863);}

.form-input:focus,.form-select:focus{
  border-color:var(--naranja);
  background:rgba(249,115,22,.07);
  box-shadow:0 0 0 3px rgba(249,115,22,.15);
}
.campo-wrap:focus-within .campo-icono{color:var(--naranja);}

/* Ver contraseña */
.btn-ver-pass{
  position:absolute;right:12px;background:none;border:none;
  cursor:pointer;color:var(--gris-medio);
  display:flex;align-items:center;padding:4px;
  border-radius:6px;transition:var(--trans);z-index:1;
}
.btn-ver-pass:hover{color:var(--naranja);background:rgba(249,115,22,.1);}
.btn-ver-pass svg{width:16px;height:16px;}

/* Mensajes de error */
.msg-error{
  display:none;
  font-size:.73rem;color:var(--rosa);
  margin-top:5px;padding:5px 9px;
  animation:fadeIn .25s ease;
}
.msg-error.visible{display:block;}
.msg-error svg{display:none;}
.form-grupo.error .form-input,
.form-grupo.error .form-select{border-color:var(--error);background:rgba(239,68,68,.07);}

@keyframes fadeIn{from{opacity:0;transform:translateY(-4px);}to{opacity:1;}}

/* ============================================================
   TOGGLE TIPO USUARIO (cliente / trabajador)
   ============================================================ */
.tipo-toggle{
  display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:4px;
}
.tipo-btn{
  display:flex;flex-direction:column;align-items:center;gap:6px;
  padding:14px 10px;
  background:rgba(255,255,255,.05);
  border:1.5px solid rgba(255,255,255,.1);
  border-radius:var(--radio-md);
  color:var(--gris-medio);cursor:pointer;
  transition:var(--trans);font-family:var(--fuente-body);
  font-size:.82rem;font-weight:500;
}
.tipo-btn svg{width:24px;height:24px;transition:var(--trans);}
.tipo-btn:hover{border-color:var(--naranja);color:var(--blanco);background:rgba(249,115,22,.08);}
.tipo-btn.activo{
  border-color:var(--naranja);background:rgba(249,115,22,.15);
  color:var(--blanco);box-shadow:0 0 0 2px rgba(249,115,22,.2);
}
.tipo-btn.activo svg{color:var(--naranja);}

/* Campos extra solo visibles para trabajadores */
.campos-trabajador{
  overflow:hidden;max-height:0;opacity:0;
  transition:max-height .4s ease, opacity .3s ease;
  display:grid;gap:14px;
}
.campos-trabajador.visible{max-height:400px;opacity:1;}

/* ============================================================
   BOTÓN PRINCIPAL
   ============================================================ */
.btn-principal{
  width:100%;margin-top:6px;padding:13px;
  background:linear-gradient(135deg,var(--naranja) 0%,#fb923c 100%);
  border:none;border-radius:var(--radio-md);
  color:#fff;font-family:var(--fuente-display);
  font-size:1.05rem;font-weight:700;letter-spacing:.08em;
  text-transform:uppercase;cursor:pointer;
  transition:var(--trans);position:relative;overflow:hidden;
  box-shadow:0 6px 24px rgba(249,115,22,.4);
  display:flex;align-items:center;justify-content:center;gap:10px;
}
.btn-principal::before{
  content:'';position:absolute;inset:0;
  background:linear-gradient(135deg,rgba(255,255,255,.15) 0%,transparent 100%);
  opacity:0;transition:var(--trans);
}
.btn-principal:hover{transform:translateY(-2px);box-shadow:0 10px 30px rgba(249,115,22,.55);}
.btn-principal:hover::before{opacity:1;}
.btn-principal:active{transform:translateY(0);}
.btn-principal.cargando{pointer-events:none;opacity:.85;}
.btn-principal.cargando .spinner{display:block;}
.btn-principal.cargando .btn-texto{opacity:.7;}
.btn-ingresar{
  width:100%;margin-top:6px;padding:13px;
  background:linear-gradient(135deg,var(--naranja) 0%,#fb923c 100%);
  border:none;border-radius:var(--radio-md);
  color:#fff;font-family:var(--fuente-display);
  font-size:1.05rem;font-weight:700;letter-spacing:.08em;
  text-transform:uppercase;cursor:pointer;
  transition:var(--trans);position:relative;overflow:hidden;
  box-shadow:0 6px 24px rgba(249,115,22,.4);
  display:flex;align-items:center;justify-content:center;gap:10px;
}
.btn-ingresar:hover{transform:translateY(-2px);box-shadow:0 10px 30px rgba(249,115,22,.55);}
.btn-ingresar.cargando{pointer-events:none;opacity:.85;}
.btn-ingresar.cargando .spinner{display:block;}
.btn-ingresar.cargando .btn-texto{opacity:.7;}

.spinner{
  width:17px;height:17px;border:2.5px solid rgba(255,255,255,.3);
  border-top-color:#fff;border-radius:50%;
  animation:spin .7s linear infinite;display:none;
}
@keyframes spin{to{transform:rotate(360deg);}}

/* Botón secundario (ghost) */
.btn-ghost{
  width:100%;padding:11px;margin-top:6px;
  background: rgba(255,255,255,0.08);
  border: 1.5px solid rgba(255,255,255,0.2);
  border-radius:var(--radio-md);
  color: var(--gris-claro);
  font-size:.85rem;font-weight:500;cursor:pointer;
  transition:var(--trans);text-decoration:none;
  display:flex;align-items:center;justify-content:center;gap:8px;
  text-align:center;
}
.btn-ghost:hover{background:rgba(255,255,255,0.14);border-color:rgba(255,255,255,0.35);color:var(--blanco);}

/* ============================================================
   ALERTA GLOBAL
   ============================================================ */
.alerta-global{
  display:none;align-items:center;gap:10px;
  padding:11px 14px;border-radius:var(--radio-sm);
  font-size:.83rem;margin-bottom:16px;
  animation:fadeIn .3s ease;
}
.alerta-global.error  {background:rgba(239,68,68,.12);border:1px solid rgba(239,68,68,.25);color:#fca5a5;}
.alerta-global.exito  {background:rgba(34,197,94,.12); border:1px solid rgba(34,197,94,.25); color:#86efac;}
.alerta-global.info   {background:rgba(59,130,246,.12);border:1px solid rgba(59,130,246,.25);color:#93c5fd;}
.alerta-global.visible{display:flex;}
.alerta-global svg{width:17px;height:17px;flex-shrink:0;}

/* ============================================================
   VERIFICACIÓN DE CÓDIGO
   ============================================================ */
.codigo-inputs{
  display:flex;gap:10px;justify-content:center;margin:18px 0;
}
.codigo-input{
  width:48px;height:56px;
  background:rgba(255,255,255,.06);
  border:1.5px solid rgba(255,255,255,.12);
  border-radius:var(--radio-md);
  color:var(--blanco);font-family:var(--fuente-display);
  font-size:1.6rem;font-weight:700;text-align:center;
  outline:none;transition:var(--trans);caret-color:var(--naranja);
}
.codigo-input:focus{
  border-color:var(--naranja);background:rgba(249,115,22,.07);
  box-shadow:0 0 0 3px rgba(249,115,22,.15);
}
.codigo-input.lleno{border-color:rgba(249,115,22,.5);}

/* Paso activo */
.paso{display:none;}
.paso.activo{display:block;animation:fadeIn .3s ease;}

/* ============================================================
   MISCELÁNEOS
   ============================================================ */
.divider{
  display:flex;align-items:center;gap:10px;
  margin:16px 0;color:rgba(148,163,184,.4);
  font-size:.72rem;letter-spacing:.1em;text-transform:uppercase;
}
.divider::before,.divider::after{content:'';flex:1;height:1px;background:rgba(255,255,255,.07);}

.link-accion{
  text-align:center;margin-top:14px;font-size:.82rem;color:var(--gris-medio);
}
.link-accion a{
  color:var(--naranja);text-decoration:none;font-weight:600;
  transition:var(--trans);border-bottom:1px solid transparent;
}
.link-accion a:hover{border-bottom-color:var(--naranja);}

.panel-footer{
  margin-top:24px;padding-top:16px;
  border-top:1px solid rgba(255,255,255,.07);
  text-align:center;font-size:.7rem;
  color:rgba(148,163,184,.4);letter-spacing:.05em;
}

/* Demo badge (solo desarrollo) */
.demo-badge{
  display:inline-flex;align-items:center;gap:6px;
  font-size:.72rem;padding:5px 10px;
  background:rgba(249,115,22,.1);border:1px solid rgba(249,115,22,.25);
  border-radius:6px;color:#fdba74;margin-top:10px;
}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media(max-width:600px){
  .panel--wide{max-width:100%;padding:28px 20px 24px;}
  .form-grid--2{grid-template-columns:1fr;}
  .tipo-toggle{grid-template-columns:1fr 1fr;}
}
@media(max-width:480px){
  .panel{padding:28px 20px 24px;border-radius:var(--radio-md);}
  .logo-titulo{font-size:1.65rem;}
  .form-titulo{font-size:1.25rem;}
  html,body{overflow:auto;}
}
@media(max-width:360px){
  .codigo-input{width:38px;height:46px;font-size:1.3rem;}
}

/* Iconos dentro de la alerta */
.alerta-global svg{width:17px;height:17px;flex-shrink:0;}

.alerta-global .icono-exito,
.alerta-global .icono-error,
.alerta-global .icono-info{display:none;}

.alerta-global.exito .icono-exito{display:inline-block;}
.alerta-global.error .icono-error{display:inline-block;}
.alerta-global.info .icono-info{display:inline-block;}

/* Animación de entrada para la alerta */
@keyframes slideInDown{from{transform:translateY(-100%);opacity:0;}to{transform:translateY(0);opacity:1;}}

.alerta-global.visible{display:flex;animation:slideInDown .4s ease;}

/* ============================================================
   BARRA DE DESPLAZAMIENTO (SCROLLBAR)
   ============================================================ */
/* Firefox */
* {
    scrollbar-color: var(--naranja) rgba(255, 255, 255, 0.08);
    scrollbar-width: thin;
}

/* Chrome, Safari, Edge */
::-webkit-scrollbar {
    width: 10px;
    height: 10px;
}

::-webkit-scrollbar-track {
    background: rgba(255, 255, 255, 0.05);
}

::-webkit-scrollbar-thumb {
    background: var(--naranja);
    border-radius: 5px;
    transition: background 0.3s ease;
}

::-webkit-scrollbar-thumb:hover {
    background: var(--naranja-hover);
    box-shadow: 0 0 12px rgba(249, 115, 22, 0.3);
}
