/*
Theme Name: Raven Astrid
Theme URI: https://example.com/raven-astrid
Author: Raven Astrid
Author URI: https://example.com
Description: Cinematic Viking music WordPress theme for Raven Astrid, built for Hostinger, YouTube traffic, music gateways, and Viking merchandise.
Version: 1.0.0
Requires at least: 6.0
Tested up to: 6.5
Requires PHP: 7.4
Text Domain: raven-astrid
Tags: entertainment, e-commerce, custom-logo, custom-menu, featured-images, full-site-editing-ready
*/

:root {
	--black: #05070a;
	--black-soft: #080b0f;
	--midnight: #07131d;
	--midnight-2: #0d1c28;
	--stone: #252b30;
	--steel: #6f8793;
	--mist: #b6c0c4;
	--ash: #858b8f;
	--bone: #f2eadf;
	--gold: #d3a757;
	--gold-soft: #eed192;
	--ember: #e06a2e;
	--crimson: #8d241d;
	--line: rgba(242, 234, 223, 0.14);
	--line-strong: rgba(211, 167, 87, 0.42);
	--shadow: 0 28px 90px rgba(0, 0, 0, 0.5);
	--radius: 8px;
	--content: min(1180px, calc(100vw - 40px));
	--serif: Georgia, "Times New Roman", serif;
	--sans: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}

* {
	box-sizing: border-box;
}

html {
	scroll-behavior: smooth;
}

