/* Core layout and component styling */
:root{
  --bg:#f7f7fb;
  --card:#ffffff;
  --text:#111827;
  --muted:#6b7280;
  --border:#e5e7eb;
  --accent:#111827;
  --radius:16px;
}

/* Dark mode styles */
:root.dark-mode{
  --bg:#0f172a;--card:#1e293b;--text:#f1f5f9;--muted:#94a3b8;--border:#334155;--accent:#60a5fa;
}
*{box-sizing:border-box}
html,body{height:100%}
body{margin:0;background:var(--bg);color:var(--text);font:16px/1.6 system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,"Apple Color Emoji","Segoe UI Emoji"}
.container{max-width:1100px;margin:auto;padding:24px}
h1{margin:0 0 4px;font-size:26px;letter-spacing:.2px}
.sub{color:var(--muted);margin:0 0 16px}
.toolbar{display:flex;flex-wrap:wrap;gap:12px;align-items:center;justify-content:space-between;margin:12px 0 16px}
.left, .right{display:flex;gap:12px;align-items:center}
/* Make the search field grow on wide screens */
#search-input{flex:1;min-width:220px}
select,input,button{border:1px solid var(--border);background:var(--card);color:var(--text);border-radius:12px;padding:8px 12px}
button{background:var(--accent);color:#fff;border-color:var(--accent);cursor:pointer}
button:disabled{opacity:.7;cursor:not-allowed}
.theme-toggle{background:transparent;border:none;color:var(--text);font-size:20px;padding:8px;cursor:pointer;transition:all 0.3s ease}
.theme-toggle:hover{opacity:0.7}
.muted{color:var(--muted);font-size:14px}

.grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}
@media (max-width:800px){.grid{grid-template-columns:1fr}}

.stat{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:16px}
.stat .title{font-size:14px;color:var(--muted)}
.stat .value{font-size:28px;font-weight:700;margin-top:4px}

.card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:16px}
.card .head{display:flex;justify-content:space-between;gap:10px;align-items:flex-start}
.badges{display:flex;gap:8px;align-items:center}
.badge{background:#f3f4f6;border:1px solid var(--border);padding:4px 10px;border-radius:999px;font-size:14px}
.badge.status-notstarted{background:#ecfccb;border-color:#bef264;color:#365314}
.badge.status-starting,.badge.status-started,.badge.status-ended,.badge.status-destroyed,.badge.status-unknown{background:#fef2f2;border-color:#fecaca;color:#991b1b}

/* Dark mode specific badge colors */
:root.dark-mode .badge{background:#374151;border-color:#334155;color:#e5e7eb}
:root.dark-mode .badge.status-notstarted{background:#064e3b;border-color:#10b981;color:#d1fae5}
:root.dark-mode .badge.status-starting,:root.dark-mode .badge.status-started,:root.dark-mode .badge.status-ended,:root.dark-mode .badge.status-destroyed,:root.dark-mode .badge.status-unknown{background:#422006;border-color:#dc2626;color:#fca5a5}
.row{display:flex;justify-content:space-between;gap:10px;padding:6px 0;border-bottom:1px dashed var(--border)}
.row:last-child{border-bottom:none}
.row-inline{justify-content:flex-start;flex-wrap:wrap;gap:16px;}
.inlineStat{display:flex;flex-direction:column;gap:4px;flex:1 1 120px;}
.inlineLabel{color:var(--muted);font-size:13px;}
.gameIdValue{display:flex;align-items:center;gap:8px;flex-wrap:wrap;justify-content:flex-end;text-align:right}
.joinBtn{border-radius:10px;padding:6px 12px;font-size:13px;}
.label{min-width:120px;color:var(--muted);font-size:14px}
code.inline{background:#f3f4f6;border:1px solid var(--border);border-radius:8px;padding:2px 6px;font-family:ui-monospace,SFMono-Regular,Menlo,monospace;color:var(--text)}
.copyBtn{border-radius:8px;padding:4px 8px;font-size:12px}
details{margin-top:8px}
summary{font-weight:600;cursor:pointer}

.error{background:#fef2f2;border:1px solid #fecaca;color:#991b1b;border-radius:12px;padding:12px}
.empty{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:20px;color:var(--muted)}

/* Dark mode specific styles */
:root.dark-mode code.inline{background:#0b1220;border-color:#334155;color:#e5e7eb}
:root.dark-mode .error{background:#1e293b;border-color:#dc2626;color:#fca5a5}


/* Responsive enhancements */
@media (max-width:800px){
  .container{padding:16px}
  h1{font-size:22px}
  .toolbar{flex-direction:column;align-items:stretch;gap:10px}
  .left,.right{width:100%;justify-content:space-between;flex-wrap:wrap}
  #search-input{flex:1;min-width:0;width:100%}
  .card .head{display:grid;grid-template-columns:1fr auto;align-items:start;gap:8px}
  .badge{margin-top:0}
  .badges{justify-self:end}
  .row-inline{display:grid;grid-template-columns:1fr 1fr;gap:12px}
  .row{display:grid;grid-template-columns:minmax(92px,36%) 1fr;gap:8px;align-items:center}
  .label{min-width:0;margin:0}
  code.inline{white-space:normal;word-break:break-word;overflow-wrap:anywhere}
}

@media (max-width:480px){
  .sub{font-size:14px}
  select,input,button{width:100%}
  .gameIdValue{gap:6px}
  .joinBtn,.copyBtn{width:100%}
  /* hide join button on small screens */
  .joinBtn{display:none}
  .row{grid-template-columns:minmax(88px,40%) 1fr}
}
