/**
 * Cursio — global stylesheet (tokens via @import, RTL-first logical properties).
 *
 * @package Cursio
 */

@import url("tokens.css");

/* -------------------------------------------------------------------------
   CSS reset
   ------------------------------------------------------------------------- */

*,
*::before,
*::after {
	box-sizing: border-box;
	margin: 0;
	padding: 0;
}

html {
	font-size: var(--cursio-html-font-size, 16px);
	scroll-behavior: smooth;
}

body {
	font-family: var(--cursio-font-family-body);
	font-size: var(--cursio-font-size-body-md);
	line-height: var(--cursio-line-height-body-md);
	font-weight: var(--cursio-font-weight-body-md);
	background-color: var(--cursio-background);
	color: var(--cursio-on-background);
	direction: inherit;
}

img {
	max-inline-size: 100%;
	block-size: auto;
	display: block;
}

/* -------------------------------------------------------------------------
   Typography scale
   ------------------------------------------------------------------------- */

h1,
h2,
h3,
h4,
h5,
h6 {
	font-family: var(--cursio-font-family-heading);
	color: var(--cursio-on-background);
}

h1 {
	font-size: var(--cursio-font-size-h1);
	line-height: var(--cursio-line-height-h1);
	font-weight: var(--cursio-font-weight-h1);
	letter-spacing: var(--cursio-letter-spacing-h1);
}

h2 {
	font-size: var(--cursio-font-size-h2);
	line-height: var(--cursio-line-height-h2);
	font-weight: var(--cursio-font-weight-h2);
	letter-spacing: var(--cursio-letter-spacing-h2);
}

h3 {
	font-size: var(--cursio-font-size-h3);
	line-height: var(--cursio-line-height-h3);
	font-weight: var(--cursio-font-weight-h3);
}

h4 {
	font-size: var(--cursio-font-size-h4);
	line-height: var(--cursio-line-height-h4);
	font-weight: var(--cursio-font-weight-h4);
}

h5 {
	font-size: var(--cursio-font-size-h5);
	line-height: var(--cursio-line-height-h5);
	font-weight: var(--cursio-font-weight-h5);
}

h6 {
	font-size: var(--cursio-font-size-h6);
	line-height: var(--cursio-line-height-h6);
	font-weight: var(--cursio-font-weight-h6);
}

p {
	margin-block: 0 var(--cursio-spacing-md);
}

p:last-child {
	margin-block-end: 0;
}

a {
	color: var(--cursio-primary);
	text-decoration-thickness: 0.08em;
	text-underline-offset: 0.15em;
}

a:hover,
a:focus {
	color: var(--cursio-primary-container);
}

small {
	font-family: var(--cursio-font-family-body);
	font-size: var(--cursio-font-size-body-sm);
	line-height: var(--cursio-line-height-body-sm);
	font-weight: var(--cursio-font-weight-body-sm);
}

/* -------------------------------------------------------------------------
   Layout utilities (logical properties only)
   ------------------------------------------------------------------------- */

.container {
	max-inline-size: var(--cursio-layout-max-width);
	margin-inline: auto;
	padding-inline: var(--cursio-spacing-gutter);
}

.stack {
	display: flex;
	flex-direction: column;
	gap: var(--cursio-spacing-md);
}

.cluster {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: var(--cursio-spacing-md);
}

.grid-auto {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(min(100%, 18rem), 1fr));
	gap: var(--cursio-spacing-md);
}

.section-padding {
	padding-block: var(--cursio-spacing-xl);
}

/* -------------------------------------------------------------------------
   Component bases
   ------------------------------------------------------------------------- */

.btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: var(--cursio-spacing-sm);
	padding-block: var(--cursio-spacing-sm);
	padding-inline: var(--cursio-spacing-lg);
	border-radius: var(--cursio-radius-lg);
	font-family: var(--cursio-font-family-body);
	font-size: var(--cursio-font-size-label-md);
	font-weight: var(--cursio-font-weight-label-md);
	line-height: var(--cursio-line-height-label-md);
	text-decoration: none;
	cursor: pointer;
	border: 1px solid transparent;
	background-color: transparent;
	color: var(--cursio-on-background);
	transition: background-color 0.15s ease, color 0.15s ease, border-color 0.15s ease;
}

