/*
 * Outliyr Interventions — /ratings/ archive + taxonomy archives.
 * Filter chips + URL state + density toggle + comparison checkboxes.
 */

.oi-archive {
	flex: 1 1 auto;
	min-width: 0;
	width: 100%;
	max-width: var(--oi-max-width);
	margin: 0 auto;
	padding: 2rem 1.5rem 4rem;
	color: var(--oi-text);
	font-family: var(--oi-font);
	container-type: inline-size;
}

.oi-sr-only {
	position: absolute;
	width: 1px;
	height: 1px;
	padding: 0;
	margin: -1px;
	overflow: hidden;
	clip: rect(0, 0, 0, 0);
	white-space: nowrap;
	border: 0;
}

/* ─── Header ───────────────────────────────────────────────── */

.oi-archive-header { margin-bottom: 2rem; text-align: center; }
.oi-archive-title {
	font-size: clamp(2rem, 4vw, 2.5rem);
	font-weight: 800;
	letter-spacing: -.02em;
	margin: 1rem 0 .5rem;
}
.oi-archive-intro {
	max-width: 680px;
	margin: 0 auto .75rem;
	color: var(--oi-text-soft);
}
.oi-archive-count {
	font-size: .85rem;
	color: var(--oi-text-dim);
	font-family: var(--oi-font-mono);
}

/* ─── Progress bar ─────────────────────────────────────────── */

.oi-progress {
	margin-bottom: 1.25rem;
	padding: .9rem 1.2rem;
	background: var(--oi-bg-raised);
	border: 1px solid var(--oi-border);
	border-radius: var(--oi-radius);
}
.oi-progress[hidden] { display: none; }

.oi-progress-inner {
	display: flex;
	flex-direction: column;
	gap: .5rem;
}

.oi-progress-bar {
	width: 100%;
	height: 8px;
	background: var(--oi-bg-sunken);
	border-radius: 4px;
	overflow: hidden;
}

.oi-progress-fill {
	width: 100%;
	height: 100%;
	background: var(--oi-accent);
	border-radius: 4px;
	transform-origin: left center;
}

.oi-progress-text {
	font-size: .85rem;
	color: var(--oi-text-soft);
	font-family: var(--oi-font-mono);
}

.oi-progress-milestones {
	display: flex;
	flex-wrap: wrap;
	gap: .4rem;
	margin-top: .5rem;
}

.oi-milestone {
	display: inline-flex;
	align-items: center;
	gap: .25rem;
	padding: .2rem .55rem;
	border-radius: var(--oi-radius);
	font-size: .72rem;
	font-weight: 600;
	border: 1px solid var(--oi-border);
	color: var(--oi-text-dim);
	background: var(--oi-bg);
	opacity: .5;
	transition: opacity .3s ease, border-color .3s ease;
}

.oi-milestone--earned {
	opacity: 1;
	color: var(--oi-accent);
	border-color: var(--oi-accent);
	background: color-mix(in srgb, var(--oi-accent) 8%, var(--oi-bg));
}

/* ─── Filters ──────────────────────────────────────────────── */

.oi-filters {
	display: flex;
	flex-direction: column;
	gap: 1rem;
	padding: 1.25rem 1.4rem;
	background: var(--oi-bg-raised);
	border: 1px solid var(--oi-border);
	border-radius: var(--oi-radius);
	margin-bottom: 1.25rem;
}
.oi-filter-group { display: flex; flex-direction: column; gap: .4rem; }
.oi-filter-label {
	font-size: .7rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: .1em;
	color: var(--oi-text-dim);
}
.oi-filter-search {
	padding: .55rem .8rem;
	border: 1px solid var(--oi-border);
	border-radius: var(--oi-radius);
	font-size: .95rem;
	background: var(--oi-bg);
	color: var(--oi-text);
	width: 100%;
	max-width: 420px;
}
.oi-filter-search:focus {
	outline: 2px solid var(--oi-accent);
	outline-offset: 2px;
}

