/* ══════════════════════════════════════════════════
   1GBRAM Responsive Tables — tables.css
   Dark gaming theme: #0e0e0e bg, #f5a623 accent
   ══════════════════════════════════════════════════ */

/* ── CSS custom properties (overridable per-site) ── */
:root {
  --gbram-accent:       #f5a623;
  --gbram-accent-dark:  #c4811a;
  --gbram-bg:           #111318;
  --gbram-bg-alt:       #1a1d24;
  --gbram-bg-hover:     #1f2330;
  --gbram-border:       #2a2e3d;
  --gbram-text:         #e2e4ed;
  --gbram-text-muted:   #8890aa;
  --gbram-header-text:  #0e0e0e;
  --gbram-radius:       8px;
  --gbram-font:         -apple-system, 'Segoe UI', system-ui, sans-serif;
  --gbram-font-mono:    'Courier New', 'Fira Code', monospace;
}

/* ── Outer wrapper injected by JS ── */
.gbram-table-wrap {
  position: relative;
  width: 100%;
  margin: 1.6rem 0;
}

/* ── Mobile scroll hint label ── */
.gbram-scroll-hint {
  display: none;
  align-items: center;
  justify-content: center;
  gap: 6px;
  font-family: var(--gbram-font);
  font-size: 11px;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--gbram-accent);
  margin-bottom: 8px;
  animation: gbram-hint-pulse 2s ease-in-out infinite;
}
.gbram-scroll-hint svg {
  width: 14px;
  height: 14px;
  fill: var(--gbram-accent);
  flex-shrink: 0;
}
@keyframes gbram-hint-pulse {
  0%, 100% { opacity: 1; }
  50%       { opacity: .5; }
}

/* ── Search / filter input ── */
.gbram-search-wrap {
  margin-bottom: 10px;
}
.gbram-search {
  width: 100%;
  max-width: 340px;
  padding: 8px 14px;
  background: var(--gbram-bg-alt);
  border: 1px solid var(--gbram-border);
  border-radius: 6px;
  color: var(--gbram-text);
  font-family: var(--gbram-font);
  font-size: 13px;
  outline: none;
  transition: border-color .2s;
}
.gbram-search::placeholder { color: var(--gbram-text-muted); }
.gbram-search:focus { border-color: var(--gbram-accent); }

/* ── Scrollable container ── */
.gbram-table-scroll {
  width: 100%;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  border-radius: var(--gbram-radius);
  border: 1px solid var(--gbram-border);
  /* thin custom scrollbar */
  scrollbar-width: thin;
  scrollbar-color: var(--gbram-accent) var(--gbram-bg-alt);
}
.gbram-table-scroll::-webkit-scrollbar        { height: 5px; }
.gbram-table-scroll::-webkit-scrollbar-track  { background: var(--gbram-bg-alt); }
.gbram-table-scroll::-webkit-scrollbar-thumb  { background: var(--gbram-accent); border-radius: 3px; }

/* ── The table itself ── */
.gbram-table-scroll table,
.gbram-table-scroll > table {
  width: 100%;
  min-width: 400px;
  border-collapse: collapse;
  border-spacing: 0;
  font-family: var(--gbram-font);
  font-size: 14px;
  color: var(--gbram-text);
  background: var(--gbram-bg);
  margin: 0 !important;     /* kill theme margins */
  padding: 0 !important;
}

/* ── Header row ── */
.gbram-table-scroll table thead tr,
.gbram-table-scroll table tr:first-child:has(th) {
  background: var(--gbram-accent) !important;
}
.gbram-table-scroll table thead th,
.gbram-table-scroll table tr:first-child th {
  background: var(--gbram-accent) !important;
  color: var(--gbram-header-text) !important;
  font-weight: 700;
  font-size: 12px;
  letter-spacing: .08em;
  text-transform: uppercase;
  padding: 11px 16px;
  white-space: nowrap;
  border: none !important;
  border-right: 1px solid rgba(0,0,0,.12) !important;
  text-align: left;
}
.gbram-table-scroll table thead th:last-child,
.gbram-table-scroll table tr:first-child th:last-child {
  border-right: none !important;
}

/* ── Body cells ── */
.gbram-table-scroll table td {
  padding: 10px 16px;
  border-bottom: 1px solid var(--gbram-border);
  border-right: 1px solid var(--gbram-border);
  vertical-align: middle;
  line-height: 1.5;
  color: var(--gbram-text) !important;
  background: transparent;
}
.gbram-table-scroll table td:last-child {
  border-right: none;
}
.gbram-table-scroll table tr:last-child td {
  border-bottom: none;
}

/* ── Striped rows ── */
.gbram-stripe .gbram-table-scroll table tbody tr:nth-child(even) td,
.gbram-stripe .gbram-table-scroll table tr:not(:first-child):nth-child(even) td {
  background: var(--gbram-bg-alt) !important;
}

/* ── Hover rows ── */
.gbram-hover .gbram-table-scroll table tbody tr:hover td,
.gbram-hover .gbram-table-scroll table tr:not(:first-child):hover td {
  background: var(--gbram-bg-hover) !important;
  transition: background .15s ease;
}

/* ── Accent left border on first TD column ── */
.gbram-table-scroll table tbody td:first-child,
.gbram-table-scroll table tr:not(:first-child) td:first-child {
  border-left: 3px solid var(--gbram-accent);
  font-weight: 500;
}

/* ── Code / keyboard content inside cells ── */
.gbram-table-scroll table td code,
.gbram-table-scroll table td kbd {
  font-family: var(--gbram-font-mono);
  font-size: 12.5px;
  background: rgba(245,166,35,.12);
  color: var(--gbram-accent);
  border: 1px solid rgba(245,166,35,.25);
  border-radius: 4px;
  padding: 2px 6px;
  white-space: nowrap;
}

/* ── Hidden rows (search filter) ── */
.gbram-row-hidden {
  display: none !important;
}

/* ── No-results message ── */
.gbram-no-results {
  display: none;
  padding: 16px 20px;
  font-size: 13px;
  color: var(--gbram-text-muted);
  font-family: var(--gbram-font);
  border-top: 1px solid var(--gbram-border);
}

/* ── Row count badge ── */
.gbram-row-count {
  font-family: var(--gbram-font);
  font-size: 11px;
  color: var(--gbram-text-muted);
  margin-top: 6px;
  padding-left: 2px;
}
.gbram-row-count span {
  color: var(--gbram-accent);
  font-weight: 600;
}

/* ══════════════════════════════════════════════════
   RESPONSIVE BREAKPOINTS
   ══════════════════════════════════════════════════ */

/* ── Show scroll hint on mobile ── */
@media (max-width: 640px) {
  .gbram-show-hint .gbram-scroll-hint {
    display: flex;
  }

  /* Tighten cell padding on small screens */
  .gbram-table-scroll table th,
  .gbram-table-scroll table td {
    padding: 8px 10px;
    font-size: 13px;
  }

  .gbram-search {
    max-width: 100%;
  }
}

@media (max-width: 400px) {
  .gbram-table-scroll table th,
  .gbram-table-scroll table td {
    padding: 7px 8px;
    font-size: 12px;
  }
}

/* ── Print: no accent BG, readable ── */
@media print {
  .gbram-scroll-hint,
  .gbram-search-wrap { display: none !important; }
  .gbram-table-scroll {
    overflow: visible;
    border: 1px solid #ccc;
  }
  .gbram-table-scroll table {
    color: #000 !important;
    background: #fff !important;
  }
  .gbram-table-scroll table thead th {
    background: #333 !important;
    color: #fff !important;
  }
}