.btn:focus-visible {
	outline: 2px solid var(--cursio-primary);
	outline-offset: 2px;
}

.btn--primary {
	background-color: var(--cursio-primary);
	color: var(--cursio-on-primary);
	border-color: transparent;
}

.btn--primary:hover,
.btn--primary:focus {
	background-color: var(--cursio-primary-container);
	color: var(--cursio-on-primary);
}

.btn--ghost {
	background-color: transparent;
	color: var(--cursio-primary);
	border-color: var(--cursio-outline-variant);
}

.btn--ghost:hover,
.btn--ghost:focus {
	background-color: var(--cursio-surface-container);
	color: var(--cursio-primary);
	border-color: var(--cursio-outline);
}

.card {
	border-radius: var(--cursio-radius-lg);
	overflow: hidden;
	background-color: var(--cursio-surface-container-lowest);
	box-shadow: 0 0.25rem 1rem color-mix(in srgb, var(--cursio-on-background) 10%, transparent);
}

.badge {
	display: inline-flex;
	align-items: center;
	border-radius: var(--cursio-radius-full);
	padding-block: var(--cursio-spacing-xs);
	padding-inline: var(--cursio-spacing-sm);
	font-family: var(--cursio-font-family-body);
	font-size: var(--cursio-font-size-label-sm);
	font-weight: var(--cursio-font-weight-label-sm);
	line-height: var(--cursio-line-height-label-sm);
	background-color: var(--cursio-surface-container);
	color: var(--cursio-on-secondary-container);
}

.tag {
	display: inline-flex;
	align-items: center;
	border-radius: var(--cursio-radius-full);
	padding-block: var(--cursio-spacing-xs);
	padding-inline: var(--cursio-spacing-md);
	font-family: var(--cursio-font-family-body);
	font-size: var(--cursio-font-size-label-sm);
	font-weight: var(--cursio-font-weight-label-sm);
	line-height: var(--cursio-line-height-label-sm);
	background-color: transparent;
	color: var(--cursio-primary);
	border: 1px solid var(--cursio-outline-variant);
}

.section-title {
	font-family: var(--cursio-font-family-heading);
	font-size: var(--cursio-font-size-h2);
	line-height: var(--cursio-line-height-h2);
	font-weight: var(--cursio-font-weight-h2);
	letter-spacing: var(--cursio-letter-spacing-h2);
	color: var(--cursio-on-background);
}

.section-subtitle {
	font-family: var(--cursio-font-family-body);
	font-size: var(--cursio-font-size-body-sm);
	line-height: var(--cursio-line-height-body-sm);
	font-weight: var(--cursio-font-weight-body-sm);
	color: var(--cursio-on-surface-variant);
	margin-block-start: var(--cursio-spacing-sm);
}

/* -------------------------------------------------------------------------
   Theme layout & templates
   ------------------------------------------------------------------------- */

.site-header {
	background-color: var(--cursio-surface-container-lowest);
	border-block-end: 1px solid var(--cursio-outline-variant);
	padding-block: var(--cursio-spacing-md);
}

.site-header__inner {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: var(--cursio-spacing-md);
}

.site-header__logo {
	flex: 0 0 auto;
}

.site-header__logo .custom-logo-link,
.site-header__logo a {
	display: inline-block;
	text-decoration: none;
}

.site-header__logo img {
	max-block-size: 3rem;
	inline-size: auto;
}

.site-header__logo .site-title {
	font-family: var(--cursio-font-family-heading);
	font-size: var(--cursio-font-size-h4);
	color: var(--cursio-primary);
}

.site-header__panel {
	flex: 1 1 auto;
	min-inline-size: 0;
}

.site-nav__list {
	list-style: none;
	margin-block: 0;
	margin-inline: 0;
	padding-block: 0;
	padding-inline: 0;
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: var(--cursio-spacing-md);
}