.oi-filter-chips {
	display: flex;
	flex-wrap: wrap;
	gap: .4rem;
}
.oi-chip {
	appearance: none;
	padding: .35rem .7rem;
	border: 1px solid var(--oi-border);
	border-radius: var(--oi-radius);
	background: var(--oi-bg);
	color: var(--oi-text-soft);
	font-size: .8rem;
	font-weight: 600;
	font-family: inherit;
	cursor: pointer;
	transition: background .15s ease, color .15s ease, border-color .15s ease, transform .1s ease;
}
.oi-chip[data-oi-filter="tier"] {
	background: color-mix(in srgb, var(--oi-tier-gradient, var(--oi-accent)) 8%, var(--oi-bg));
	border-color: color-mix(in srgb, var(--oi-tier-gradient, var(--oi-accent)) 20%, var(--oi-border));
}
.oi-chip:hover { border-color: var(--oi-accent); color: var(--oi-text); }
.oi-chip[aria-pressed="true"] {
	background: var(--oi-bg);
	color: var(--oi-accent);
	border-color: var(--oi-accent);
	box-shadow: 0 0 0 1px var(--oi-accent);
}
/* Preserve the accent text color when a non-tier pressed chip is hovered —
   otherwise the base :hover rule paints --oi-text on an accent-tinted
   background and the label vanishes. */
.oi-chip[aria-pressed="true"]:hover {
	color: var(--oi-accent);
}
.oi-chip[data-oi-filter="tier"][aria-pressed="true"] {
	background: var(--oi-tier-gradient, var(--oi-accent));
	color: #fff;
	border-color: transparent;
}
/* Same for tier chips: pressed-tier has a saturated gradient background,
   and hover's dark --oi-text would make the label invisible. */
.oi-chip[data-oi-filter="tier"][aria-pressed="true"]:hover {
	color: #fff;
}
.oi-chip:active { transform: scale(.96); }
.oi-chip--sub {
	font-size: .72rem;
	padding: .25rem .55rem;
	color: var(--oi-text-dim);
	font-weight: 500;
}

/* Use-case chips collapse to top 10 by default with a "Show all" toggle.
   Overflow chips carry the [hidden] attribute server-side; JS removes it
   when the container gets the expanded modifier. */
.oi-chip--expand {
	background: transparent;
	border-style: dashed;
	color: var(--oi-text-dim);
	font-weight: 500;
}
.oi-chip--expand:hover {
	border-style: solid;
	color: var(--oi-accent);
}
.oi-filter-chips--uses.oi-filter-chips--expanded .oi-chip--expand {
	display: none;
}

/* Subcategory chip container */
.oi-filter-chips--sub {
	gap: .3rem;
	margin-top: .3rem;
	padding-left: .5rem;
	border-left: 2px solid var(--oi-border-soft, var(--oi-border));
}
.oi-filter-chips--sub[hidden] { display: none; }

/* Use case chips — smaller, subtler than category/tier */
.oi-chip--use {
	font-size: .72rem;
	padding: .22rem .5rem;
	color: var(--oi-text-dim);
	font-weight: 500;
	border-color: color-mix(in srgb, var(--oi-border) 60%, transparent);
}
.oi-filter-chips--uses { gap: .8rem; }
@media screen and (max-width: 782px) {
	.oi-filter-chips--uses { gap: .5rem; }
}

.oi-filter-controls {
	display: flex;
	flex-wrap: wrap;
	gap: 1rem;
	align-items: flex-end;
	padding-top: .5rem;
	border-top: 1px solid var(--oi-border-soft);
}
.oi-filter-controls select {
	padding: .5rem .75rem;
	border: 1px solid var(--oi-border);
	border-radius: var(--oi-radius);
	background: var(--oi-bg);
	color: var(--oi-text);
	font-size: .9rem;
	font-family: inherit;
	cursor: pointer;
}
.oi-density-toggle { display: inline-flex; gap: .25rem; }
.oi-filter-clear {
	margin-left: auto;
	padding: .5rem 1rem;
	background: transparent;
	border: 1px solid var(--oi-border);
	border-radius: var(--oi-radius);
	color: var(--oi-text-soft);
	font-size: .85rem;
	font-weight: 600;
	cursor: pointer;
	transition: color .15s ease, border-color .15s ease;
}
.oi-filter-clear:hover { color: var(--oi-accent); border-color: var(--oi-accent); }

