/* ===== Welysis brand tokens (alineados con Welysis Launcher) ===== */
:root{
  --navy:#0F172A;
  --navy-deep:#0A0F1E;
  --blue:#3474E0;
  --cyan:#21A0CD;
  --teal:#22DEA4;
  --violet:#8B5CF6;
  --ink:#E8EEF7;
  --ink-dim:#94A3B8;
  --line:rgba(148,163,184,.14);
  --card:rgba(148,163,184,.045);
  --card-hi:rgba(148,163,184,.09);
  --ok:#22DEA4; --bad:#F0556B; --warn:#F5B340;
  --radius:18px;
  --radius-sm:12px;
}
*{box-sizing:border-box;margin:0;padding:0}
html,body{min-height:100%}
body{
  font-family:'Arsenal','Segoe UI',system-ui,sans-serif;
  background:var(--navy-deep);
  color:var(--ink);
  -webkit-font-smoothing:antialiased;
  font-size:15px;
}
a{color:var(--cyan);text-decoration:none}
a:hover{color:var(--teal)}

/* ===== Fondo atmosferico (orbes + grid + grain) ===== */
.bg{position:fixed;inset:0;z-index:0;overflow:hidden;pointer-events:none}
.orb{position:absolute;border-radius:50%;filter:blur(90px);opacity:.42;animation:drift 22s ease-in-out infinite}
.orb.a{width:560px;height:560px;background:radial-gradient(circle,var(--blue),transparent 70%);top:-200px;left:-140px}
.orb.b{width:620px;height:620px;background:radial-gradient(circle,var(--cyan),transparent 70%);bottom:-260px;right:-180px;animation-delay:-7s}
.orb.c{width:420px;height:420px;background:radial-gradient(circle,var(--teal),transparent 70%);bottom:-140px;left:35%;opacity:.25;animation-delay:-13s}
@keyframes drift{0%,100%{transform:translate(0,0) scale(1)}33%{transform:translate(40px,-30px) scale(1.08)}66%{transform:translate(-30px,25px) scale(.95)}}
.grid-lines{position:fixed;inset:0;z-index:1;pointer-events:none;
  background-image:linear-gradient(var(--line) 1px,transparent 1px),linear-gradient(90deg,var(--line) 1px,transparent 1px);
  background-size:64px 64px;mask-image:radial-gradient(ellipse 95% 75% at 50% 30%,#000 30%,transparent 78%);opacity:.45}
.grain{position:fixed;inset:0;z-index:2;pointer-events:none;opacity:.04;mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}

/* ===== Layout ===== */
.app{position:relative;z-index:3;display:flex;min-height:100vh}
.sidebar{
  width:248px;flex:none;background:rgba(15,23,42,.55);backdrop-filter:blur(14px);
  border-right:1px solid var(--line);display:flex;flex-direction:column;padding:22px 0;
}
.brand{display:flex;align-items:center;gap:13px;padding:0 22px 20px}
.brand .logo{width:42px;height:42px;display:grid;place-items:center;filter:drop-shadow(0 6px 18px rgba(33,160,205,.35))}
.brand .logo img{width:42px;height:42px;object-fit:contain}
.brand .logo.fallback{border-radius:12px;background:linear-gradient(135deg,var(--blue),var(--teal))}
.brand b{font-size:19px;font-weight:700;letter-spacing:-.3px;line-height:1}
.brand b span{color:var(--ink-dim);font-weight:400}
.brand .sub{font-size:10.5px;color:var(--ink-dim);letter-spacing:1px;text-transform:uppercase;margin-top:4px;display:block}
.nav{display:flex;flex-direction:column;gap:3px;padding:10px}
.nav a{color:var(--ink);padding:11px 14px;border-radius:var(--radius-sm);display:flex;gap:10px;align-items:center;
  border:1px solid transparent;transition:.25s}
.nav a:hover{background:var(--card-hi);color:var(--ink)}
.nav a.activo{background:color-mix(in srgb,var(--blue) 18%,transparent);border-color:color-mix(in srgb,var(--blue) 35%,transparent);color:#fff}
.nav .sep{flex:1}
.content{flex:1;padding:30px 40px;max-width:1120px}

.topbar{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:26px}
.topbar h1{margin:0;font-size:26px;font-weight:700;letter-spacing:-.6px}
.user-chip{color:var(--ink-dim);font-size:13px}
.user-chip b{color:var(--ink)}

/* ===== Glass surfaces ===== */
.card,.form,table{background:var(--card);border:1px solid var(--line);backdrop-filter:blur(12px)}
.grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(190px,1fr));gap:18px;margin-bottom:30px}
.card{border-radius:var(--radius);padding:22px}
.card .n{font-size:34px;font-weight:700;letter-spacing:-1px;
  background:linear-gradient(110deg,var(--cyan),var(--teal));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.card .l{color:var(--ink-dim);font-size:13px;margin-top:6px;text-transform:uppercase;letter-spacing:.6px}

/* ===== Tables ===== */
table{width:100%;border-collapse:separate;border-spacing:0;border-radius:var(--radius);overflow:hidden}
th,td{text-align:left;padding:12px 16px;border-bottom:1px solid var(--line);font-size:14px}
th{color:var(--ink-dim);font-weight:600;background:rgba(148,163,184,.06);text-transform:uppercase;font-size:11.5px;letter-spacing:.6px}
tr:last-child td{border-bottom:none}
tbody tr{transition:background .2s}
tbody tr:hover td{background:var(--card-hi)}

/* ===== Forms ===== */
.form{border-radius:var(--radius);padding:24px;margin-bottom:22px}
.form h2{margin:0 0 16px;font-size:18px;font-weight:700;letter-spacing:-.3px}
label{display:block;color:var(--ink-dim);font-size:13px;margin:12px 0 6px}
input[type=text],input[type=email],input[type=password],select{
  width:100%;padding:10px 13px;background:rgba(10,15,30,.6);border:1px solid var(--line);
  border-radius:var(--radius-sm);color:var(--ink);font-size:14px;font-family:inherit;transition:.2s}
input:focus,select:focus{outline:none;border-color:var(--cyan);box-shadow:0 0 0 3px color-mix(in srgb,var(--cyan) 18%,transparent)}
input:disabled{opacity:.55}
.row{display:flex;gap:16px;flex-wrap:wrap}
.row>div{flex:1;min-width:180px}
.check{display:flex;align-items:center;gap:9px;margin-top:16px}
.check input{width:auto}

/* ===== Buttons ===== */
.btn{display:inline-flex;align-items:center;gap:8px;padding:10px 18px;border-radius:var(--radius-sm);border:1px solid transparent;
  cursor:pointer;font-size:14px;font-family:inherit;font-weight:600;color:#fff;
  background:linear-gradient(120deg,var(--blue),var(--cyan));transition:.25s;text-decoration:none}
.btn:hover{filter:brightness(1.12);transform:translateY(-1px);color:#fff}
.btn.sec{background:var(--card-hi);color:var(--ink);border:1px solid var(--line)}
.btn.sec:hover{background:rgba(148,163,184,.16);filter:none}
.btn.danger{background:linear-gradient(120deg,#b91c1c,var(--bad))}
.btn.sm{padding:6px 12px;font-size:13px;font-weight:600}
.acciones{display:flex;gap:10px;margin-top:20px;flex-wrap:wrap}

/* ===== Matriz ===== */
.grupo{margin:20px 0}
.grupo-tit{text-transform:uppercase;font-size:11.5px;letter-spacing:1.2px;color:var(--cyan);
  margin-bottom:10px;display:flex;align-items:center;gap:9px}
.grupo-tit::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--cyan);box-shadow:0 0 10px var(--cyan)}
.matriz .badge{font-size:11px;padding:2px 8px;border-radius:7px;background:rgba(148,163,184,.1);color:var(--ink-dim);margin-left:6px}
.matriz select{max-width:180px}
.celda-ok{transition:background .5s}
.celda-flash{background:color-mix(in srgb,var(--teal) 20%,transparent)!important}

/* ===== Misc ===== */
.alert{background:color-mix(in srgb,var(--bad) 12%,transparent);border:1px solid color-mix(in srgb,var(--bad) 45%,transparent);
  color:#fecdd3;padding:11px 15px;border-radius:var(--radius-sm);margin-bottom:14px}
.pill{font-size:11px;padding:3px 10px;border-radius:30px;font-weight:600;border:1px solid var(--line)}
.pill.on{background:color-mix(in srgb,var(--ok) 14%,transparent);color:var(--teal);border-color:color-mix(in srgb,var(--ok) 30%,transparent)}
.pill.off{background:rgba(148,163,184,.1);color:var(--ink-dim)}
.pill.sa{background:color-mix(in srgb,var(--blue) 18%,transparent);color:#93c5fd;border-color:color-mix(in srgb,var(--blue) 35%,transparent)}
.muted{color:var(--ink-dim);font-size:13px}

/* ===== Login (eco del launcher) ===== */
.login-wrap{position:relative;z-index:3;display:flex;align-items:center;justify-content:center;min-height:100vh;padding:20px}
.login-box{width:380px;background:rgba(15,23,42,.6);border:1px solid var(--line);border-radius:24px;padding:36px 34px;
  backdrop-filter:blur(16px);box-shadow:0 24px 70px rgba(0,0,0,.5);
  opacity:0;transform:translateY(16px);animation:fadeUp .7s .1s forwards cubic-bezier(.2,.8,.2,1)}
.login-box .brand{flex-direction:column;justify-content:center;text-align:center;padding-bottom:8px;gap:14px}
.login-box .brand .logo{width:58px;height:58px}
.login-box .brand .logo img{width:58px;height:58px}
.login-box .hero-sub{text-align:center;color:var(--ink-dim);font-size:13.5px;margin-bottom:22px}
.login-box .hero-sub em{font-style:normal;background:linear-gradient(110deg,var(--cyan),var(--teal));
  -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;font-weight:700}
@keyframes fadeUp{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:none}}

/* ===== Launcher web (/mis-accesos) ===== */
.lwrap{position:relative;z-index:3;min-height:100vh;display:flex;flex-direction:column;
  padding:clamp(24px,4vh,56px) clamp(24px,6vw,90px)}
.lhead{display:flex;align-items:center;justify-content:space-between;
  opacity:0;animation:fadeDown .8s .1s forwards cubic-bezier(.2,.8,.2,1)}
.lhead .brand{gap:16px}
.lhead .brand .logo{width:54px;height:54px}
.lhead .brand .logo img{width:54px;height:54px}
.lhead .brand b{font-size:23px}
.luser{text-align:right}
.luser .nom{font-size:18px;font-weight:700}
.luser .rol{font-size:12px;color:var(--ink-dim);text-transform:uppercase;letter-spacing:.6px;margin-top:2px}
.luser a{font-size:12px}
.lhero{margin:clamp(26px,5vh,56px) 0 clamp(18px,3vh,32px);
  opacity:0;animation:fadeDown .8s .25s forwards cubic-bezier(.2,.8,.2,1)}
.lhero h2{font-size:clamp(28px,4vw,46px);font-weight:700;letter-spacing:-1.1px;line-height:1.05}
.lhero h2 em{font-style:normal;background:linear-gradient(110deg,var(--cyan),var(--teal));
  -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.lhero p{color:var(--ink-dim);font-size:15px;margin-top:10px}
.lgrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:22px}
.lcard{position:relative;border:1px solid var(--line);border-radius:22px;background:var(--card);
  backdrop-filter:blur(12px);padding:24px;min-height:190px;display:flex;flex-direction:column;
  justify-content:space-between;overflow:hidden;text-decoration:none;color:var(--ink);
  transition:transform .4s cubic-bezier(.2,.8,.2,1),border-color .4s,background .4s;
  opacity:0;transform:translateY(20px);animation:cardIn .7s forwards cubic-bezier(.2,.8,.2,1)}
.lcard::before{content:"";position:absolute;inset:0;border-radius:22px;padding:1px;
  background:linear-gradient(135deg,var(--accent),transparent 55%);
  -webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);
  -webkit-mask-composite:xor;mask-composite:exclude;opacity:0;transition:opacity .4s}
.lcard:hover{transform:translateY(-8px);background:var(--card-hi);border-color:transparent;color:var(--ink);text-decoration:none}
.lcard:hover::before{opacity:.9}
.lcard.off{opacity:.5;pointer-events:none;animation:cardIn .7s forwards}
.lcard .ic{width:46px;height:46px;border-radius:13px;display:grid;place-items:center;font-weight:700;font-size:18px;
  background:color-mix(in srgb,var(--accent) 16%,transparent);
  border:1px solid color-mix(in srgb,var(--accent) 30%,transparent);color:var(--accent)}
.lcard .name{font-size:20px;font-weight:700;letter-spacing:-.3px;margin-top:auto}
.lcard .meta{display:flex;gap:8px;align-items:center;margin-top:8px;flex-wrap:wrap}
.lcard .rolb{font-size:11px;font-weight:600;padding:3px 10px;border-radius:30px;color:var(--accent);
  background:color-mix(in srgb,var(--accent) 12%,transparent);border:1px solid color-mix(in srgb,var(--accent) 26%,transparent)}
.lcard .scope{font-size:10.5px;text-transform:uppercase;letter-spacing:1px;color:var(--ink-dim)}
.lempty{color:var(--ink-dim);background:var(--card);border:1px solid var(--line);border-radius:18px;padding:30px;text-align:center}
.lfoot{margin-top:auto;padding-top:26px;font-size:12px;color:var(--ink-dim);display:flex;justify-content:space-between}
