@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&family=Sora:wght@600;700;800&display=swap');

:root {
	--ah-color-rank-gold: #f2c14e;
	--ah-color-frost: #eaf7fa;
	--ah-color-mist: #9fb4bf;
	--ah-color-smoke: #647682;
	--ah-bg-page: #080c10;
	--ah-bg-surface: #101820;
	--ah-bg-surface-raised: #15202a;
	--ah-text-primary: var(--ah-color-frost);
	--ah-text-secondary: var(--ah-color-mist);
	--ah-text-muted: var(--ah-color-smoke);
	--ah-action-secondary: #44b6ca;
	--ah-status-warning: var(--ah-color-rank-gold);
	--ah-border: rgb(234 247 250 / 0.14);
	--ah-border-soft: rgb(234 247 250 / 0.09);
	--ah-font-display: "Sora", "Space Grotesk", "Rajdhani", system-ui, sans-serif;
	--ah-font-body: "Inter", "Source Sans 3", "IBM Plex Sans", system-ui, sans-serif;
	--ah-font-mono: "SFMono-Regular", Consolas, "Liberation Mono", monospace;
	--ah-type-page-title: clamp(38px, 5vw, 64px);
	--ah-type-tool-title: clamp(18px, 2vw, 24px);
	--ah-type-body-sm: 15px;
	--ah-type-label: 12px;
	--ah-space-2: 8px;
	--ah-space-3: 12px;
	--ah-space-4: 16px;
	--ah-space-5: 20px;
	--ah-space-6: 24px;
	--ah-radius-sm: 4px;
	--ah-radius-md: 6px;
	--ah-radius-lg: 8px;
	--ah-focus-ring: 0 0 0 3px rgb(93 235 255 / 0.35);
	--ah-transition-fast: 140ms ease;
	--ah-transition-base: 220ms ease;
}

* {
	box-sizing: border-box;
}

html {
	scroll-behavior: smooth;
}

body {
	margin: 0;
	background: var(--ah-bg-page);
	color: var(--ah-text-primary);
	font-family: var(--ah-font-body);
	overflow-x: hidden;
}

body.mobile-menu-open {
	overflow: hidden;
}

.site-header {
	position: sticky;
	top: 0;
	z-index: 20;
	display: flex;
	align-items: center;
	justify-content: space-between;
	min-height: 68px;
	padding: var(--ah-space-3) clamp(var(--ah-space-4), 4vw, 48px);
	border-bottom: 1px solid var(--ah-border);
	background: var(--ah-bg-page);
}

.brand-lockup {
	display: flex;
	align-items: center;
	gap: var(--ah-space-3);
	color: var(--ah-text-primary);
	text-decoration: none;
}

.brand-mark {
	width: 46px;
	height: 46px;
	object-fit: contain;
}

.brand-name {
	font-family: var(--ah-font-display);
	font-size: 18px;
	font-weight: 800;
}

.site-nav {
	display: flex;
	align-items: center;
	gap: clamp(var(--ah-space-3), 2vw, var(--ah-space-6));
}

.site-nav a {
	color: var(--ah-text-secondary);
	font-size: 14px;
	font-weight: 700;
	text-decoration: none;
	transition: color var(--ah-transition-fast), box-shadow var(--ah-transition-fast);
}

.site-nav a[aria-current="page"],
.site-nav a:hover {
	color: var(--ah-text-primary);
}

.site-nav a[aria-current="page"] {
	box-shadow: inset 0 -2px 0 var(--ah-action-secondary);
}

.layout {
	min-height: calc(100vh - 68px);
	display: grid;
	grid-template-columns: minmax(0, 1fr) minmax(360px, 39vw);
}

.left {
	padding: clamp(20px, 3vw, 40px);
	border-right: 1px solid var(--ah-border);
}

.right {
	position: sticky;
	top: 68px;
	height: calc(100vh - 68px);
	padding: clamp(16px, 2vw, 28px);
	background: var(--ah-bg-page);
}