/* ─── Compare bar ──────────────────────────────────────────── */

.oi-compare-bar {
	display: flex;
	align-items: center;
	gap: 1rem;
	padding: .75rem 1.1rem;
	background: color-mix(in srgb, var(--oi-accent) 12%, var(--oi-bg-raised));
	border: 1px solid var(--oi-accent);
	border-radius: var(--oi-radius);
	margin-bottom: 1rem;
	position: sticky;
	top: 1rem;
	z-index: 50;
	box-shadow: var(--oi-shadow);
}
.oi-compare-count { font-weight: 600; color: var(--oi-text); }
.oi-compare-open {
	padding: .5rem 1rem;
	background: var(--oi-accent);
	border: none;
	border-radius: var(--oi-radius);
	color: #fff;
	font-weight: 700;
	cursor: pointer;
}
.oi-compare-open:disabled { opacity: .4; cursor: not-allowed; }
.oi-compare-clear {
	padding: .5rem 1rem;
	background: transparent;
	border: 1px solid var(--oi-border);
	border-radius: var(--oi-radius);
	color: var(--oi-text-soft);
	cursor: pointer;
}

/* ─── Results table ────────────────────────────────────────── */

.oi-results-table {
	width: 100%;
	border-collapse: collapse;
	font-size: 14px;
}
.oi-results-table thead th {
	background: var(--oi-bg-raised);
	color: var(--oi-text);
	text-align: left;
	padding: .75rem .9rem;
	border: 1px solid var(--oi-border);
	font-size: .9rem;
	font-weight: 700;
}
.oi-results-table tbody td,
.oi-results-table tbody th {
	padding: .7rem .9rem;
	border: 1px solid var(--oi-border);
	text-align: left;
	vertical-align: middle;
	font-weight: 400;
}
.oi-results-table tbody tr:nth-child(even) { background: var(--oi-bg-sunken); }
.oi-results-table tbody tr:hover { background: color-mix(in srgb, var(--oi-accent) 8%, transparent); }

.oi-col-compare { width: 32px; text-align: center; }
.oi-col-score { width: 88px; font-variant-numeric: tabular-nums; text-align: center; font-size: 1.05rem; }
.oi-col-score-denom { font-size: .75rem; font-weight: 500; color: var(--oi-text-dim); margin-left: 1px; }
.oi-score-locked {
	display: inline-block;
	font-size: 1.15rem;
	opacity: .65;
	cursor: help;
}
.oi-score-locked-blur {
	display: inline-block;
	font-weight: 700;
	font-size: 1.05rem;
	user-select: none;
	color: var(--oi-text);
}
.oi-score-blur-number {
	display: inline-block;
	filter: blur(5px);
	-webkit-filter: blur(5px);
}
.oi-tier-pill--embargoed {
	display: inline-block;
	padding: .25rem .65rem;
	background: var(--oi-tier-gradient);
	color: #fff;
	font-weight: 600;
	border-radius: var(--oi-radius);
	font-size: .78rem;
	user-select: none;
}
.oi-tier-pill--embargoed-neutral {
	display: inline-block;
	padding: .25rem .65rem;
	background: var(--oi-bg-sunken);
	color: var(--oi-text-soft);
	border: 1px dashed var(--oi-border);
	font-weight: 600;
	border-radius: var(--oi-radius);
	font-size: .78rem;
	user-select: none;
}
.oi-tier-blur-text {
	display: inline-block;
	filter: blur(4px);
	-webkit-filter: blur(4px);
	letter-spacing: 0.08em;
}
.oi-embargo-hint {
	font-style: italic;
	color: var(--oi-text-dim);
	font-size: .85rem;
}
.oi-row--embargoed .oi-col-name a { color: var(--oi-text-soft); }
.oi-row--embargoed .oi-col-name a::after {
	content: '';
	display: inline-block;
	width: 0;
}
.oi-col-tier { width: 220px; }
.oi-col-name a { color: var(--oi-text); font-weight: 600; }
.oi-col-name a:hover { color: var(--oi-accent); }
.oi-col-best { color: var(--oi-text-soft); font-size: .9rem; }

