/* Weber SaaS — UI alineada al builder (oscuro · azul builder) · pagyna.com */
:root{
  /* fondos oscuros (mismos del preloader del builder) */
  --bg:        #2b2b2e;
  --bg-2:      #232122;
  --panel:     #363636;   /* paneles laterales del builder */
  --card:      #303033;   /* tarjetas */
  --card-2:    #3a3a3e;   /* inputs / hover */
  --line:      #45454a;
  /* acentos del builder */
  --azul:     #00c0ff;   /* acento principal (builder) */
  --azul-d:   #00a6dd;
  --cian:      #00c0ff;   /* acento secundario (indicadores) */
  --durazno:   #f0a868;   /* icono IA */
  /* texto */
  --texto:     #ececf0;
  --texto-soft:#9a9aa2;
  --texto-dim: #6f6f77;
  /* estados */
  --error:     #e0614e;
  --ok:        #00c0ff;
  --shadow:    0 18px 50px rgba(0,0,0,.45);
  --shadow-sm: 0 4px 16px rgba(0,0,0,.30);
  --radius:    0px;
}
*{box-sizing:border-box}
body{
  margin:0;font-family:'Open Sans',-apple-system,BlinkMacSystemFont,"Segoe UI",
    Helvetica,Arial,sans-serif;
  background:linear-gradient(135deg,#2b2b2e 0%,#232122 100%);
  color:var(--texto);min-height:100vh;-webkit-font-smoothing:antialiased;
}
a{color:var(--cian);text-decoration:none}
a:hover{text-decoration:underline}

/* logo Pagyna en pantallas de auth */
.auth-logo{display:block;margin:0 auto 26px;width:150px;height:auto;opacity:.92}

/* ---- fondo de partículas (solo login) ---- */
#bg-particles{position:fixed;inset:0;width:100%;height:100%;z-index:0;
  display:block;pointer-events:none}
.auth-wrap.has-particles{position:relative;z-index:1}
.auth-wrap.has-particles::before{content:"";position:fixed;inset:0;z-index:0;
  background:
    radial-gradient(60% 50% at 50% 38%, rgba(0,192,255,.20), transparent 70%),
    radial-gradient(50% 40% at 80% 80%, rgba(0,192,255,.12), transparent 70%);
  pointer-events:none}
.auth-wrap.has-particles .auth-card{position:relative;z-index:2;
  backdrop-filter:blur(2px);
  background:rgba(48,48,51,.92);
  box-shadow:0 22px 60px rgba(0,0,0,.55),0 0 0 1px rgba(0,192,255,.15)}

/* ---- centro (login / registro) ---- */
.auth-wrap{min-height:100vh;display:flex;align-items:center;
  justify-content:center;padding:24px}
.auth-card{background:var(--card);width:100%;max-width:420px;
  border-radius:var(--radius);box-shadow:var(--shadow);
  padding:40px 36px;border:1px solid var(--line)}
.auth-card h1{margin:0 0 4px;font-size:23px;font-weight:600;letter-spacing:-.2px;
  text-align:center}
.auth-card .sub{color:var(--texto-soft);margin:0 0 26px;font-size:14px;text-align:center}

.field{margin-bottom:18px}
.field label{display:block;font-size:13px;font-weight:600;
  margin-bottom:7px;color:var(--texto)}
.field input,.field select{
  width:100%;padding:12px 14px;border:1px solid var(--line);
  border-radius:0;background:var(--card-2);font-size:15px;color:var(--texto);
  transition:border-color .15s,box-shadow .15s}
.field input::placeholder{color:var(--texto-dim)}
.field input:focus,.field select:focus{outline:none;border-color:var(--azul);
  box-shadow:0 0 0 3px rgba(0,192,255,.25)}
.field select option{background:var(--panel);color:var(--texto)}
.field input[type=file]{padding:9px 12px;cursor:pointer;color:var(--texto-soft)}
.field input[type=file]::file-selector-button{
  background:var(--card-2);color:var(--texto);border:1px solid var(--line);
  padding:7px 13px;margin-right:12px;border-radius:0;cursor:pointer;font:inherit;
  font-size:13px;font-weight:600;transition:background .15s}
.field input[type=file]::file-selector-button:hover{background:var(--azul);color:#06222b;border-color:var(--azul)}

.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;
  width:100%;padding:13px 18px;border:none;border-radius:0;
  background:var(--azul);color:#fff;font-size:15px;font-weight:600;
  cursor:pointer;transition:background .15s,transform .05s;box-shadow:var(--shadow-sm)}
.btn:hover{background:var(--azul-d)}
.btn:active{transform:translateY(1px)}
.btn.secondary{background:transparent;color:var(--texto);
  border:1px solid var(--line);box-shadow:none}
