/*!
 * TableFilter.css — v1.0.0
 * Stylesheet for the TableFilter.js plugin.
 * Supports: [data-tf-theme="dark"] and [data-tf-theme="light"]
 */

@import url('https://fonts.googleapis.com/css2?family=DM+Mono:wght@400;500&family=Syne:wght@400;600;700&display=swap');

/* ══════════════════════════════════════════
   CSS VARIABLES — DARK THEME (default)
══════════════════════════════════════════ */
.tf-table,
.tf-wrapper {
  --tf-bg:        #0d0f14;
  --tf-surface:   #13161e;
  --tf-surface2:  #1b1f2b;
  --tf-border:    #252935;
  --tf-accent:    #5b9cf6;
  --tf-accent2:   #a78bfa;
  --tf-text:      #e8eaf0;
  --tf-muted:     #6b7280;
  --tf-shadow:    rgba(0, 0, 0, 0.6);
  --tf-row-hover: #1b1f2b;
  --tf-radius:    8px;
  --tf-font-body: 'Arial-Narrow', sans-serif;
  --tf-font-mono: 'Arial-Narrow', sans-serif;
}

/* ══════════════════════════════════════════
   LIGHT THEME
══════════════════════════════════════════ */
.tf-table[data-tf-theme="light"],
.tf-wrapper:has(.tf-table[data-tf-theme="light"]) {
  --tf-bg:        #f5f6fa;
  --tf-surface:   #ffffff;
  --tf-surface2:  #f0f1f5;
  --tf-border:    #c3c4c7;
  --tf-accent:    #3b7ef8;
  --tf-accent2:   #7c5cbf;
  --tf-text:      #1a1d26;
  --tf-muted:     #000!important;
  --tf-shadow:    rgba(0, 0, 0, 0.12);
  --tf-row-hover: #f0f1f5;
}

/* ══════════════════════════════════════════
   WRAPPER
══════════════════════════════════════════ */
.tf-wrapper {
  font-family: var(--tf-font-body);
  background: var(--tf-surface);
  border: 1px solid var(--tf-border);
  border-radius: 6px;
  overflow: visible;
  /* box-shadow: 0 0px 60px var(--tf-shadow); */
  position: relative;
  margin-top:20px;
}

/* ══════════════════════════════════════════
   TOOLBAR
══════════════════════════════════════════ */
.tf-toolbar {
  display: flex;
  align-items: center;
  /* justify-content: space-between; */
  padding: 0.25rem .5rem;
  /* background: var(--tf-surface2); */
  /* border-bottom: 1px solid var(--tf-border); */
  border-radius: 6px 12px 0 0;
  flex-wrap: wrap;
  gap: 0.5rem;
  width:100%
}

.tf-count {
  font-family: var(--tf-font-mono);
  font-size: 0.75rem;
  color: var(--tf-muted);
}

.tf-count-visible {
  color: var(--tf-accent);
  font-weight: 600;
}

.tf-clear-btn {
  font-family: var(--tf-font-body);
  font-size: 0.75rem;
  font-weight: 600;
  padding: 0.32rem 0.85rem;
  border-radius: 6px;
  border: 1px solid var(--tf-border);
  background: transparent;
  color: var(--tf-muted);
  cursor: pointer;
  transition: border-color 0.2s, color 0.2s;
}

.tf-clear-btn:hover {
  border-color: var(--tf-accent);
  color: var(--tf-accent);
}

/* ══════════════════════════════════════════
   TABLE BASE
══════════════════════════════════════════ */
.tf-table {
  width: 100%;
  border-collapse: collapse;
  color: var(--tf-text);
}

.tf-table thead th {
  background: var(--tf-surface2);
  border-bottom: 2px solid var(--tf-border);
  padding: 0;
  vertical-align: top;
  position: relative;
}

/* Header label row */
.tf-table thead tr:first-child th {
  padding: 0.85rem 1rem;
  font-family: var(--tf-font-body);
  font-size: 0.72rem;
  font-weight: 700;
  /* letter-spacing: 0.08em; */
  /* text-transform: uppercase; */
  color: var(--tf-muted);
  white-space: nowrap;
}