.oi-tier-pill {
	display: inline-block;
	padding: .25rem .6rem;
	background: var(--oi-tier-gradient, var(--oi-tier-neutral));
	color: #fff;
	border-radius: var(--oi-radius);
	font-size: .68rem;
	font-weight: 700;
	white-space: nowrap;
}
.oi-pending { color: var(--oi-text-dim); font-style: italic; }

.oi-compare-check {
	width: 18px;
	height: 18px;
	cursor: pointer;
	accent-color: var(--oi-accent);
}

.oi-results[data-oi-density="cards"] .oi-results-table { display: none; }

/* ─── Cards grid ──────────────────────────────────────────── */

.oi-cards-grid { display: none; }
.oi-results[data-oi-density="cards"] .oi-cards-grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
	gap: 1rem;
}

.oi-card {
	display: flex;
	flex-direction: column;
	gap: .5rem;
	padding: 1.1rem 1.2rem;
	background: var(--oi-bg-raised);
	border: 1px solid var(--oi-border);
	border-left: 4px solid var(--oi-card-tier, var(--oi-border));
	border-radius: var(--oi-radius);
	transition: border-color .15s ease, box-shadow .15s ease;
}
.oi-card:hover {
	border-color: var(--oi-accent);
	box-shadow: 0 2px 8px rgba(0, 0, 0, .08);
}
.oi-card[data-oi-card-hidden="true"] { display: none; }

.oi-card-head {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: .75rem;
}
.oi-card-score {
	font-size: 1.75rem;
	font-weight: 800;
	line-height: 1;
	font-variant-numeric: tabular-nums;
	color: var(--oi-text);
	flex-shrink: 0;
}
.oi-card-name {
	font-size: .95rem;
	font-weight: 600;
	line-height: 1.25;
	min-width: 0;
}
.oi-card-name a {
	color: var(--oi-text);
	text-decoration: none;
}
.oi-card-name a:hover { color: var(--oi-accent); }

.oi-card-meta {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: .4rem;
}
.oi-card-category {
	font-size: .75rem;
	color: var(--oi-text-dim);
	text-transform: uppercase;
	letter-spacing: .05em;
	font-weight: 600;
}
.oi-card-best {
	font-size: .8rem;
	color: var(--oi-text-soft);
	line-height: 1.3;
	overflow: hidden;
	text-overflow: ellipsis;
	white-space: nowrap;
}

.oi-results-empty {
	padding: 2.5rem 1rem;
	text-align: center;
	color: var(--oi-text-dim);
}
.oi-inline-link {
	background: none;
	border: none;
	color: var(--oi-accent);
	font: inherit;
	text-decoration: underline;
	cursor: pointer;
	padding: 0;
}

.oi-archive-empty {
	padding: 3rem 1rem;
	text-align: center;
	color: var(--oi-text-dim);
	font-style: italic;
}

/* Hide filtered-out rows via data attribute */
.oi-row[data-oi-hidden="true"] { display: none; }

/* ─── Compare modal ───────────────────────────────────────── */

.oi-compare-modal {
	position: fixed;
	inset: 0;
	z-index: 9999;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 1rem;
}
.oi-compare-modal[hidden] { display: none; }

.oi-compare-backdrop {
	position: absolute;
	inset: 0;
	background: rgba(0, 0, 0, .55);
}

.oi-compare-card {
	position: relative;
	width: 100%;
	max-width: 900px;
	max-height: 85vh;
	overflow-y: auto;
	background: var(--oi-bg);
	border: 1px solid var(--oi-border);
	border-radius: var(--oi-radius);
	box-shadow: var(--oi-shadow), 0 16px 48px rgba(0,0,0,.25);
	padding: 1.5rem;
}

