:root {
  --bg: #0f021a;
  --bg-soft: #1a0827;
  --bg-panel: #1e0b30;
  --border-soft: rgba(255, 255, 255, 0.16);
  --accent: #ff4da6;
  --accent-soft: #ff8bc4;
  --accent-alt: #00d9ff;
  --text: #ffffff;
  --muted: #c6b8d8;
  --shadow-soft: 0 18px 50px rgba(0, 0, 0, 0.7);
  --radius: 16px;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0;min-height:100%}
body{
  font-family:system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
  background:
    radial-gradient(circle at 0% 0%,rgba(255,77,166,.3),transparent 60%),
    radial-gradient(circle at 100% 100%,rgba(0,217,255,.25),transparent 50%),
    linear-gradient(135deg,#050008,#1c0432 45%,#36115d);
  color:var(--text);
}
#game{max-width:1200px;margin:1.5rem auto 2.5rem;padding:0 1rem}
.game-header{display:flex;flex-direction:column;gap:1rem;margin-bottom:1.25rem}
.brand{display:flex;align-items:center;gap:.75rem}
.logo{
  width:52px;height:52px;border-radius:14px;
  background:radial-gradient(circle at 0% 0%,#fff,transparent 50%),linear-gradient(135deg,var(--accent),var(--accent-soft));
  box-shadow:0 8px 26px rgba(0,0,0,.6);
  display:flex;align-items:center;justify-content:center;font-weight:800;color:#2b0220;
}
h1{margin:0;font-size:clamp(2rem,5vw,2.8rem);letter-spacing:.04em}
.blink{animation:blink 1.2s steps(2,end) infinite}
@keyframes blink{50%{opacity:0}}
.subtitle{margin:.15rem 0 0;color:var(--muted);font-size:.96rem}
.status-bar{display:flex;flex-wrap:wrap;gap:.75rem;align-items:center}
.status-group{display:flex;flex-direction:column;gap:.25rem;min-width:160px}
.status-group .label{font-size:.75rem;text-transform:uppercase;letter-spacing:.1em;color:var(--muted)}
.progress{width:100%;height:9px;border-radius:999px;background:rgba(255,255,255,.07);overflow:hidden}
.progress-fill{
  width:0%;height:100%;border-radius:999px;
  background:linear-gradient(90deg,var(--accent),var(--accent-alt));
  box-shadow:0 0 8px rgba(255,77,166,.9);transition:width .25s ease-out;
}
.pill{align-self:flex-start;padding:.25rem .7rem;border-radius:999px;border:1px solid var(--border-soft);background:rgba(255,255,255,.04);font-size:.8rem}

.switch{display:inline-flex;align-items:center;gap:.4rem;cursor:pointer}
.switch input{display:none}
.switch .slider{
  width:40px;height:22px;border-radius:999px;background:rgba(255,255,255,.2);
  position:relative;transition:background .2s ease;
}
.switch .slider::after{
  content:"";position:absolute;width:18px;height:18px;border-radius:50%;background:#fff;
  top:2px;left:2px;transition:transform .2s ease;box-shadow:0 4px 10px rgba(0,0,0,.4);
}
.switch input:checked + .slider{background:linear-gradient(90deg,var(--accent),var(--accent-alt))}
.switch input:checked + .slider::after{transform:translateX(18px)}
.switch-label{font-size:.85rem;color:var(--muted)}

.layout{display:grid;grid-template-columns:minmax(0,7fr) minmax(0,5fr);gap:1rem}
.panel{
  background:radial-gradient(circle at 0% 0%,rgba(255,255,255,.06),transparent 55%),
             radial-gradient(circle at 100% 100%,rgba(0,217,255,.12),transparent 55%),
             var(--bg-panel);
  border-radius:var(--radius);
  border:1px solid var(--border-soft);
  box-shadow:var(--shadow-soft);
  padding:1.1rem 1.15rem;
}

.scene-header{display:flex;justify-content:space-between;gap:.75rem;align-items:baseline;margin-bottom:.35rem}
.scene-header h2{margin:0;font-size:1.2rem}
.scene-tags{display:flex;gap:.3rem;flex-wrap:wrap}
.scene-tag{padding:.15rem .6rem;border-radius:999px;border:1px solid rgba(255,255,255,.16);font-size:.75rem}
.scene-tag.subtle{opacity:.8;border-style:dashed}
.scene-description{margin:0 0 .7rem;color:var(--muted);font-size:.92rem}

.scene-illustration{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(150px,1fr));
  gap:.7rem;margin-bottom:.75rem;
}

.hotspot{
  position:relative;border-radius:14px;padding:.65rem .7rem .6rem;
  background:rgba(10,0,30,.7);border:1px solid rgba(255,255,255,.15);
  cursor:pointer;overflow:hidden;
  transition:transform .16s ease,box-shadow .16s ease,border-color .16s ease;
}
.hotspot:hover{
  transform:translateY(-2px);
  box-shadow:0 10px 22px rgba(0,0,0,.6);
  border-color:rgba(255,77,166,.6);
}
.hotspot-title{font-size:.9rem;font-weight:600;margin-bottom:.25rem}
.hotspot-desc{font-size:.78rem;color:var(--muted)}
.hotspot-tag{position:absolute;bottom:.4rem;right:.5rem;font-size:.7rem;opacity:.75}

.scene-actions{
  border-top:1px solid rgba(255,255,255,.14);
  padding-top:.6rem;margin-top:.25rem;
  display:flex;flex-direction:column;gap:.4rem;
}
.scene-actions label{font-size:.85rem;color:var(--muted)}
.scene-actions input[type=text],
.scene-actions input[type=password],
.scene-actions input[type=number]{
  width:100%;padding:.4rem .55rem;border-radius:10px;
  border:1px solid rgba(255,255,255,.25);
  background:rgba(3,0,10,.9);color:var(--text);font-size:.9rem;
}
.scene-actions .input-row{display:flex;gap:.45rem}

.btn-primary,.btn-ghost,.mini-btn{
  border-radius:999px;font-size:.85rem;padding:.35rem .9rem;border:none;cursor:pointer;
  display:inline-flex;align-items:center;gap:.25rem;
}
.btn-primary{
  background:linear-gradient(90deg,var(--accent),var(--accent-alt));
  color:#210015;font-weight:600;box-shadow:0 10px 22px rgba(0,0,0,.6);
}
.btn-primary:hover{filter:brightness(1.08)}
.btn-ghost{
  background:transparent;color:var(--muted);
  border:1px solid rgba(255,255,255,.22);
}
.btn-ghost:hover{border-color:var(--accent-soft);color:var(--accent-soft)}
.mini-btn{
  padding:.2rem .5rem;font-size:.78rem;
  background:rgba(255,255,255,.08);color:var(--text);
}

.sidebar{display:flex;flex-direction:column;gap:.6rem}
.sidebar-block{
  border-radius:12px;padding:.55rem .6rem .55rem;
  background:radial-gradient(circle at 0 0,rgba(255,255,255,.04),transparent 50%),
             rgba(5,0,10,.9);
  border:1px solid rgba(255,255,255,.12);
}
.sidebar-block h3{margin:0 0 .4rem;font-size:.95rem}

.inventory,.tasks{
  list-style:none;padding-left:1rem;margin:0;
  max-height:120px;overflow-y:auto;font-size:.84rem;
}
.inventory li::marker{color:var(--accent-soft)}
.tasks li::marker{color:var(--accent-alt)}
.tasks li.done{text-decoration:line-through;opacity:.7}
.tasks li span.tag{font-size:.7rem;opacity:.8;margin-left:.4rem}

.log-block{flex:1;display:flex;flex-direction:column}
.log-header{display:flex;justify-content:space-between;align-items:center}
.log{
  margin-top:.3rem;border-radius:10px;background:rgba(0,0,0,.65);
  padding:.35rem .45rem;font-size:.78rem;max-height:190px;overflow-y:auto;
}
.log-entry{margin-bottom:.15rem;color:var(--muted)}
.log-entry strong{color:var(--accent-soft)}

.game-footer{
  margin-top:.7rem;display:flex;justify-content:space-between;
  gap:.75rem;align-items:center;font-size:.84rem;color:var(--muted);
}
.game-footer .hint{flex:1;text-align:center}

.overlay{
  position:fixed;inset:0;background:rgba(3,0,10,.75);
  display:flex;align-items:center;justify-content:center;z-index:20;
}
.overlay.hidden{display:none}
.modal{
  max-width:520px;width:calc(100% - 2rem);
  background:radial-gradient(circle at 0% 0%,rgba(255,255,255,.08),transparent 50%),
             #1a0828;
  border-radius:var(--radius);border:1px solid var(--border-soft);
  box-shadow:var(--shadow-soft);padding:.75rem .9rem .85rem;
}
.modal-header{display:flex;justify-content:space-between;align-items:center}
.modal-header h2{margin:0;font-size:1.05rem}
.modal-close{border:none;background:transparent;color:var(--muted);font-size:1.2rem;cursor:pointer}
.modal-body{margin-top:.5rem;font-size:.9rem;color:var(--muted)}
.modal-body p{margin-top:.35rem}

.fx-canvas{position:fixed;inset:0;pointer-events:none;z-index:5}

body.chill{
  background:radial-gradient(circle at 20% 0%,rgba(255,255,255,.18),transparent 60%),
             linear-gradient(135deg,#0b101e,#101a32 45%,#14293f);
}
body.chill .panel{box-shadow:0 10px 30px rgba(0,0,0,.6)}

@media(max-width:880px){
  .layout{grid-template-columns:minmax(0,1fr)}
}
@media(max-width:600px){
  .brand{flex-direction:row;align-items:center}
}