.site-nav__list .sub-menu {
	list-style: none;
	margin-block: 0;
	margin-inline: 0;
	padding-block: var(--cursio-spacing-xs);
	padding-inline: 0;
}

.site-nav a {
	font-family: var(--cursio-font-family-body);
	font-size: var(--cursio-font-size-label-md);
	font-weight: var(--cursio-font-weight-label-md);
	color: var(--cursio-on-background);
	text-decoration: none;
	padding-block: var(--cursio-spacing-xs);
	padding-inline: var(--cursio-spacing-sm);
	border-radius: var(--cursio-radius-lg);
}

.site-nav a:hover,
.site-nav a:focus {
	background-color: var(--cursio-surface-container);
	color: var(--cursio-primary);
}

.site-header__lang {
	flex: 0 0 auto;
	min-block-size: 1.5rem;
}

.site-header__cta {
	flex: 0 0 auto;
}

.site-header__toggle {
	display: none;
	flex: 0 0 auto;
	align-items: center;
	justify-content: center;
	inline-size: 2.75rem;
	block-size: 2.75rem;
	padding-block: 0;
	padding-inline: 0;
	border: 1px solid var(--cursio-outline-variant);
	border-radius: var(--cursio-radius-lg);
	background-color: transparent;
	color: var(--cursio-on-background);
	cursor: pointer;
}

.site-header__toggle:hover,
.site-header__toggle:focus {
	background-color: var(--cursio-surface-container);
	color: var(--cursio-primary);
}

.site-header__toggle:focus-visible {
	outline: 2px solid var(--cursio-primary);
	outline-offset: 2px;
}

.hamburger {
	position: relative;
	display: block;
	inline-size: 1.25rem;
	block-size: 2px;
	background-color: var(--cursio-on-background);
	border-radius: var(--cursio-radius-full);
	box-shadow:
		0 calc(-1 * var(--cursio-spacing-sm)) 0 0 var(--cursio-on-background),
		0 var(--cursio-spacing-sm) 0 0 var(--cursio-on-background);
}

.site-header__toggle:hover .hamburger,
.site-header__toggle:focus .hamburger {
	background-color: var(--cursio-primary);
	box-shadow:
		0 calc(-1 * var(--cursio-spacing-sm)) 0 0 var(--cursio-primary),
		0 var(--cursio-spacing-sm) 0 0 var(--cursio-primary);
}

.cursio-template-full-width .site-main--page > .container {
	max-inline-size: 100%;
}

.site-header--landing .site-header__inner {
	justify-content: flex-start;
}

.site-footer--landing .site-footer__bottom--simple {
	margin-block-start: 0;
	padding-block: var(--cursio-spacing-lg);
	text-align: center;
}

.cursio-category-toolbar {
	display: flex;
	flex-wrap: wrap;
	gap: var(--cursio-spacing-md);
	margin-block-end: var(--cursio-spacing-lg);
}

.cursio-category-filter {
	min-inline-size: 12rem;
	padding-block: var(--cursio-spacing-sm);
	padding-inline: var(--cursio-spacing-md);
	border-radius: var(--cursio-radius-lg);
	border: 1px solid var(--cursio-outline-variant);
	background-color: var(--cursio-surface-container-lowest);
	font-family: var(--cursio-font-family-body);
}

.cursio-before-posts-widget-area {
	margin-block-end: var(--cursio-spacing-xl);
}

.cursio-homepage-banner-widgets {
	margin-block-end: var(--cursio-spacing-md);
}

.site-nav__list > li {
	position: relative;
}

.cursio-nav__submenu-toggle {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	margin-inline-start: var(--cursio-spacing-xs);
	padding-block: 0;
	padding-inline: var(--cursio-spacing-xs);
	border: none;
	background: transparent;
	color: inherit;
	cursor: pointer;
	border-radius: var(--cursio-radius-default);
	vertical-align: middle;
}

.cursio-nav__submenu-toggle:focus-visible {
	outline: 2px solid var(--cursio-primary);
	outline-offset: 2px;
}