body {
	margin: 0;
	background:
		radial-gradient(circle at 78% 12%, rgba(211, 167, 87, 0.16), transparent 30vw),
		radial-gradient(circle at 16% 36%, rgba(111, 135, 147, 0.13), transparent 24vw),
		linear-gradient(180deg, var(--black), #07111a 38%, var(--black) 100%);
	color: var(--bone);
	font-family: var(--sans);
	font-size: 16px;
	line-height: 1.65;
	letter-spacing: 0;
}

body.nav-open {
	overflow: hidden;
}

img {
	display: block;
	max-width: 100%;
	height: auto;
}

a {
	color: inherit;
	text-decoration: none;
}

p {
	margin: 0 0 1rem;
	color: var(--mist);
}

h1,
h2,
h3,
h4 {
	margin: 0;
	color: var(--bone);
	font-family: var(--serif);
	font-weight: 700;
	line-height: 1.02;
	letter-spacing: 0;
}

h1 {
	max-width: 960px;
	font-size: clamp(3.2rem, 8vw, 7.5rem);
}

h2 {
	font-size: clamp(2.25rem, 5vw, 4.8rem);
}

h3 {
	font-size: clamp(1.35rem, 2vw, 1.85rem);
}

.screen-reader-text {
	position: absolute;
	width: 1px;
	height: 1px;
	overflow: hidden;
	clip: rect(1px, 1px, 1px, 1px);
	white-space: nowrap;
}

.skip-link:focus {
	position: fixed;
	top: 12px;
	left: 12px;
	z-index: 1000;
	width: auto;
	height: auto;
	padding: 10px 14px;
	clip: auto;
	background: var(--gold);
	color: var(--black);
}

.site-header {
	position: fixed;
	top: 0;
	left: 0;
	z-index: 100;
	width: 100%;
	border-bottom: 1px solid rgba(242, 234, 223, 0.09);
	background: linear-gradient(180deg, rgba(5, 7, 10, 0.88), rgba(5, 7, 10, 0.44));
	backdrop-filter: blur(14px);
}

.nav-shell {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 20px;
	width: var(--content);
	min-height: 76px;
	margin: 0 auto;
}

.brand {
	display: inline-flex;
	align-items: center;
	gap: 12px;
	min-width: 210px;
}

.brand-mark {
	display: grid;
	place-items: center;
	width: 44px;
	height: 44px;
	border: 1px solid var(--line-strong);
	background:
		linear-gradient(135deg, rgba(211, 167, 87, 0.25), rgba(111, 135, 147, 0.08)),
		var(--black-soft);
	color: var(--gold-soft);
	font-family: var(--serif);
	font-weight: 700;
}

.brand-logo img {
	width: 46px;
	height: 46px;
	object-fit: cover;
}

.brand-copy {
	display: grid;
	line-height: 1.1;
}

.brand-name {
	font-family: var(--serif);
	font-size: 1.16rem;
	font-weight: 700;
}

.brand-line {
	color: var(--ash);
	font-size: 0.72rem;
	text-transform: uppercase;
}

.primary-nav .menu,
.footer-menu {
	display: flex;
	align-items: center;
	gap: 24px;
	padding: 0;
	margin: 0;
	list-style: none;
}

.primary-nav a {
	color: rgba(242, 234, 223, 0.82);
	font-size: 0.86rem;
	font-weight: 700;
	text-transform: uppercase;
}

.primary-nav a:hover,
.primary-nav a:focus,
.footer-nav a:hover,
.footer-nav a:focus {
	color: var(--gold-soft);
}

.header-action,
.button {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: 46px;
	padding: 0 18px;
	border: 1px solid var(--line);
	border-radius: 4px;
	font-size: 0.82rem;
	font-weight: 800;
	text-transform: uppercase;
	transition: transform 180ms ease, border-color 180ms ease, background 180ms ease, color 180ms ease;
}

.header-action {
	border-color: rgba(211, 167, 87, 0.5);
	color: var(--gold-soft);
}

.header-action:hover,
.button:hover {
	transform: translateY(-2px);
}

.nav-toggle {
	display: none;
	width: 44px;
	height: 44px;
	padding: 0;
	border: 1px solid var(--line);
	border-radius: 4px;
	background: rgba(5, 7, 10, 0.55);
	color: var(--bone);
}

.nav-toggle span:not(.screen-reader-text) {
	display: block;
	width: 18px;
	height: 2px;
	margin: 4px auto;
	background: currentColor;
}

.section-inner {
	width: var(--content);
	margin: 0 auto;
}

.site-main {
	overflow: hidden;
}

.hero {
	position: relative;
	display: grid;
	align-items: end;
	min-height: 100vh;
	padding: 148px 0 86px;
	background: var(--black);
}

.hero-media,
.story-bg,
.final-cta > img {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.hero-media {
	object-position: 48% 50%;
	filter: saturate(0.92) contrast(1.08);
}

.hero-shade {
	position: absolute;
	inset: 0;
	background:
		linear-gradient(90deg, rgba(5, 7, 10, 0.94) 0%, rgba(5, 7, 10, 0.66) 40%, rgba(5, 7, 10, 0.22) 74%),
		linear-gradient(0deg, rgba(5, 7, 10, 0.96) 0%, rgba(5, 7, 10, 0.06) 48%, rgba(5, 7, 10, 0.54) 100%);
}

.hero-weather {
	position: absolute;
	inset: 0;
	opacity: 0.45;
	background-image:
		radial-gradient(circle, rgba(242, 234, 223, 0.7) 0 1px, transparent 1.5px),
		radial-gradient(circle, rgba(224, 106, 46, 0.72) 0 1.4px, transparent 1.8px);
	background-position: 0 0, 24px 18px;
	background-size: 150px 150px, 210px 210px;
	animation: raven-weather 18s linear infinite;
}

@keyframes raven-weather {
	to {
		background-position: 120px 220px, -160px -180px;
	}
}

.hero-inner {
	position: relative;
	z-index: 2;
}

.eyebrow {
	display: inline-flex;
	align-items: center;
	gap: 10px;
	margin: 0 0 18px;
	color: var(--gold-soft);
	font-size: 0.77rem;
	font-weight: 900;
	text-transform: uppercase;
}

.eyebrow::before {
	content: "";
	display: inline-block;
	width: 44px;
	height: 1px;
	background: linear-gradient(90deg, var(--gold), transparent);
}

.hero-copy {
	max-width: 760px;
	margin-top: 26px;
	color: rgba(242, 234, 223, 0.84);
	font-size: clamp(1rem, 1.8vw, 1.22rem);
}

.button-row {
	display: flex;
	flex-wrap: wrap;
	gap: 12px;
	margin-top: 30px;
}

.button-primary {
	border-color: rgba(211, 167, 87, 0.76);
	background: linear-gradient(135deg, #d6a64f, #7f251d);
	color: #120d08;
	box-shadow: 0 15px 42px rgba(141, 36, 29, 0.28);
}

.button-secondary {
	border-color: rgba(242, 234, 223, 0.32);
	background: rgba(8, 19, 29, 0.56);
	color: var(--bone);
}

.button-ghost {
	background: rgba(242, 234, 223, 0.08);
	color: var(--bone);
}

.hero-tags {
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
	margin-top: 42px;
}

.hero-tags span {
	padding: 8px 12px;
	border: 1px solid rgba(242, 234, 223, 0.18);
	background: rgba(5, 7, 10, 0.42);
	color: rgba(242, 234, 223, 0.78);
	font-size: 0.78rem;
	font-weight: 800;
	text-transform: uppercase;
}

.social-rail {
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
	max-width: 980px;
	margin-top: 22px;
}

.social-orb {
	position: relative;
	display: inline-flex;
	align-items: center;
	gap: 10px;
	min-height: 54px;
	padding: 8px 14px 8px 8px;
	overflow: hidden;
	border: 1px solid rgba(242, 234, 223, 0.18);
	border-radius: 6px;
	background:
		linear-gradient(135deg, rgba(242, 234, 223, 0.1), rgba(242, 234, 223, 0.03)),
		rgba(5, 7, 10, 0.62);
	color: var(--bone);
	box-shadow: 0 14px 44px rgba(0, 0, 0, 0.28);
	transition: transform 180ms ease, border-color 180ms ease, box-shadow 180ms ease;
}

.social-orb::after {
	content: "";
	position: absolute;
	inset: auto 0 0;
	height: 2px;
	background: var(--social-color, var(--gold));
	box-shadow: 0 0 20px var(--social-glow, rgba(211, 167, 87, 0.5));
}

.social-orb:hover,
.social-orb:focus {
	transform: translateY(-3px);
	border-color: var(--social-color, var(--line-strong));
	box-shadow: 0 18px 54px var(--social-glow, rgba(211, 167, 87, 0.28));
}

.social-orb.is-pending {
	opacity: 0.72;
}

.social-icon {
	display: grid;
	place-items: center;
	width: 38px;
	height: 38px;
	border-radius: 4px;
	background:
		linear-gradient(135deg, var(--social-color, var(--gold)), rgba(242, 234, 223, 0.18)),
		var(--black);
	color: #05070a;
	font-size: 0.78rem;
	font-weight: 950;
	line-height: 1;
}

.social-name {
	font-size: 0.78rem;
	font-weight: 900;
	text-transform: uppercase;
	white-space: nowrap;
}

.social-soon {
	padding: 2px 6px;
	border: 1px solid rgba(242, 234, 223, 0.16);
	color: var(--ash);
	font-size: 0.64rem;
	font-weight: 900;
	text-transform: uppercase;
}

.social-youtube {
	--social-color: #ff3d2f;
	--social-glow: rgba(255, 61, 47, 0.34);
}

.social-tiktok {
	--social-color: #7afcff;
	--social-glow: rgba(122, 252, 255, 0.26);
}

.social-facebook {
	--social-color: #5c8cff;
	--social-glow: rgba(92, 140, 255, 0.32);
}

.social-x {
	--social-color: #f2eadf;
	--social-glow: rgba(242, 234, 223, 0.24);
}

.social-apple {
	--social-color: #f5f0ea;
	--social-glow: rgba(245, 240, 234, 0.22);
}

.social-spotify {
	--social-color: #1ed760;
	--social-glow: rgba(30, 215, 96, 0.32);
}

.social-instagram {
	--social-color: #f0a34a;
	--social-glow: rgba(240, 86, 124, 0.34);
}

.section {
	position: relative;
	padding: clamp(72px, 9vw, 132px) 0;
	border-top: 1px solid rgba(242, 234, 223, 0.08);
}

.section-about,
.section-gateways,
.section-studio {
	background:
		linear-gradient(180deg, rgba(9, 19, 28, 0.86), rgba(5, 7, 10, 0.98)),
		var(--midnight);
}

.section-universe,
.section-symbols {
	background:
		radial-gradient(circle at 18% 0%, rgba(111, 135, 147, 0.14), transparent 34vw),
		linear-gradient(180deg, var(--black), #0a1118);
}

.section-videos,
.section-shop {
	background:
		radial-gradient(circle at 82% 22%, rgba(224, 106, 46, 0.11), transparent 30vw),
		linear-gradient(180deg, #070a0d, #0c151c);
}

.split {
	display: grid;
	grid-template-columns: minmax(0, 1.05fr) minmax(320px, 0.72fr);
	gap: clamp(34px, 7vw, 88px);
	align-items: center;
}

.split.reverse {
	grid-template-columns: minmax(320px, 0.78fr) minmax(0, 1fr);
}

.section-copy h2,
.section-heading h2 {
	max-width: 860px;
}

.section-copy p {
	max-width: 720px;
}

.section-heading {
	display: grid;
	gap: 10px;
	margin-bottom: 36px;
}

.section-heading.narrow {
	max-width: 760px;
	margin-inline: auto;
	text-align: center;
}

.section-heading.narrow .eyebrow {
	margin-inline: auto;
}

.framed-media {
	position: relative;
	margin: 0;
	border: 1px solid var(--line);
	box-shadow: var(--shadow);
}

.framed-media::before {
	content: "";
	position: absolute;
	inset: 12px;
	border: 1px solid rgba(211, 167, 87, 0.26);
	pointer-events: none;
}

.framed-media img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}

.tall-media {
	aspect-ratio: 4 / 5;
}

.world-grid {
	display: grid;
	grid-template-columns: repeat(5, minmax(0, 1fr));
	gap: 14px;
}

.world-card,
.symbol-card,
.gateway-card,
.post-card {
	border: 1px solid var(--line);
	background:
		linear-gradient(145deg, rgba(242, 234, 223, 0.08), rgba(242, 234, 223, 0.02)),
		rgba(5, 7, 10, 0.72);
	box-shadow: 0 18px 60px rgba(0, 0, 0, 0.22);
}

.world-card {
	min-height: 270px;
	padding: 24px;
}

.card-count {
	display: block;
	margin-bottom: 56px;
	color: var(--gold);
	font-family: var(--serif);
	font-size: 2rem;
	line-height: 1;
}

.world-card h3,
.symbol-card h3,
.product-card h3,
.video-card h3 {
	margin-bottom: 12px;
}

.world-card p,
.symbol-card p,
.product-card p,
.video-card p,
.gateway-card p {
	font-size: 0.95rem;
}

.video-grid {
	display: grid;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	gap: 18px;
}

.video-card,
.product-card {
	overflow: hidden;
	border: 1px solid var(--line);
	background: rgba(5, 7, 10, 0.78);
	box-shadow: var(--shadow);
}

.video-card img {
	width: 100%;
	aspect-ratio: 16 / 10;
	object-fit: cover;
}

.video-card-body {
	padding: 22px;
}

.video-card a,
.text-link {
	color: var(--gold-soft);
	font-weight: 900;
	text-transform: uppercase;
}

.section-story {
	min-height: 620px;
	display: grid;
	align-items: end;
	background: var(--black);
}

.story-bg {
	filter: saturate(0.84) contrast(1.08);
}

.section-story::after,
.final-cta::after {
	content: "";
	position: absolute;
	inset: 0;
	background:
		linear-gradient(90deg, rgba(5, 7, 10, 0.94), rgba(5, 7, 10, 0.48), rgba(5, 7, 10, 0.82)),
		linear-gradient(0deg, rgba(5, 7, 10, 0.98), rgba(5, 7, 10, 0.12));
}

.story-panel {
	position: relative;
	z-index: 2;
	padding-bottom: 28px;
}

.story-columns {
	display: grid;
	grid-template-columns: repeat(2, minmax(0, 1fr));
	gap: 28px;
	max-width: 960px;
	margin-top: 28px;
}

.gateway-grid {
	display: grid;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	gap: 16px;
}

.gateway-card {
	min-height: 220px;
	padding: 24px;
	transition: transform 180ms ease, border-color 180ms ease, background 180ms ease;
}

.gateway-card:hover {
	transform: translateY(-4px);
	border-color: var(--line-strong);
	background:
		linear-gradient(145deg, rgba(211, 167, 87, 0.14), rgba(242, 234, 223, 0.03)),
		rgba(5, 7, 10, 0.8);
}

.gateway-card span {
	display: block;
	margin-bottom: 42px;
	color: var(--gold-soft);
	font-family: var(--serif);
	font-size: 1.8rem;
	font-weight: 700;
}

.symbol-grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 16px;
}

.symbol-card {
	position: relative;
	min-height: 210px;
	padding: 28px 24px 24px;
	overflow: hidden;
}

.symbol-card span {
	display: block;
	width: 54px;
	height: 54px;
	margin-bottom: 34px;
	border: 1px solid rgba(211, 167, 87, 0.42);
	background:
		linear-gradient(135deg, rgba(211, 167, 87, 0.24), rgba(111, 135, 147, 0.05)),
		radial-gradient(circle, rgba(224, 106, 46, 0.3), transparent 58%);
}

.product-grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 18px;
}

.product-card img {
	width: 100%;
	aspect-ratio: 4 / 5;
	object-fit: cover;
}

.product-card > div {
	padding: 22px;
}

.center-actions {
	display: flex;
	justify-content: center;
	margin-top: 34px;
}

.image-stack {
	position: relative;
	min-height: 620px;
}

.image-stack img {
	position: absolute;
	width: 62%;
	aspect-ratio: 4 / 5;
	object-fit: cover;
	border: 1px solid var(--line);
	box-shadow: var(--shadow);
}

.image-stack img:first-child {
	left: 0;
	top: 0;
}

.image-stack img:last-child {
	right: 0;
	bottom: 0;
}

.final-cta {
	position: relative;
	display: grid;
	align-items: center;
	min-height: 580px;
	padding: 96px 0;
	background: var(--black);
}

.final-cta > img {
	filter: saturate(0.88) contrast(1.08);
}

.final-cta-inner {
	position: relative;
	z-index: 2;
	max-width: var(--content);
}

.final-cta h2 {
	max-width: 930px;
}

.site-footer {
	border-top: 1px solid var(--line);
	background: #040608;
}

.footer-shell {
	display: grid;
	grid-template-columns: minmax(0, 1fr) auto;
	gap: 24px;
	align-items: start;
	width: var(--content);
	margin: 0 auto;
	padding: 34px 0;
}

.footer-brand {
	display: inline-block;
	margin-bottom: 8px;
	color: var(--bone);
	font-family: var(--serif);
	font-size: 1.35rem;
	font-weight: 700;
}

.footer-nav {
	display: flex;
	flex-wrap: wrap;
	gap: 18px;
	justify-content: flex-end;
}

.footer-nav a {
	color: var(--mist);
	font-size: 0.82rem;
	font-weight: 800;
	text-transform: uppercase;
}

.footer-credit {
	grid-column: 1 / -1;
	margin: 0;
	color: var(--ash);
	font-size: 0.86rem;
}

.archive-main,
.content-main {
	padding: 130px 0 86px;
}

.post-list {
	display: grid;
	gap: 18px;
}

.post-card {
	display: grid;
	grid-template-columns: 220px minmax(0, 1fr);
	gap: 22px;
	padding: 18px;
}

.post-thumb img {
	width: 100%;
	aspect-ratio: 16 / 10;
	object-fit: cover;
}

.content-shell {
	max-width: 880px;
}

.content-header {
	margin-bottom: 32px;
}

.entry-content {
	color: var(--mist);
}

.entry-content a {
	color: var(--gold-soft);
	text-decoration: underline;
}

.single-hero {
	margin: 0 0 32px;
}

.single-hero img {
	width: 100%;
	max-height: 560px;
	object-fit: cover;
}

.commerce-main {
	padding-top: 86px;
	background:
		radial-gradient(circle at 80% 14%, rgba(224, 106, 46, 0.12), transparent 28vw),
		linear-gradient(180deg, var(--black), #0c151c);
}

.commerce-shell .woocommerce {
	color: var(--mist);
}

.woocommerce .woocommerce-breadcrumb,
.woocommerce-result-count,
.woocommerce-products-header__title.page-title {
	color: var(--mist);
}

.woocommerce ul.products {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 18px;
}

.woocommerce ul.products::before,
.woocommerce ul.products::after {
	display: none;
}

.woocommerce ul.products li.product,
.woocommerce-page ul.products li.product {
	float: none;
	width: auto;
	margin: 0;
	padding: 0;
	overflow: hidden;
	border: 1px solid var(--line);
	background: rgba(5, 7, 10, 0.78);
	box-shadow: var(--shadow);
}

.woocommerce ul.products li.product a img {
	width: 100%;
	aspect-ratio: 4 / 5;
	margin: 0;
	object-fit: cover;
}

.woocommerce ul.products li.product .woocommerce-loop-product__title,
.woocommerce div.product .product_title {
	padding: 18px 18px 4px;
	color: var(--bone);
	font-family: var(--serif);
	font-size: 1.35rem;
	line-height: 1.12;
}

.woocommerce ul.products li.product .price,
.woocommerce div.product p.price,
.woocommerce div.product span.price {
	display: block;
	padding: 0 18px;
	color: var(--gold-soft);
	font-weight: 800;
}

.woocommerce a.button,
.woocommerce button.button,
.woocommerce input.button,
.woocommerce #respond input#submit,
.woocommerce div.product form.cart .button {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: 44px;
	margin: 14px 18px 20px;
	padding: 0 18px;
	border: 1px solid rgba(211, 167, 87, 0.76);
	border-radius: 4px;
	background: linear-gradient(135deg, #d6a64f, #7f251d);
	color: #120d08;
	font-size: 0.82rem;
	font-weight: 900;
	text-transform: uppercase;
}

.woocommerce div.product {
	color: var(--mist);
}

.woocommerce div.product div.images img {
	border: 1px solid var(--line);
	box-shadow: var(--shadow);
}

.woocommerce div.product .woocommerce-tabs ul.tabs li {
	border-color: var(--line);
	background: rgba(242, 234, 223, 0.08);
}

.woocommerce div.product .woocommerce-tabs ul.tabs li a {
	color: var(--bone);
}

.woocommerce-message,
.woocommerce-info,
.woocommerce-error {
	border-top-color: var(--gold);
	background: rgba(242, 234, 223, 0.08);
	color: var(--bone);
}

.error-main {
	background: var(--black);
}

.error-cta {
	min-height: 100vh;
}

@media (max-width: 1080px) {
	.header-action {
		display: none;
	}

	.world-grid,
	.video-grid,
	.woocommerce ul.products {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.gateway-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
}

@media (max-width: 820px) {
	:root {
		--content: min(100vw - 28px, 680px);
	}

	.nav-shell {
		min-height: 66px;
	}

	.nav-toggle {
		display: block;
	}

	.primary-nav {
		position: fixed;
		top: 66px;
		left: 14px;
		right: 14px;
		display: none;
		padding: 18px;
		border: 1px solid var(--line);
		background: rgba(5, 7, 10, 0.96);
		box-shadow: var(--shadow);
	}

	.primary-nav.is-open {
		display: block;
	}

	.primary-nav .menu {
		display: grid;
		gap: 14px;
	}

	.hero {
		min-height: 92vh;
		padding-top: 118px;
	}

	.hero-shade {
		background:
			linear-gradient(90deg, rgba(5, 7, 10, 0.92) 0%, rgba(5, 7, 10, 0.62) 58%, rgba(5, 7, 10, 0.32) 100%),
			linear-gradient(0deg, rgba(5, 7, 10, 0.98) 0%, rgba(5, 7, 10, 0.1) 48%, rgba(5, 7, 10, 0.58) 100%);
	}

	.split,
	.split.reverse,
	.story-columns {
		grid-template-columns: 1fr;
	}

	.tall-media {
		max-height: 720px;
	}

	.symbol-grid,
	.product-grid,
	.woocommerce ul.products {
		grid-template-columns: 1fr;
	}

	.image-stack {
		min-height: 520px;
	}

	.footer-shell {
		grid-template-columns: 1fr;
	}

	.footer-nav {
		justify-content: flex-start;
	}
}

@media (max-width: 560px) {
	h1 {
		font-size: clamp(2.8rem, 15vw, 4.25rem);
	}

	h2 {
		font-size: 2.3rem;
	}

	.brand {
		min-width: 0;
	}

	.brand-line {
		display: none;
	}

	.button-row,
	.button {
		width: 100%;
	}

	.button {
		padding: 0 14px;
		text-align: center;
	}

	.hero-tags {
		display: grid;
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.hero-tags span {
		text-align: center;
	}

	.social-rail {
		display: grid;
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}

	.social-orb {
		width: 100%;
		padding-right: 10px;
	}

	.world-grid,
	.video-grid,
	.gateway-grid {
		grid-template-columns: 1fr;
	}

	.world-card,
	.gateway-card,
	.symbol-card {
		min-height: auto;
	}

	.card-count,
	.gateway-card span {
		margin-bottom: 26px;
	}

	.post-card {
		grid-template-columns: 1fr;
	}

	.image-stack {
		display: grid;
		gap: 14px;
		min-height: 0;
	}

	.image-stack img {
		position: static;
		width: 100%;
	}
}
