/* ============================================================
   THE TRADING GAME — Sistema de diseño (Pixel Art RPG Oscuro)
   Paleta: Esmeralda · Dorado · Rojo · Azul · Morado
   ============================================================ */

/* ---------- Fuentes ---------- */
@import url('https://fonts.googleapis.com/css2?family=Press+Start+2P&family=VT323&family=Inter:wght@400;500;600;700;800&display=swap');

/* ---------- Variables ---------- */
:root{
  --bg-0:#070b0a;
  --bg-1:#0c1311;
  --bg-2:#10191a;
  --panel:#121d1c;
  --panel-2:#16241f;
  --panel-line:#1f3a31;
  --panel-glow:rgba(46,229,157,.12);

  --emerald:#2ee59d;
  --emerald-deep:#0f9d63;
  --emerald-dark:#0a5f3d;
  --gold:#ffce4d;
  --gold-deep:#e0a32e;
  --red:#ff5562;
  --red-deep:#c0303c;
  --blue:#4db4ff;
  --blue-deep:#2a6fb0;
  --purple:#b06bff;
  --purple-deep:#7a3fd0;

  --text:#e8fff5;
  --text-dim:#9fc4b6;
  --text-mute:#6f8c80;

  --pixel:'Press Start 2P', monospace;
  --mono:'VT323', monospace;
  --sans:'Inter', system-ui, sans-serif;

  --radius:14px;
  --shadow:0 10px 40px rgba(0,0,0,.55);
}

/* ---------- Reset ---------- */
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:var(--sans);
  color:var(--text);
  background:
    radial-gradient(1200px 600px at 80% -10%, rgba(122,63,208,.10), transparent 60%),
    radial-gradient(900px 500px at -10% 20%, rgba(46,229,157,.08), transparent 60%),
    var(--bg-0);
  background-attachment:fixed;
  line-height:1.55;
  min-height:100vh;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer}