.cursio-nav__submenu-icon {
	display: inline-block;
	inline-size: 0.5rem;
	block-size: 0.5rem;
	border-inline-end: 2px solid currentColor;
	border-block-end: 2px solid currentColor;
	transform: rotate(45deg);
	margin-block-start: -0.15rem;
}

.site-nav__list .sub-menu {
	min-inline-size: 12rem;
	background-color: var(--cursio-surface-container-lowest);
	border: 1px solid var(--cursio-outline-variant);
	border-radius: var(--cursio-radius-lg);
	box-shadow: 0 4px 12px rgba(0, 0, 0, 0.08);
}

@media (min-width: 48.001rem) {
	.site-nav__list > li > .sub-menu {
		position: absolute;
		inset-inline-start: 0;
		inset-block-start: 100%;
		z-index: 40;
		margin-block-start: var(--cursio-spacing-xs);
	}

	.site-nav__list > li > .sub-menu[hidden] {
		display: none !important;
	}
}

@media (max-width: 48rem) {
	.site-nav__list .sub-menu {
		margin-inline-start: var(--cursio-spacing-md);
		margin-block-start: var(--cursio-spacing-sm);
	}

	.site-nav__list .sub-menu[hidden] {
		display: none !important;
	}
}

@media (max-width: 48rem) {
	.site-header__toggle {
		display: inline-flex;
		margin-inline-start: auto;
	}

	.site-header__panel {
		flex: 1 0 100%;
		order: 10;
		max-block-size: 0;
		overflow: hidden;
		opacity: 0;
		visibility: hidden;
		padding-block: 0;
		padding-inline: 0;
		border-block-end: none;
		transition:
			max-block-size 0.25s ease,
			opacity 0.2s ease,
			padding-block 0.2s ease,
			visibility 0.2s ease;
	}

	.site-header__panel.is-open {
		max-block-size: 80vh;
		opacity: 1;
		visibility: visible;
		padding-block-start: var(--cursio-spacing-md);
		border-block-end: 1px solid var(--cursio-outline-variant);
	}

	.site-nav__list {
		flex-direction: column;
		align-items: stretch;
	}
}

.site-main {
	max-inline-size: var(--cursio-layout-max-width);
	margin-inline: auto;
	padding-block: var(--cursio-spacing-xl);
	padding-inline: var(--cursio-spacing-gutter);
}

.site-main--single .entry-content,
.site-main--page .entry-content {
	max-inline-size: var(--cursio-layout-content-width);
}

#secondary.widget-area {
	max-inline-size: var(--cursio-layout-max-width);
	margin-inline: auto;
	padding-block: var(--cursio-spacing-xl);
	padding-inline: var(--cursio-spacing-gutter);
}

.widget {
	margin-block-end: calc(var(--cursio-spacing-xl) + var(--cursio-spacing-md));
}

.widget-title {
	font-family: var(--cursio-font-family-heading);
	font-size: var(--cursio-font-size-h5);
	margin-block: 0 var(--cursio-spacing-sm);
	margin-inline: 0;
}

.page-header {
	margin-block-end: calc(var(--cursio-spacing-xl) + var(--cursio-spacing-md));
}

.page-title {
	margin-block: 0;
	margin-inline: 0;
}

.entry {
	margin-block-end: calc(var(--cursio-spacing-xl) + var(--cursio-spacing-md));
	padding-block-end: var(--cursio-spacing-xl);
	border-block-end: 1px solid var(--cursio-outline-variant);
}

.entry:last-child {
	border-block-end: none;
}

.entry-header {
	margin-block-end: var(--cursio-spacing-md);
}

.entry-title {
	margin-block: 0 var(--cursio-spacing-sm);
	margin-inline: 0;
}

.entry-title a {
	color: var(--cursio-on-background);
	text-decoration: none;
}

.entry-title a:hover,
.entry-title a:focus {
	color: var(--cursio-primary);
}

.entry-meta,
.entry-footer {
	font-family: var(--cursio-font-family-body);
	font-size: var(--cursio-font-size-label-sm);
	color: var(--cursio-on-surface-variant);
}

.entry-meta > span,
.entry-footer > span {
	margin-inline-end: var(--cursio-spacing-md);
}