.headline {
	display: grid;
	grid-template-columns: minmax(0, 1fr) auto;
	gap: var(--ah-space-6);
	align-items: end;
	padding-bottom: var(--ah-space-6);
	border-bottom: 1px solid var(--ah-border);
}

.section-kicker {
	margin: 0 0 var(--ah-space-3);
	color: var(--ah-action-secondary);
	font-size: var(--ah-type-label);
	font-weight: 800;
	text-transform: uppercase;
}

.headline h1 {
	margin: 0;
	color: var(--ah-text-primary);
	font-family: var(--ah-font-display);
	font-size: var(--ah-type-page-title);
	font-weight: 800;
	line-height: .98;
}

.headline p:not(.section-kicker) {
	max-width: 68ch;
	margin: var(--ah-space-4) 0 0;
	color: var(--ah-text-secondary);
	font-size: clamp(18px, 2vw, 21px);
	line-height: 1.55;
}

.count-panel {
	min-width: 148px;
	padding: var(--ah-space-4);
	border: 1px solid var(--ah-border);
	border-radius: var(--ah-radius-md);
	background: var(--ah-bg-surface);
	text-align: right;
}

.count-panel span {
	display: block;
	color: var(--ah-text-muted);
	font-size: var(--ah-type-label);
	font-weight: 800;
	text-transform: uppercase;
}

.count-panel strong {
	display: block;
	margin-top: 4px;
	color: var(--ah-action-secondary);
	font-family: var(--ah-font-display);
	font-size: clamp(44px, 5vw, 68px);
	font-weight: 800;
	line-height: .9;
}

.family-switch {
	display: inline-grid;
	grid-template-columns: repeat(2, minmax(132px, 1fr));
	gap: 2px;
	margin-top: var(--ah-space-5);
	padding: 3px;
	border: 1px solid var(--ah-border);
	border-radius: var(--ah-radius-md);
	background: var(--ah-bg-surface);
}

.family-switch button {
	min-height: 42px;
	border: 0;
	border-radius: var(--ah-radius-sm);
	background: transparent;
	color: var(--ah-text-secondary);
	font: 800 13px / 1 var(--ah-font-body);
	text-transform: uppercase;
	cursor: pointer;
	transition: background var(--ah-transition-fast), color var(--ah-transition-fast), box-shadow var(--ah-transition-fast);
}

.family-switch button:hover,
.family-switch button.is-current {
	background: var(--ah-bg-surface-raised);
	color: var(--ah-text-primary);
}

.family-switch button.is-current {
	box-shadow: inset 0 0 0 1px var(--ah-action-secondary);
}

.filters {
	position: sticky;
	top: 84px;
	z-index: 8;
	display: grid;
	grid-template-columns: minmax(220px, 1.25fr) repeat(auto-fit, minmax(140px, 1fr));
	gap: var(--ah-space-3);
	margin: var(--ah-space-5) 0;
	padding: var(--ah-space-4);
	border-block: 1px solid var(--ah-border);
	background: var(--ah-bg-page);
}

.filters.is-stuck {
	border: 1px solid var(--ah-border);
	border-radius: var(--ah-radius-md);
}

.mobile-menu-toggle,
.mobile-menu,
.return-top {
	display: none;
}

.mobile-menu-toggle,
.mobile-menu__close,
.inspector-close,
.return-top {
	min-height: 44px;
	padding-inline: var(--ah-space-5);
	border: 1px solid var(--ah-border);
	border-radius: var(--ah-radius-md);
	background: var(--ah-bg-surface);
	color: var(--ah-text-primary);
	font: 800 14px / 1 var(--ah-font-body);
	cursor: pointer;
	transition: background var(--ah-transition-fast), border-color var(--ah-transition-fast), color var(--ah-transition-fast);
}