::selection{background:var(--emerald);color:#04130c}

::-webkit-scrollbar{width:12px;height:12px}
::-webkit-scrollbar-track{background:var(--bg-1)}
::-webkit-scrollbar-thumb{background:var(--emerald-dark);border-radius:8px;border:3px solid var(--bg-1)}
::-webkit-scrollbar-thumb:hover{background:var(--emerald-deep)}

/* ---------- Tipografía ---------- */
.pixel{font-family:var(--pixel);letter-spacing:.5px;line-height:1.5;text-transform:uppercase}
.mono{font-family:var(--mono);font-size:1.25rem}
.glow-em{text-shadow:0 0 12px rgba(46,229,157,.7)}
.glow-gold{text-shadow:0 0 12px rgba(255,206,77,.7)}
.t-em{color:var(--emerald)}
.t-gold{color:var(--gold)}
.t-red{color:var(--red)}
.t-blue{color:var(--blue)}
.t-purple{color:var(--purple)}
.t-dim{color:var(--text-dim)}
.t-mute{color:var(--text-mute)}

/* ---------- Layout ---------- */
.wrap{max-width:1180px;margin:0 auto;padding:0 22px}
.section{padding:90px 0}
.center{text-align:center}
.grid{display:grid;gap:22px}
.cols-2{grid-template-columns:repeat(2,1fr)}
.cols-3{grid-template-columns:repeat(3,1fr)}
.cols-4{grid-template-columns:repeat(4,1fr)}
.row{display:flex;gap:16px;align-items:center}
.between{justify-content:space-between}
.wrapflex{flex-wrap:wrap}
@media(max-width:880px){
  .cols-2,.cols-3,.cols-4{grid-template-columns:1fr}
  .section{padding:60px 0}
}

/* ---------- Panel / Card ---------- */
.panel{
  position:relative;
  background:linear-gradient(180deg,var(--panel-2),var(--panel));
  border:2px solid var(--panel-line);
  border-radius:var(--radius);
  box-shadow:var(--shadow), inset 0 1px 0 rgba(255,255,255,.03);
  padding:22px;
}
.panel.glow{box-shadow:var(--shadow),0 0 0 1px rgba(46,229,157,.15),0 0 28px var(--panel-glow)}
.panel.framed::before,.panel.framed::after{
  content:'';position:absolute;width:12px;height:12px;border:2px solid var(--gold);opacity:.6
}
.panel.framed::before{top:8px;left:8px;border-right:0;border-bottom:0}
.panel.framed::after{bottom:8px;right:8px;border-left:0;border-top:0}

.card-h{font-family:var(--pixel);font-size:.72rem;color:var(--text-dim);text-transform:uppercase;letter-spacing:1px;margin-bottom:14px;display:flex;align-items:center;gap:8px}

/* ---------- Botones ---------- */
.btn{
  display:inline-flex;align-items:center;gap:10px;justify-content:center;
  font-family:var(--pixel);font-size:.7rem;text-transform:uppercase;letter-spacing:1px;
  padding:16px 24px;border-radius:12px;border:2px solid transparent;
  color:#04130c;background:linear-gradient(180deg,var(--emerald),var(--emerald-deep));
  box-shadow:0 6px 0 var(--emerald-dark),0 10px 24px rgba(46,229,157,.25);
  transition:transform .08s ease, box-shadow .08s ease, filter .15s ease;
  position:relative;
}
.btn:hover{filter:brightness(1.08)}
.btn:active{transform:translateY(4px);box-shadow:0 2px 0 var(--emerald-dark),0 4px 12px rgba(46,229,157,.2)}
.btn.gold{background:linear-gradient(180deg,var(--gold),var(--gold-deep));box-shadow:0 6px 0 #9c6f15,0 10px 24px rgba(255,206,77,.25);color:#1a1304}
.btn.ghost{background:transparent;color:var(--emerald);border-color:var(--panel-line);box-shadow:none}
.btn.ghost:hover{border-color:var(--emerald);background:rgba(46,229,157,.06)}
.btn.red{background:linear-gradient(180deg,var(--red),var(--red-deep));box-shadow:0 6px 0 #7c1a22;color:#fff}
.btn.purple{background:linear-gradient(180deg,var(--purple),var(--purple-deep));box-shadow:0 6px 0 #4d2587;color:#fff}
.btn.sm{padding:11px 16px;font-size:.6rem}
.btn.block{width:100%}
.btn:disabled{opacity:.45;cursor:not-allowed}

/* ---------- Barra XP / progreso ---------- */
.bar{
  --val:50%;
  height:18px;border-radius:20px;background:#0a1412;border:2px solid var(--panel-line);
  overflow:hidden;position:relative;
}
.bar > i{
  display:block;height:100%;width:var(--val);
  background:linear-gradient(90deg,var(--emerald-deep),var(--emerald));
  box-shadow:0 0 14px rgba(46,229,157,.6);
  border-radius:20px;transition:width .8s cubic-bezier(.2,.8,.2,1);
  position:relative;
}
.bar > i::after{
  content:'';position:absolute;inset:0;border-radius:20px;
  background:repeating-linear-gradient(45deg,rgba(255,255,255,.14) 0 8px,transparent 8px 16px);
  animation:barflow 1.2s linear infinite;
}
@keyframes barflow{to{background-position:32px 0}}
.bar.gold > i{background:linear-gradient(90deg,var(--gold-deep),var(--gold));box-shadow:0 0 14px rgba(255,206,77,.6)}
.bar.red > i{background:linear-gradient(90deg,var(--red-deep),var(--red));box-shadow:0 0 14px rgba(255,85,98,.5)}
.bar.blue > i{background:linear-gradient(90deg,var(--blue-deep),var(--blue))}
.bar.purple > i{background:linear-gradient(90deg,var(--purple-deep),var(--purple))}
.bar.thin{height:12px}
.bar.tall{height:24px}

/* ---------- Chips ---------- */
.chip{
  display:inline-flex;align-items:center;gap:6px;font-size:.74rem;font-weight:600;
  padding:5px 12px;border-radius:999px;border:1px solid var(--panel-line);
  background:rgba(255,255,255,.03);color:var(--text-dim);
}
.chip.em{color:var(--emerald);border-color:rgba(46,229,157,.4);background:rgba(46,229,157,.08)}
.chip.gold{color:var(--gold);border-color:rgba(255,206,77,.4);background:rgba(255,206,77,.08)}
.chip.red{color:var(--red);border-color:rgba(255,85,98,.4);background:rgba(255,85,98,.08)}
.chip.purple{color:var(--purple);border-color:rgba(176,107,255,.4);background:rgba(176,107,255,.08)}
.chip.blue{color:var(--blue);border-color:rgba(77,180,255,.4);background:rgba(77,180,255,.08)}

/* ---------- Stat tiles ---------- */
.stat{display:flex;flex-direction:column;gap:4px;padding:16px;border-radius:12px;background:rgba(255,255,255,.02);border:1px solid var(--panel-line)}
.stat .k{font-size:.68rem;text-transform:uppercase;letter-spacing:1px;color:var(--text-mute);font-weight:700}
.stat .v{font-family:var(--pixel);font-size:1.05rem}

/* ---------- Navbar ---------- */
.nav{
  position:sticky;top:0;z-index:50;
  background:rgba(7,11,10,.82);backdrop-filter:blur(10px);
  border-bottom:2px solid var(--panel-line);
}
.nav .wrap{display:flex;align-items:center;justify-content:space-between;height:68px}
.brand{display:flex;align-items:center;gap:12px;font-family:var(--pixel);font-size:.85rem}
.brand .logo{width:34px;height:34px;border-radius:8px;display:grid;place-items:center;
  background:linear-gradient(135deg,var(--emerald),var(--emerald-deep));color:#04130c;font-size:.8rem;
  box-shadow:0 0 16px rgba(46,229,157,.5)}
.nav-links{display:flex;gap:26px;align-items:center}
.nav-links a{font-size:.85rem;color:var(--text-dim);font-weight:600;transition:color .15s}
.nav-links a:hover,.nav-links a.active{color:var(--emerald)}
@media(max-width:880px){.nav-links{display:none}}

/* ---------- Monster card ---------- */
.monster{
  display:flex;gap:14px;align-items:center;padding:14px;border-radius:12px;
  background:rgba(0,0,0,.25);border:1px solid var(--panel-line);
}
.monster .face{
  width:64px;height:64px;flex:0 0 64px;border-radius:10px;display:grid;place-items:center;
  font-size:2rem;filter:drop-shadow(0 0 10px currentColor);
}
.monster .meta{flex:1;min-width:0}
.monster .name{font-family:var(--pixel);font-size:.7rem;display:flex;justify-content:space-between;gap:8px;margin-bottom:6px}
.m-miedo{color:var(--red)}
.m-codicia{color:var(--purple)}
.m-impaciencia{color:var(--blue)}
.m-ego{color:var(--emerald)}
.m-duda{color:#aab4b0}

/* ---------- Cofre ---------- */
.chest{font-size:2.4rem;filter:drop-shadow(0 0 14px rgba(255,206,77,.6));animation:bob 2.4s ease-in-out infinite}
@keyframes bob{0%,100%{transform:translateY(0)}50%{transform:translateY(-6px)}}

/* ---------- Hero ---------- */
.hero{position:relative;padding:80px 0 60px;overflow:hidden}
.hero h1{font-family:var(--pixel);font-size:2.6rem;line-height:1.35;margin-bottom:22px}
.hero .sub{font-size:1.15rem;color:var(--text-dim);max-width:640px;margin:0 auto 34px}
@media(max-width:880px){.hero h1{font-size:1.4rem}}
.scanlines::before{
  content:'';position:absolute;inset:0;pointer-events:none;z-index:1;
  background:repeating-linear-gradient(transparent 0 3px,rgba(0,0,0,.12) 3px 4px);mix-blend-mode:overlay;opacity:.5
}

/* ---------- Mission ---------- */
.mission{display:flex;gap:14px;align-items:center;padding:14px;border-radius:12px;background:rgba(0,0,0,.25);border:1px solid var(--panel-line)}
.mission .ic{font-size:1.5rem;width:42px;height:42px;display:grid;place-items:center;border-radius:10px;background:rgba(255,206,77,.1);border:1px solid rgba(255,206,77,.3)}
.mission .body{flex:1}
.mission .t{font-weight:700;margin-bottom:6px}

/* ---------- Forms ---------- */
.field{display:flex;flex-direction:column;gap:7px;margin-bottom:16px}
.field label{font-size:.78rem;font-weight:700;color:var(--text-dim);text-transform:uppercase;letter-spacing:.5px}
.field input,.field select,.field textarea{
  background:#0a1412;border:2px solid var(--panel-line);border-radius:10px;
  color:var(--text);padding:13px 14px;font-family:var(--sans);font-size:.95rem;transition:border-color .15s,box-shadow .15s;
}
.field input:focus,.field select:focus,.field textarea:focus{
  outline:none;border-color:var(--emerald);box-shadow:0 0 0 3px rgba(46,229,157,.15)
}
.field textarea{resize:vertical;min-height:90px}
.field .hint{font-size:.72rem;color:var(--text-mute)}
.field.err input,.field.err select{border-color:var(--red)}

.pickgrid{display:grid;gap:10px;grid-template-columns:repeat(auto-fit,minmax(120px,1fr))}
.pick{
  cursor:pointer;padding:14px;border-radius:12px;border:2px solid var(--panel-line);
  background:rgba(255,255,255,.02);text-align:center;transition:all .12s;font-weight:600;font-size:.9rem;
}
.pick:hover{border-color:var(--emerald)}
.pick.sel{border-color:var(--emerald);background:rgba(46,229,157,.1);box-shadow:0 0 18px rgba(46,229,157,.2)}
.pick .ic{font-size:1.6rem;display:block;margin-bottom:6px}

/* ---------- Tables ---------- */
.tbl-wrap{overflow-x:auto}
.tbl{width:100%;border-collapse:collapse;font-size:.88rem}
.tbl th{font-family:var(--pixel);font-size:.55rem;text-transform:uppercase;color:var(--text-mute);text-align:left;padding:12px 10px;border-bottom:2px solid var(--panel-line);white-space:nowrap}
.tbl td{padding:12px 10px;border-bottom:1px solid rgba(255,255,255,.05);white-space:nowrap}
.tbl tr:hover td{background:rgba(46,229,157,.04)}
.tag-win{color:var(--emerald);font-weight:700}
.tag-loss{color:var(--red);font-weight:700}

/* ---------- Wizard ---------- */
.steps{display:flex;gap:8px;margin-bottom:26px;flex-wrap:wrap}
.step-dot{flex:1;min-width:60px;height:8px;border-radius:8px;background:var(--panel-line)}
.step-dot.on{background:linear-gradient(90deg,var(--emerald-deep),var(--emerald));box-shadow:0 0 12px rgba(46,229,157,.5)}

/* ---------- Toast ---------- */
.toast-wrap{position:fixed;right:18px;bottom:18px;z-index:200;display:flex;flex-direction:column;gap:10px}
.toast{
  background:linear-gradient(180deg,var(--panel-2),var(--panel));border:2px solid var(--emerald);
  border-radius:12px;padding:14px 18px;min-width:240px;max-width:340px;box-shadow:var(--shadow);
  animation:slidein .3s ease;font-weight:600;font-size:.9rem;
}
.toast.gold{border-color:var(--gold)}
.toast.red{border-color:var(--red)}
.toast .pixel{font-size:.55rem;color:var(--text-dim);display:block;margin-bottom:5px}
@keyframes slidein{from{transform:translateX(40px);opacity:0}to{transform:translateX(0);opacity:1}}

/* ---------- Overlay ---------- */
.overlay{position:fixed;inset:0;z-index:300;display:none;place-items:center;background:rgba(0,0,0,.82);backdrop-filter:blur(4px);padding:20px}
.overlay.show{display:grid;animation:fadein .25s}
@keyframes fadein{from{opacity:0}to{opacity:1}}
.levelcard{text-align:center;padding:40px;animation:pop .4s cubic-bezier(.2,1.4,.4,1);max-width:480px}
@keyframes pop{from{transform:scale(.6);opacity:0}to{transform:scale(1);opacity:1}}
.modal{max-width:680px;width:100%;max-height:90vh;overflow-y:auto}

/* ---------- Footer ---------- */
.footer{border-top:2px solid var(--panel-line);padding:40px 0;color:var(--text-mute);font-size:.85rem}

/* ---------- Helpers ---------- */
.mt-8{margin-top:8px}.mt-16{margin-top:16px}.mt-24{margin-top:24px}.mt-40{margin-top:40px}
.mb-8{margin-bottom:8px}.mb-16{margin-bottom:16px}.mb-24{margin-bottom:24px}
.hidden{display:none!important}
.fade-up{animation:fadeup .6s both}
@keyframes fadeup{from{opacity:0;transform:translateY(18px)}to{opacity:1;transform:none}}
.big-num{font-family:var(--pixel);font-size:1.6rem}
.divider{height:2px;background:var(--panel-line);margin:24px 0;border-radius:2px}
.txt-c{text-align:center}