.entry-content {
	font-size: var(--cursio-font-size-body-md);
}

.entry-summary {
	color: var(--cursio-on-surface-variant);
}

.post-thumbnail {
	margin-block: var(--cursio-spacing-md);
	margin-inline: 0;
	border-radius: var(--cursio-radius-xl);
	overflow: hidden;
}

.read-more {
	display: inline-block;
	margin-block-start: var(--cursio-spacing-sm);
	font-family: var(--cursio-font-family-body);
	font-size: var(--cursio-font-size-label-md);
	font-weight: var(--cursio-font-weight-label-md);
}

.site-footer {
	background-color: var(--cursio-surface-container);
	border-block-start: 1px solid var(--cursio-outline-variant);
	padding-block: var(--cursio-spacing-xl);
	margin-block-start: calc(var(--cursio-spacing-xl) + var(--cursio-spacing-md));
}

.site-footer__grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(min(100%, 14rem), 1fr));
	gap: var(--cursio-spacing-xl);
	margin-block-end: var(--cursio-spacing-xl);
	text-align: start;
}

.site-footer__brand {
	gap: var(--cursio-spacing-sm);
}

.site-footer__logo .custom-logo-link,
.site-footer__logo a {
	display: inline-block;
	text-decoration: none;
}

.site-footer__logo img {
	max-block-size: 3rem;
	inline-size: auto;
}

.site-footer__site-name {
	font-family: var(--cursio-font-family-heading);
	font-size: var(--cursio-font-size-h5);
	color: var(--cursio-primary);
}

.site-footer__tagline {
	margin-block: 0;
	margin-inline: 0;
	font-size: var(--cursio-font-size-body-sm);
	color: var(--cursio-on-surface-variant);
}

.site-footer__menus {
	min-inline-size: 0;
}

.site-footer__nav {
	list-style: none;
	margin-block: 0;
	margin-inline: 0;
	padding-block: 0;
	padding-inline: 0;
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(min(100%, 10rem), 1fr));
	gap: var(--cursio-spacing-lg);
}

.site-footer__nav > .menu-item {
	display: flex;
	flex-direction: column;
	gap: var(--cursio-spacing-sm);
}

.site-footer__nav > .menu-item > a {
	font-family: var(--cursio-font-family-heading);
	font-size: var(--cursio-font-size-body-sm);
	font-weight: var(--cursio-font-weight-label-md);
	color: var(--cursio-on-background);
	text-decoration: none;
}

.site-footer__nav .sub-menu {
	list-style: none;
	margin-block: 0;
	margin-inline: 0;
	padding-block: 0;
	padding-inline: 0;
	display: flex;
	flex-direction: column;
	gap: var(--cursio-spacing-xs);
}

.site-footer__nav .sub-menu a {
	font-family: var(--cursio-font-family-body);
	font-size: var(--cursio-font-size-body-sm);
	color: var(--cursio-on-surface-variant);
	text-decoration: none;
}

.site-footer__nav .sub-menu a:hover,
.site-footer__nav .sub-menu a:focus {
	color: var(--cursio-primary);
}

.site-footer__social-wrap {
	min-inline-size: 0;
}

.site-footer__social {
	list-style: none;
	margin-block: 0;
	margin-inline: 0;
	padding-block: 0;
	padding-inline: 0;
	display: flex;
	flex-wrap: wrap;
	gap: var(--cursio-spacing-md);
	align-items: center;
}

.site-footer__social a {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	inline-size: 2.5rem;
	block-size: 2.5rem;
	border-radius: var(--cursio-radius-lg);
	border: 1px solid var(--cursio-outline-variant);
	background-color: var(--cursio-surface-container-lowest);
	text-decoration: none;
	color: var(--cursio-on-background);
}

.site-footer__social a:hover,
.site-footer__social a:focus {
	border-color: var(--cursio-primary);
	color: var(--cursio-primary);
}

.site-footer__bottom {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: space-between;
	gap: var(--cursio-spacing-md);
	padding-block-start: var(--cursio-spacing-lg);
	border-block-start: 1px solid var(--cursio-outline-variant);
	text-align: start;
}