.mobile-menu-toggle:hover,
.mobile-menu__close:hover,
.inspector-close:hover,
.return-top:hover {
	border-color: var(--ah-action-secondary);
	background: var(--ah-bg-surface-raised);
}

.mobile-menu {
	position: fixed;
	inset: 0;
	z-index: 40;
	padding: 1rem;
	background: var(--ah-bg-page);
}

.mobile-menu__inner {
	height: min(100%, 44rem);
	overflow: auto;
	border: 1px solid var(--ah-border);
	border-radius: var(--ah-radius-lg);
	background: var(--ah-bg-surface);
	padding: var(--ah-space-5);
}

.mobile-menu__header {
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: var(--ah-space-4);
	margin-bottom: var(--ah-space-4);
}

.mobile-menu__header strong {
	font-family: var(--ah-font-display);
	font-size: 24px;
	font-weight: 800;
	color: var(--ah-text-primary);
}

.mobile-menu__filters {
	margin-top: 0;
}

.field {
	display: grid;
	gap: 7px;
	color: var(--ah-text-muted);
	font-size: var(--ah-type-label);
	font-weight: 800;
	text-transform: uppercase;
}

.field[hidden] {
	display: none;
}

input,
select {
	width: 100%;
	min-height: 44px;
	padding: 0 var(--ah-space-4);
	border: 1px solid var(--ah-border);
	border-radius: var(--ah-radius-md);
	background: var(--ah-bg-surface);
	color: var(--ah-text-primary);
	font: 600 14px / normal var(--ah-font-body);
	appearance: none;
	-webkit-appearance: none;
	transition: border-color var(--ah-transition-fast), box-shadow var(--ah-transition-fast), background var(--ah-transition-fast);
}

select {
	height: 44px;
	padding: 0 42px 0 var(--ah-space-4);
	background-color: var(--ah-bg-surface);
	background-image:
		linear-gradient(45deg, transparent 50%, var(--ah-text-secondary) 50%),
		linear-gradient(135deg, var(--ah-text-secondary) 50%, transparent 50%);
	background-position:
		calc(100% - 20px) 18px,
		calc(100% - 14px) 18px;
	background-size: 6px 6px, 6px 6px;
	background-repeat: no-repeat;
}

select option {
	background: var(--ah-bg-surface);
	color: var(--ah-text-primary);
}

input::placeholder {
	color: var(--ah-text-muted);
}

input:hover,
select:hover {
	border-color: var(--ah-action-secondary);
}

input:focus-visible,
select:focus-visible,
.mobile-menu-toggle:focus-visible,
.mobile-menu__close:focus-visible,
.inspector-close:focus-visible,
.return-top:focus-visible,
.family-switch button:focus-visible,
.item:focus-visible {
	outline: none;
	box-shadow: var(--ah-focus-ring);
}

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

.results-head {
	display: grid;
	grid-template-columns: 92px minmax(0, 1fr) 180px;
	gap: var(--ah-space-4);
	padding: 0 var(--ah-space-4) var(--ah-space-2);
	color: var(--ah-text-muted);
	font-size: var(--ah-type-label);
	font-weight: 800;
	text-transform: uppercase;
}

.stack {
	margin: 0;
	padding: 0;
	list-style: none;
	display: grid;
	border-top: 1px solid var(--ah-border);
}

.stack li {
	margin: 0;
}

.empty-row {
	padding: var(--ah-space-6) var(--ah-space-4);
	border-bottom: 1px solid var(--ah-border-soft);
	color: var(--ah-text-secondary);
}

.item {
	position: relative;
	display: grid;
	grid-template-columns: 92px minmax(0, 1fr) 180px;
	gap: var(--ah-space-4);
	align-items: center;
	width: 100%;
	min-height: 84px;
	padding: var(--ah-space-4);
	border: 0;
	border-bottom: 1px solid var(--ah-border-soft);
	background: transparent;
	color: inherit;
	text-align: left;
	cursor: pointer;
	transition: background var(--ah-transition-fast), box-shadow var(--ah-transition-fast);
}