.oi-compare-close {
	position: sticky;
	top: 0;
	float: right;
	background: var(--oi-bg-raised);
	border: 1px solid var(--oi-border);
	border-radius: var(--oi-radius);
	width: 36px;
	height: 36px;
	font-size: 1.4rem;
	line-height: 1;
	cursor: pointer;
	color: var(--oi-text-soft);
	z-index: 1;
	display: flex;
	align-items: center;
	justify-content: center;
}
.oi-compare-close:hover { color: var(--oi-text); border-color: var(--oi-accent); }

.oi-cmp-table {
	width: 100%;
	border-collapse: collapse;
	font-size: .9rem;
	margin-top: .5rem;
}
.oi-cmp-table th,
.oi-cmp-table td {
	padding: .6rem .75rem;
	border: 1px solid var(--oi-border);
	vertical-align: middle;
	text-align: center;
}
.oi-cmp-label {
	text-align: left !important;
	font-weight: 600;
	color: var(--oi-text-soft);
	white-space: nowrap;
	width: 140px;
	min-width: 120px;
}
.oi-cmp-head {
	background: var(--oi-bg-raised);
	font-weight: 700;
	font-size: .95rem;
}
.oi-cmp-head a {
	color: var(--oi-text);
	text-decoration: none;
}
.oi-cmp-head a:hover { color: var(--oi-accent); }

.oi-cmp-section td {
	background: var(--oi-bg-sunken);
	font-weight: 700;
	font-size: .75rem;
	text-transform: uppercase;
	letter-spacing: .08em;
	color: var(--oi-text-dim);
	text-align: left !important;
	padding: .4rem .75rem;
}

.oi-cmp-cell { font-variant-numeric: tabular-nums; }
.oi-cmp-winner {
	background: color-mix(in srgb, var(--oi-accent) 10%, transparent);
}

.oi-cmp-personal {
	font-size: .65rem;
	color: var(--oi-accent);
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: .05em;
}

.oi-cmp-dim {
	display: inline-flex;
	align-items: center;
	gap: .4rem;
	width: 100%;
	max-width: 120px;
}
.oi-cmp-dim-bar {
	flex: 1;
	height: 6px;
	background: var(--oi-bg-sunken);
	border-radius: 3px;
	overflow: hidden;
}
.oi-cmp-dim-fill {
	display: block;
	height: 100%;
	background: var(--oi-accent);
	border-radius: 3px;
	transition: width .2s ease;
}
.oi-cmp-dim-val {
	font-size: .8rem;
	font-variant-numeric: tabular-nums;
	color: var(--oi-text);
	min-width: 2ch;
}
.oi-cmp-dim-na {
	color: var(--oi-text-dim);
}

@container (max-width: 600px) {
	.oi-compare-card { padding: 1rem .75rem; }
	.oi-cmp-table { font-size: .8rem; }
	.oi-cmp-table th,
	.oi-cmp-table td { padding: .4rem .5rem; }
	.oi-cmp-label { width: auto; min-width: 80px; font-size: .75rem; }
	.oi-cmp-dim { max-width: 80px; }
}

/* ─── Personalize panel ────────────────────────────────────────────── */

.oi-personalize-panel {
	padding: .6rem 1rem;
	margin-bottom: 1rem;
	border-radius: var(--oi-radius);
	background: var(--oi-bg-sunken);
	font-size: .85rem;
	color: var(--oi-text-soft);
}
.oi-personalize-panel a {
	color: var(--oi-accent);
	text-decoration: none;
	font-weight: 600;
}
.oi-personalize-panel a:hover { text-decoration: underline; }

/* ─── Suggestion box ─────────────────────────────────────── */

.oi-suggest {
	margin-top: 2.5rem;
	padding: 2.5rem 2rem;
	border-top: none;
	background: var(--oi-bg-sunken);
	border-radius: var(--oi-radius);
	text-align: center;
}
.oi-suggest-title {
	font-size: 1.4rem;
	font-weight: 700;
	margin: 0 0 .5rem;
}
.oi-suggest-desc {
	color: var(--oi-text-soft);
	margin: 0 0 1rem;
	max-width: 520px;
	margin-inline: auto;
}
.oi-suggest-cta {
	display: inline-block;
	padding: .6rem 1.4rem;
	background: var(--oi-accent);
	color: #fff;
	border-radius: var(--oi-radius);
	font-weight: 700;
	font-size: .9rem;
	text-decoration: none;
	transition: opacity .15s ease;
}
.oi-suggest-cta:hover { opacity: .85; }