.site-footer__copy {
	margin-block: 0;
	margin-inline: 0;
	font-size: var(--cursio-font-size-body-sm);
	color: var(--cursio-on-surface-variant);
}

.site-footer__payments {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	gap: var(--cursio-spacing-sm);
	min-block-size: 1.5rem;
}

/* -------------------------------------------------------------------------
   Homepage
   ------------------------------------------------------------------------- */

.site-main.site-main--front {
	padding-inline: 0;
	padding-block-start: 0;
}

.home-hero {
	background-color: var(--cursio-hero-bg, var(--cursio-surface-container-low));
}

.home-hero__grid {
	display: grid;
	gap: var(--cursio-spacing-xl);
	align-items: center;
	grid-template-columns: 1fr;
}

.home-hero__figure {
	margin-block: 0;
	margin-inline: 0;
	overflow: hidden;
	border-radius: var(--cursio-radius-xl);
}

.home-hero__bg {
	display: block;
	inline-size: 100%;
	block-size: auto;
	max-block-size: min(70vh, 28rem);
	object-fit: cover;
}

.home-hero__content {
	max-inline-size: var(--cursio-layout-content-width);
}

.home-hero__title {
	margin-block-end: 0;
}

.home-hero__subtitle {
	margin-block-start: 0;
}

.home-hero__actions {
	margin-block: 0;
	margin-inline: 0;
}

@media (min-width: 48rem) {
	.home-hero__grid {
		grid-template-columns: 1fr 1fr;
	}
}

.home-categories__grid {
	list-style: none;
	margin-block: 0;
	margin-inline: 0;
	padding-block: 0;
	padding-inline: 0;
	display: grid;
	gap: var(--cursio-spacing-md);
	grid-template-columns: repeat(auto-fit, minmax(min(100%, 10rem), 1fr));
}

@media (min-width: 48rem) {
	.home-categories__grid {
		grid-template-columns: repeat(auto-fill, minmax(min(100%, 10rem), 1fr));
	}
}

.home-categories__grid--count-1,
.home-categories__grid--count-2,
.home-categories__grid--count-3 {
	grid-template-columns: 1fr;
	max-inline-size: 22rem;
}

.home-categories__card {
	display: flex;
	flex-direction: column;
	align-items: start;
	gap: var(--cursio-spacing-sm);
	padding-block: var(--cursio-spacing-md);
	padding-inline: var(--cursio-spacing-md);
	text-decoration: none;
	color: inherit;
}

.home-categories__card:hover,
.home-categories__card:focus {
	color: var(--cursio-primary);
}

.home-categories__icon-wrap {
	margin-block: 0;
	margin-inline: 0;
}

.home-categories__icon {
	inline-size: 3rem;
	block-size: 3rem;
	object-fit: contain;
}

.home-programs__track {
	display: flex;
	flex-direction: row;
	flex-wrap: nowrap;
	gap: var(--cursio-spacing-md);
	overflow-x: auto;
	overflow-y: hidden;
	scroll-snap-type: x mandatory;
	scroll-padding-inline: var(--cursio-spacing-md);
	padding-block-end: var(--cursio-spacing-sm);
	justify-content: start;
}

.home-programs__track--count-1,
.home-programs__track--count-2,
.home-programs__track--count-3 {
	justify-content: start;
}

.home-programs__card {
	flex: 0 0 min(85vw, 22rem);
	scroll-snap-align: start;
	display: flex;
	flex-direction: column;
}

.home-programs__thumb {
	margin-block: 0;
	margin-inline: 0;
}

.home-programs__thumb a {
	display: block;
}

.home-programs__thumb-img {
	display: block;
	inline-size: 100%;
	block-size: auto;
}

.home-programs__body {
	padding-block: var(--cursio-spacing-md);
	padding-inline: var(--cursio-spacing-md);
}

.home-programs__card-title {
	font-family: var(--cursio-font-family-heading);
	font-size: var(--cursio-font-size-h5);
	margin-block: 0;
	margin-inline: 0;
}

