/* ============================================================================
   Integration tab — Quickstart, code samples, live tester, tile preview.
   Lives alongside the rest of the customer dashboard; no admin styles here.
   ========================================================================= */

.db-int-tabs {
  display: flex; gap: 6px; flex-wrap: wrap;
  margin: 18px 0 22px;
  border-bottom: 1px solid var(--ink-line);
}
.db-int-tab {
  appearance: none; cursor: pointer;
  background: transparent; border: 0;
  /* C5: was --ink-mute (too dim on dark dashboard). --ink-soft sits one
     step brighter so inactive tabs are legible without competing with the
     active state. */
  color: var(--ink-soft, rgba(255,255,255,0.72));
  font-family: var(--font-mono); font-size: 0.85rem;
  padding: 10px 16px;
  border-bottom: 2px solid transparent;
  margin-bottom: -1px;
}
.db-int-tab:hover { color: var(--ink); }
.db-int-tab.is-active {
  color: var(--admin-accent, #4a7eff);
  border-bottom-color: var(--admin-accent, #4a7eff);
}

.db-int-panel { display: none; }
.db-int-panel.is-active { display: block; }

/* ── Quickstart steps ─────────────────────────────────────────────── */
.db-int-steps {
  list-style: none; padding: 0; margin: 0;
  display: flex; flex-direction: column; gap: 14px;
  max-width: 760px;
}
.db-int-step {
  display: grid; grid-template-columns: 36px 1fr; gap: 14px;
  align-items: start;
  padding: 16px 18px;
  background: var(--canvas-paper);
  border: 1px solid var(--ink-line);
  border-radius: 12px;
}
.db-int-step.is-done {
  border-color: rgba(60,160,80,0.4);
  background: rgba(60,160,80,0.06);
}
.db-int-step-num {
  display: inline-flex; align-items: center; justify-content: center;
  width: 32px; height: 32px;
  border-radius: 50%;
  background: var(--canvas);
  border: 1px solid var(--ink-line);
  font-family: var(--font-mono); font-weight: 600;
  color: var(--ink-mute);
}
.db-int-step.is-done .db-int-step-num {
  background: rgb(60,160,80); color: #fff; border-color: rgb(60,160,80);
}
.db-int-step-body strong { color: var(--ink); font-size: 0.95rem; }
.db-int-step-body p {
  margin: 4px 0 8px; color: var(--ink-mute); font-size: 0.85rem;
}
.db-int-step-body code {
  background: var(--canvas); padding: 1px 5px; border-radius: 3px;
  font-size: 0.78rem;
}

/* ── Code samples ──────────────────────────────────────────────────── */
.db-int-samples {
  display: flex; flex-direction: column; gap: 22px;
  max-width: 920px;
}
.db-int-sample {
  background: var(--canvas-paper);
  border: 1px solid var(--ink-line);
  border-radius: 12px;
  overflow: hidden;
}
.db-int-sample-head {
  display: flex; align-items: center; justify-content: space-between;
  gap: 16px; padding: 14px 18px;
  border-bottom: 1px solid var(--ink-line);
}
.db-int-sample-head h3 { margin: 0; font-size: 0.95rem; color: var(--ink); }

.db-int-lang-tabs { display: inline-flex; gap: 4px; }
.db-int-lang {
  appearance: none; cursor: pointer;
  background: var(--canvas); border: 1px solid var(--ink-line);
  color: var(--ink-mute);
  font-family: var(--font-mono); font-size: 0.75rem;
  padding: 4px 10px; border-radius: 5px;
}
.db-int-lang.is-active {
  background: var(--admin-tint, rgba(74,126,255,0.1));
  color: var(--admin-accent, #4a7eff);
  border-color: var(--admin-accent, #4a7eff);
}

.db-int-codes { position: relative; }
.db-int-code {
  display: none;
  margin: 0; padding: 16px 56px 16px 18px;
  background: #0e1116; color: #e8eaf0;
  font-family: var(--font-mono); font-size: 0.78rem;
  line-height: 1.55;
  white-space: pre-wrap; word-break: break-word;
  position: relative;
}
.db-int-code.is-active { display: block; }
.db-int-code code { color: inherit; background: transparent; padding: 0; }
.db-int-copy {
  position: absolute; top: 10px; right: 10px;
  appearance: none; cursor: pointer;
  background: rgba(255,255,255,0.08); color: #e8eaf0;
  border: 1px solid rgba(255,255,255,0.2);
  padding: 4px 10px; border-radius: 5px;
  font-family: var(--font-mono); font-size: 0.72rem;
}
.db-int-copy:hover { background: rgba(255,255,255,0.15); }

/* ── Live tester ──────────────────────────────────────────────────── */
.db-int-tester { max-width: 920px; }
.db-int-tester-intro {
  margin: 0 0 16px;
  padding: 12px 14px;
  background: var(--admin-tint, rgba(74,126,255,0.08));
  border-left: 3px solid var(--admin-accent, #4a7eff);
  border-radius: 6px;
  font-size: 0.85rem; color: var(--ink);
}
.db-int-tester-intro code {
  background: rgba(0,0,0,0.06); padding: 1px 5px; border-radius: 3px;
  font-size: 0.78rem;
}
.db-int-tester-list { display: flex; flex-direction: column; gap: 14px; }
.db-int-tester-row {
  background: var(--canvas-paper);
  border: 1px solid var(--ink-line);
  border-radius: 12px;
  overflow: hidden;
}
.db-int-tester-row-head {
  padding: 10px 16px;
  border-bottom: 1px solid var(--ink-line);
  background: var(--canvas);
  font-size: 0.85rem;
}
.db-int-tester-row-head code {
  background: transparent; color: var(--ink); font-weight: 500;
}
.db-int-method {
  display: inline-block; min-width: 48px; text-align: center;
  padding: 2px 8px; border-radius: 4px;
  background: var(--admin-accent, #4a7eff); color: #fff;
  font-family: var(--font-mono); font-size: 0.7rem; font-weight: 600;
  margin-right: 8px;
}
.db-int-tester-row pre {
  position: relative;
  margin: 0; padding: 14px 56px 14px 16px;
  background: #0e1116; color: #e8eaf0;
  font-family: var(--font-mono); font-size: 0.76rem;
  white-space: pre-wrap; word-break: break-word;
}

.db-int-tester-row-head {
  display: flex; align-items: center; gap: 10px;
}
.db-int-run {
  margin-left: auto;
  appearance: none; cursor: pointer;
  background: var(--admin-accent, #4a7eff); color: #fff;
  border: 0; border-radius: 5px;
  padding: 4px 12px; font-family: var(--font-mono); font-size: 0.78rem;
}
.db-int-run:disabled { opacity: 0.5; cursor: progress; }

.db-int-tester-output { padding: 14px 16px; background: var(--canvas-paper); }
.db-int-tester-running {
  font-family: var(--font-mono); font-size: 0.84rem; color: var(--ink-mute);
}
.db-int-tester-error {
  font-family: var(--font-mono); font-size: 0.84rem;
  /* C6: lighter foreground + visible border so the error reads against
     the dashboard's dark backdrop. The 8% fill was nearly invisible. */
  color: #ff8a8a;
  background: rgba(229, 72, 77, 0.18);
  border: 1px solid rgba(229, 72, 77, 0.55);
  padding: 10px 12px; border-radius: 6px;
}
.db-int-tester-cols {
  display: grid; grid-template-columns: 1fr 1fr; gap: 14px;
}
@media (max-width: 900px) { .db-int-tester-cols { grid-template-columns: 1fr; } }
.db-int-tester-col-head {
  font-family: var(--font-mono); font-size: 0.78rem;
  color: var(--ink); margin-bottom: 6px;
  display: flex; align-items: center; gap: 8px;
}
.db-int-tester-status {
  display: inline-block; padding: 1px 6px; border-radius: 3px;
  font-family: var(--font-mono); font-size: 0.72rem; font-weight: 600;
}
.db-int-tester-status.is-ok  { background: rgba(60,160,80,0.18); color: rgb(60,160,80); }
.db-int-tester-status.is-bad { background: rgba(200,60,60,0.18); color: rgb(200,60,60); }
.db-int-tester-pre {
  position: relative; margin: 0;
  padding: 12px 50px 12px 14px;
  background: #0e1116; color: #e8eaf0;
  font-family: var(--font-mono); font-size: 0.74rem;
  white-space: pre-wrap; word-break: break-word;
  max-height: 360px; overflow-y: auto;
  border-radius: 6px;
}
.db-int-canonical { margin-top: 8px; }
.db-int-canonical summary {
  cursor: pointer; font-size: 0.78rem; color: var(--ink-mute);
  font-family: var(--font-mono);
}
.db-int-canonical pre {
  margin: 6px 0 0; padding: 10px 12px;
  background: var(--canvas); border: 1px solid var(--ink-line);
  border-radius: 6px;
  font-size: 0.72rem; color: var(--ink);
  white-space: pre-wrap; word-break: break-word;
}
.db-int-tester-note {
  margin-top: 10px; padding: 8px 12px;
  background: var(--admin-tint, rgba(74,126,255,0.08));
  border-left: 3px solid var(--admin-accent, #4a7eff);
  border-radius: 4px;
  font-size: 0.78rem; color: var(--ink-mute);
}

/* ── Tile preview ─────────────────────────────────────────────────── */
.db-int-tiles { max-width: 920px; }
.db-int-tiles h3 { font-size: 0.95rem; margin: 22px 0 10px; color: var(--ink); }
.db-int-tiles p  { color: var(--ink-mute); font-size: 0.86rem; }
.db-int-tiles pre {
  margin: 12px 0;
  padding: 14px 16px;
  background: #0e1116; color: #e8eaf0;
  border-radius: 8px;
  font-family: var(--font-mono); font-size: 0.78rem;
  overflow-x: auto;
}
.db-int-tile-row {
  display: grid; grid-template-columns: repeat(auto-fill, minmax(120px, 1fr));
  gap: 10px;
}
.db-int-tile {
  position: relative;
  border-radius: 12px; overflow: hidden;
  background: var(--canvas);
  border: 1px solid var(--ink-line);
}
.db-int-tile img,
.db-int-tile-noimg {
  display: block;
  width: 100%; aspect-ratio: 9 / 16;
  object-fit: cover; object-position: center;
}
.db-int-tile-noimg {
  display: flex; align-items: center; justify-content: center;
  background: linear-gradient(135deg, #2a3447, #1a2030);
  color: rgba(255,255,255,0.55);
  font-family: var(--font-mono); font-size: 1.6rem; font-weight: 700;
  letter-spacing: 0.1em;
}
.db-int-tile-caption {
  position: absolute; left: 0; right: 0; bottom: 0;
  padding: 8px 10px 10px;
  background: linear-gradient(180deg, rgba(0,0,0,0), rgba(0,0,0,0.85));
  color: #fff;
}
.db-int-tile-caption strong {
  display: block; font-size: 0.78rem; line-height: 1.2;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.db-int-tile-caption span {
  display: block; font-size: 0.66rem; opacity: 0.75;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}

/* ── Reference panel ──────────────────────────────────────────────── */
.db-int-reference { max-width: 920px; }
.db-int-reference h3 { font-size: 0.95rem; margin: 22px 0 10px; color: var(--ink); }
.db-int-doclist {
  list-style: none; padding: 0; margin: 0 0 18px;
  display: flex; flex-direction: column; gap: 8px;
}
.db-int-doclist a {
  display: inline-block;
  padding: 8px 12px; border-radius: 7px;
  background: var(--canvas-paper); border: 1px solid var(--ink-line);
  color: var(--ink); text-decoration: none;
  font-family: var(--font-mono); font-size: 0.84rem;
}
.db-int-doclist a:hover { border-color: var(--admin-accent, #4a7eff); color: var(--admin-accent, #4a7eff); }

/* O6: endpoint reference table — wrap so long /api/v1/... paths don't
   push the dashboard layout. The outer wrapper handles overflow; the
   table itself keeps its rounded look via the wrapper's border-radius. */
.db-int-ep-wrap {
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  background: var(--canvas-paper);
  border: 1px solid var(--ink-line);
  border-radius: 8px;
}
.db-int-ep-table {
  width: 100%; border-collapse: collapse;
  font-size: 0.84rem;
}
.db-int-ep-table th,
.db-int-ep-table td {
  text-align: left; padding: 8px 12px;
  border-bottom: 1px solid var(--ink-line);
}
.db-int-ep-table th {
  background: var(--canvas); color: var(--ink-mute);
  font-weight: 600; font-family: var(--font-mono); font-size: 0.78rem;
}
.db-int-ep-table tr:last-child td { border-bottom: 0; }
.db-int-ep-table td code {
  background: var(--canvas); padding: 1px 6px; border-radius: 3px;
  font-size: 0.78rem;
}

/* ── Usage page polish: per-endpoint breakdown + top games ─────────── */
.db-usage-grid {
  display: grid; grid-template-columns: 1.4fr 1fr; gap: 20px;
  margin-top: 28px;
}
@media (max-width: 980px) {
  .db-usage-grid { grid-template-columns: 1fr; }
}

.db-usage-table {
  width: 100%; border-collapse: collapse; font-size: 0.84rem;
}
.db-usage-table th,
.db-usage-table td {
  text-align: left; padding: 8px 12px;
  border-bottom: 1px solid var(--ink-line);
}
.db-usage-table th {
  color: var(--ink-mute); font-family: var(--font-mono);
  font-size: 0.74rem; font-weight: 600; text-transform: uppercase;
  letter-spacing: 0.04em;
}
.db-usage-table td.num,
.db-usage-table th.num { text-align: right; font-variant-numeric: tabular-nums; font-family: var(--font-mono); }
.db-usage-table td.ep code { background: var(--canvas); padding: 1px 6px; border-radius: 3px; font-size: 0.78rem; }
.db-usage-table tr:last-child td { border-bottom: 0; }
.db-usage-table .is-bad  { color: rgb(200,60,60); }
.db-usage-table .is-warn { color: rgb(200,140,40); }

.db-topgames-list {
  list-style: none; padding: 0; margin: 0;
  display: flex; flex-direction: column; gap: 8px;
}
.db-topgame {
  display: grid; grid-template-columns: 28px 64px 1fr auto; gap: 12px;
  align-items: center;
  padding: 8px 10px;
  border: 1px solid var(--ink-line); border-radius: 8px;
  background: var(--canvas);
}
.db-topgame-rank {
  font-family: var(--font-mono); font-size: 0.85rem; font-weight: 700;
  color: var(--ink-mute); text-align: center;
}
.db-topgame-img {
  width: 64px; aspect-ratio: 16 / 10; overflow: hidden;
  border-radius: 5px; background: var(--canvas-paper);
}
.db-topgame-img img { width: 100%; height: 100%; object-fit: cover; display: block; }
.db-topgame-noimg {
  display: flex; align-items: center; justify-content: center;
  width: 100%; height: 100%;
  background: linear-gradient(135deg, #2a3447, #1a2030);
  color: rgba(255,255,255,0.7);
  font-family: var(--font-mono); font-weight: 600; font-size: 0.85rem;
}
.db-topgame-meta strong {
  display: block; color: var(--ink); font-size: 0.86rem;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
  max-width: 260px;
}
.db-topgame-meta .db-muted { font-size: 0.74rem; }
.db-topgame-cat {
  display: inline-block; margin-left: 4px;
  padding: 1px 6px; border-radius: 3px;
  font-family: var(--font-mono); font-size: 0.62rem; font-weight: 600;
  letter-spacing: 0.04em; text-transform: uppercase;
  background: rgba(40,120,200,0.18); color: rgb(40,120,200);
}
.db-topgame-cat--table { background: rgba(60,150,80,0.18); color: rgb(60,150,80); }
.db-topgame-cat--live  { background: rgba(200,60,60,0.18); color: rgb(200,60,60); }
.db-topgame-cat--other { background: rgba(100,100,100,0.18); color: var(--ink-mute); }
.db-topgame-count {
  font-family: var(--font-mono); font-size: 0.92rem;
  font-variant-numeric: tabular-nums;
  color: var(--ink); text-align: right; min-width: 60px;
}

/* ── API Keys polish: scope chips + IP allowlist + last-used IP ────── */
.db-key-meta-row2 {
  display: flex; flex-wrap: wrap; gap: 10px; align-items: center;
  margin-top: 6px;
}
.db-key-meta-label {
  color: var(--ink-mute); font-family: var(--font-mono);
  font-size: 0.7rem; text-transform: uppercase; letter-spacing: 0.04em;
  margin-right: 4px;
}
.db-key-scope {
  display: inline-block;
  padding: 1px 6px; border-radius: 3px;
  background: rgba(74,126,255,0.12); color: var(--admin-accent, #4a7eff);
  font-family: var(--font-mono); font-size: 0.7rem;
  cursor: help;
}
.db-key-scope + .db-key-scope { margin-left: 3px; }
.db-key-scopes-line { display: inline-flex; align-items: center; flex-wrap: wrap; gap: 4px; }

.db-key-ip-pill,
.db-key-cb-pill,
.db-key-rate {
  display: inline-block;
  padding: 2px 8px; border-radius: 4px;
  background: var(--canvas); border: 1px solid var(--ink-line);
  font-family: var(--font-mono); font-size: 0.7rem;
  color: var(--ink);
  cursor: help;
}
.db-key-ip-pill--open { color: var(--ink-mute); border-style: dashed; }
.db-key-cb-pill--default { color: var(--ink-mute); border-style: dashed; }

.db-key-last-ip { color: var(--ink-mute); }
.db-key-last-ip code {
  background: var(--canvas); padding: 0 4px; border-radius: 3px;
  font-size: 0.72rem;
}

.am-help {
  /* C9: --ink-mute was borderline-invisible on dark; --ink-soft is one
     step brighter and reads cleanly under a form input. */
  margin-top: 5px;
  color: var(--ink-soft, rgba(255,255,255,0.72)); font-size: 0.74rem;
}
textarea.am-input {
  resize: vertical; min-height: 80px; font-family: var(--font-mono); font-size: 0.8rem;
}

/* ── Free Spins page (customer dashboard) ───────────────────────────── */
.db-fs-grid {
  display: grid; grid-template-columns: 1fr 1.5fr; gap: 22px;
  margin-top: 18px;
}
@media (max-width: 1100px) { .db-fs-grid { grid-template-columns: 1fr; } }

.db-fs-form { display: flex; flex-direction: column; gap: 14px; }
.db-fs-form-row {
  display: grid; grid-template-columns: 1fr 1fr; gap: 10px;
}
.db-fs-form-row label { display: flex; flex-direction: column; gap: 4px; font-size: 0.78rem; color: var(--ink-mute); }
.db-fs-form input[type="text"],
.db-fs-form input[type="number"],
.db-fs-form input[type="datetime-local"] {
  width: 100%;
  background: var(--canvas); border: 1px solid var(--ink-line);
  border-radius: 6px; padding: 7px 10px;
  font-family: var(--font-mono); font-size: 0.84rem; color: var(--ink);
}
.db-fs-game-pick { position: relative; }
.db-fs-game-results {
  position: absolute; top: 100%; left: 0; right: 0; z-index: 10;
  max-height: 280px; overflow-y: auto;
  background: var(--canvas-paper);
  border: 1px solid var(--ink-line); border-radius: 7px;
  box-shadow: 0 8px 20px rgba(0,0,0,0.12);
  margin-top: 4px;
}
.db-fs-game-opt {
  display: flex; align-items: center; gap: 10px;
  width: 100%; padding: 8px 10px;
  background: transparent; border: 0; border-bottom: 1px solid var(--ink-line);
  cursor: pointer; text-align: left;
}
.db-fs-game-opt:hover { background: var(--admin-tint, rgba(74,126,255,0.08)); }
.db-fs-game-opt img,
.db-fs-game-opt .db-fs-game-noimg {
  width: 48px; aspect-ratio: 16/10; object-fit: cover;
  border-radius: 4px; background: var(--canvas);
}
.db-fs-game-opt small { color: var(--ink-mute); font-size: 0.72rem; }
.db-fs-game-noresult { padding: 12px; text-align: center; color: var(--ink-mute); font-size: 0.82rem; }
.db-fs-game-pick-current { color: var(--ink-mute); font-size: 0.74rem; }

.db-fs-form-error {
  padding: 8px 12px; border-radius: 6px;
  /* C7: dark dashboard needs lighter error text — was invisible. */
  background: rgba(229, 72, 77, 0.18);
  color: #ff8a8a;
  border: 1px solid rgba(229, 72, 77, 0.55);
  font-size: 0.82rem;
}
.db-fs-submit { align-self: flex-start; }

.db-fs-filters { display: flex; gap: 6px; margin-left: auto; }

/* O7: wrap the Free Spins campaign list in its own scroll context so long
   game-uuids / player-ids never push the dashboard layout sideways. */
#db-fs-list {
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
}
.db-fs-table {
  width: 100%; border-collapse: collapse; font-size: 0.82rem;
}
.db-fs-table th, .db-fs-table td {
  padding: 7px 10px; border-bottom: 1px solid var(--ink-line);
  text-align: left;
}
.db-fs-table th {
  color: var(--ink-mute); font-family: var(--font-mono);
  font-size: 0.7rem; text-transform: uppercase; letter-spacing: 0.04em;
}
.db-fs-table td.num,
.db-fs-table th.num { text-align: right; font-variant-numeric: tabular-nums; font-family: var(--font-mono); }
.db-fs-table tr:last-child td { border-bottom: 0; }

.db-fs-status {
  display: inline-block; padding: 1px 7px; border-radius: 3px;
  font-family: var(--font-mono); font-size: 0.7rem; font-weight: 600;
  letter-spacing: 0.04em; text-transform: uppercase;
}
/* C8: pill fg colors were set for a light theme — invisible on dark.
   Lighten each so they pop against the dashboard background. */
.db-fs-status--active    { background: rgba(60,160,80,0.22);   color: #7eea9c; }
.db-fs-status--consumed  { background: rgba(74,126,255,0.22);  color: #9cb3ff; }
.db-fs-status--cancelled { background: rgba(180,180,180,0.20); color: #cfd0d4; }
.db-fs-status--expired   { background: rgba(220,160,40,0.22);  color: #f4c976; }
.db-fs-status--failed    { background: rgba(229,72,77,0.22);   color: #ff8a8a; }
