/* /opt/flighthub2/adminui/static/style.css */
:root { --bg:#0b0d12; --card:#121826; --text:#e8eefc; --muted:#9aa6c5; --line:#24304a; --ok:#2ad67a; --ng:#ff5b5b; }
*{ box-sizing:border-box; }
body{ margin:0; font-family:system-ui,-apple-system,Segoe UI,Roboto,"Noto Sans JP",sans-serif; background:var(--bg); color:var(--text); }
.top{ display:flex; justify-content:space-between; align-items:center; padding:14px 18px; border-bottom:1px solid var(--line); position:sticky; top:0; background:rgba(11,13,18,.9); backdrop-filter: blur(10px); z-index:10; }
.brand{ font-weight:700; letter-spacing:.3px; }
.right{ display:flex; align-items:center; gap:10px; color:var(--muted); font-size:14px; }
.dot{ width:10px; height:10px; border-radius:99px; display:inline-block; background:#666; }
.dot.ok{ background:var(--ok); }
.dot.ng{ background:var(--ng); }

.badge{
  border:1px solid var(--line);
  background:#0f1422;
  color:var(--text);
  padding:6px 10px;
  border-radius:999px;
  font-size:12px;
}
button.ghost{
  padding:7px 10px;
  border-radius:10px;
  border:1px solid var(--line);
  background:transparent;
  color:var(--text);
  cursor:pointer;
}

.wrap{ max-width:1100px; margin:0 auto; padding:18px; }
.panel{ background:var(--card); border:1px solid var(--line); border-radius:14px; padding:14px; }
.row{ display:grid; grid-template-columns:auto 1fr auto 1fr auto 200px auto; gap:10px; align-items:center; }
.row label{ color:var(--muted); font-size:13px; }
.row input, .row select{ width:100%; padding:8px 10px; border-radius:10px; border:1px solid var(--line); background:#0f1422; color:var(--text); }
.row input:disabled{ opacity:.85; cursor:not-allowed; }
.row button{ padding:9px 12px; border-radius:10px; border:1px solid var(--line); background:#0f1422; color:var(--text); cursor:pointer; }
.row2{ display:flex; gap:10px; margin:10px 0; }
button.primary{ background:#1b2a52; border-color:#2a3c70; }
.tabs{ display:flex; gap:8px; margin-top:12px; border-bottom:1px solid var(--line); padding-bottom:10px; }
.tab{ padding:8px 12px; border:1px solid var(--line); background:#0f1422; color:var(--text); border-radius:999px; cursor:pointer; }
.tab.active{ background:#1b2a52; border-color:#2a3c70; }
.tabBody{ padding-top:12px; }
.hidden{ display:none !important; }
.hint{ color:var(--muted); font-size:13px; margin-bottom:10px; }
textarea{ width:100%; height:420px; padding:12px; border-radius:12px; border:1px solid var(--line); background:#0f1422; color:var(--text); font-family:ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", monospace; font-size:12px; line-height:1.4; }
.msg{ margin-top:10px; color:var(--muted); font-size:13px; }
.msg.ok{ color:var(--ok); }
.msg.ng{ color:var(--ng); }
.grid2{ display:grid; grid-template-columns:1fr 1fr; gap:14px; }
.fileList{ list-style:none; padding:0; margin:0; }
.fileList li{ display:flex; justify-content:space-between; gap:10px; padding:8px 10px; border:1px solid var(--line); border-radius:10px; margin-bottom:8px; background:#0f1422; }
.fileList a{ color:#bcd1ff; text-decoration:none; word-break:break-all; }
.fileList .meta{ color:var(--muted); font-size:12px; white-space:nowrap; }
.foot{ color:var(--muted); font-size:12px; padding:12px 4px; }

/* login overlay */
.overlay{
  position:fixed; inset:0;
  background:rgba(0,0,0,.55);
  display:flex; align-items:center; justify-content:center;
  z-index:999;
}
.modal{
  width:min(520px, calc(100% - 32px));
  background:var(--card);
  border:1px solid var(--line);
  border-radius:16px;
  padding:16px;
  box-shadow: 0 18px 60px rgba(0,0,0,.5);
}
.modal h2{ margin:2px 0 8px; }
.muted{ color:var(--muted); margin:0 0 12px; font-size:13px; }
.form{ display:grid; gap:8px; }
.form label{ color:var(--muted); font-size:13px; }
.form input{
  width:100%;
  padding:10px 12px;
  border-radius:12px;
  border:1px solid var(--line);
  background:#0f1422;
  color:var(--text);
}
.form button{ margin-top:8px; padding:10px 12px; border-radius:12px; border:1px solid var(--line); background:#0f1422; color:var(--text); cursor:pointer; }