.btn.secondary:hover{background:var(--card-2)}
.btn.small{width:auto;padding:8px 14px;font-size:13px}
.btn.danger{background:var(--error)}
.btn.ghost{background:transparent;color:var(--texto-soft);box-shadow:none}
.btn.ghost:hover{background:var(--card-2);color:var(--texto)}

.alt{margin-top:22px;text-align:center;font-size:14px;color:var(--texto-soft)}

.msg{padding:12px 14px;border-radius:0;font-size:14px;margin-bottom:20px}
.msg.err{background:rgba(224,97,78,.14);color:#f0a193;border:1px solid rgba(224,97,78,.4)}
.msg.ok{background:rgba(0,192,255,.12);color:#7fdcff;border:1px solid rgba(0,192,255,.35)}
.msg.info{background:rgba(255,255,255,.05);color:var(--texto-soft);border:1px solid var(--line)}

/* ---- dashboard / admin ---- */
.topbar{background:var(--panel);border-bottom:1px solid var(--line);
  padding:0 28px;height:62px;display:flex;align-items:center;
  justify-content:space-between;position:sticky;top:0;z-index:10}
.topbar .brand{font-weight:700;font-size:17px;letter-spacing:-.2px;
  display:flex;align-items:center;gap:10px;color:var(--texto)}
.topbar .brand img{height:22px;width:auto;display:block}
.topbar .brand .tag{font-size:11px;font-weight:600;color:var(--texto-dim);
  border-left:1px solid var(--line);padding-left:10px;margin-left:2px}
.topbar nav{display:flex;gap:4px;align-items:center}
.topbar nav a{padding:8px 14px;border-radius:0;font-size:14px;
  font-weight:500;color:var(--texto-soft)}
.topbar nav a.active,.topbar nav a:hover{background:var(--card-2);
  color:var(--texto);text-decoration:none}

.container{max-width:960px;margin:32px auto;padding:0 24px}
.card{background:var(--card);border:1px solid var(--line);
  border-radius:var(--radius);box-shadow:var(--shadow-sm);
  padding:28px;margin-bottom:24px}
.card h2{margin:0 0 6px;font-size:18px;font-weight:600;color:var(--texto)}
.card h2+.hint{margin:0 0 22px}
.hint{color:var(--texto-soft);font-size:14px;line-height:1.5}
.hint code,code{background:var(--bg-2);padding:2px 6px;border-radius:5px;
  font-size:12px;color:var(--cian);font-family:ui-monospace,Menlo,monospace}

.grid2{display:grid;grid-template-columns:1fr 1fr;gap:16px}
@media(max-width:560px){.grid2{grid-template-columns:1fr}}

table{width:100%;border-collapse:collapse;font-size:14px}
th,td{text-align:left;padding:12px 10px;border-bottom:1px solid var(--line);
  color:var(--texto)}
th{font-weight:600;color:var(--texto-soft);font-size:12px;
  text-transform:uppercase;letter-spacing:.4px}
tr:last-child td{border-bottom:none}

.badge{display:inline-block;padding:3px 10px;border-radius:20px;
  font-size:12px;font-weight:600}
.badge.pending{background:rgba(240,168,104,.18);color:#f0b988}
.badge.active{background:rgba(0,192,255,.16);color:#6fd6ff}
.badge.suspended{background:rgba(224,97,78,.18);color:#f0a193}
.badge.admin{background:rgba(0,192,255,.22);color:#7fd6ff}

.row-actions{display:flex;gap:6px;flex-wrap:wrap}
.empty{text-align:center;color:var(--texto-soft);padding:40px 0}

/* ---- acceso destacado al builder ---- */
.builder-launch{display:flex;align-items:center;gap:18px;text-decoration:none;
  background:linear-gradient(135deg, rgba(0,192,255,.16), rgba(0,192,255,.06));
  border:1px solid rgba(0,192,255,.45);
  padding:22px 24px;margin-bottom:24px;color:var(--texto);
  transition:background .15s,border-color .15s,transform .06s}
.builder-launch:hover{text-decoration:none;
  background:linear-gradient(135deg, rgba(0,192,255,.26), rgba(0,192,255,.10));
  border-color:var(--azul)}
.builder-launch:active{transform:translateY(1px)}
.builder-launch__icon{flex:0 0 auto;width:52px;height:52px;display:flex;
  align-items:center;justify-content:center;background:var(--azul);color:#06222b}
.builder-launch__icon svg{width:28px;height:28px}
.builder-launch__text{display:flex;flex-direction:column;line-height:1.3;flex:1 1 auto}
.builder-launch__text strong{font-size:18px;font-weight:700;color:var(--texto)}
.builder-launch__text small{font-size:13px;color:var(--texto-soft)}
.builder-launch__arrow{flex:0 0 auto;color:var(--azul);
  transition:transform .15s}
.builder-launch__arrow svg{width:24px;height:24px;display:block}
.builder-launch:hover .builder-launch__arrow{transform:translateX(4px)}