/* Sortable header */
.tf-table thead tr:first-child th.tf-sortable {
  cursor: pointer;
  user-select: none;
  transition: color 0.2s;
}

.tf-table thead tr:first-child th.tf-sortable:hover {
  color: var(--tf-text);
}

/* Sort icon */
.tf-sort-icon {
  display: inline-block;
  margin-left: 0.4rem;
  font-size: 0.62rem;
  opacity: 0.4;
  transition: opacity 0.2s, color 0.2s;
  vertical-align: middle;
}

.tf-sort-icon.tf-sorted {
  opacity: 1;
  color: var(--tf-accent);
}

/* ══════════════════════════════════════════
   FILTER ROW CELLS
══════════════════════════════════════════ */
.tf-filter-row th.tf-filter-cell {
  /* padding: 0.2rem 0.2rem 0.2rem; */
  padding: 0px!important;
  background: var(--tf-surface2);
  border-bottom: 2px solid var(--tf-border);
  text-transform: none;
  /* letter-spacing: 0; */
  font-size: 0.8rem;
  font-weight: 400;
  vertical-align: top;
  position: relative;
}

/* ══════════════════════════════════════════
   TEXT / NUMBER INPUT
══════════════════════════════════════════ */
.tf-input-wrap {
  position: relative;
}

.tf-input {
  width: 100%;
  font-family: var(--tf-font-mono);
  font-size: 0.74rem;
  padding: 0.2rem 0.2rem;
  background: #ffffdd;
  border:none;
  /* border: 1px solid var(--tf-border); */
  /* border-radius: 6px; */
  color: var(--tf-text);
  outline: none;
  transition: border-color 0.2s, box-shadow 0.2s, background 0.2s;
  appearance: none;
  -webkit-appearance: none;
  min-width: 60px;
}

.tf-input::placeholder {
  color: black!important;
  opacity: 0.5;
}

.tf-input:focus {
  border-color: var(--tf-accent);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--tf-accent) 20%, transparent);
}

.tf-input.tf-active {
  border-color: var(--tf-accent2);
  background: color-mix(in srgb, var(--tf-accent2) 6%, var(--tf-bg));
}

/* Single select arrow */
.tf-select {
  cursor: pointer;
  padding-right: 1.8rem;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M0 0l5 6 5-6z' fill='%236b7280'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 0.6rem center;
  background-size: 8px;
}

/* ══════════════════════════════════════════
   MULTI-SELECT TRIGGER
══════════════════════════════════════════ */
.tf-ms-wrap {
  position: relative;
  min-width: 10px;
}

.tf-ms-trigger {
  width: 100%;
  font-family: var(--tf-font-mono);
  font-size: 0.74rem;
  padding: 0.20rem 0.4rem;
  background: #ffffdd;
  border: 0px none var(--tf-border);
  border-radius: 0px;
  color: var(--tf-muted);
  cursor: pointer;
  display: flex;
  align-items: center;
  gap: 0.3rem;
  text-align: left;
  transition: border-color 0.2s, box-shadow 0.2s, background 0.2s;
}

.tf-ms-trigger:hover {
  border-color: var(--tf-accent);
}

.tf-ms-trigger.tf-open {
  border-color: var(--tf-accent2);
  box-shadow: 0 0 0 3px color-mix(in srgb, var(--tf-accent2) 18%, transparent);
}

.tf-ms-trigger.tf-active {
  border-color: var(--tf-accent2);
  background: color-mix(in srgb, var(--tf-accent2) 6%, var(--tf-bg));
  color: var(--tf-text);
}

.tf-ms-label {
  flex: 1;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.tf-ms-arrow {
  font-size: 0.52rem;
  opacity: 0.45;
  flex-shrink: 0;
  transition: transform 0.2s, opacity 0.2s;
}

.tf-ms-trigger.tf-open .tf-ms-arrow {
  transform: rotate(180deg);
  opacity: 0.9;
}

/* Count badge */
.tf-ms-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 17px;
  height: 17px;
  padding: 0 4px;
  background: var(--tf-accent2);
  color: #fff;
  border-radius: 9px;
  font-size: 0.6rem;
  font-weight: 700;
  flex-shrink: 0;
}

