:root {
	--keg-ink: #16202b;
	--keg-body: #3d4a57;
	--keg-muted: #6b7884;
	--keg-page-bg: #fbfaf8;
	--keg-surface: #fff;
	--keg-hairline: #e4e0d6;
	--keg-row-divider: #f4f1ea;
	--keg-accent-blue: #2a5ba8;
	--keg-accent-red: #c0334a;
	--keg-rl-newcomer: #3e9b68;
	--keg-rl-beginner: #3b72c4;
	--keg-rl-practical: #c29234;
	--keg-rl-advanced: #c84f62;
	--keg-font-sans: "Public Sans", system-ui, sans-serif;
	--keg-font-serif: "Source Serif 4", Georgia, serif;
	--keg-font-mono: "IBM Plex Mono", ui-monospace, monospace;
}

.keg-hero br,
.keg-category-card-grid br,
.keg-latest-guides br,
.keg-popular-guides br,
.keg-info-box br,
.keg-sidebar br,
.keg-index br {
	display: none !important;
}

.keg-hero {
	position: relative;
	height: 330px;
	overflow: hidden;
	border-bottom: 1px solid rgba(255, 255, 255, 0.08);
	background: var(--keg-ink);
	color: #fff;
}

.keg-hero--graphic {
	background: #162332;
}

.keg-hero--graphic::before {
	position: absolute;
	inset: 0;
	background:
		linear-gradient(90deg, rgba(12, 18, 25, 0.14), rgba(12, 18, 25, 0) 58%),
		repeating-linear-gradient(90deg, transparent 0 79px, rgba(255, 255, 255, 0.022) 80px),
		repeating-linear-gradient(0deg, transparent 0 79px, rgba(255, 255, 255, 0.018) 80px);
	content: "";
}

.keg-hero-slides,
.keg-hero-slide,
.keg-hero-image,
.keg-hero-overlay {
	position: absolute;
	inset: 0;
}

.keg-hero-slide {
	visibility: hidden;
	opacity: 0;
	transition: opacity 0.6s ease, visibility 0.6s ease;
}

.keg-hero-slide.is-active {
	visibility: visible;
	opacity: 1;
}

