/* ==========================================================================
   TBSJ DANI — theme-aware stylesheet.
   theme="auto" inherits font + color from the host theme. Borders use
   color-mix(currentColor) so they adapt to any palette.
   ========================================================================== */

.tbsj-dani, .tbsj-dani * { box-sizing: border-box; }
.tbsj-dani {
	--dani-accent:        #f7931a;
	--dani-accent-dim:    #c87010;
	--dani-rule:          color-mix(in srgb, currentColor 18%, transparent);
	--dani-rule-soft:     color-mix(in srgb, currentColor 10%, transparent);
	--dani-bg-soft:       color-mix(in srgb, currentColor 4%, transparent);
	--dani-mute:          color-mix(in srgb, currentColor 60%, transparent);
	--dani-pos:           #16a34a;
	--dani-neg:           #dc2626;
	--dani-mono:          ui-monospace, "JetBrains Mono", "SF Mono", Menlo, Consolas, monospace;
	font-family: inherit;
	color: inherit;
	line-height: 1.5;
	margin: 1.5rem 0;
}
.tbsj-dani a { color: inherit; text-decoration: none; }
.tbsj-dani a:hover { color: var(--dani-accent); }

.tbsj-dani-theme-light { background: #faf6ec; color: #1a1a1a; padding: 1.5rem; border: 1px solid color-mix(in srgb, #1a1a1a 12%, transparent); }
.tbsj-dani-theme-dark  { background: #0d0d0d; color: #ece6d5; padding: 1.5rem; border: 1px solid color-mix(in srgb, #ece6d5 15%, transparent); }

/* ── Masthead ── */
.tbsj-dani .dani-masthead {
	border-bottom: 2px solid currentColor;
	padding-bottom: 1rem;
	margin-bottom: 1.25rem;
}
.tbsj-dani .dani-tag {
	font-family: var(--dani-mono);
	font-size: 0.7rem;
	letter-spacing: 0.22em;
	text-transform: uppercase;
	color: var(--dani-accent);
	margin-bottom: 0.4rem;
}
.tbsj-dani .dani-h1 {
	font-size: clamp(2rem, 5vw, 3.4rem);
	font-weight: 800;
	letter-spacing: -0.02em;
	line-height: 1;
	margin: 0 0 0.4rem;
}
.tbsj-dani .dani-h1 em {
	font-style: italic;
	font-weight: 500;
	color: var(--dani-accent);
}
.tbsj-dani .dani-sub {
	font-size: 0.85rem;
	color: var(--dani-mute);
	display: flex;
	gap: 0.75rem;
	flex-wrap: wrap;
	align-items: baseline;
}
.tbsj-dani .dani-sub strong { color: inherit; font-weight: 600; }
.tbsj-dani .dani-sub a { color: var(--dani-accent); }

/* ── Category index grid ── */
.tbsj-dani .dani-cat-grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
	gap: 0;
	border-top: 1px solid var(--dani-rule);
	border-left: 1px solid var(--dani-rule);
}
.tbsj-dani .dani-cat-card {
	display: block;
	padding: 1.1rem 1.2rem;
	border-right: 1px solid var(--dani-rule);
	border-bottom: 1px solid var(--dani-rule);
	transition: background 150ms;
	position: relative;
	min-height: 7.5rem;
}
.tbsj-dani .dani-cat-card:hover {
	background: var(--dani-bg-soft);
}
.tbsj-dani .dani-cat-card:hover .dani-cat-arrow {
	transform: translateX(3px);
	color: var(--dani-accent);
}
.tbsj-dani .dani-cat-key {
	font-family: var(--dani-mono);
	font-size: 0.65rem;
	letter-spacing: 0.22em;
	text-transform: uppercase;
	color: var(--dani-accent);
	margin-bottom: 0.3rem;
}
.tbsj-dani .dani-cat-name {
	font-size: 1.15rem;
	font-weight: 700;
	letter-spacing: -0.01em;
	margin-bottom: 0.4rem;
	line-height: 1.2;
}
.tbsj-dani .dani-cat-desc {
	font-size: 0.85rem;
	color: var(--dani-mute);
	line-height: 1.4;
}
.tbsj-dani .dani-cat-arrow {
	position: absolute;
	top: 1.1rem;
	right: 1.2rem;
	font-size: 1rem;
	color: var(--dani-mute);
	transition: transform 150ms, color 150ms;
}

/* ── Toolbar (search) ── */
.tbsj-dani .dani-toolbar { margin: 1rem 0 0.75rem; }
.tbsj-dani .dani-search { display: flex; gap: 0.4rem; align-items: stretch; max-width: 32rem; flex-wrap: wrap; }
.tbsj-dani .dani-search input[type="search"] {
	flex: 1;
	min-width: 12rem;
	padding: 0.55em 0.8em;
	border: 1px solid var(--dani-rule);
	background: transparent;
	color: inherit;
	font-family: inherit;
	font-size: 0.9rem;
	border-radius: 0;
}
.tbsj-dani .dani-search input[type="search"]:focus {
	outline: 2px solid var(--dani-accent);
	outline-offset: -1px;
	border-color: var(--dani-accent);
}
.tbsj-dani .dani-search-btn {
	padding: 0.55em 1.1em;
	border: 1px solid currentColor;
	background: transparent;
	color: inherit;
	font-family: var(--dani-mono);
	font-size: 0.75rem;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	cursor: pointer;
}
.tbsj-dani .dani-search-btn:hover { background: var(--dani-accent); border-color: var(--dani-accent); color: #0a0a0a; }
.tbsj-dani .dani-clear { font-size: 0.75rem; color: var(--dani-mute); align-self: center; }

/* ── A-Z nav ── */
.tbsj-dani .dani-az {
	display: flex;
	flex-wrap: wrap;
	gap: 2px;
	padding-bottom: 0.85rem;
	margin-bottom: 0.75rem;
	border-bottom: 1px solid var(--dani-rule);
	font-family: var(--dani-mono);
}
.tbsj-dani .dani-az a, .tbsj-dani .dani-az span {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 1.7em;
	height: 1.7em;
	padding: 0 0.35em;
	font-size: 0.78rem;
	border: 1px solid transparent;
}
.tbsj-dani .dani-az a:hover { border-color: var(--dani-rule); color: inherit; }
.tbsj-dani .dani-az a.is-active { background: var(--dani-accent); color: #0a0a0a; border-color: var(--dani-accent); font-weight: 700; }
.tbsj-dani .dani-az .is-disabled { color: color-mix(in srgb, currentColor 25%, transparent); cursor: default; }

/* ── Stats line ── */
.tbsj-dani .dani-cat-meta { margin-bottom: 0.5rem; }
.tbsj-dani .dani-cat-blurb { color: var(--dani-mute); font-size: 0.95rem; margin: 0; }
.tbsj-dani .dani-stats {
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
	gap: 0.5rem 1rem;
	font-size: 0.85rem;
	color: var(--dani-mute);
	margin-bottom: 0.75rem;
}
.tbsj-dani .dani-stats strong { color: inherit; font-weight: 600; }
.tbsj-dani .dani-snapshot { font-family: var(--dani-mono); font-size: 0.7rem; letter-spacing: 0.15em; text-transform: uppercase; }

/* ── Two-column grid ── */
.tbsj-dani .dani-grid {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	border-top: 1px solid var(--dani-rule);
	border-left: 1px solid var(--dani-rule);
}
@media (max-width: 640px) {
	.tbsj-dani .dani-grid { grid-template-columns: 1fr; }
}
.tbsj-dani .dani-row {
	display: grid;
	grid-template-columns: 2.5rem 2rem 1fr auto;
	gap: 12px;
	align-items: center;
	padding: 12px 14px;
	border-right: 1px solid var(--dani-rule);
	border-bottom: 1px solid var(--dani-rule);
	transition: background 120ms;
	min-width: 0;
}
.tbsj-dani .dani-row:hover { background: var(--dani-bg-soft); }
.tbsj-dani .dani-row:hover .dani-name { color: var(--dani-accent); }
.tbsj-dani .dani-rank {
	font-family: var(--dani-mono);
	font-size: 0.7rem;
	color: var(--dani-mute);
	text-align: right;
}
.tbsj-dani .dani-img {
	width: 28px;
	height: 28px;
	border-radius: 50%;
	object-fit: cover;
	background: var(--dani-bg-soft);
}
.tbsj-dani .dani-img-ph { display: inline-block; }
.tbsj-dani .dani-id { min-width: 0; }
.tbsj-dani .dani-name {
	display: block;
	font-size: 0.95rem;
	font-weight: 600;
	line-height: 1.2;
	margin-bottom: 2px;
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
}
.tbsj-dani .dani-sym {
	display: block;
	font-family: var(--dani-mono);
	font-size: 0.7rem;
	color: var(--dani-mute);
	letter-spacing: 0.05em;
	text-transform: uppercase;
}
.tbsj-dani .dani-numbers { text-align: right; }
.tbsj-dani .dani-price {
	display: block;
	font-family: var(--dani-mono);
	font-size: 0.85rem;
	font-weight: 600;
}
.tbsj-dani .dani-change {
	display: block;
	font-family: var(--dani-mono);
	font-size: 0.7rem;
}
.tbsj-dani .dani-change.pos { color: var(--dani-pos); }
.tbsj-dani .dani-change.neg { color: var(--dani-neg); }

.tbsj-dani .dani-empty {
	grid-column: 1 / -1;
	padding: 4rem 1rem;
	text-align: center;
	color: var(--dani-mute);
	font-family: var(--dani-mono);
	letter-spacing: 0.12em;
	border-right: 1px solid var(--dani-rule);
	border-bottom: 1px solid var(--dani-rule);
}

/* ── Pagination ── */
.tbsj-dani .dani-pager {
	display: flex;
	justify-content: center;
	align-items: center;
	gap: 4px;
	flex-wrap: wrap;
	margin-top: 1.5rem;
	font-family: var(--dani-mono);
}
.tbsj-dani .dani-pager a, .tbsj-dani .dani-pager span {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-width: 2.3em;
	padding: 0.4em 0.7em;
	font-size: 0.8rem;
	border: 1px solid var(--dani-rule);
}
.tbsj-dani .dani-pager a:hover { background: var(--dani-bg-soft); }
.tbsj-dani .dani-pager .is-active { background: currentColor; color: var(--dani-accent); border-color: currentColor; font-weight: 700; }
.tbsj-dani .dani-pager .is-disabled { color: color-mix(in srgb, currentColor 25%, transparent); border-color: var(--dani-rule-soft); }
.tbsj-dani .dani-pager .dani-pg-dots { border: none; min-width: auto; padding: 0 4px; color: var(--dani-mute); }

/* ── Error + footer ── */
.tbsj-dani .dani-error {
	border: 1px solid var(--dani-rule);
	border-left: 3px solid #c0392b;
	padding: 0.75em 1em;
	margin-bottom: 1em;
	background: color-mix(in srgb, #c0392b 6%, transparent);
	font-size: 0.9em;
}
.tbsj-dani .dani-foot {
	margin-top: 2rem;
	padding-top: 1rem;
	border-top: 1px solid var(--dani-rule);
	font-family: var(--dani-mono);
	font-size: 0.7rem;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	color: var(--dani-mute);
	text-align: center;
}
