:root{
  --bg:#0b0f14; --bg2:#121822; --panel:#161d28; --edge:#243042;
  --fg:#c7d2e0; --dim:#7d8aa0; --accent:#4aa3ff; --good:#39d98a; --warn:#ffb454; --bad:#ff5d6c;
  --mono:"SF Mono",ui-monospace,Consolas,monospace;
}
*{box-sizing:border-box}
html,body{height:100%;margin:0}
body{background:var(--bg);color:var(--fg);font:14px/1.5 ui-sans-serif,system-ui,Segoe UI,sans-serif;
  display:flex;flex-direction:column}

#bar{display:flex;gap:6px;align-items:center;padding:8px 10px;background:var(--bg2);
  border-bottom:1px solid var(--edge);flex-wrap:wrap}
.brand{font-weight:700;color:var(--accent);margin-right:6px}
#bar input,#bar select{background:#0c1119;border:1px solid var(--edge);color:var(--fg);
  border-radius:6px;padding:5px 7px}
#bar button{background:#1d2735;border:1px solid var(--edge);color:var(--fg);border-radius:6px;
  padding:5px 11px;cursor:pointer}
#bar button:hover:not(:disabled){border-color:var(--accent)}
#bar button:disabled{opacity:.4;cursor:default}
#bar button.on{border-color:var(--accent);color:var(--accent);background:#16314c}
.state{margin-left:auto;font:12px var(--mono);color:var(--dim);padding:3px 9px;border-radius:10px;
  border:1px solid var(--edge)}
.state[data-s="connected"]{color:var(--good);border-color:#1d5a3f}
.state[data-s="closed"]{color:var(--bad)}

main{flex:1;display:flex;min-height:0}
#left{flex:1;display:flex;flex-direction:column;min-width:0;position:relative}

/* ---- layered compositing: map canvas behind, frosted text overlay in front ---- */
#mapcanvas{position:absolute;inset:0;width:100%;height:100%;z-index:0;display:block;
  background:radial-gradient(120% 120% at 50% 40%,#0e141d 0%,#0a0e13 100%);
  pointer-events:none;                       /* default: text catches clicks */
  filter:brightness(calc(.5 + .5*var(--focus,0)));transition:filter .25s}
#main{flex:1;overflow:auto;padding:12px 16px;white-space:pre-wrap;word-break:break-word;
  font:14px/1.55 var(--mono);position:relative;z-index:1;
  background:rgba(11,15,20,calc(.9 - .62*var(--focus,0)));
  backdrop-filter:blur(calc(3px*(1 - var(--focus,0))));
  opacity:calc(1 - .66*var(--focus,0));transition:opacity .25s,background .25s}
#promptline{position:relative;z-index:3}     /* command line always live */
body.map-forward #main{pointer-events:none}   /* clicks fall through to the map */
body.map-forward #mapcanvas{pointer-events:auto;cursor:grab}

/* focus slider in the toolbar */
#focusctl{display:flex;align-items:center;gap:5px;font:11px var(--mono);color:var(--dim)}
#focusctl input[type=range]{width:84px;accent-color:var(--accent)}
.window{background:var(--bg)}
#promptline{display:flex;align-items:center;gap:8px;padding:7px 12px;background:var(--bg2);
  border-top:1px solid var(--edge)}
#prompt{color:var(--good);font:14px var(--mono)}
#cmd{flex:1;background:#0c1119;border:1px solid var(--edge);color:var(--fg);border-radius:6px;
  padding:7px 10px;font:14px var(--mono)}
#cmd:focus{outline:none;border-color:var(--accent)}
#rtbar{min-width:54px;height:18px;border-radius:4px;font:11px var(--mono);color:#0b0f14;
  display:flex;align-items:center;justify-content:center;background:#27313f;color:var(--dim)}
#rtbar.active{background:linear-gradient(90deg,var(--bad) var(--rt,0%),#27313f var(--rt,0%));
  color:#fff;font-weight:700}

