:root{
  --bg0:#070a0f;
  --bg1:#0b0f14;
  --card: rgba(16, 22, 34, .72);
  --card2: rgba(9, 13, 20, .55);
  --text:#f2f7ff;
  --muted:rgba(242,247,255,.78);
  --muted2:rgba(242,247,255,.62);
  --border:rgba(255,255,255,.12);
  --border2:rgba(255,255,255,.18);
  --accent:#7bd389;
  --accent2:#6aa7ff;
  --danger:#ff6b6b;
  --shadow:0 18px 50px rgba(0,0,0,.45);
  --shadow2:0 10px 26px rgba(0,0,0,.35);
  --radius:20px;
  --radius2:16px;
  --mono: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
  --sans: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial;
}

*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  color:var(--text);
  font-family:var(--sans);
  background:
    radial-gradient(1200px 700px at 20% 10%, rgba(123,211,137,.20), transparent 60%),
    radial-gradient(1100px 700px at 85% 0%, rgba(106,167,255,.20), transparent 55%),
    radial-gradient(900px 700px at 45% 80%, rgba(255,255,255,.06), transparent 55%),
    linear-gradient(180deg, var(--bg0), var(--bg1));
}

.wrap{max-width:980px;margin:0 auto;padding:28px 18px 54px}

.top{
  display:flex;align-items:center;justify-content:space-between;gap:14px;margin-bottom:14px;
}
.brand{display:flex;gap:12px;align-items:center;min-width:0}
.logo{width:46px;height:46px;filter: drop-shadow(0 12px 24px rgba(0,0,0,.55));}

h1{margin:0;font-size:22px;letter-spacing:.2px}
.tag{margin:2px 0 0 0;color:var(--muted2);font-size:13px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

.actions{display:flex;gap:10px;flex-wrap:wrap;justify-content:flex-end}

.card{
  position:relative;
  background:
    linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.02));
  border:1px solid var(--border);
  border-radius:var(--radius);
  box-shadow:var(--shadow);
  padding:18px;
  margin:14px 0;
  overflow:hidden;
}

.card::before{
  content:"";
  position:absolute; inset:-2px;
  background: radial-gradient(600px 220px at 10% 0%, rgba(123,211,137,.12), transparent 60%),
              radial-gradient(520px 260px at 90% 0%, rgba(106,167,255,.12), transparent 62%);
  pointer-events:none;
}

.story{padding:20px}

.meta{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:12px;align-items:center;justify-content:space-between}

.pill{
  background:rgba(255,255,255,.05);
  border:1px solid rgba(255,255,255,.12);
  padding:8px 12px;
  border-radius:999px;
  color:var(--text);
  box-shadow:var(--shadow2);
}

.progress{display:flex;gap:10px;align-items:center;flex:1;min-width:240px;justify-content:flex-end}
.bar{width:min(340px, 46vw);height:10px;border-radius:999px;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.10);overflow:hidden}
.fill{height:100%;background:linear-gradient(90deg, rgba(123,211,137,.95), rgba(106,167,255,.92));box-shadow:0 0 18px rgba(123,211,137,.25)}
.barLabel{color:var(--muted2);font-size:12px;letter-spacing:.08em;text-transform:uppercase}

.scene{font-size:18px;line-height:1.65;padding:10px 2px 6px;max-width:74ch}
.scene p{margin:0 0 12px 0}

.choices{display:flex;flex-direction:column;gap:10px;margin-top:10px}

.btn{
  appearance:none;
  border:1px solid rgba(255,255,255,.14);
  background:rgba(123,211,137,.20);
  color:var(--text);
  padding:10px 14px;
  border-radius:12px;
  cursor:pointer;
  font-weight:700;
  letter-spacing:.2px;
  transition: transform .12s ease, border-color .12s ease, background .12s ease, box-shadow .12s ease;
  box-shadow: 0 12px 22px rgba(0,0,0,.22);
}
.btn.secondary{background:rgba(106,167,255,.20)}
.btn.ghost{background:rgba(255,255,255,.04)}
.btn.danger{border-color:rgba(255,107,107,.45);}
.btn:disabled{opacity:.45;cursor:not-allowed}
.btn:hover:not(:disabled){border-color:rgba(255,255,255,.26); transform: translateY(-1px)}
.btn:active:not(:disabled){transform: translateY(0px) scale(.99)}

.choiceBtn{
  text-align:left;
  padding:14px 14px;
  background:rgba(0,0,0,.22);
  border:1px solid rgba(255,255,255,.12);
  border-radius:16px;
  cursor:pointer;
  box-shadow: 0 16px 32px rgba(0,0,0,.22);
  transition: transform .12s ease, border-color .12s ease, background .12s ease;
}
.choiceBtn:hover{border-color:rgba(255,255,255,.28); transform: translateY(-1px)}
.choiceTitle{font-weight:800;letter-spacing:.15px}
.choiceHint{color:var(--muted2);font-size:13px;margin-top:4px;line-height:1.4}

.ending{margin-top:14px;padding-top:14px;border-top:1px dashed rgba(255,255,255,.16)}
.endingName{font-family:var(--mono);font-size:20px;margin:8px 0}

.collection h2{margin:0 0 8px 0}
.endingList{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;margin-top:12px}
.endingCard{border:1px solid rgba(255,255,255,.12);border-radius:16px;background:rgba(0,0,0,.22);padding:12px;min-height:88px}
.endingCard .n{font-family:var(--mono);font-weight:800}
.endingCard .d{color:var(--muted2);font-size:13px;margin-top:6px;line-height:1.45}
.endingCard.locked{opacity:.70}
.endingCard.locked .n{filter: blur(.8px)}
.endingCard.locked .d{filter: blur(1.2px)}
.endingCard .lock{display:inline-block;margin-left:8px;color:rgba(255,255,255,.55);font-size:12px}

.row{display:flex;gap:10px;align-items:center;flex-wrap:wrap}
.row.split{justify-content:space-between}

.muted{color:var(--muted2);font-size:13px;margin:6px 0 12px;line-height:1.5}

.foot{margin-top:18px;color:var(--muted2);font-size:13px}
.foot a{color:rgba(106,167,255,.92);text-decoration:none}
.foot a:hover{text-decoration:underline}

dialog::backdrop{background:rgba(0,0,0,.62)}
.dialog{min-width:min(840px, 94vw)}
.dialog canvas{width:100%;height:auto;border-radius:16px;border:1px solid rgba(255,255,255,.14);background:#0b0f14}
menu{display:flex;justify-content:flex-end;padding:0;margin:10px 0 0 0}

:focus-visible{outline:2px solid rgba(123,211,137,.75); outline-offset: 2px}

@media(max-width:720px){
  .endingList{grid-template-columns:1fr}
  .progress{justify-content:flex-start}
  .bar{width:100%}
}