.item::before {
	content: "";
	position: absolute;
	inset: 0 auto 0 0;
	width: 3px;
	background: transparent;
	transition: background var(--ah-transition-fast), box-shadow var(--ah-transition-fast);
}

.item:hover {
	background: var(--ah-bg-surface);
}

.item.is-current {
	background: var(--ah-bg-surface);
}

.item.is-current::before {
	background: var(--ah-action-secondary);
}

.item__rating {
	display: grid;
	gap: 6px;
	align-content: start;
}

.item__rating strong {
	color: var(--ah-status-warning);
	font-family: var(--ah-font-display);
	font-size: 34px;
	font-weight: 800;
	line-height: 1;
}

.item__rating > span:not(.star-rating) {
	color: var(--ah-text-secondary);
	font-size: 11px;
	font-weight: 800;
	line-height: 1.25;
	text-transform: uppercase;
}

.item__label {
	display: block;
	color: var(--ah-text-muted);
	font-size: var(--ah-type-label);
	font-weight: 800;
	text-transform: uppercase;
}

.item__body h3 {
	margin: 0;
	color: var(--ah-text-primary);
	font-family: var(--ah-font-display);
	font-size: var(--ah-type-tool-title);
	font-weight: 800;
	line-height: 1.15;
}

.item__body p {
	margin: 6px 0 0;
	color: var(--ah-text-secondary);
	font-size: var(--ah-type-body-sm);
	line-height: 1.5;
}

.item__type {
	display: grid;
	gap: 5px;
	justify-items: end;
	text-align: right;
}

.item__type strong {
	width: fit-content;
	min-height: 24px;
	padding: 5px 8px;
	border: 1px solid var(--ah-border);
	border-radius: var(--ah-radius-sm);
	background: transparent;
	color: var(--ah-action-secondary);
	font-size: var(--ah-type-label);
	font-weight: 800;
	line-height: 1;
}

.inspector {
	position: relative;
	height: 100%;
	display: grid;
	align-content: start;
	gap: var(--ah-space-5);
	overflow: auto;
	border: 1px solid var(--ah-border);
	border-radius: var(--ah-radius-lg);
	padding: var(--ah-space-5);
	background: var(--ah-bg-surface);
}

.inspector-toolbar {
	display: flex;
	justify-content: flex-end;
}

.inspector-close {
	display: none;
}

.inspector-empty {
	max-width: 32ch;
	color: var(--ah-text-secondary);
	font-size: 16px;
	line-height: 1.55;
}

.inspector-head {
	padding-bottom: var(--ah-space-4);
	border-bottom: 1px solid var(--ah-border);
}

.inspector-head h2 {
	margin: var(--ah-space-3) 0 var(--ah-space-2);
	color: var(--ah-text-primary);
	font-family: var(--ah-font-display);
	font-size: clamp(30px, 4vw, 52px);
	font-weight: 800;
	line-height: 1.05;
}

.index-tag {
	display: inline-flex;
	align-items: center;
	width: fit-content;
	min-height: 22px;
	padding-inline: 7px;
	border: 1px solid var(--ah-border);
	border-radius: var(--ah-radius-sm);
	background: transparent;
	color: var(--ah-action-secondary);
	font-size: var(--ah-type-label);
	font-weight: 800;
	line-height: 1;
	text-transform: uppercase;
}

.inspector-section {
	border-top: 1px solid var(--ah-border-soft);
	padding-top: var(--ah-space-4);
}

.inspector-section h3 {
	margin: 0 0 var(--ah-space-2);
	color: var(--ah-text-primary);
	font-family: var(--ah-font-display);
	font-size: 18px;
	font-weight: 800;
	line-height: 1.2;
}

.inspector-section p,
.inspector-head p,
li {
	color: var(--ah-text-secondary);
	line-height: 1.6;
}