.keg-hero-image {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.keg-hero-graphic {
	position: absolute;
	inset: 0 0 0 48%;
	overflow: hidden;
	background:
		radial-gradient(circle at 72% 45%, rgba(42, 91, 168, 0.22), transparent 31%),
		radial-gradient(circle at 84% 76%, rgba(192, 51, 74, 0.1), transparent 24%);
	opacity: 0.9;
}

.keg-hero-graphic--levels {
	background:
		radial-gradient(circle at 72% 48%, rgba(42, 91, 168, 0.2), transparent 34%),
		linear-gradient(120deg, rgba(255, 255, 255, 0.018), rgba(255, 255, 255, 0.055));
}

.keg-graphic-level {
	position: absolute;
	z-index: 2;
	display: inline-flex;
	align-items: center;
	gap: 7px;
	padding: 7px 13px;
	border: 1px solid rgba(220, 229, 238, 0.24);
	border-radius: 100px;
	background: rgba(249, 248, 244, 0.1);
	color: rgba(242, 246, 250, 0.86);
	font: 600 11px/1 var(--keg-font-sans);
	backdrop-filter: blur(5px);
}

.keg-graphic-level i {
	width: 7px;
	height: 7px;
	border-radius: 50%;
}

.keg-graphic-level--newcomer { top: 54px; right: 35%; }
.keg-graphic-level--newcomer i { background: var(--keg-rl-newcomer); }
.keg-graphic-level--beginner { top: 102px; right: 12%; }
.keg-graphic-level--beginner i { background: var(--keg-rl-beginner); }
.keg-graphic-level--practical { top: 174px; right: 38%; }
.keg-graphic-level--practical i { background: var(--keg-rl-practical); }
.keg-graphic-level--advanced { top: 230px; right: 15%; }
.keg-graphic-level--advanced i { background: var(--keg-rl-advanced); }

.keg-graphic-list-row {
	position: absolute;
	right: 8%;
	width: 330px;
	height: 52px;
	border: 1px solid rgba(205, 218, 231, 0.14);
	border-radius: 7px;
	background:
		linear-gradient(90deg, rgba(255, 255, 255, 0.06) 0 56px, transparent 56px),
		rgba(255, 255, 255, 0.018);
}

.keg-graphic-list-row--one { top: 36px; opacity: 0.42; }
.keg-graphic-list-row--two { top: 132px; opacity: 0.58; }
.keg-graphic-list-row--three { top: 228px; opacity: 0.34; }

.keg-hero-graphic--recommended {
	background:
		radial-gradient(circle at 78% 45%, rgba(42, 91, 168, 0.2), transparent 35%),
		radial-gradient(circle at 54% 82%, rgba(192, 51, 74, 0.08), transparent 25%);
}

.keg-graphic-guide-card {
	position: absolute;
	display: block;
	width: 170px;
	height: 112px;
	border: 1px solid rgba(215, 225, 235, 0.22);
	border-top: 3px solid rgba(42, 91, 168, 0.72);
	border-radius: 8px;
	background: rgba(255, 255, 255, 0.045);
	box-shadow: 0 20px 42px rgba(4, 10, 16, 0.16);
}

.keg-graphic-guide-card i,
.keg-graphic-guide-card b {
	position: absolute;
	left: 18px;
	display: block;
	height: 6px;
	border-radius: 6px;
	background: rgba(220, 229, 238, 0.24);
}

.keg-graphic-guide-card i { top: 28px; width: 104px; }
.keg-graphic-guide-card b { top: 49px; width: 72px; opacity: 0.6; }
.keg-graphic-guide-card--one { top: 48px; right: 32%; transform: rotate(-2deg); }
.keg-graphic-guide-card--two { top: 162px; right: 9%; border-top-color: rgba(46, 125, 82, 0.75); transform: rotate(1.5deg); }
.keg-graphic-guide-card--three { top: 188px; right: 42%; border-top-color: rgba(192, 51, 74, 0.72); transform: rotate(-1deg); }

.keg-fallback-node {
	position: absolute;
	width: 148px;
	height: 86px;
	border: 1px solid rgba(197, 211, 226, 0.22);
	border-left: 3px solid rgba(78, 124, 190, 0.72);
	border-radius: 8px;
	background: rgba(255, 255, 255, 0.035);
	box-shadow: 0 18px 38px rgba(4, 10, 16, 0.12);
}

.keg-fallback-node::before,
.keg-fallback-node::after {
	position: absolute;
	left: 18px;
	height: 5px;
	border-radius: 5px;
	background: rgba(217, 226, 235, 0.24);
	content: "";
}

.keg-fallback-node::before {
	top: 22px;
	width: 72px;
}

.keg-fallback-node::after {
	top: 39px;
	width: 102px;
	opacity: 0.58;
}

.keg-fallback-node--one { top: 42px; right: 21%; }
.keg-fallback-node--two { top: 154px; right: 8%; border-left-color: rgba(192, 51, 74, 0.62); }
.keg-fallback-node--three { top: 188px; right: 38%; }

.keg-fallback-line {
	position: absolute;
	height: 1px;
	background: rgba(183, 201, 220, 0.2);
	transform-origin: left center;
}

.keg-fallback-line--one {
	top: 142px;
	right: 19%;
	width: 190px;
	transform: rotate(29deg);
}

.keg-fallback-line--two {
	top: 208px;
	right: 29%;
	width: 170px;
	transform: rotate(-14deg);
}

.keg-hero-overlay {
	background: linear-gradient(90deg, rgba(12, 18, 25, 0.86), rgba(12, 18, 25, 0.5) 52%, rgba(12, 18, 25, 0.2));
}

.keg-hero-slide--light .keg-hero-overlay {
	background: linear-gradient(90deg, rgba(248, 244, 236, 0.68) 0%, rgba(248, 244, 236, 0.38) 46%, rgba(248, 244, 236, 0.04) 70%);
}

.keg-hero-slide--light .keg-hero-copy {
	top: 50%;
	max-width: 620px;
	padding: 21px 24px 23px;
	border: 1px solid rgba(60, 99, 145, 0.16);
	border-radius: 8px;
	background: rgba(250, 246, 239, 0.7);
	box-shadow: 0 10px 34px rgba(80, 60, 35, 0.06);
	transform: translateY(-58%);
	backdrop-filter: blur(3px);
}

.keg-hero-slide--light .keg-hero-kicker {
	display: none;
}

.keg-hero-slide--light .keg-hero-title {
	color: #2c3a52;
}

.keg-hero-slide--light .keg-hero-subtitle {
	color: #6f6553;
}

.keg-hero.is-light .keg-hero-dots button {
	border-color: rgba(44, 58, 82, 0.58);
}

.keg-hero.is-light .keg-hero-dots button.is-active {
	background: #2c3a52;
}

.keg-hero-copy {
	position: absolute;
	z-index: 2;
	top: 82px;
	left: max(32px, calc((100vw - 1200px) / 2 + 32px));
	width: min(560px, calc(100% - 64px));
}

.keg-hero-kicker {
	margin-bottom: 12px;
	color: #9fb4d6;
	font: 600 11px/1.4 var(--keg-font-mono);
	letter-spacing: 0.1em;
	text-transform: uppercase;
}

.keg-hero-title {
	margin: 0 0 10px;
	color: #fff;
	font: 700 36px/1.1 var(--keg-font-serif);
}

.keg-hero-title a {
	color: inherit;
}

.keg-hero-subtitle {
	max-width: 520px;
	margin: 0;
	color: #ccd4dd;
	font: 400 16px/1.5 var(--keg-font-serif);
}

.keg-hero-search {
	position: absolute;
	z-index: 5;
	bottom: 24px;
	left: max(32px, calc((100vw - 1200px) / 2 + 32px));
	display: flex;
	width: min(520px, calc(100% - 120px));
	height: 48px;
	padding: 4px;
	border-radius: 7px;
	background: #fff;
	box-shadow: 0 8px 28px rgba(0, 0, 0, 0.22);
}

.keg-hero-search input {
	flex: 1;
	min-width: 0;
	padding: 0 14px;
	border: 0;
	background: transparent;
	font: 400 15px var(--keg-font-serif);
}

.keg-hero-search button,
.keg-filter-rail button {
	min-width: 44px;
	border: 0;
	border-radius: 6px;
	background: var(--keg-accent-blue);
	color: #fff;
	font: 600 13px var(--keg-font-sans);
	cursor: pointer;
}

.keg-hero-dots {
	position: absolute;
	z-index: 6;
	right: max(32px, calc((100vw - 1200px) / 2 + 32px));
	bottom: 32px;
	display: flex;
	gap: 8px;
}

.keg-hero-dots button {
	width: 10px;
	height: 10px;
	padding: 0;
	border: 1px solid rgba(255, 255, 255, 0.7);
	border-radius: 10px;
	background: transparent;
	cursor: pointer;
	transition: width 0.2s ease, background 0.2s ease;
}

.keg-hero-dots button.is-active {
	width: 28px;
	background: #fff;
}

.keg-category-card-grid {
	display: grid;
	width: 100%;
	max-width: 1200px;
	margin-inline: auto;
	grid-template-columns: repeat(var(--keg-card-columns, 3), minmax(0, 1fr));
	gap: 24px;
}

.keg-category-card {
	display: flex;
	min-height: 156px;
	flex-direction: column;
	justify-content: flex-start;
	padding: 24px 24px 21px;
	border: 1px solid var(--keg-hairline);
	border-left: 3px solid var(--keg-category-color);
	border-radius: 8px;
	background: var(--keg-surface);
	box-shadow: 0 1px 2px rgba(20, 32, 43, 0.04);
	color: var(--keg-ink);
	transition: transform 0.18s ease, box-shadow 0.18s ease, border-color 0.18s ease;
}

.keg-category-card:hover {
	border-color: #dad5c9;
	box-shadow: 0 6px 20px rgba(20, 32, 43, 0.1);
	text-decoration: none;
	transform: translateY(-2px);
}

.keg-category-card-heading {
	display: flex;
	align-items: center;
	gap: 9px;
}

.keg-category-card-dot {
	width: 8px;
	height: 8px;
	flex: 0 0 8px;
	border-radius: 50%;
	background: var(--keg-category-color);
}

.keg-category-card-title {
	color: var(--keg-ink);
	font: 700 16px/1.3 var(--keg-font-sans);
}

.keg-category-card-description {
	margin-top: 11px;
	color: var(--keg-muted);
	font: 400 14px/1.52 var(--keg-font-serif);
}

.keg-category-card-link {
	margin-top: auto;
	padding-top: 14px;
	color: var(--keg-accent-blue);
	font: 600 12px/1.3 var(--keg-font-sans);
}

.keg-category-card:hover .keg-category-card-title {
	color: var(--keg-accent-blue);
}

.keg-latest-guides.keg-layout-grid {
	display: grid;
	width: 100%;
	max-width: 1200px;
	margin-inline: auto;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 24px;
}

.keg-guide-card {
	overflow: hidden;
	border: 1px solid var(--keg-hairline);
	border-radius: 8px;
	background: var(--keg-surface);
	box-shadow: 0 1px 2px rgba(20, 32, 43, 0.04);
}

.keg-guide-card-image,
.keg-guide-card-image img,
.keg-guide-card-placeholder {
	display: block;
	width: 100%;
	aspect-ratio: 16 / 9;
	object-fit: cover;
	background: var(--keg-row-divider);
}

.keg-guide-card-body {
	padding: 18px;
}

.keg-guide-card h3 {
	margin: 12px 0 14px;
	font: 700 16px/1.35 var(--keg-font-sans);
}

.keg-card-data,
.keg-guide-row-data {
	display: flex;
	flex-wrap: wrap;
	gap: 6px 14px;
	color: var(--keg-muted);
	font: 500 12px/1.4 var(--keg-font-mono);
}

.keg-level {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	padding: 4px 11px;
	border: 1px solid var(--keg-hairline);
	border-radius: 100px;
	background: #f4f2ec;
	color: #41505e;
	font: 600 11.5px/1 var(--keg-font-sans);
	white-space: nowrap;
}

.keg-level i {
	width: 7px;
	height: 7px;
	border-radius: 50%;
}

.keg-level--newcomer i { background: var(--keg-rl-newcomer); }
.keg-level--beginner i { background: var(--keg-rl-beginner); }
.keg-level--practical i { background: var(--keg-rl-practical); }
.keg-level--advanced i { background: var(--keg-rl-advanced); }

.keg-popular-guides {
	width: 100%;
	max-width: 1200px;
	margin: 0;
	padding: 0;
	overflow: hidden;
	border: 1px solid var(--keg-hairline);
	border-radius: 8px;
	background: var(--keg-surface);
	list-style: none;
}

body.home .keg-category-card-grid,
body.home .keg-latest-guides,
body.home .keg-popular-guides {
	position: relative;
	left: 50%;
	width: min(1200px, calc(100vw - 48px));
	max-width: 1200px;
	margin-right: 0;
	margin-left: 0;
	transform: translateX(-50%);
}

.keg-popular-row {
	display: grid;
	grid-template-columns: 44px minmax(0, 1fr) auto;
	gap: 14px;
	align-items: center;
	padding: 16px 20px;
	border-bottom: 1px solid var(--keg-row-divider);
}

.keg-popular-row:last-child {
	border-bottom: 0;
}

.keg-popular-rank,
.keg-popular-views {
	color: var(--keg-muted);
	font: 600 12px var(--keg-font-mono);
}

.keg-popular-content {
	display: flex;
	min-width: 0;
	align-items: center;
	gap: 12px;
}

.keg-popular-title {
	overflow: hidden;
	color: var(--keg-ink);
	font: 700 14px var(--keg-font-sans);
	text-overflow: ellipsis;
	white-space: nowrap;
}

.keg-info-box {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 0;
	margin: 22px 0 28px;
	border: 1px solid var(--keg-hairline);
	border-radius: 8px;
	background: var(--keg-page-bg);
}

.keg-info-item {
	display: flex;
	min-width: 0;
	flex-direction: column;
	gap: 8px;
	padding: 16px 18px;
	border-right: 1px solid var(--keg-hairline);
	color: var(--keg-ink);
	font: 600 13px/1.4 var(--keg-font-sans);
}

.keg-info-item:last-child {
	border-right: 0;
}

.keg-info-label {
	color: var(--keg-muted);
	font: 700 10px/1.2 var(--keg-font-sans);
	letter-spacing: 0.08em;
	text-transform: uppercase;
}

.keg-sidebar {
	display: grid;
	gap: 18px;
}

.keg-sidebar-section {
	padding: 20px;
	border: 1px solid var(--keg-hairline);
	border-radius: 8px;
	background: var(--keg-surface);
}

.keg-sidebar-section h2 {
	margin: 0 0 16px;
	font: 700 14px var(--keg-font-sans);
}

.keg-sidebar-links,
.keg-sidebar-levels {
	display: grid;
	gap: 10px;
	margin: 0;
	padding: 0;
	list-style: none;
}

.keg-sidebar-section .keg-popular-guides {
	border: 0;
}

.keg-sidebar-section .keg-popular-row {
	grid-template-columns: 24px minmax(0, 1fr);
	padding: 10px 0;
}

.keg-sidebar-section .keg-popular-views,
.keg-sidebar-section .keg-level {
	display: none;
}

.keg-index {
	display: grid;
	grid-template-columns: 248px minmax(0, 1fr);
	gap: 32px;
	align-items: start;
	margin-top: 32px;
}

.keg-filter-open {
	display: none;
}

.keg-filter-close {
	display: none;
}

.keg-filter-rail {
	position: sticky;
	top: 130px;
	display: grid;
	gap: 22px;
	padding: 20px;
	border: 1px solid var(--keg-hairline);
	border-radius: 8px;
	background: var(--keg-surface);
}

.keg-filter-rail fieldset {
	display: grid;
	gap: 10px;
	margin: 0;
	padding: 0;
	border: 0;
}

.keg-filter-rail legend {
	margin-bottom: 10px;
	color: var(--keg-ink);
	font: 700 12px var(--keg-font-sans);
	letter-spacing: 0.05em;
	text-transform: uppercase;
}

.keg-filter-topics {
	display: grid;
	gap: 8px;
	margin: 0;
	padding: 0;
	list-style: none;
	font: 600 13px/1.4 var(--keg-font-sans);
}

.keg-filter-topics .is-current a {
	color: var(--keg-ink);
	text-decoration: underline;
	text-decoration-thickness: 2px;
	text-underline-offset: 4px;
}

.keg-filter-check {
	display: flex;
	min-height: 32px;
	align-items: center;
	gap: 8px;
	font: 500 13px var(--keg-font-sans);
}

.keg-filter-check input {
	width: 18px;
	height: 18px;
}

.keg-filter-rail > button {
	min-height: 42px;
}

.keg-index-toolbar {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 16px;
	margin-bottom: 12px;
}

.keg-level-toggle {
	padding: 9px 11px;
	border: 1px solid var(--keg-hairline);
	border-radius: 6px;
	background: var(--keg-surface);
	font: 600 12px var(--keg-font-sans);
	white-space: nowrap;
}

.keg-result-count {
	margin: 0;
	color: var(--keg-muted);
	font: 500 13px var(--keg-font-mono);
}

.keg-sort-control {
	display: flex;
	align-items: center;
	gap: 8px;
	color: var(--keg-muted);
	font: 600 12px var(--keg-font-sans);
}

.keg-sort-control select {
	min-height: 40px;
	padding: 0 34px 0 12px;
	border: 1px solid var(--keg-hairline);
	border-radius: 6px;
	background: var(--keg-surface);
	color: var(--keg-ink);
}

.keg-guide-rows {
	overflow: hidden;
	border: 1px solid var(--keg-hairline);
	border-radius: 8px;
	background: var(--keg-surface);
}

.keg-guide-row {
	display: grid;
	grid-template-columns: 92px minmax(0, 1fr);
	gap: 18px;
	align-items: center;
	padding: 18px;
	border-bottom: 1px solid var(--keg-row-divider);
}

.keg-guide-row:last-child {
	border-bottom: 0;
}

.keg-guide-row-thumb,
.keg-guide-row-image,
.keg-guide-row-placeholder {
	display: block;
	width: 92px;
	height: 56px;
	border-radius: 6px;
	background: var(--keg-row-divider);
	object-fit: cover;
}

.keg-guide-row-meta {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: 8px;
}

.keg-row-category {
	font: 600 12px var(--keg-font-sans);
}

.keg-guide-row-title {
	margin: 7px 0;
	font: 700 16px/1.35 var(--keg-font-sans);
}

.keg-guide-row-title a {
	color: var(--keg-ink);
}

.keg-guide-row-title mark {
	padding: 0 2px;
	border-radius: 2px;
	background: #fbf0a8;
	color: inherit;
}

.keg-pagination .page-numbers {
	display: flex;
	justify-content: center;
	gap: 6px;
	margin: 24px 0 0;
	padding: 0;
	list-style: none;
}

.keg-pagination a,
.keg-pagination span {
	display: grid;
	min-width: 40px;
	min-height: 40px;
	place-items: center;
	border: 1px solid var(--keg-hairline);
	border-radius: 6px;
	background: var(--keg-surface);
}

.keg-empty-state {
	display: grid;
	gap: 24px;
}

@media (max-width: 1023px) {
	.keg-hero { height: 260px; }
	.keg-hero-graphic { left: 52%; }
	.keg-category-card-grid,
	.keg-latest-guides.keg-layout-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
	.keg-index { grid-template-columns: 1fr; }
	.keg-filter-rail { position: static; grid-template-columns: repeat(2, 1fr); }
	.keg-filter-rail > button { align-self: end; }
}

@media (max-width: 639px) {
	.keg-hero { height: 188px; }
	.keg-hero-overlay { background: linear-gradient(0deg, rgba(12, 18, 25, 0.92) 8%, rgba(12, 18, 25, 0.25) 85%); }
	.keg-hero-copy { top: auto; right: 16px; bottom: 58px; left: 16px; width: auto; }
	.keg-hero-slide--light .keg-hero-copy {
		top: auto;
		bottom: 58px;
		padding: 12px 14px;
		background: rgba(250, 246, 239, 0.82);
		transform: none;
	}
	.keg-hero-kicker { margin-bottom: 6px; font-size: 9px; }
	.keg-hero-title { margin: 0; font-size: 21px; }
	.keg-hero-subtitle { display: none; }
	.keg-hero-search { right: 16px; bottom: 12px; left: 16px; width: auto; height: 38px; }
	.keg-hero-search button { font-size: 11px; }
	.keg-hero-dots { display: none; }
	.keg-hero-graphic {
		inset: 0;
		opacity: 0.36;
	}
	.keg-fallback-node--one { top: 24px; right: 5%; }
	.keg-fallback-node--two { display: none; }
	.keg-fallback-node--three { display: none; }
	.keg-fallback-line { display: none; }
	.keg-graphic-level--newcomer { top: 26px; right: 7%; }
	.keg-graphic-level--beginner { top: 68px; right: 17%; }
	.keg-graphic-level--practical,
	.keg-graphic-level--advanced,
	.keg-graphic-list-row { display: none; }
	.keg-graphic-guide-card { width: 124px; height: 78px; }
	.keg-graphic-guide-card--one { top: 18px; right: 5%; }
	.keg-graphic-guide-card--two,
	.keg-graphic-guide-card--three { display: none; }
	.keg-category-card-grid,
	.keg-latest-guides.keg-layout-grid { grid-template-columns: 1fr; }
	body.home .keg-category-card-grid,
	body.home .keg-latest-guides,
	body.home .keg-popular-guides {
		width: calc(100vw - 32px);
	}
	.keg-category-card {
		min-height: 0;
		padding: 21px 20px 19px;
	}
	.keg-popular-row { grid-template-columns: 34px minmax(0, 1fr); }
	.keg-popular-content { display: grid; gap: 7px; }
	.keg-popular-views { grid-column: 2; }
	.keg-info-box { grid-template-columns: 1fr; }
	.keg-info-item { border-right: 0; border-bottom: 1px solid var(--keg-hairline); }
	.keg-info-item:last-child { border-bottom: 0; }
	.keg-filter-open {
		display: block;
		min-height: 44px;
		padding: 0 16px;
		border: 1px solid var(--keg-hairline);
		border-radius: 6px;
		background: var(--keg-surface);
		color: var(--keg-ink);
		font: 600 13px var(--keg-font-sans);
	}
	.keg-filter-rail {
		position: fixed;
		z-index: 100;
		right: 0;
		bottom: 0;
		left: 0;
		display: none;
		grid-template-columns: 1fr;
		max-height: 82vh;
		overflow-y: auto;
		padding: 24px;
		border-radius: 16px 16px 0 0;
		box-shadow: 0 -12px 36px rgba(20, 32, 43, 0.2);
	}
	.keg-filter-rail.is-open { display: grid; }
	.keg-filter-rail .keg-filter-close {
		display: block;
		min-height: 44px;
		border: 1px solid var(--keg-hairline);
		background: var(--keg-surface);
		color: var(--keg-ink);
	}
	.keg-index-toolbar { align-items: stretch; flex-direction: column; }
	.keg-sort-control { justify-content: space-between; }
	.keg-sort-control select { flex: 1; max-width: 260px; }
	.keg-guide-row { grid-template-columns: 66px minmax(0, 1fr); gap: 12px; padding: 14px; }
	.keg-guide-row-thumb,
	.keg-guide-row-image,
	.keg-guide-row-placeholder { width: 66px; height: 44px; }
	.keg-guide-row-title { font-size: 14px; }
	.keg-guide-row-data { font-size: 11px; }
}

@media (prefers-reduced-motion: reduce) {
	.keg-hero-slide,
	.keg-category-card,
	.keg-hero-dots button {
		transition: none;
	}
}
