:root{
  --bg:#070512;
  --bg2:#0d0826;
  --surface:#141033;
  --surface2:#1c1647;
  --t1:#ffffff;
  --t2:#c7c2e6;
  --t3:#8a83b8;
  --pink:#ff2d9b;
  --cyan:#22d3ee;
  --violet:#7c3aed;
  --yellow:#ffd23f;
  --grad:linear-gradient(90deg,var(--pink),var(--violet),var(--cyan));
  --grad-btn:linear-gradient(90deg,#ff2d9b,#ff7a3d,#ffd23f);
  --ok:#22c55e;--err:#ef4444;
}
*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
body{
  font-family:'Inter',system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  background:radial-gradient(1200px 600px at 50% -10%,#1b1147 0%,var(--bg) 55%);
  color:var(--t1);min-height:100dvh;-webkit-font-smoothing:antialiased;
}
a{color:inherit;text-decoration:none}
.wrap{max-width:920px;margin:0 auto;padding:18px}
.center{display:flex;align-items:center;justify-content:center;min-height:100dvh;flex-direction:column}

/* Marca */
.brand{font-weight:900;letter-spacing:1px;font-size:26px;line-height:1}
.brand .a{color:var(--pink)}
.brand .b{color:var(--cyan)}
.brand-sub{font-size:11px;letter-spacing:3px;color:var(--t3);font-weight:700}

/* Botones */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  border:none;border-radius:40px;padding:16px 22px;font-size:17px;font-weight:800;
  color:#1a0a14;background:var(--grad-btn);cursor:pointer;width:100%;
  box-shadow:0 10px 30px rgba(255,45,155,.35);transition:transform .15s ease,filter .15s ease;
}
.btn:active{transform:scale(.98)}
.btn:hover{filter:brightness(1.05)}
.btn.ghost{background:transparent;color:var(--t1);border:1px solid var(--surface2);box-shadow:none}
.btn.small{width:auto;padding:9px 14px;font-size:13px;border-radius:10px}
.btn.danger{background:transparent;color:var(--err);border:1px solid rgba(239,68,68,.4)}

/* Inputs */
.input{
  width:100%;background:var(--surface);border:1px solid var(--surface2);color:var(--t1);
  border-radius:12px;padding:15px 16px;font-size:16px;outline:none;transition:border .15s;
}
.input:focus{border-color:var(--pink)}
.field-label{font-size:12px;color:var(--t3);margin:0 0 6px 2px;font-weight:700;text-transform:uppercase;letter-spacing:1px}

.card{background:linear-gradient(180deg,var(--surface),#0f0b29);border:1px solid var(--surface2);border-radius:20px;padding:22px}
.msg{font-size:14px;margin-top:10px;min-height:18px}
.msg.err{color:var(--err)}
.msg.ok{color:var(--ok)}

/* ---------- LANDING ---------- */
.hero{padding:26px 18px 40px;max-width:1000px;margin:0 auto}
.hero-top{display:flex;align-items:center;gap:10px;margin-bottom:18px}
.pill{display:inline-flex;align-items:center;gap:8px;background:rgba(124,58,237,.15);border:1px solid rgba(124,58,237,.45);color:#c4b5fd;padding:8px 14px;border-radius:30px;font-size:12px;font-weight:700}
.hero h1{font-size:clamp(34px,9vw,62px);font-weight:900;line-height:.95;letter-spacing:-1px;margin:14px 0}
.hero h1 .big{background:var(--grad-btn);-webkit-background-clip:text;background-clip:text;color:transparent;display:block;font-size:1.25em}
.hero p.lead{color:var(--t2);font-size:17px;max-width:560px;margin:10px 0 20px}
.consoles{display:flex;flex-wrap:wrap;gap:8px;margin:18px 0}
.console-chip{border:1px solid var(--surface2);background:var(--surface);border-radius:10px;padding:8px 12px;font-size:12px;font-weight:800;color:var(--t2)}
.features{display:flex;flex-wrap:wrap;gap:14px;margin:22px 0}
.feature{display:flex;align-items:center;gap:10px;color:var(--t2);font-size:13px}
.feature b{color:var(--t1);display:block;font-size:14px}
.feature .ic{font-size:20px}
.price-box{display:flex;align-items:baseline;gap:12px;margin:8px 0 18px;flex-wrap:wrap}
.price-box .tag{font-size:13px;color:var(--cyan);font-weight:800;text-transform:uppercase;letter-spacing:1px}
.price-box .amount{font-size:clamp(40px,11vw,64px);font-weight:900;line-height:1}
.price-box .cur{color:var(--t3);font-weight:800;font-size:18px}
.trust{display:flex;gap:18px;flex-wrap:wrap;justify-content:center;color:var(--t3);font-size:12px;font-weight:700;border-top:1px solid var(--surface2);margin-top:30px;padding-top:18px}
.mock{display:flex;justify-content:center;margin-top:8px}
.grid-games{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;max-width:300px}
.gthumb{aspect-ratio:1;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:22px;font-weight:900;color:#fff;text-shadow:0 1px 4px rgba(0,0,0,.5)}
.foot-links{text-align:center;margin-top:20px;color:var(--t3);font-size:12px}
.foot-links a{color:var(--cyan)}

/* ---------- APP / BIBLIOTECA ---------- */
.appbar{position:sticky;top:0;z-index:20;background:rgba(7,5,18,.85);backdrop-filter:blur(10px);border-bottom:1px solid var(--surface2);padding:12px 16px;display:flex;align-items:center;justify-content:space-between;gap:10px}
.search{flex:1;max-width:420px}
.lib{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:14px;padding:18px}
.game{background:var(--surface);border:1px solid var(--surface2);border-radius:14px;overflow:hidden;cursor:pointer;transition:transform .15s,border .15s}
.game:hover{transform:translateY(-3px);border-color:var(--pink)}
.game .cover{aspect-ratio:1;display:flex;align-items:center;justify-content:center;font-weight:900;color:#fff;text-align:center;padding:8px;font-size:15px;text-shadow:0 1px 4px rgba(0,0,0,.5)}
.game .meta{padding:8px 10px}
.game .meta .t{font-size:13px;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.game .meta .s{font-size:11px;color:var(--t3);text-transform:uppercase}
.empty{grid-column:1/-1;text-align:center;color:var(--t3);padding:50px 20px}

/* Modal jugador */
.overlay{position:fixed;inset:0;background:rgba(2,1,8,.92);z-index:50;display:none;align-items:center;justify-content:center;flex-direction:column}
.overlay.show{display:flex}
.player{width:100%;max-width:900px;aspect-ratio:4/3;max-height:78dvh;background:#000;border-radius:8px;overflow:hidden}
.player-bar{width:100%;max-width:900px;display:flex;justify-content:space-between;align-items:center;padding:10px;color:var(--t2)}

/* ---------- ADMIN ---------- */
.admin-head{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:10px;margin-bottom:18px}
.stats{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:16px}
.stat{flex:1;min-width:120px;background:var(--surface);border:1px solid var(--surface2);border-radius:14px;padding:14px}
.stat .n{font-size:26px;font-weight:900}
.stat .l{font-size:12px;color:var(--t3);text-transform:uppercase;letter-spacing:1px}
.toolbar{display:flex;gap:10px;flex-wrap:wrap;align-items:flex-end;background:var(--surface);border:1px solid var(--surface2);border-radius:14px;padding:14px;margin-bottom:16px}
.toolbar .grow{flex:1;min-width:120px}
table{width:100%;border-collapse:collapse;font-size:13px}
th,td{text-align:left;padding:10px 8px;border-bottom:1px solid var(--surface2)}
th{color:var(--t3);font-size:11px;text-transform:uppercase;letter-spacing:1px}
.code-cell{font-family:ui-monospace,Menlo,Consolas,monospace;font-weight:700;letter-spacing:1px}
.badge{display:inline-block;padding:3px 9px;border-radius:20px;font-size:11px;font-weight:800}
.badge.active{background:rgba(34,197,94,.15);color:#4ade80}
.badge.used{background:rgba(34,211,238,.15);color:var(--cyan)}
.badge.off{background:rgba(239,68,68,.15);color:#f87171}
.row-actions{display:flex;gap:6px;flex-wrap:wrap}
.icon-btn{background:transparent;border:1px solid var(--surface2);color:var(--t2);border-radius:8px;padding:6px 9px;cursor:pointer;font-size:12px}
.icon-btn:hover{border-color:var(--pink);color:#fff}
.tabs{display:flex;gap:8px;margin-bottom:16px}
.tab{padding:9px 16px;border-radius:10px;background:var(--surface);border:1px solid var(--surface2);cursor:pointer;font-weight:700;font-size:14px;color:var(--t2)}
.tab.active{background:var(--violet);color:#fff;border-color:var(--violet)}
.hidden{display:none}
.table-wrap{overflow-x:auto;background:var(--surface);border:1px solid var(--surface2);border-radius:14px;padding:6px 14px}
select.input{appearance:none}
.note{color:var(--t3);font-size:12px;margin-top:6px}