.inspector-head p {
	margin: 0;
	color: var(--ah-status-warning);
	font-weight: 800;
}

.star-rating {
	display: inline-flex;
	align-items: center;
	flex-wrap: wrap;
	gap: 7px;
	color: var(--ah-status-warning);
	font-weight: 800;
	line-height: 1.1;
}

.star-rating__icons {
	display: inline-flex;
	align-items: center;
	gap: 2px;
	color: currentColor;
}

.star-rating__icon {
	width: 13px;
	height: 13px;
	fill: currentColor;
	flex: 0 0 auto;
}

.star-rating__label,
.score-label {
	color: var(--ah-text-secondary);
	font-size: 11px;
	font-weight: 800;
	text-transform: uppercase;
}

.inspector-rating {
	display: flex;
	align-items: center;
	flex-wrap: wrap;
	gap: 10px;
}

.inspector-rating .star-rating__icon {
	width: 15px;
	height: 15px;
}

.score-label {
	padding-left: 10px;
	border-left: 1px solid var(--ah-border);
}

.stat-priority {
	display: grid;
	gap: var(--ah-space-2);
}

.stat-priority__line {
	display: flex;
	flex-wrap: nowrap;
	align-items: center;
	gap: 8px 10px;
	overflow-x: auto;
	padding-bottom: 2px;
}

.stat-priority__item {
	display: inline-flex;
	align-items: center;
	flex: 0 0 auto;
	color: var(--ah-text-primary);
	font-size: 13px;
	font-weight: 800;
	line-height: 1.3;
}

.stat-priority__item + .stat-priority__item::before {
	content: "/";
	margin-right: 10px;
	color: var(--ah-text-muted);
	font-weight: 700;
}

.stat-priority__item--primary {
	color: #ffc1ad;
}

.section-note {
	margin: 0;
	color: var(--ah-text-muted);
	font-size: 12px;
	font-weight: 700;
	line-height: 1.45;
}

.info-boxes {
	display: flex;
	flex-wrap: wrap;
	gap: 6px;
	padding: var(--ah-space-3);
}

.info-box {
	display: inline-flex;
	align-items: center;
	min-height: 28px;
	padding: 6px 10px;
	border: 1px solid var(--ah-border);
	border-radius: var(--ah-radius-sm);
	background: transparent;
	color: var(--ah-text-primary);
	font-size: 12px;
	font-weight: 700;
	line-height: 1.25;
}

.detail-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
	gap: var(--ah-space-3);
}

.detail-grid > div {
	padding: var(--ah-space-3);
	border: 1px solid var(--ah-border-soft);
	border-radius: var(--ah-radius-md);
	background: transparent;
}

.detail-grid strong {
	display: block;
	margin-bottom: var(--ah-space-2);
	color: var(--ah-text-primary);
	font-size: var(--ah-type-label);
	font-weight: 800;
	text-transform: uppercase;
}

.detail-grid .info-boxes {
	display: grid;
	grid-template-columns: 1fr;
	padding: 0;
}

.detail-grid .info-box {
	width: 100%;
	justify-content: flex-start;
}

.slot-priority-grid > div {
	padding: 0 var(--ah-space-3) 0 0;
	border: 0;
	border-right: 1px solid var(--ah-border-soft);
	border-radius: 0;
	background: transparent;
}

.slot-priority-grid > div:last-child {
	padding-right: 0;
	border-right: 0;
}

.slot-priority-grid .info-boxes {
	margin-top: var(--ah-space-3);
	gap: 6px;
}

.slot-priority-grid .info-box {
	min-height: auto;
	padding: 0;
	border: 0;
	background: transparent;
	box-shadow: none;
	color: var(--ah-text-primary);
	font-size: 12px;
	font-weight: 800;
	line-height: 1.35;
}

.detail-grid p,
.muted {
	margin: var(--ah-space-2) 0 0;
	color: var(--ah-text-secondary);
}

