/* Robotomaton RPG (pixel art UI) */
@import url('https://fonts.googleapis.com/css2?family=Press+Start+2P&family=Inter:wght@400;600&display=swap');

:root{
  --bg:#0b0a10;
  --panel:#151221;
  --panel2:#110f18;
  --text:#efe7d6;
  --muted:#b9b1a2;
  --gold:#d4af37;
  --blue:#6cb6ff;
  --red:#d15a5a;
  --green:#6ee7a8;
  --shadow:rgba(0,0,0,.55);
  --px: 2px;
}

*{box-sizing:border-box;}
html,body{height:100%;}
body{
  margin:0;
  background:
    radial-gradient(900px 600px at 30% 10%, rgba(212,175,55,.08), transparent 65%),
    radial-gradient(700px 520px at 80% 30%, rgba(108,182,255,.06), transparent 60%),
    var(--bg);
  color:var(--text);
}

/* pixel-friendly headings + readable body */
.pixel{font-family:'Press Start 2P', ui-monospace, monospace; letter-spacing:.08em;}
.body{font-family:Inter, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;}

a{color:var(--blue); text-decoration:none;}
a:hover{text-decoration:underline;}

.wrap{max-width:1040px;margin:18px auto 24px;padding:0 14px;}

/* Settings pill */
.rpgSettings{
  position:sticky;top:0;z-index:50;
  display:flex;gap:10px;align-items:center;flex-wrap:wrap;
  margin:10px 0 12px;
}
.rpgSettings input[type="range"]{width:120px;}
.rpgToggle{display:inline-flex;align-items:center;gap:8px;user-select:none;}
.rpgToggle span{font-family:Inter;font-size:12px;color:var(--muted);} 
.rpgToggle input{accent-color:var(--gold);}

/* Legacy layout (server still emits .top/.row/.card) */
.topbar,
.top{
  display:flex;gap:12px;align-items:baseline;justify-content:space-between;
  margin-bottom:10px;
}
.brand{display:flex;flex-direction:column;gap:6px;}

.title{font-family:'Press Start 2P', ui-monospace, monospace; letter-spacing:.10em; text-transform:uppercase; font-size:14px; line-height:1.25;}
.sub{font-family:Inter, system-ui; color:var(--muted); font-size:12px; letter-spacing:.02em;}

.nav{display:flex;gap:10px;flex-wrap:wrap;align-items:center;justify-content:flex-end;}
.nav a{font-family:'Press Start 2P', ui-monospace, monospace; font-size:10px; color:rgba(212,175,55,.9);}

/* pixel-panel style */
.panel,
.card{
  background:linear-gradient(180deg, rgba(255,255,255,.04), rgba(0,0,0,.08)), var(--panel);
  border:var(--px) solid rgba(212,175,55,.35);
  box-shadow: 0 20px 60px var(--shadow);
  padding:14px;
  border-radius:14px;
}
.panel + .panel{margin-top:12px;}

.grid,
.row{display:grid;grid-template-columns:repeat(12,1fr);gap:12px;}

/* Keep older .card grid behavior */
.card{grid-column:span 6;}
.card.wide{grid-column:span 12;}
@media (max-width:900px){.card{grid-column:span 12;}}

/* Stats list (server emits .stat) */
.stat,
.statRow{display:flex;justify-content:space-between;gap:12px;padding:10px 0;border-bottom:1px dashed rgba(212,175,55,.22);}
.stat:last-child,.statRow:last-child{border-bottom:0;}

.mono{font-family:ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;}

.pill{display:inline-flex;align-items:center;gap:8px;padding:6px 10px;border:1px solid rgba(212,175,55,.25);background:rgba(0,0,0,.20);border-radius:10px;font-family:Inter;font-size:12px;color:var(--muted);}

/* Form elements (server uses plain tags) */
label{display:block;font-family:'Press Start 2P';font-size:10px;color:rgba(212,175,55,.85);margin:10px 0 6px;}
input,select,textarea{
  width:100%;
  padding:10px 12px;
  border-radius:10px;
  border:1px solid rgba(212,175,55,.28);
  background:rgba(0,0,0,.30);
  color:var(--text);
  font-family:Inter;
}
textarea{min-height:90px;}

button{
  appearance:none;
  border:var(--px) solid rgba(212,175,55,.45);
  background:linear-gradient(180deg, rgba(212,175,55,.18), rgba(0,0,0,.08)), rgba(0,0,0,.25);
  color:var(--text);
  padding:10px 12px;
  cursor:pointer;
  font-family:'Press Start 2P';
  font-size:10px;
  text-transform:uppercase;
  letter-spacing:.08em;
  border-radius:12px;
}
button:hover{border-color:rgba(108,182,255,.55);} 
button:active{transform:translateY(1px);} 

.err{color:var(--red);font-family:Inter;font-size:13px;margin-top:8px;white-space:pre-wrap;}

/* XP bar */
.xpWrap{margin:10px 0 12px;}
.xpBar{height:12px;border:1px solid rgba(212,175,55,.35);background:rgba(0,0,0,.25);border-radius:3px;overflow:hidden;}
.xpFill{height:100%;width:0%;background:linear-gradient(90deg, rgba(108,182,255,.85), rgba(110,231,168,.85));transition:width 650ms ease;}

/* FX toast */
.fxFloat{
  position:fixed;left:50%;top:18px;transform:translateX(-50%);
  background:rgba(0,0,0,.72);
  border:1px solid rgba(212,175,55,.35);
  color:rgba(239,231,214,.95);
  padding:10px 12px;
  font-family:'Press Start 2P';
  font-size:10px;
  z-index:9999;
  opacity:0;
  transition: opacity 140ms ease, transform 550ms ease;
}
.fxFloat.on{opacity:1; transform:translateX(-50%) translateY(12px);}

/* Pixel burst particles */
.fxSpark{
  position:fixed;
  width:6px;height:6px;
  background:rgba(212,175,55,.95);
  box-shadow:0 0 0 2px rgba(0,0,0,.25);
  left:0;top:0;
  transform:translate(-50%,-50%);
  image-rendering:pixelated;
  z-index:9998;
  animation: spark 700ms cubic-bezier(.2,.8,.2,1) forwards;
}
@keyframes spark{
  from{opacity:1; transform:translate(-50%,-50%) translate(0,0) scale(1);}
  to{opacity:0; transform:translate(-50%,-50%) translate(var(--dx), var(--dy)) scale(.8);}
}

/* Reduced motion support: respects system prefs + JS override (body[data-motion='reduce']) */
@media (prefers-reduced-motion: reduce){
  .xpFill{transition:none;}
  .fxFloat{transition:none;}
  .fxSpark{animation:none;opacity:0;}
  button:active{transform:none;}
}
body[data-motion="reduce"] .xpFill{transition:none;}
body[data-motion="reduce"] .fxFloat{transition:none;}
body[data-motion="reduce"] .fxSpark{animation:none;opacity:0;}
body[data-motion="reduce"] button:active{transform:none;}