.oi-suggest-form {
	display: flex;
	flex-direction: column;
	gap: .5rem;
	max-width: 520px;
	margin: 0 auto;
}
.oi-suggest-row {
	display: flex;
	gap: .5rem;
}
.oi-suggest-input,
.oi-suggest-email-input {
	flex: 1;
	padding: .55rem .8rem;
	border: 1px solid var(--oi-border);
	border-radius: var(--oi-radius);
	font-size: .95rem;
	background: var(--oi-bg);
	color: var(--oi-text);
}
.oi-suggest-input:focus,
.oi-suggest-email-input:focus {
	outline: 2px solid var(--oi-accent);
	outline-offset: 2px;
}
.oi-suggest-submit {
	padding: .55rem 1.2rem;
	background: var(--oi-accent);
	color: #fff;
	border: none;
	border-radius: var(--oi-radius);
	font-weight: 700;
	font-size: .9rem;
	cursor: pointer;
	transition: opacity .15s ease;
	white-space: nowrap;
}
.oi-suggest-submit:hover { opacity: .85; }
.oi-suggest-submit:disabled { opacity: .5; cursor: not-allowed; }

.oi-suggest-thanks {
	padding: .8rem 1.2rem;
	background: color-mix(in srgb, #22c55e 12%, var(--oi-bg));
	border-radius: var(--oi-radius);
	color: var(--oi-text);
	max-width: 520px;
	margin: 0 auto;
}
.oi-suggest-thanks p { margin: 0; }

.oi-suggest-locked[hidden],
.oi-suggest-unlocked[hidden],
.oi-suggest-thanks[hidden],
.oi-suggest-form[hidden] { display: none; }

@container (max-width: 700px) {
	.oi-results-table thead { display: none; }
	.oi-results-table tbody td,
	.oi-results-table tbody th {
		display: block;
		border: none;
		padding: .25rem 0;
		width: auto !important;
		text-align: left !important;
		font-size: .95rem;
	}
	.oi-results-table tbody tr {
		display: block;
		padding: 1rem 1.1rem;
		border: 1px solid var(--oi-border);
		border-radius: var(--oi-radius);
		margin-bottom: .75rem;
		background: var(--oi-bg);
	}
	.oi-results-table tbody tr:nth-child(even) { background: var(--oi-bg); }
	/* Hide the "Tried" checkbox on mobile — too fiddly for a thumb, and
	   the empty bordered box reads as a broken UI element */
	.oi-results-table .oi-col-tried { display: none !important; }
	/* Inline the compare checkbox with the intervention name */
	.oi-results-table .oi-col-compare {
		display: inline-block !important;
		vertical-align: middle;
		margin-right: .5rem;
		padding: 0 !important;
	}
	.oi-results-table .oi-col-name {
		display: inline-block !important;
		vertical-align: middle;
		font-size: 1.1rem;
		font-weight: 700;
		margin-bottom: .5rem;
	}
	.oi-col-type { font-size: .88rem; color: var(--oi-text-soft); }
	.oi-col-score::before { content: 'BioHarmony Score: '; font-weight: 600; color: var(--oi-text-dim); }
	.oi-col-type::before { content: 'Category: '; font-weight: 600; color: var(--oi-text-dim); }
	.oi-col-best::before { content: 'Best for: '; font-weight: 600; color: var(--oi-text-dim); }
	.oi-col-score strong { font-size: 1.15rem; }
	.oi-col-tier { margin-top: .3rem; }
}

/* ─── Methodology link (archive header) ──────────────────────── */

.oi-archive-method-link {
	margin-top: .5rem;
	margin-bottom: 0;
}
.oi-ratings-method-link {
	font-size: .82rem;
	color: var(--oi-accent, #6366f1);
	text-decoration: none;
}
.oi-ratings-method-link:hover { text-decoration: underline; }