.set-bonus-ladder {
	display: grid;
	gap: 0;
	overflow: hidden;
	border: 1px solid rgb(234 247 250 / 0.1);
	border-radius: var(--ah-radius-md);
	background: transparent;
}

.set-bonus-row {
	display: grid;
	grid-template-columns: 52px minmax(0, 1fr);
	gap: var(--ah-space-4);
	align-items: start;
	padding: 10px var(--ah-space-3);
	background: transparent;
}

.set-bonus-row + .set-bonus-row {
	border-top: 1px solid rgb(234 247 250 / 0.075);
}

.set-bonus-row span {
	display: inline-flex;
	align-items: center;
	min-height: 22px;
	color: var(--ah-action-secondary);
	font-family: var(--ah-font-mono);
	font-size: 12px;
	font-weight: 800;
	text-transform: uppercase;
}

.set-bonus-row p {
	margin: 0;
	color: var(--ah-text-secondary);
	font-size: 13px;
	line-height: 1.5;
}

ul {
	margin: var(--ah-space-2) 0 0;
	padding-left: 1.1rem;
}

@media (max-width: 980px) {
	.site-header {
		padding-inline: var(--ah-space-4);
	}

	.site-nav {
		display: none;
	}

	.layout {
		grid-template-columns: 1fr;
	}

	.left {
		padding: var(--ah-space-5) var(--ah-space-4) 6rem;
		border-right: 0;
	}

	.right {
		position: fixed;
		inset: 0;
		z-index: 30;
		display: none;
		height: auto;
		padding: var(--ah-space-4);
		background: rgb(8 12 16 / 0.92);
	}

	.right.right--open {
		display: block;
	}

	.inspector {
		max-height: min(100dvh - 2rem, 48rem);
		margin-top: auto;
	}

	.inspector-close {
		display: inline-flex;
		align-items: center;
	}

	.filters {
		grid-template-columns: 1fr;
	}

	.headline {
		grid-template-columns: minmax(0, 1fr) auto;
		gap: var(--ah-space-3);
		align-items: start;
		padding-top: 3.25rem;
	}

	.headline > div {
		min-width: 0;
	}

	.headline h1 {
		font-size: clamp(34px, 10vw, 44px);
	}

	.headline p:not(.section-kicker) {
		font-size: 16px;
	}

	.family-switch {
		width: 100%;
	}

	.count-panel {
		min-width: 86px;
		margin-top: 24px;
		padding: 10px;
		text-align: right;
	}

	.count-panel strong {
		font-size: 34px;
	}

	.left > .filters {
		display: none;
	}

	.mobile-menu__filters {
		display: grid;
	}

	.results-head {
		display: none;
	}

	.item {
		grid-template-columns: 74px minmax(0, 1fr);
		gap: var(--ah-space-3);
		padding-inline: var(--ah-space-3);
	}

	.item__type {
		grid-column: 2;
		display: flex;
		align-items: center;
		gap: var(--ah-space-2);
		justify-items: start;
		text-align: left;
	}

	.mobile-menu-toggle {
		position: fixed;
		top: 82px;
		right: var(--ah-space-4);
		z-index: 20;
		display: inline-flex;
		align-items: center;
	}

	.mobile-menu[hidden] {
		display: none;
	}

	.mobile-menu:not([hidden]) {
		display: block;
	}

	.return-top {
		position: fixed;
		right: var(--ah-space-4);
		bottom: var(--ah-space-4);
		z-index: 25;
		background: var(--ah-bg-surface);
		opacity: 0;
		pointer-events: none;
		transform: translateY(.75rem);
		transition: opacity var(--ah-transition-base), transform var(--ah-transition-base);
	}

	.return-top.is-visible {
		display: inline-flex;
		align-items: center;
		opacity: 1;
		pointer-events: auto;
		transform: translateY(0);
	}
}
