:root {
  --green: #0b5c2e;
  --green-2: #0e7a3c;
  --green-soft: #e8f4ec;
  --ink: #16241b;
  --muted: #5e6e63;
  --line: #d9e2db;
  --bg: #f4f7f4;
  --card: #ffffff;
  --danger: #b3261e;
  --danger-soft: #fde8e6;
  --warn: #8a5a00;
  --warn-soft: #fff3d6;
  --radius: 14px;
  --shadow: 0 1px 3px rgba(0,0,0,.08), 0 6px 20px rgba(0,0,0,.05);
}

* { box-sizing: border-box; }
html, body { margin: 0; }
body {
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
  background: var(--bg);
  color: var(--ink);
  -webkit-font-smoothing: antialiased;
  padding: env(safe-area-inset-top) env(safe-area-inset-right) env(safe-area-inset-bottom) env(safe-area-inset-left);
}

.hidden { display: none !important; }
.muted { color: var(--muted); }
.small { font-size: .82rem; }
.spacer { flex: 1; }
.stack { display: flex; flex-direction: column; gap: 14px; }
.row { display: flex; align-items: center; }
.row.between { justify-content: space-between; }
.row.gap { gap: 10px; }

.view { max-width: 560px; margin: 0 auto; padding: 14px; }

/* Cards */
.card {
  background: var(--card);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  padding: 16px;
}
h1, h2 { margin: 0 0 6px; }
h2 { font-size: 1.05rem; }

/* Buttons */
.btn {
  appearance: none;
  border: 1px solid transparent;
  border-radius: 10px;
  padding: 11px 14px;
  font-size: .95rem;
  font-weight: 600;
  cursor: pointer;
  background: #eef1ee;
  color: var(--ink);
}
.btn.small { padding: 7px 11px; font-size: .82rem; }
.btn.primary { background: var(--green); color: #fff; }
.btn.primary:active { background: var(--green-2); }
.btn.ghost { background: transparent; border-color: var(--line); }
.btn.danger { background: var(--danger-soft); color: var(--danger); border-color: #f0c5c1; }
.btn:disabled { opacity: .5; cursor: not-allowed; }

/* Auth */
.auth-card { margin-top: 8vh; }
.brand { font-size: 1.6rem; }
.brand-sm { font-weight: 800; }
.tabs { display: flex; gap: 6px; margin: 14px 0; }
.tab { flex: 1; padding: 9px; border: 1px solid var(--line); background: #fff; border-radius: 10px; font-weight: 600; }
.tab.active { background: var(--green-soft); border-color: var(--green); color: var(--green); }
.auth-form { display: flex; flex-direction: column; gap: 12px; }

/* checkbox row (remember me) */
.checkrow { flex-direction: row; align-items: center; gap: 8px; font-weight: 500; color: var(--muted); font-size: .9rem; cursor: pointer; }
.checkrow input { width: 18px; height: 18px; accent-color: var(--green); }

/* footer */
.site-footer { text-align: center; color: var(--muted); font-size: .8rem; padding: 22px 14px calc(22px + env(safe-area-inset-bottom)); }
.site-footer a { color: var(--green-2); text-decoration: none; }

/* Inputs */
label { display: flex; flex-direction: column; gap: 6px; font-weight: 600; font-size: .9rem; }
input, select {
  font: inherit;
  padding: 11px 12px;
  border: 1px solid var(--line);
  border-radius: 10px;
  background: #fff;
  font-weight: 500;
}
input:focus, select:focus { outline: 2px solid var(--green-2); border-color: var(--green-2); }

/* App bar */
.appbar { display: flex; align-items: center; gap: 10px; padding: 6px 2px 14px; }

/* Banner */
.banner { border-radius: 10px; padding: 10px 12px; font-size: .88rem; margin-bottom: 12px; }
.banner.warn { background: var(--warn-soft); color: var(--warn); border: 1px solid #f0dca8; }

/* Kill switch */
.kill-switch {
  width: 100%;
  border: none;
  border-radius: 12px;
  padding: 16px;
  font-size: 1.05rem;
  font-weight: 800;
  letter-spacing: .3px;
  color: #fff;
  background: var(--danger);
  box-shadow: 0 4px 14px rgba(179,38,30,.3);
  cursor: pointer;
  margin-bottom: 14px;
}
.kill-switch:active { filter: brightness(.94); }

/* Requests */
.requests, .accounts { display: flex; flex-direction: column; gap: 10px; margin-top: 10px; }
.req {
  border: 1px solid var(--line);
  border-radius: 12px;
  padding: 12px;
}
.req .req-top { display: flex; justify-content: space-between; align-items: center; gap: 8px; }
.req .when { font-weight: 700; }
.req .sub { color: var(--muted); font-size: .82rem; margin-top: 2px; }
.req .actions { display: flex; flex-wrap: wrap; gap: 6px; margin-top: 10px; }

.badge { font-size: .72rem; font-weight: 800; padding: 3px 8px; border-radius: 999px; text-transform: uppercase; letter-spacing: .4px; }
.badge.draft  { background: #eceff0; color: #5b6b62; }
.badge.armed  { background: var(--green-soft); color: var(--green); }
.badge.fired  { background: #e7eefc; color: #2950b3; }
.badge.booked { background: #def7e6; color: #0b7a35; }
.badge.failed { background: var(--danger-soft); color: var(--danger); }
.badge.killed { background: #eceff0; color: #6b6b6b; }
.badge.live   { background: #ffe0db; color: var(--danger); margin-left: 6px; }
.badge.dry    { background: #eef1ee; color: var(--muted); margin-left: 6px; }

.acc { border: 1px solid var(--line); border-radius: 10px; padding: 10px 12px; display: flex; justify-content: space-between; align-items: center; }

/* Modal */
.modal { position: fixed; inset: 0; background: rgba(10,20,14,.45); display: flex; align-items: flex-end; justify-content: center; z-index: 50; }
.modal-card {
  background: #fff;
  width: 100%;
  max-width: 560px;
  border-radius: 18px 18px 0 0;
  padding: 18px 16px calc(18px + env(safe-area-inset-bottom));
  max-height: 92vh;
  overflow-y: auto;
}
@media (min-width: 600px) {
  .modal { align-items: center; }
  .modal-card { border-radius: 18px; }
}

/* Segmented mode toggle */
.mode-toggle { gap: 8px; }
.seg { display: inline-flex; border: 1px solid var(--line); border-radius: 10px; overflow: hidden; }
.seg input { display: none; }
.seg label { padding: 9px 18px; cursor: pointer; font-weight: 700; }
.seg input:checked + label { background: var(--green); color: #fff; }
.seg input#mode-live:checked + label.live { background: var(--danger); color: #fff; }

/* Messages */
.msg { font-size: .85rem; min-height: 1em; margin: 0; }
.msg.err, .msg.warn { color: var(--danger); }
.msg.ok { color: var(--green); }
.banner.warn b { font-weight: 800; }

.kv { display: grid; grid-template-columns: auto minmax(0, 1fr); gap: 4px 12px; font-size: .88rem; margin: 8px 0; }
.kv dt { color: var(--muted); }
.kv dd { margin: 0; word-break: break-word; }
.log { font-family: ui-monospace, SFMono-Regular, Menlo, monospace; font-size: .76rem; background: #f6f8f6; border: 1px solid var(--line); border-radius: 8px; padding: 8px; max-height: 140px; overflow: auto; white-space: pre-wrap; word-break: break-word; overflow-wrap: anywhere; }
#detail-body h3 { margin: 12px 0 4px; }