/* ---- text presets / styles (SF) ---- */
.bold,.preset-monsterbold{color:#ffd479;font-weight:600}
.echo{color:#5f9bff}                          /* echoed player command */
.sys{color:var(--dim);font-style:italic}
.style-roomName,.preset-roomName{color:#7fd3ff;font-weight:700}
.preset-roomDesc{color:#aeb9cc}
.preset-speech{color:#9fe6a0}
.preset-whisper{color:#9fd6e6}
.preset-thought{color:#caa6ff}
.style-prompt{color:var(--good)}
.style-spell,.preset-spell{color:#ff9ad2}
.link{color:var(--accent);cursor:pointer;text-decoration:none;border-bottom:1px dotted #2f5d8a}
.link:hover{background:#16314c}
.selectedLink{color:#ffd479}
.mono{font-family:var(--mono)}

/* ---- side panel ---- */
#side{width:264px;background:var(--bg2);border-left:1px solid var(--edge);overflow:auto;
  display:flex;flex-direction:column;gap:10px;padding:10px}
.panel{background:var(--panel);border:1px solid var(--edge);border-radius:8px;padding:9px 10px}
.phdr{font:11px var(--mono);letter-spacing:.08em;text-transform:uppercase;color:var(--dim)}
.vital{margin:5px 0}
.vital label{font:11px var(--mono);color:var(--dim)}
.track{position:relative;height:16px;background:#0c1119;border-radius:8px;overflow:hidden;margin-top:2px}
.track span{position:absolute;inset:0 auto 0 0;width:0;transition:width .25s}
.track b{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;
  font:11px var(--mono);color:#e9eef6}
.vital[data-id=health] .track span{background:linear-gradient(90deg,#7a1f29,var(--bad))}
.vital[data-id=mana]    .track span{background:linear-gradient(90deg,#1f3a7a,var(--accent))}
.vital[data-id=stamina] .track span{background:linear-gradient(90deg,#1f6e4a,var(--good))}
.vital[data-id=spirit]  .track span{background:linear-gradient(90deg,#6a5a1f,var(--warn))}
.vital[data-id=concentration] .track span{background:linear-gradient(90deg,#4a1f6e,#a06ee0)}
.hands div{font:13px var(--mono);margin:3px 0}
.hands label{display:inline-block;width:42px;color:var(--dim)}

.compass{display:grid;grid-template-columns:repeat(4,1fr);gap:4px;margin-top:6px}
.compass i{height:22px;border-radius:4px;background:#0c1119;border:1px solid var(--edge);
  font:10px var(--mono);font-style:normal;color:#3a455a;display:flex;align-items:center;justify-content:center}
.compass i::after{content:attr(data-d)}
.compass i.on{background:#16314c;color:var(--accent);border-color:#2f5d8a}

.indicators{display:flex;flex-wrap:wrap;gap:4px;margin-top:6px}
.ind{font:10px var(--mono);padding:2px 6px;border-radius:4px;background:#0c1119;color:#3a455a;border:1px solid var(--edge)}
.ind.on{background:#3a1f24;color:var(--bad);border-color:#7a1f29}

/* ---- window list (sidebar chips to focus/restore floating windows) ---- */
.winlist{display:flex;flex-wrap:wrap;gap:4px;margin-top:6px}
.winchip{background:#0c1119;border:1px solid var(--edge);color:var(--fg);border-radius:4px;
  font:11px var(--mono);padding:3px 7px;cursor:pointer}
.winchip:hover{border-color:var(--accent);color:var(--accent)}
.winchip.on{background:#16314c;color:var(--accent);border-color:#2f5d8a}
.winlist .dim{color:var(--dim);font:11px var(--mono)}

/* ---- floating / pop-out stream windows ---- */
.floatwin{position:fixed;width:340px;height:220px;background:var(--panel);border:1px solid var(--edge);
  border-radius:8px;box-shadow:0 10px 34px rgba(0,0,0,.55);display:flex;flex-direction:column;
  min-width:200px;min-height:90px;overflow:hidden;resize:both}
.floatwin>header{display:flex;align-items:center;justify-content:space-between;cursor:move;
  background:#1d2735;border-bottom:1px solid var(--edge);padding:4px 5px 4px 9px}
.floatwin>header .t{font:12px var(--mono);font-weight:700;color:var(--accent)}
.floatwin>header .btns button{background:none;border:0;color:var(--dim);cursor:pointer;
  font:13px var(--mono);line-height:1;padding:1px 5px;border-radius:4px}
.floatwin>header .btns button:hover{color:var(--fg);background:#0c1119}
.floatwin .fbody{flex:1;overflow:auto;padding:8px 10px;white-space:pre-wrap;word-break:break-word;
  font:13px/1.5 var(--mono);background:var(--bg)}
.floatwin.min{height:auto!important;resize:none}
.floatwin.min .fbody{display:none}
.floatwin .slot{display:block;margin:0 0 4px}
.floatwin .slot:empty{display:none}
.floatwin.popped .fbody{opacity:.35}
.floatwin.popped>header .t::after{content:" · popped out";color:var(--dim);font-weight:400}

/* ---- injuries dialogs (self window + empath patient windows) ---- */
.injbody{display:flex;flex-direction:column;gap:8px;white-space:normal}
.injparts{display:grid;grid-template-columns:1fr 1fr;gap:3px 10px}
.injparts .part{font:12px var(--mono);color:#3a455a}
.injparts .part.hurt{color:var(--bad);font-weight:700}
.injparts .part.takeable{cursor:pointer;text-decoration:underline dotted}
.injparts .part.takeable:hover{color:#ff9a8e}
.injhint{font:10px var(--mono);color:var(--dim)}
.injhealth .track span{background:linear-gradient(90deg,#7a1f29,var(--bad))}
.injctl{display:flex;flex-wrap:wrap;gap:4px}
.injbtn{background:#0c1119;border:1px solid var(--edge);color:var(--fg);border-radius:4px;
  font:11px var(--mono);padding:3px 7px;cursor:pointer}
.injbtn:hover{border-color:var(--accent);color:var(--accent)}
.injbtn.radio{color:var(--dim)}
.injbtn.radio.on{background:#16314c;color:var(--accent);border-color:#2f5d8a}

/* main game window while detached into its own browser window */
#main.popped{opacity:.3;position:relative}
#main.popped::after{content:"game text detached — click Reattach to bring it back";
  position:sticky;top:0;display:block;color:var(--dim);font:12px var(--mono);
  background:var(--bg2);border:1px dashed var(--edge);border-radius:6px;padding:6px 9px;margin-bottom:8px}

/* a popped-out window loads /style.css into its own document */
body.popout{margin:0;background:var(--bg)}
body.popout .fbody{height:100vh;overflow:auto;padding:10px;white-space:pre-wrap;word-break:break-word;
  font:13px/1.55 var(--mono);color:var(--fg)}

/* ============================================================================
   account page (/accounts) — login/register + Simu-account link + roster.
   Reuses the toolbar (#bar/.brand/.state) and .panel card look from the client.
   ============================================================================ */
body.account{display:block;overflow:auto}
.account .acct-sub{font:12px var(--mono);color:var(--dim);letter-spacing:.06em;
  text-transform:uppercase;margin-right:auto}
.account .acct-who{display:flex;align-items:center;gap:10px}
.account .acct-name{font:13px var(--mono);color:var(--fg)}
.account #logout{background:#1d2735;border:1px solid var(--edge);color:var(--fg);border-radius:6px;
  padding:5px 11px;cursor:pointer}
.account #logout:hover{border-color:var(--accent)}

#acct-main{display:flex;flex-direction:column;align-items:center;gap:16px;
  padding:26px 16px 40px;max-width:760px;margin:0 auto;width:100%}
/* The `hidden` attribute must win over the id/display rules below (e.g. #dash{display:flex}),
   otherwise the logged-in dashboard shows while signed out. */
[hidden]{display:none!important}
#dash{display:flex;flex-direction:column;gap:16px;width:100%}

.acct-card{width:100%;padding:18px 20px}
.acct-card h2{margin:0 0 6px;font:600 16px/1.3 ui-sans-serif,system-ui,sans-serif;color:var(--fg)}
.acct-help{margin:0 0 14px;color:var(--dim);font-size:13px}
.acct-help.dim{color:var(--dim)}
.acct-card code{font:12px var(--mono);background:#0c1119;border:1px solid var(--edge);
  border-radius:4px;padding:1px 5px;color:var(--accent)}

.acct-card form label{display:block;margin:10px 0;font:11px var(--mono);letter-spacing:.06em;
  text-transform:uppercase;color:var(--dim)}
.acct-card form input{display:block;width:100%;margin-top:5px;background:#0c1119;
  border:1px solid var(--edge);color:var(--fg);border-radius:6px;padding:9px 11px;
  font:14px var(--mono);text-transform:none}
.acct-card form input:focus{outline:none;border-color:var(--accent)}
.acct-card form input:disabled{opacity:.5}

.acct-actions{display:flex;gap:8px;margin-top:14px;flex-wrap:wrap}
.acct-card button{background:#1d2735;border:1px solid var(--edge);color:var(--fg);border-radius:6px;
  padding:8px 16px;cursor:pointer;font-size:13px}
.acct-card button:hover:not(:disabled){border-color:var(--accent)}
.acct-card button:disabled{opacity:.45;cursor:default}
.acct-card button.primary{background:#16314c;border-color:#2f5d8a;color:var(--accent);font-weight:600}
.acct-card button.primary:hover:not(:disabled){border-color:var(--accent);background:#1b3a5c}

.acct-err,.acct-ok{margin:12px 0 0;font:12px var(--mono);padding:8px 11px;border-radius:6px}
.acct-err{color:var(--bad);background:#2a161a;border:1px solid #7a1f29}
.acct-ok{color:var(--good);background:#13261d;border:1px solid #1d5a3f}

/* character sharing (the inline Share panel under an owned character) */
.share-panel{margin:0 0 10px;padding:10px 12px;background:#0c1119;border:1px solid var(--edge);
  border-radius:6px}
.share-panel select{background:#0c1119;border:1px solid var(--edge);color:var(--fg);
  border-radius:6px;padding:6px 8px;font-size:13px}
.share-panel .grants{margin-top:10px}
.grant-row{display:flex;align-items:center;justify-content:space-between;gap:8px;
  font:12px var(--mono);color:var(--dim);padding:4px 0}

/* Sign in with Google (shown only when the server enables it) */
.acct-google{margin-top:16px}
.acct-or{display:flex;align-items:center;gap:10px;color:var(--dim);
  font:11px var(--mono);letter-spacing:.08em;text-transform:uppercase;margin:4px 0 14px}
.acct-or::before,.acct-or::after{content:"";flex:1;height:1px;background:var(--edge)}
.g-btn-host{display:flex;justify-content:center;min-height:40px}

/* roster */
.acct-roster-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}
.acct-roster-head h2{margin:0}
#refresh{background:#1d2735;border:1px solid var(--edge);color:var(--dim);border-radius:6px;
  padding:5px 11px;cursor:pointer;font:12px var(--mono)}
#refresh:hover{border-color:var(--accent);color:var(--accent)}

.roster{display:flex;flex-direction:column;gap:8px}
.char{display:flex;align-items:center;gap:12px;background:#0c1119;border:1px solid var(--edge);
  border-radius:8px;padding:11px 14px}
.char:hover{border-color:#2f5d8a}
.char-info{display:flex;flex-direction:column;gap:2px;min-width:0;flex:1}
.char-name{font:600 14px/1.2 ui-sans-serif,system-ui,sans-serif;color:#7fd3ff}
.char-meta{font:12px var(--mono);color:var(--dim);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.char-tag{align-self:flex-start;margin-top:3px;font:10px var(--mono);text-transform:uppercase;
  letter-spacing:.06em;color:var(--warn);background:#2a2113;border:1px solid #6a5a1f;
  border-radius:4px;padding:1px 6px}
.char-go{flex:none}

/* transcript review overlay (account page Review button) */
#transcript-overlay{position:fixed;inset:0;background:rgba(4,7,11,.75);z-index:50;
  display:flex;align-items:center;justify-content:center;padding:24px}
.transcript-box{background:var(--panel);border:1px solid var(--edge);border-radius:8px;
  width:min(900px,95vw);height:min(85vh,900px);display:flex;flex-direction:column}
.transcript-head{display:flex;align-items:center;justify-content:space-between;gap:8px;
  padding:10px 14px;border-bottom:1px solid var(--edge);color:var(--dim);font-size:13px}
.transcript-body{flex:1;overflow:auto;padding:10px 14px;
  font:12.5px/1.45 ui-monospace,SFMono-Regular,Menlo,monospace;white-space:pre-wrap}
.tl-text{color:var(--fg)}
.tl-cmd{color:var(--accent);margin-top:2px}
.tl-ts{color:var(--dim)}
