:root{
  --bg:#0f1418; --panel:#161d23; --panel2:#1c252d; --line:#2a353f;
  --ink:#e6edf3; --muted:#8b9aa7; --accent:#4ea1ff; --accent2:#2d7fd6;
  --good:#3fb950; --warn:#d29922; --chip:#22303b; --radius:8px;
}
*{box-sizing:border-box}
html,body{margin:0;height:100%}
body{
  background:var(--bg); color:var(--ink);
  font:14px/1.5 system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
}
.hidden{display:none !important}
.muted{color:var(--muted)}
.small{font-size:12px}
button{cursor:pointer;font:inherit}
a{color:var(--accent);text-decoration:none}
a:hover{text-decoration:underline}

/* ── Login ── */
.login{min-height:100%;display:grid;place-items:center;padding:24px}
.login-card{
  background:var(--panel);border:1px solid var(--line);border-radius:12px;
  padding:28px;width:min(380px,100%);display:flex;flex-direction:column;gap:12px;
}
.login-card h1{margin:0;font-size:20px}
.login-card label{display:flex;flex-direction:column;gap:4px;font-size:12px;color:var(--muted)}
.login-card input{
  background:var(--panel2);border:1px solid var(--line);border-radius:var(--radius);
  color:var(--ink);padding:10px;font:inherit;
}
.login-card button{
  background:var(--accent2);color:#fff;border:0;border-radius:var(--radius);
  padding:11px;font-weight:600;margin-top:4px;
}
.login-card button:hover{background:var(--accent)}
.error{color:#ff7b72;font-size:13px;min-height:18px}

/* ── Topbar ── */
.topbar{
  display:flex;align-items:center;gap:16px;padding:10px 18px;
  background:var(--panel);border-bottom:1px solid var(--line);position:sticky;top:0;z-index:5;
}
.brand{font-weight:700;letter-spacing:.3px}
.coverage{flex:1;font-size:12px}
.link{background:none;border:0;color:var(--accent);padding:0}
.link:hover{text-decoration:underline}

/* ── Layout ── */
.layout{display:grid;grid-template-columns:minmax(340px,420px) 1fr;gap:0;height:calc(100% - 49px);max-width:1280px;width:100%;margin:0 auto}
.col-query{padding:18px;border-right:1px solid var(--line);overflow:auto}
.col-results{padding:18px;overflow:auto}
@media(max-width:820px){
  .layout{grid-template-columns:1fr;height:auto}
  .col-query{border-right:0;border-bottom:1px solid var(--line)}
}

/* ── Query ── */
.drop{position:relative;border:1.5px dashed var(--line);border-radius:10px;transition:border-color .15s,background .15s}
.drop.dragover{border-color:var(--accent);background:rgba(78,161,255,.06)}
.drop textarea{
  width:100%;background:var(--panel);border:0;border-radius:10px;color:var(--ink);
  padding:12px;font:inherit;resize:vertical;min-height:130px;outline:none;
}
.drop-hint{position:absolute;right:10px;bottom:8px;font-size:11px;color:var(--muted);pointer-events:none}

.controls{display:flex;align-items:center;gap:12px;margin:12px 0;flex-wrap:wrap}
#searchBtn{
  background:var(--accent2);color:#fff;border:0;border-radius:var(--radius);
  padding:9px 20px;font-weight:600;
}
#searchBtn:hover{background:var(--accent)}
#searchBtn:disabled{opacity:.55;cursor:default}
.inline{display:inline-flex;align-items:center;gap:6px;font-size:12px;color:var(--muted)}
.inline select,.inline input{accent-color:var(--accent)}
select,.inline select{
  background:var(--panel2);border:1px solid var(--line);border-radius:6px;color:var(--ink);padding:5px;
}
.status{font-size:12px;color:var(--muted)}

/* ── Filters ── */
.filters{background:var(--panel);border:1px solid var(--line);border-radius:10px;padding:8px 12px;margin-bottom:12px}
.filters summary{cursor:pointer;font-weight:600;font-size:13px}
.filter-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin:12px 0}
.filter-grid label{display:flex;flex-direction:column;gap:3px;font-size:11px;color:var(--muted)}
.filter-grid input,.filter-grid select{
  background:var(--panel2);border:1px solid var(--line);border-radius:6px;color:var(--ink);padding:7px;font:inherit;
}
.filter-actions{display:flex;gap:16px;margin-bottom:6px}

