/* ============================================================
   NXT Datasette Theme — pilot-matching
   ============================================================ */

@import url('https://assets.plataforma.app/nxt-theme/tokens.css');

/* ─── reset & base ─── */
html, body {
  background: var(--background) !important;
  color: var(--foreground) !important;
  font-family: var(--font-sans) !important;
  font-feature-settings: "ss01", "ss02", "cv11";
  font-optical-sizing: auto;
  letter-spacing: -0.005em;
  line-height: 1.5;
}

a {
  color: var(--foreground) !important;
  text-decoration: none;
  transition: color 180ms var(--ease-quart-out);
}
a:hover {
  color: var(--nxt) !important;
}
/* dashed underline somente em prosa/conteúdo (não em chrome/topbar) */
.markdown-rendered a,
.description-text a {
  border-bottom: 1px dashed var(--border);
}
.markdown-rendered a:hover,
.description-text a:hover {
  border-bottom-color: var(--nxt);
}

/* ─── headings ─── */
h1, h2, h3, h4, h5, h6 {
  font-family: var(--font-display);
  color: var(--foreground) !important;
  letter-spacing: -0.02em;
  font-weight: 600;
}
h1 {
  font-size: 1.875rem;
  border-bottom: 1px solid var(--border);
  padding-bottom: 0.75rem;
  margin-bottom: 1.25rem;
  line-height: 1.15;
}
h2 { font-size: 1.5rem; line-height: 1.2; }
h3 { font-size: 1.125rem; line-height: 1.3; }

/* ─── topbar / header (alinhado com pilot + assets) ─── */
header {
  background: var(--sidebar) !important;
  border-bottom: 1px solid var(--sidebar-border) !important;
  height: var(--titlebar-h);
  padding: 0 1.25rem !important;
  position: sticky;
  top: 0;
  z-index: 100;
  backdrop-filter: blur(12px);
}
header h1 {
  font-size: 0.875rem !important;
  border-bottom: none;
  padding: 0;
  margin: 0;
  font-weight: 500;
}
header h1::after {
  content: "";
  display: inline-block;
  width: 1px;
  height: 14px;
  background: var(--border);
  margin-left: 0.75rem;
  vertical-align: middle;
}
header a { border-bottom: none; }
header nav {
  display: flex !important;
  gap: 0.5rem !important;
  align-items: center !important;
  width: 100%;
}
/* crumbs herdam estilo do header — sem border-bottom dashed */
header nav .crumbs { margin: 0; }
header nav .crumbs a {
  border-bottom: none !important;
  font-size: 0.875rem;
  color: var(--foreground) !important;
}
header nav .crumbs a:hover { color: var(--nxt) !important; }
/* nav-menu (hamburger) discreto */
header .nav-menu summary {
  cursor: pointer;
  padding: 4px 8px;
  border-radius: var(--radius-md);
  color: var(--muted-foreground);
}
header .nav-menu summary:hover { color: var(--nxt); }
header .nav-menu .nav-menu-inner {
  background: var(--popover);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 8px;
  margin-top: 4px;
}
header .nav-menu a { color: var(--foreground) !important; }
header .nav-menu a:hover { color: var(--nxt) !important; }

/* ─── tables (the heart of Datasette) ─── */
table {
  background: var(--card) !important;
  color: var(--card-foreground) !important;
  border: 1px solid var(--border) !important;
  border-radius: var(--radius);
  border-collapse: separate;
  border-spacing: 0;
  overflow: hidden;
  font-size: 13px;
}
table thead th {
  background: var(--sidebar) !important;
  color: var(--muted-foreground) !important;
  font-family: var(--font-mono);
  font-size: 11px !important;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  padding: 10px 12px !important;
  border-bottom: 1px solid var(--border) !important;
  position: sticky;
  top: var(--titlebar-h);
  z-index: 10;
}
table tbody tr {
  border-bottom: 1px solid var(--border);
  transition: background 120ms var(--ease-quart-out);
}
table tbody tr:hover {
  background: oklch(from var(--card) calc(l + 0.04) c h) !important;
}
table tbody tr:nth-child(even) {
  background: oklch(from var(--card) calc(l - 0.015) c h) !important;
}
table td, table th {
  border-color: var(--border) !important;
  padding: 8px 12px !important;
  vertical-align: top;
}

/* ─── primary key highlight ─── */
table .pk {
  font-family: var(--font-mono);
  color: var(--nxt) !important;
  font-weight: 500;
}

/* ─── facets sidebar ─── */
.facets, .facet-info {
  background: var(--card) !important;
  border: 1px solid var(--border) !important;
  border-radius: var(--radius);
  padding: 12px 14px !important;
  margin: 8px 0;
}
.facet-info h2, .facet-info h3 {
  color: var(--nxt) !important;
  font-family: var(--font-mono);
  font-size: 10px !important;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  margin: 0 0 8px 0;
  border-bottom: none;
  padding-bottom: 0;
}
.facet-info ul {
  list-style: none;
  padding: 0;
  margin: 0;
}
.facet-info li {
  padding: 3px 0;
  font-size: 13px;
}
.facet-info a {
  border-bottom: none;
  color: var(--card-foreground) !important;
}
.facet-info a:hover {
  color: var(--nxt) !important;
}
.facet-info .count {
  color: var(--muted-foreground);
  font-family: var(--font-mono);
  font-size: 11px;
  margin-left: 6px;
}