.home-programs__card-title a {
	color: inherit;
	text-decoration: none;
}

.home-programs__excerpt {
	margin-block: 0;
	margin-inline: 0;
	font-size: var(--cursio-font-size-body-sm);
	color: var(--cursio-on-surface-variant);
}

.home-programs__card-cta {
	margin-block: 0;
	margin-inline: 0;
}

.home-articles__grid,
.home-tools__grid,
.home-podcasts__grid {
	list-style: none;
	margin-block: 0;
	margin-inline: 0;
	padding-block: 0;
	padding-inline: 0;
	display: grid;
	gap: var(--cursio-spacing-lg);
	grid-template-columns: 1fr;
}

@media (min-width: 48rem) {
	.home-articles__grid,
	.home-tools__grid,
	.home-podcasts__grid {
		grid-template-columns: repeat(auto-fill, minmax(min(100%, 18rem), 1fr));
	}
}

.home-articles__grid--count-1,
.home-tools__grid--count-1,
.home-podcasts__grid--count-1,
.home-articles__grid--count-2,
.home-tools__grid--count-2,
.home-podcasts__grid--count-2,
.home-articles__grid--count-3,
.home-tools__grid--count-3,
.home-podcasts__grid--count-3 {
	grid-template-columns: 1fr;
	max-inline-size: 22rem;
}

.cursio-ltr-text {
	unicode-bidi: isolate;
	direction: ltr;
	display: inline-block;
}

.home-articles__thumb,
.home-tools__thumb,
.home-podcasts__thumb {
	margin-block: 0;
	margin-inline: 0;
}

.home-articles__thumb a,
.home-tools__thumb a,
.home-podcasts__thumb a {
	display: block;
}

.home-articles__thumb-img,
.home-tools__thumb-img,
.home-podcasts__thumb-img {
	display: block;
	inline-size: 100%;
	block-size: auto;
}

.home-articles__body,
.home-tools__body,
.home-podcasts__body {
	padding-block: var(--cursio-spacing-md);
	padding-inline: var(--cursio-spacing-md);
}

.home-articles__badge-wrap {
	margin-block: 0;
	margin-inline: 0;
}

.home-articles__badge {
	text-decoration: none;
}

.home-articles__card-title,
.home-tools__card-title,
.home-podcasts__card-title {
	font-family: var(--cursio-font-family-heading);
	font-size: var(--cursio-font-size-h6);
	margin-block: 0;
	margin-inline: 0;
}

.home-articles__card-title a,
.home-tools__card-title a,
.home-podcasts__card-title a {
	color: inherit;
	text-decoration: none;
}

.home-articles__excerpt,
.home-tools__description,
.home-podcasts__excerpt {
	margin-block: 0;
	margin-inline: 0;
	font-size: var(--cursio-font-size-body-sm);
	color: var(--cursio-on-surface-variant);
}

.home-articles__date {
	font-size: var(--cursio-font-size-label-sm);
	color: var(--cursio-on-surface-variant);
}

.home-tools__cta,
.home-podcasts__cta {
	margin-block: 0;
	margin-inline: 0;
}

.home-cta-banner {
	background-color: var(--cursio-tertiary-fixed);
	color: var(--cursio-on-tertiary-fixed);
}

.home-cta-banner__title {
	color: var(--cursio-on-tertiary-fixed);
}

.home-cta-banner__text {
	margin-block: 0;
	margin-inline: 0;
	max-inline-size: var(--cursio-layout-content-width);
}

.home-cta-banner__notice {
	margin-block: 0;
	margin-inline: 0;
	font-weight: var(--cursio-font-weight-label-md);
}

.home-cta-banner__form {
	align-items: stretch;
}

.home-cta-banner__label {
	flex: 1 1 12rem;
}

.home-cta-banner__input {
	inline-size: 100%;
	padding-block: var(--cursio-spacing-sm);
	padding-inline: var(--cursio-spacing-md);
	font-family: var(--cursio-font-family-body);
	font-size: var(--cursio-font-size-body-md);
	border: 1px solid var(--cursio-outline-variant);
	border-radius: var(--cursio-radius-lg);
	background-color: var(--cursio-surface-container-lowest);
	color: var(--cursio-on-background);
}