/* ── Retrieval meta ── */
.retrieval{font-size:12px;color:var(--muted)}
.retrieval .chip{
  display:inline-block;background:var(--chip);border:1px solid var(--line);
  border-radius:20px;padding:2px 9px;margin:2px 4px 2px 0;color:var(--ink);font-size:11px;
}
.retrieval .chip b{color:var(--accent);font-weight:600}

/* ── Results toolbar (count + sort) ── */
.results-bar{display:flex;align-items:center;gap:10px;margin-bottom:12px}
.results-bar .spacer{flex:1}
.results-bar select{min-width:140px}

/* ── Results ── */
.results{display:flex;flex-direction:column;gap:12px}
.card{
  background:var(--panel);border:1px solid var(--line);border-radius:10px;padding:14px 16px;
}
.card.exact{border-color:var(--good);box-shadow:0 0 0 1px var(--good) inset}
.card-head{display:flex;align-items:baseline;gap:10px;flex-wrap:wrap}
.rank{font-weight:700;color:var(--muted);font-size:13px}
.agency{background:var(--chip);border-radius:5px;padding:1px 8px;font-size:11px;font-weight:600;letter-spacing:.3px}
.title{font-weight:600}
.spacer{flex:1}
.scores{display:flex;gap:6px;flex-wrap:wrap}
.score{font-size:10.5px;background:var(--panel2);border:1px solid var(--line);border-radius:5px;padding:1px 6px;color:var(--muted)}
.score b{color:var(--ink);font-weight:600}
.meta{font-size:12px;color:var(--muted);margin:6px 0}
.meta span{margin-right:12px}
.passage{font-size:13px;line-height:1.55;margin:8px 0 6px;color:#cdd9e3}
.src-id{font-weight:500}
.refcopy{background:var(--chip);border:1px solid var(--line);border-radius:5px;color:var(--ink);font:inherit;font-size:11px;font-weight:600;letter-spacing:.3px;padding:1px 8px;cursor:pointer}
.refcopy:hover{border-color:var(--accent);color:var(--accent)}
.refcopy.copied{color:var(--good);border-color:var(--good)}
.nolink{color:var(--warn);font-size:11px}
.tailcopy{background:none;border:0;padding:0;margin:0;color:var(--ink);font-family:inherit;font-size:18px;font-weight:800;letter-spacing:.6px;line-height:1.15;cursor:pointer}
.tailcopy:hover{color:var(--accent);text-decoration:underline}
.tailcopy.copied{color:var(--good);text-decoration:none}
.tailsep{font-size:14px;color:var(--muted);align-self:center}

/* ── Plane ID — front & center ── */
.planeid{display:flex;align-items:baseline;gap:10px;flex-wrap:wrap;margin:5px 0 2px}
.planeid .tail{font-size:18px;font-weight:800;letter-spacing:.6px;color:var(--ink)}
.planeid .actype{font-size:13px;font-weight:600;color:var(--accent)}

/* ── Two-part blurb: what happened / probable cause ── */
.blurb{display:flex;flex-direction:column;gap:8px;margin:9px 0 6px}
.blurb-row{font-size:13px;line-height:1.5}
.blurb-row p{margin:0;color:#cdd9e3}
.blurb-label{display:block;font-size:10px;text-transform:uppercase;letter-spacing:.7px;color:var(--muted);margin-bottom:2px}
.blurb-what{border-left:2px solid var(--accent2);padding-left:10px}
.blurb-cause{border-left:2px solid var(--warn);padding-left:10px}
.blurb-cause p{color:#ecdcb2}
.blurb-row p.clamp{display:-webkit-box;-webkit-line-clamp:4;-webkit-box-orient:vertical;overflow:hidden}
.blurb-row p.expanded{-webkit-line-clamp:unset;overflow:visible}
.blurb-more{background:none;border:0;color:var(--accent);padding:0;margin-top:4px;font-size:11px;cursor:pointer}
.blurb-more:hover{text-decoration:underline}

.card-foot{display:flex;align-items:center;gap:14px;font-size:12px}
.dupes{color:var(--muted);font-size:11px}
.badge-exact{color:var(--good);font-weight:600;font-size:11px}
.placeholder{color:var(--muted);text-align:center;margin-top:40px}
.spin{display:inline-block;width:13px;height:13px;border:2px solid var(--line);border-top-color:var(--accent);border-radius:50%;animation:s .7s linear infinite;vertical-align:-2px}
@keyframes s{to{transform:rotate(360deg)}}