/* ══════════════════════════════════════════
   MULTI-SELECT PANEL
══════════════════════════════════════════ */
.tf-ms-panel {
  display: none;
  position: absolute;
  top: calc(100% + 3px);
  left: 0;
  min-width: 40px;
  width: max-content;
  max-width: 260px; 
  background: var(--tf-surface2);
  border: 1px solid var(--tf-accent2);
  border-radius: var(--tf-radius);
  box-shadow: 0 16px 48px var(--tf-shadow);
  z-index: 9999;
  overflow: hidden;
}

.tf-ms-panel.tf-open {
  display: block;
  animation: tf-pop-in 0.15s ease;
}

@keyframes tf-pop-in {
  from { opacity: 0; transform: translateY(-5px) scale(0.97); }
  to   { opacity: 1; transform: translateY(0) scale(1); }
}

/* Panel search */
.tf-ms-search {
  width: 100%;
  font-family: var(--tf-font-mono);
  font-size: 0.72rem;
  padding: 0.48rem 0.7rem;
  background: var(--tf-bg);
  border: none;
  border-bottom: 1px solid var(--tf-border);
  color: var(--tf-text);
  outline: none;
}

.tf-ms-search::placeholder { color: var(--tf-muted); }

/* Panel action bar */
.tf-ms-actions {
  display: flex;
  border-bottom: 1px solid var(--tf-border);
}

.tf-ms-action {
  flex: 1;
  font-family: var(--tf-font-mono);
  font-size: 0.67rem;
  padding: 0.3rem 0.5rem;
  background: transparent;
  border: none;
  color: var(--tf-muted);
  cursor: pointer;
  transition: background 0.12s, color 0.12s;
  text-align: center;
}

.tf-ms-action:hover {
  background: color-mix(in srgb, var(--tf-accent) 8%, transparent);
  color: var(--tf-text);
}

.tf-ms-action + .tf-ms-action {
  border-left: 1px solid var(--tf-border);
}

/* Options list */
.tf-ms-options {
  max-height: 190px;
  overflow-y: auto;
  scrollbar-width: thin;
  scrollbar-color: var(--tf-border) transparent;
}

.tf-ms-option {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.45rem 0.75rem;
  font-family: var(--tf-font-mono);
  font-size: 0.74rem;
  color: var(--tf-text);
  cursor: pointer;
  user-select: none;
  transition: background 0.1s;
}

.tf-ms-option:hover {
  background: color-mix(in srgb, var(--tf-accent) 8%, transparent);
}

.tf-ms-option input[type="checkbox"] {
  accent-color: var(--tf-accent2);
  width: 14px;
  height: 14px;
  cursor: pointer;
  flex-shrink: 0;
}

.tf-ms-option.tf-hidden {
  display: none !important;
}

/* ══════════════════════════════════════════
   TABLE BODY ROWS
══════════════════════════════════════════ */
.tf-table tbody tr {
  border-bottom: 1px solid var(--tf-border);
  transition: background 0.12s;
}

.tf-table tbody tr:last-child {
  border-bottom: none;
}

.tf-table tbody tr:hover {
  background: var(--tf-row-hover);
}

.tf-table tbody tr.tf-row-hidden {
  display: none;
}

.tf-table td {
  padding: 0.8rem 1rem;
  font-size: 0.85rem;
  color: var(--tf-text);
  vertical-align: middle;
}

/* ══════════════════════════════════════════
   NO RESULTS MESSAGE
══════════════════════════════════════════ */
.tf-no-results {
  display: none;
  text-align: center;
  padding: 2.5rem 1rem;
  font-family: var(--tf-font-mono);
  font-size: 0.8rem;
  color: var(--tf-muted);
  border-top: 1px solid var(--tf-border);
}

.tf-no-results.tf-visible {
  display: block;
}

/* ══════════════════════════════════════════
   SCROLLABLE TABLE (optional utility)
══════════════════════════════════════════ */
.tf-scroll {
  overflow-x: auto;
}