.home-cta-banner__submit {
	flex: 0 0 auto;
}

.comments-area {
	margin-block-start: var(--cursio-spacing-xl);
	padding-block-start: var(--cursio-spacing-xl);
	border-block-start: 1px solid var(--cursio-outline-variant);
}

.comment-list {
	list-style: none;
	margin-block: 0;
	margin-inline: 0;
	padding-block: 0;
	padding-inline: 0;
}

.comment-body {
	margin-block-end: var(--cursio-spacing-lg);
	padding-block: var(--cursio-spacing-md);
	padding-inline: var(--cursio-spacing-md);
	background-color: var(--cursio-surface-container);
	border-radius: var(--cursio-radius-lg);
}

.search-form {
	display: flex;
	flex-wrap: wrap;
	gap: var(--cursio-spacing-sm);
	margin-block: var(--cursio-spacing-md);
	margin-inline: 0;
}

.search-form label {
	flex: 1 1 12rem;
}

.search-form input[type="search"] {
	inline-size: 100%;
	padding-block: var(--cursio-spacing-sm);
	padding-inline: var(--cursio-spacing-md);
	font-family: var(--cursio-font-family-body);
	font-size: var(--cursio-font-size-body-md);
	border: 1px solid var(--cursio-outline-variant);
	border-radius: var(--cursio-radius-xl);
	background-color: var(--cursio-surface-container);
}

.search-form input[type="submit"],
button:not(.site-header__toggle),
input[type="button"],
input[type="submit"] {
	font-family: var(--cursio-font-family-body);
	font-size: var(--cursio-font-size-label-md);
	font-weight: var(--cursio-font-weight-label-md);
	padding-block: var(--cursio-spacing-sm);
	padding-inline: var(--cursio-spacing-lg);
	border: none;
	border-radius: var(--cursio-radius-lg);
	background-color: var(--cursio-primary);
	color: var(--cursio-on-primary);
	cursor: pointer;
}

.search-form input[type="submit"]:hover,
.search-form input[type="submit"]:focus,
button:not(.site-header__toggle):hover,
button:not(.site-header__toggle):focus {
	background-color: var(--cursio-primary-container);
}

.screen-reader-text {
	border: 0 !important;
	clip: rect(1px, 1px, 1px, 1px) !important;
	clip-path: inset(50%) !important;
	block-size: 1px !important;
	margin-block: -1px !important;
	margin-inline: -1px !important;
	overflow: hidden !important;
	padding-block: 0 !important;
	padding-inline: 0 !important;
	position: absolute !important;
	inline-size: 1px !important;
	overflow-wrap: normal !important;
	word-wrap: normal !important;
}

/* Focusable screen-reader text: reset clip/size (skip link and other controls). */
.screen-reader-text:focus,
.screen-reader-text:active {
	clip: auto !important;
	clip-path: none !important;
	block-size: auto !important;
	inline-size: auto !important;
	margin-block: 0 !important;
	margin-inline: 0 !important;
	overflow: visible !important;
	position: absolute !important;
	overflow-wrap: normal !important;
	word-wrap: normal !important;
}

/* Skip link visible focus (compound selector keeps !important within screen-reader pattern). */
.skip-link.screen-reader-text:focus,
.skip-link.screen-reader-text:active {
	padding-block: var(--cursio-spacing-sm) !important;
	padding-inline: var(--cursio-spacing-md) !important;
	inset-block-start: var(--cursio-spacing-sm);
	inset-inline-start: var(--cursio-spacing-sm);
	background-color: var(--cursio-primary);
	color: var(--cursio-on-primary);
	z-index: 100000;
	text-decoration: none;
	border-radius: var(--cursio-radius-default);
}

.posts-navigation,
.post-navigation,
.comment-navigation {
	margin-block: var(--cursio-spacing-xl);
	margin-inline: 0;
}

.posts-navigation .nav-links,
.comment-navigation .nav-links {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	gap: var(--cursio-spacing-md);
}
