:root{
  --bg:#0f172a;
  --bg2:#1e293b;
  --card:#111827;
  --cardSoft:#0b1220;
  --muted:#94a3b8;
  --text:#f8fafc;
  --accent:#f97316;
  --accentDark:#ea580c;
  --blue:#2563eb;
  --line:#243044;
  --lineSoft:#334155;
  --ok:#22c55e;
  --shadow:0 18px 40px rgba(0,0,0,.26);
}
*{box-sizing:border-box;-webkit-tap-highlight-color:transparent}
html{font-size:16px}
body{
  margin:0;
  font-family:system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  background:linear-gradient(165deg,var(--bg),var(--bg2));
  color:var(--text);
  min-height:100vh;
}
header{
  display:flex;
  justify-content:space-between;
  align-items:flex-start;
  gap:12px;
  padding:18px 16px 10px;
}
h1,h2,h3,p{margin-top:0}
h1{font-size:1.9rem;line-height:1.05;margin-bottom:6px}
h2{font-size:1.35rem;line-height:1.15;margin-bottom:10px}
h3{font-size:1.12rem;margin-bottom:10px}
.subhead{margin:0;color:var(--muted);font-size:.98rem;line-height:1.35}
.eyebrow{margin:0 0 4px;text-transform:uppercase;letter-spacing:.12em;color:var(--accent);font-size:.72rem;font-weight:800}
main{width:min(760px,100%);margin:auto;padding:0 12px 38px}
.card{
  background:rgba(17,24,39,.92);
  border:1px solid var(--line);
  border-radius:24px;
  padding:18px;
  margin:12px 0;
  box-shadow:var(--shadow);
}
.compactCard{padding:16px}
.hero{background:linear-gradient(135deg,rgba(249,115,22,.16),rgba(17,24,39,.96))}
.grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}
.searchRow{display:grid;grid-template-columns:1fr auto;gap:10px;align-items:stretch}
input,select,button,textarea{
  font:inherit;
}
input,select,textarea{
  width:100%;
  background:var(--cardSoft);
  border:1px solid var(--lineSoft);
  color:var(--text);
  border-radius:16px;
  padding:15px 16px;
  margin:6px 0;
  font-size:1rem;
  min-height:54px;
}
button{
  background:var(--accent);
  color:white;
  border:0;
  border-radius:16px;
  padding:15px 16px;
  min-height:54px;
  font-weight:800;
  cursor:pointer;
  box-shadow:0 6px 18px rgba(249,115,22,.22);
}
button.secondary{background:var(--blue);box-shadow:0 6px 18px rgba(37,99,235,.2)}
button.ghost{background:transparent;border:1px solid #475569;color:var(--text);box-shadow:none}
button:disabled{opacity:.5}
.hidden{display:none!important}
.muted{color:var(--muted)}
.helperText{font-size:.96rem;line-height:1.4;margin-bottom:12px}
.results{display:grid;gap:10px;margin-top:12px}
.result{
  padding:14px;
  border:1px solid var(--line);
  border-radius:18px;
  background:var(--cardSoft);
  display:grid;
  grid-template-columns:1fr auto;
  gap:10px;
  align-items:center;
}
.resultInfo b{font-size:1.02rem}
.teamHead{display:flex;justify-content:space-between;gap:12px;align-items:flex-start}
.statusBox{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;margin:14px 0 18px}
.statusBox div{background:var(--cardSoft);border:1px solid var(--line);border-radius:18px;padding:15px}
.statusBox span{display:block;color:var(--muted);font-size:.82rem;margin-bottom:6px}
.statusBox strong{font-size:1.1rem;line-height:1.25}
.runners{display:grid;gap:10px}
.runnerRow{
  display:grid;
  gap:10px;
  padding:12px;
  border:1px solid var(--line);
  border-radius:18px;
  background:var(--cardSoft);
}
.runnerTop input{margin:0;font-weight:700;font-size:1.02rem}
.runnerBottom{display:flex;justify-content:space-between;align-items:center;gap:10px;flex-wrap:wrap}
.runnerBottom button{flex:1 1 180px}
.pill{display:inline-block;background:#101a2d;border:1px solid var(--lineSoft);border-radius:999px;padding:7px 11px;color:var(--muted);font-size:.86rem}
.runnerRow.selectedRunner{outline:2px solid rgba(244,116,40,.85);background:rgba(244,116,40,.12)}
.runnerRow.selectedRunner .pill{color:#ffd7be;border-color:rgba(244,116,40,.4)}
.teamActions{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin:14px 0 20px}
.manual{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}
.manual button{background:#334155;box-shadow:none}
.passages{display:grid;gap:8px}
.passageRow,.nightRow{
  display:block;
  padding:12px;
  border:1px solid var(--line);
  border-radius:16px;
  background:var(--cardSoft);
}
.staffTools{display:grid;gap:14px}
.staffTools > div{padding:14px;border:1px solid var(--line);border-radius:18px;background:var(--cardSoft)}
.staffTools textarea{min-height:88px;width:100%;border-radius:14px;background:#0b1220;color:white;border:1px solid #334155;padding:12px}
.staffTools button{width:100%;margin-top:8px}
.staffTools .secondary{margin-top:8px}
@media (max-width:760px){
  html{font-size:17px}
  header{padding:16px 14px 10px}
  main{padding:0 10px 26px}
  .grid,.singleMobile{grid-template-columns:1fr}
  .searchRow,.result,.teamHead,.teamActions,.manual,.statusBox{grid-template-columns:1fr}
  .searchRow button,.result button,.teamActions button,.manual button{width:100%}
  .result{display:grid}
  .teamHead{display:grid}
  .statusBox strong{font-size:1.02rem}
}


.headerActions{display:flex;gap:10px;align-items:center;flex-wrap:wrap}
.navBtn,.ghostLink{display:inline-flex;align-items:center;justify-content:center;min-height:48px;padding:12px 16px;border-radius:16px;text-decoration:none;font-weight:800}
.ghostLink{background:transparent;border:1px solid #475569;color:var(--text)}
.stackBtns{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.toast{position:fixed;left:50%;bottom:18px;transform:translateX(-50%);background:#22c55e;color:#07120b;padding:14px 18px;border-radius:16px;font-weight:800;box-shadow:0 12px 30px rgba(0,0,0,.35);z-index:50;max-width:92vw;text-align:center}
.toast.error{background:#ef4444;color:white}
@media (max-width:760px){.stackBtns{grid-template-columns:1fr}.headerActions{width:100%}.headerActions .ghostLink,.headerActions button{flex:1}.teamHeadActions{display:grid;grid-template-columns:1fr}.teamHeadActions button{width:100%}}


.teamHeadActions{display:flex;gap:8px;flex-wrap:wrap}
button.danger{background:#dc2626;box-shadow:0 6px 18px rgba(220,38,38,.22)}
button.danger.ghost{background:transparent;border:1px solid #7f1d1d;color:#fecaca;box-shadow:none}


.notice{background:#0b1220;border:1px solid var(--line);border-radius:16px;padding:12px 14px;margin-top:0}
.okText{color:#86efac!important;border-color:rgba(34,197,94,.45)!important}


.savedTeams{display:grid;gap:10px}
.savedTeamCard{display:grid;grid-template-columns:1fr auto;gap:10px;align-items:center;padding:14px;border:1px solid var(--line);border-radius:18px;background:var(--cardSoft)}
.savedTeamActions{display:flex;gap:8px;align-items:center}
.savedTeamActions button{min-height:48px;padding:12px 14px}
@media (max-width:760px){.savedTeamCard{grid-template-columns:1fr}.savedTeamActions{display:grid;grid-template-columns:1fr 1fr}.savedTeamActions button{width:100%}}
