/* Smart TOC – Frontend Styles */

.stoc {
	display: block;
	margin: 1.5em 0;
	background: var(--stoc-bg, #f8fafc);
	border: 1px solid var(--stoc-border, #e2e8f0);
	border-radius: var(--stoc-radius, 6px);
	overflow: hidden;
	box-shadow: var(--stoc-shadow, none);
	font-family: inherit;
	font-size: 1em;
}

.stoc *,
.stoc *::before,
.stoc *::after { box-sizing: border-box; }

/* Progress bar */
.stoc-progress {
	height: 3px;
	background: rgba(59,130,246,.15);
}
.stoc-progress__fill {
	height: 100%;
	width: 0;
	background: var(--stoc-accent, #3b82f6);
	transition: width .12s linear;
	will-change: width;
}

/* Header */
.stoc__header {
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: 11px 16px;
	border-bottom: 1px solid var(--stoc-border, #e2e8f0);
	gap: 8px;
	outline: none;
}
.stoc__header[role="button"] { cursor: pointer; user-select: none; }
.stoc__header:focus-visible  { outline: 2px solid var(--stoc-accent, #3b82f6); outline-offset: -2px; }

.stoc-title {
	font-size: var(--stoc-title-fs, 115%);
	font-weight: var(--stoc-title-fw, 600);
	color: var(--stoc-title-c, #1e293b);
	line-height: 1.3;
	margin: 0;
}

/* Toggle button */
.stoc-toggle {
	background: none;
	border: none;
	padding: 2px 4px;
	cursor: pointer;
	color: var(--stoc-title-c, #1e293b);
	opacity: .55;
	flex-shrink: 0;
	line-height: 0;
	transition: opacity .12s;
}
.stoc-toggle:hover { opacity: 1; }
.stoc-toggle:focus-visible { outline: 2px solid var(--stoc-accent, #3b82f6); border-radius: 3px; }

/* Panel */
.stoc__panel { padding: 8px 15px 10px; }

/* ── List reset — must be !important to beat theme ol/ul/li styles ── */
.stoc .stoc-list,
.stoc .stoc-list li,
.stoc ul.stoc-list,
.stoc ul.stoc-list li {
	list-style: none !important;
	list-style-type: none !important;
	margin: 0 !important;
	padding: 0 !important;
}
.stoc .stoc-list::before,
.stoc .stoc-list::after,
.stoc .stoc-item::before,
.stoc .stoc-item::after {
	/* block any stray theme ::before/::after on list elements */
	content: none !important;
}

.stoc .stoc-list {
	padding: 0 14px !important;
}
.stoc .stoc-list .stoc-list {
	padding-left: 14px !important;
	margin-top: 2px !important;
}

/* Links */
.stoc .stoc-link {
	display: block;
	padding: 4px 2px;
	font-size: var(--stoc-link-fs, 95%);
	font-weight: var(--stoc-link-fw, 400);
	color: var(--stoc-link-c, #475569);
	text-decoration: none;
	line-height: 1.45;
	border-radius: 3px;
	transition: color .13s;
}
.stoc .stoc-link:hover   { color: var(--stoc-hover-c, #2563eb); text-decoration: underline; text-underline-offset: 3px; }
.stoc .stoc-link:visited { color: var(--stoc-visited-c, #7c3aed); }
.stoc .stoc-link:focus-visible { outline: 2px solid var(--stoc-accent, #3b82f6); outline-offset: 2px; }

/* Active state set by JS */
.stoc .stoc-link.is-active {
	color: var(--stoc-accent, #3b82f6) !important;
	font-weight: 600;
}

/* ── Counter styles ────────────────────────────────────────────
   All numbering/bullets are done via CSS ::before — never via the
   browser's native list marker, which would cause double-numbering.
──────────────────────────────────────────────────────────────── */

/* Decimal: nested counters (e.g. 1.  1.1.  1.2.) */
.stoc--counter-decimal .stoc-list                 { counter-reset: stoc-counter; }
.stoc--counter-decimal .stoc-list .stoc-list      { counter-reset: stoc-counter; }

.stoc--counter-decimal .stoc-link {
	display: flex;
	align-items: baseline;
	gap: 0;
}
.stoc--counter-decimal .stoc-link::before {
	counter-increment: stoc-counter;
	content: counters(stoc-counter, '.') '. ';
	font-weight: 500;
	color: var(--stoc-link-c, #475569);
	opacity: .7;
	flex-shrink: 0;
	min-width: 1.8em;
	margin-right: .25em;
}

/* Bullets */
.stoc--counter-disc   .stoc-link::before { content: '•';  margin-right: .4em; color: var(--stoc-accent, #3b82f6); }
.stoc--counter-circle .stoc-link::before { content: '○';  margin-right: .4em; color: var(--stoc-accent, #3b82f6); }
.stoc--counter-square .stoc-link::before { content: '▪';  margin-right: .4em; color: var(--stoc-accent, #3b82f6); }

/* None: no ::before at all */
.stoc--counter-none .stoc-link::before { content: none; }

/* ── Reduced motion ── */
@media (prefers-reduced-motion: reduce) {
	.stoc-progress__fill,
	.stoc-toggle svg,
	.stoc .stoc-link { transition: none !important; }
}

/* ── 2-column layout ─────────────────────────────────
   Splits the top-level list into 2 columns on desktop.
   Nested sub-items follow their parent and never split.
──────────────────────────────────────────────────────── */
.stoc--cols-2 .stoc__panel > .stoc-list {
	columns: 2;
	column-gap: 1.5em;
}
/* Keep each item + its children together in one column */
.stoc--cols-2 .stoc-item {
	break-inside: avoid;
	-webkit-column-break-inside: avoid;
	page-break-inside: avoid;
}
/* On narrow screens fall back to 1 column */
@media (max-width: 640px) {
	.stoc--cols-2 .stoc__panel > .stoc-list {
		columns: 1;
	}
}