/* ─── inputs ─── */
input[type="text"],
input[type="search"],
input[type="number"],
input[type="email"],
input[type="password"],
input[type="url"],
textarea,
select {
  background: var(--input) !important;
  color: var(--foreground) !important;
  border: 1px solid var(--border) !important;
  padding: 7px 12px !important;
  border-radius: var(--radius-md) !important;
  font-family: var(--font-sans);
  font-size: 13px;
  transition: border-color 150ms var(--ease-quart-out), box-shadow 150ms var(--ease-quart-out);
}
input[type="text"]:focus,
input[type="search"]:focus,
textarea:focus,
select:focus {
  border-color: var(--nxt) !important;
  outline: none;
  box-shadow: 0 0 0 3px oklch(from var(--nxt) l c h / 0.15);
}

/* ─── buttons (subtle por default — lime APENAS em primary CTAs explícitos) ─── */
button:not(.nxt-theme-toggle):not(.md-icon),
input[type="submit"],
.button:not(.nxt-theme-toggle) {
  background: var(--card);
  color: var(--foreground);
  border: 1px solid var(--border);
  padding: 7px 14px;
  border-radius: var(--radius-md);
  cursor: pointer;
  font-family: var(--font-sans);
  font-weight: 500;
  font-size: 13px;
  letter-spacing: -0.01em;
  transition: border-color 150ms var(--ease-quart-out), background 150ms var(--ease-quart-out);
}
button:not(.nxt-theme-toggle):not(.md-icon):hover,
input[type="submit"]:hover,
.button:not(.nxt-theme-toggle):hover {
  border-color: var(--nxt);
  background: oklch(from var(--card) calc(l + 0.04) c h);
}

/* primary CTA — opt-in via .button-primary classe explícita */
.button-primary, button.primary {
  background: var(--nxt) !important;
  color: var(--nxt-fg) !important;
  border: none !important;
}

/* ─── code & pre (pretty-json plugin) ─── */
code, pre, .json-pretty {
  background: var(--popover) !important;
  color: var(--foreground) !important;
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  font-family: var(--font-mono) !important;
  font-size: 12px;
  font-feature-settings: "ss02";
  letter-spacing: 0;
}
pre {
  padding: 12px 14px !important;
  overflow-x: auto;
  line-height: 1.5;
}
code {
  padding: 1px 6px !important;
}

/* JSON pretty colors (datasette-pretty-json) */
.json-pretty .json-key { color: var(--nxt) !important; font-weight: 500; }
.json-pretty .json-string { color: oklch(0.78 0.09 197) !important; }
.json-pretty .json-number { color: oklch(0.80 0.16 75) !important; }
.json-pretty .json-boolean { color: oklch(0.70 0.18 22) !important; }
.json-pretty .json-null { color: var(--muted-foreground) !important; font-style: italic; }

/* ─── images / logos (datasette-render-images, restrito a tables) ─── */
table img {
  max-width: 32px !important;
  max-height: 32px !important;
  border-radius: var(--radius-sm);
  background: var(--card);
  border: 1px solid var(--border);
  object-fit: contain;
  padding: 2px;
}

/* NXT logo no header — sem constraints de tabela */
.nxt-logo {
  max-width: none !important;
  max-height: 1.5rem !important;
  border: none !important;
  background: transparent !important;
  padding: 0 !important;
  border-radius: 0 !important;
}

/* ─── markdown rendered (datasette-render-markdown) ─── */
.markdown-rendered {
  font-size: 13px;
  line-height: 1.6;
  color: var(--muted-foreground);
}
.markdown-rendered h1,
.markdown-rendered h2,
.markdown-rendered h3 {
  border-bottom: none;
  padding-bottom: 0;
  margin-top: 1rem;
}
.markdown-rendered code {
  font-size: 11px;
}
.markdown-rendered a { color: var(--nxt) !important; }

/* ─── footer (override Datasette's bright teal default) ─── */
footer.ft, footer {
  color: var(--muted-foreground) !important;
  background: var(--sidebar) !important;
  border-top: 1px solid var(--border) !important;
  padding: 14px 1.25rem !important;
  margin-top: 40px;
  font-size: 11px;
  font-family: var(--font-mono);
}
footer.ft a, footer a {
  color: var(--foreground) !important;
  border-bottom: none !important;
}
footer.ft a:hover, footer a:hover {
  color: var(--nxt) !important;
}

/* ─── Datasette table title decoration (the teal bar before "recursos") ─── */
.index h2,
h2.index {
  border-left: 3px solid var(--nxt) !important;
  padding-left: 12px !important;
  background: transparent !important;
}

/* ─── Search submit button (Datasette homepage) ─── */
input[type="submit"][value="Search"] {
  background: var(--card) !important;
  color: var(--foreground) !important;
  border: 1px solid var(--border) !important;
}
input[type="submit"][value="Search"]:hover {
  border-color: var(--nxt) !important;
  background: oklch(from var(--card) calc(l + 0.04) c h) !important;
}

/* ─── pagination ─── */
.pagination {
  margin: 16px 0;
  display: flex;
  gap: 6px;
  align-items: center;
}
.pagination a {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  padding: 5px 10px;
  font-size: 13px;
  font-family: var(--font-mono);
}
.pagination a:hover {
  background: oklch(from var(--nxt) l c h / 0.10);
  color: var(--nxt) !important;
  border-color: var(--nxt);
}
.pagination a.this-page,
.pagination a[aria-current="page"] {
  background: var(--nxt);
  color: var(--nxt-fg) !important;
  border-color: var(--nxt);
}

/* ─── selection ─── */
::selection {
  background: var(--nxt);
  color: var(--nxt-fg);
}

/* ─── scrollbar ─── */
::-webkit-scrollbar {
  width: 10px;
  height: 10px;
}
::-webkit-scrollbar-track {
  background: var(--background);
}
::-webkit-scrollbar-thumb {
  background: var(--border);
  border-radius: 5px;
  border: 2px solid var(--background);
}
::-webkit-scrollbar-thumb:hover {
  background: var(--muted-foreground);
}

/* ─── description html (top of page) ─── */
.search, .search-content, .rendered-content {
  font-family: var(--font-sans);
}

.description-text {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 16px 20px;
  margin: 16px 0;
  font-size: 14px;
  color: var(--muted-foreground);
}
.description-text strong {
  color: var(--foreground);
  font-weight: 500;
}
.description-text a {
  color: var(--foreground) !important;
  border-bottom: 1px dashed var(--border);
  padding: 0 1px;
  transition: color 150ms var(--ease-quart-out), border-color 150ms var(--ease-quart-out);
}
.description-text a:hover {
  color: var(--nxt) !important;
  border-bottom-color: var(--nxt);
}

/* ─── dashboards (datasette-dashboards) ─── */
.dashboard-wrapper, .dashboard {
  background: var(--background);
}
.dashboard-card,
.dashboards-charts > div {
  background: var(--card) !important;
  border: 1px solid var(--border) !important;
  border-radius: var(--radius);
  padding: 16px 18px !important;
}
.dashboard-card h3,
.dashboards-charts h3 {
  font-family: var(--font-mono);
  font-size: 11px !important;
  color: var(--muted-foreground) !important;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  border-bottom: none;
  padding-bottom: 0;
}

/* ─── small details / counts / badges ─── */
.count-link, .num {
  background: oklch(from var(--nxt) l c h / 0.12) !important;
  color: var(--nxt) !important;
  font-family: var(--font-mono);
  font-size: 11px;
  padding: 2px 7px;
  border-radius: 999px;
  font-weight: 500;
}

/* SQL editor (CodeMirror) */
.cm-editor {
  background: var(--popover) !important;
  font-family: var(--font-mono) !important;
  border-radius: var(--radius);
  border: 1px solid var(--border);
}

/* ============================================================
   Page-load staggered animations
   ============================================================ */
@keyframes nxt-fade-up {
  from { opacity: 0; transform: translateY(8px); }
  to { opacity: 1; transform: translateY(0); }
}
header { animation: nxt-fade-up 380ms var(--ease-expo-out); }
h1 { animation: nxt-fade-up 420ms 60ms var(--ease-expo-out) backwards; }
.facet-info { animation: nxt-fade-up 460ms 120ms var(--ease-expo-out) backwards; }
table { animation: nxt-fade-up 500ms 180ms var(--ease-expo-out) backwards; }
.dashboards-charts > div { animation: nxt-fade-up 480ms calc(80ms * var(--i, 1)) var(--ease-expo-out) backwards; }
.dashboards-charts > div:nth-child(1) { --i: 1; }
.dashboards-charts > div:nth-child(2) { --i: 2; }
.dashboards-charts > div:nth-child(3) { --i: 3; }
.dashboards-charts > div:nth-child(4) { --i: 4; }
.dashboards-charts > div:nth-child(5) { --i: 5; }
.dashboards-charts > div:nth-child(6) { --i: 6; }

/* Respect prefers-reduced-motion */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation-duration: 0.01ms !important; transition-duration: 0.01ms !important; }
}

/* ============================================================
   Vega-Lite chart wrappers (datasette-dashboards)
   ============================================================ */
.vega-embed {
  background: var(--card) !important;
  border-radius: var(--radius-sm);
  padding: 6px;
}
.vega-embed canvas, .vega-embed svg {
  background: transparent;
}
.vega-embed .marks { background: transparent; }
.vega-embed details summary { color: var(--muted-foreground); font-family: var(--font-mono); font-size: 11px; }
