/*
Theme Name: Halloween Scout
Theme URI: https://halloweenscout.com/
Author: McKrackin
Description: Lightweight launch theme for Halloween Scout.
Version: 0.1.0
Text Domain: halloweenscout
*/

:root {
	--slime-green: #a7d129;
	--pumpkin-orange: #f26a21;
	--bone-beige: #f2e9d7;
	--night-black: #15170f;
	--dark-olive: #1f2a17;
	--paper: #fff7df;
	--ink: #1d1a13;
	--muted: #605640;
	--line: #6d6248;
}

* { box-sizing: border-box; }

body {
	margin: 0;
	background: var(--paper);
	color: var(--ink);
	font-family: "DM Sans", Arial, sans-serif;
	font-size: 17px;
	line-height: 1.55;
}

a { color: inherit; }

.hscout-topbar {
	background: var(--dark-olive);
	color: var(--bone-beige);
	font-family: "Bebas Neue", Impact, sans-serif;
	letter-spacing: 0.12em;
	text-align: center;
	text-transform: uppercase;
	padding: 0.45rem 1rem;
}

.site-header {
	background: rgba(242, 233, 215, 0.97);
	border-bottom: 3px solid var(--night-black);
	box-shadow: 0 3px 0 rgba(21, 23, 15, 0.2);
	position: sticky;
	top: 0;
	z-index: 20;
}

.site-header-inner {
	align-items: center;
	display: flex;
	gap: 2rem;
	justify-content: space-between;
	margin: 0 auto;
	max-width: 1180px;
	padding: 0.75rem 1.25rem;
}

.site-branding a {
	align-items: center;
	display: flex;
	gap: 0.75rem;
	text-decoration: none;
}

.brand-logo {
	display: block;
	height: auto;
	max-height: 82px;
	max-width: min(440px, 48vw);
	width: auto;
}

.brand-subtitle {
	display: block;
	font-family: "Bebas Neue", Impact, sans-serif;
	font-size: 0.7rem;
	letter-spacing: 0.15em;
	margin-top: -0.25rem;
	text-transform: uppercase;
}

.main-navigation ul {
	display: flex;
	flex-wrap: wrap;
	gap: 1rem 1.6rem;
	list-style: none;
	margin: 0;
	padding: 0;
}

.main-navigation a {
	font-family: "Bebas Neue", Impact, sans-serif;
	font-size: 1.15rem;
	letter-spacing: 0.06em;
	text-decoration: none;
	text-transform: uppercase;
}

.site-main {
	margin: 0 auto;
	max-width: 1180px;
	padding: 0 1.25rem 2rem;
}

.home .site-main {
	max-width: none;
	padding: 0;
}

.home .entry-title { display: none; }

.hscout-hero {
	background:
		linear-gradient(90deg, rgba(8, 10, 7, 0.96) 0%, rgba(11, 15, 9, 0.9) 34%, rgba(15, 20, 12, 0.42) 62%, rgba(8, 10, 7, 0.24) 100%),
		url("assets/images/hero-camp-scout.webp") center / cover no-repeat,
		var(--dark-olive);
	border-bottom: 5px solid var(--night-black);
	color: var(--bone-beige);
	display: block;
	min-height: 410px;
	overflow: hidden;
	padding: clamp(2rem, 4vw, 3.4rem) max(1.25rem, calc((100vw - 1180px) / 2));
	position: relative;
}

.hscout-hero::before {
	background:
		linear-gradient(135deg, transparent 0 48%, rgba(242, 233, 215, 0.08) 49% 51%, transparent 52%),
		linear-gradient(45deg, transparent 0 48%, rgba(242, 233, 215, 0.07) 49% 51%, transparent 52%);
	background-size: 120px 120px;
	content: "";
	inset: 0;
	opacity: 0.35;
	position: absolute;
}

.hscout-hero-copy,
.hscout-hero-art {
	position: relative;
	z-index: 1;
}

.hscout-hero-copy {
	max-width: 760px;
}

.hscout-kicker {
	color: var(--slime-green);
	font-family: "Bebas Neue", Impact, sans-serif;
	letter-spacing: 0.18em;
	text-transform: uppercase;
}

.hscout-hero h1,
.entry-title,
.hscout-section h2,
.hscout-quick-filter h2,
.hscout-newsletter h2 {
	font-family: "Bebas Neue", Impact, sans-serif;
	letter-spacing: 0.04em;
	line-height: 0.95;
	text-transform: uppercase;
}

.hscout-hero h1 {
	font-size: clamp(2.6rem, 4.6vw, 4.25rem);
	margin: 0 0 1rem;
	max-width: 690px;
	text-wrap: balance;
}

.accent-orange {
	color: var(--pumpkin-orange);
}

.accent-green {
	color: var(--slime-green);
}

.hscout-hero p {
	font-size: 1.15rem;
	max-width: 560px;
}

.hscout-button,
.hscout-newsletter button {
	background: var(--slime-green);
	border: 2px solid var(--bone-beige);
	border-radius: 7px;
	box-shadow: 0 3px 0 var(--night-black);
	color: var(--night-black);
	display: inline-block;
	font-family: "Bebas Neue", Impact, sans-serif;
	letter-spacing: 0.08em;
	padding: 0.62rem 1.2rem;
	text-decoration: none;
	text-transform: uppercase;
}

.hscout-button-orange,
.hscout-newsletter button {
	background: var(--pumpkin-orange);
	color: #fff;
}

.hscout-button-small {
	font-size: 0.95rem;
	padding: 0.35rem 0.8rem;
}

.hscout-hero-actions {
	display: flex;
	flex-wrap: wrap;
	gap: 1rem;
	margin-top: 1.3rem;
}

.hscout-moon {
	display: none;
}

.hscout-lantern {
	background: rgba(21, 23, 15, 0.72);
	border: 2px solid rgba(242, 233, 215, 0.7);
	border-radius: 8px;
	box-shadow: 0 0 24px rgba(242, 106, 33, 0.24);
	color: var(--bone-beige);
	display: block;
	font-family: "Bebas Neue", Impact, sans-serif;
	font-size: clamp(1.45rem, 3vw, 2.25rem);
	line-height: 1;
	padding: 0.9rem 1.1rem;
	position: absolute;
	right: max(1.25rem, calc((100vw - 1180px) / 2));
	top: clamp(1rem, 4vw, 3rem);
	transform: rotate(-3deg);
}

.hscout-quick-filter,
.hscout-section,
.hscout-two-col,
.hscout-newsletter,
.entry-content {
	margin: 0 auto;
	max-width: 1180px;
}

.hscout-quick-filter {
	background: var(--dark-olive);
	border: 3px solid var(--bone-beige);
	border-radius: 12px;
	box-shadow: 0 3px 0 var(--night-black);
	color: var(--bone-beige);
	margin-top: -2.2rem;
	padding: 1rem;
	position: relative;
	text-align: center;
	z-index: 3;
}

.hscout-quick-filter h2,
.hscout-section h2 {
	font-size: 2rem;
	margin: 0 0 0.8rem;
	text-align: center;
}

.hscout-quick-filter div {
	display: flex;
	flex-wrap: wrap;
	gap: 0.8rem;
	justify-content: center;
}

.hscout-quick-filter a {
	background: var(--bone-beige);
	border: 2px solid var(--line);
	border-radius: 999px;
	font-family: "Bebas Neue", Impact, sans-serif;
	min-width: 132px;
	padding: 0.45rem 1rem;
	text-decoration: none;
	text-transform: uppercase;
}

.hscout-section { padding: 2rem 1.25rem 0; }

.hscout-card-grid,
.hscout-drop-list,
.hscout-category-grid,
.hscout-two-col,
.hscout-seasonal-cards {
	display: grid;
	gap: 1rem;
}

.hscout-card-grid { grid-template-columns: repeat(6, minmax(0, 1fr)); }

.hscout-card,
.hscout-drop-card,
.hscout-category-grid a,
.hscout-local-box,
.hscout-seasonal-box,
.entry-content {
	background: rgba(255, 247, 223, 0.9);
	border: 2px solid var(--line);
	border-radius: 8px;
	box-shadow: 0 2px 0 rgba(21, 23, 15, 0.35);
}

.hscout-card,
.hscout-drop-card,
.hscout-category-grid a,
.hscout-local-box,
.hscout-seasonal-box {
	background-image:
		linear-gradient(rgba(255, 247, 223, 0.9), rgba(255, 247, 223, 0.9)),
		radial-gradient(circle at 20% 15%, rgba(31, 42, 23, 0.08), transparent 10rem);
}

.hscout-card a,
.hscout-category-grid a,
.hscout-seasonal-cards a {
	display: block;
	text-decoration: none;
}

.hscout-card {
	margin-top: 2rem;
	padding: 2.65rem 1rem 1rem;
	position: relative;
	text-align: center;
}

.hscout-card-icon {
	align-items: center;
	background:
		radial-gradient(circle at 35% 28%, rgba(255, 247, 223, 0.28), transparent 34%),
		var(--dark-olive);
	border: 4px solid #d4a029;
	border-radius: 50%;
	box-shadow:
		0 0 0 4px var(--bone-beige),
		0 4px 0 rgba(21, 23, 15, 0.42);
	color: var(--bone-beige);
	display: inline-flex;
	font-family: "Bebas Neue", Impact, sans-serif;
	font-size: 2.15rem;
	height: 78px;
	justify-content: center;
	left: 50%;
	overflow: hidden;
	position: absolute;
	top: -39px;
	transform: translateX(-50%);
	width: 78px;
}

.hscout-card-icon img {
	background: #fff;
	display: block;
	height: 48px;
	object-fit: contain;
	padding: 6px;
	width: 48px;
}

.hscout-card h3,
.hscout-drop-card h3 {
	font-family: "Bebas Neue", Impact, sans-serif;
	font-size: 1.55rem;
	letter-spacing: 0.04em;
	line-height: 1;
	margin: 0.75rem 0 0.35rem;
	text-transform: uppercase;
}

.hscout-card p,
.hscout-drop-card p {
	color: var(--muted);
	font-size: 0.92rem;
	margin: 0 0 0.8rem;
}

.hscout-drop-list { grid-template-columns: repeat(4, minmax(0, 1fr)); }

.hscout-drop-card { padding: 1rem; }

.hscout-drop-card > span {
	background: var(--pumpkin-orange);
	border-radius: 999px;
	color: #fff;
	display: inline-block;
	font-family: "Bebas Neue", Impact, sans-serif;
	font-size: 0.9rem;
	letter-spacing: 0.06em;
	padding: 0.1rem 0.55rem;
	text-transform: uppercase;
}

.hscout-category-grid { grid-template-columns: repeat(6, minmax(0, 1fr)); }

.hscout-category-grid a {
	background: var(--dark-olive);
	color: var(--bone-beige);
	font-family: "Bebas Neue", Impact, sans-serif;
	font-size: 1.45rem;
	letter-spacing: 0.06em;
	padding: 1.6rem 0.75rem;
	text-align: center;
	text-transform: uppercase;
}

.hscout-two-col {
	grid-template-columns: 1fr 1.4fr;
	padding: 1rem 1.25rem 0;
}

.hscout-local-box,
.hscout-seasonal-box { padding: 1.25rem; }

.hscout-seasonal-cards { grid-template-columns: 1fr 1fr; }

.hscout-seasonal-cards a {
	background: var(--dark-olive);
	border-radius: 8px;
	color: var(--bone-beige);
	min-height: 150px;
	padding: 1rem;
}

.hscout-seasonal-cards strong {
	color: var(--pumpkin-orange);
	display: block;
	font-family: "Bebas Neue", Impact, sans-serif;
	font-size: 2.1rem;
	line-height: 1;
	text-transform: uppercase;
}

.hscout-newsletter {
	align-items: center;
	background:
		linear-gradient(90deg, rgba(21, 23, 15, 0.96), rgba(31, 42, 23, 0.92)),
		url("assets/images/hero-camp-scout.webp") center 62% / cover no-repeat;
	color: var(--bone-beige);
	display: grid;
	gap: 1rem;
	grid-template-columns: 1fr auto;
	margin-top: 1.5rem;
	padding: 1.25rem;
}

.hscout-newsletter h2 {
	color: var(--slime-green);
	font-size: 2.2rem;
	margin: 0;
	text-align: left;
}

.hscout-newsletter p { margin: 0; }

.hscout-newsletter form {
	display: flex;
	gap: 0.75rem;
}

.hscout-newsletter input {
	border: 0;
	border-radius: 6px;
	font: inherit;
	min-width: 280px;
	padding: 0.7rem 1rem;
}

.entry-title {
	font-size: clamp(2.6rem, 6vw, 5rem);
	margin: 2rem auto 1rem;
	max-width: 1180px;
}

.entry-content { padding: 1.5rem; }

.hscout-disclosure,
.hscout-hy-cta {
	background: #fff3c7;
	border-left: 5px solid var(--pumpkin-orange);
	margin: 1.25rem 0;
	padding: 1rem;
}

.site-footer {
	background: var(--night-black);
	color: var(--bone-beige);
	margin-top: 2rem;
}

.site-footer-inner {
	display: grid;
	gap: 1.5rem;
	grid-template-columns: 2fr 1fr 1fr 1fr;
	margin: 0 auto;
	max-width: 1180px;
	padding: 2rem 1.25rem;
}

.site-footer h2,
.site-footer h3 {
	color: var(--slime-green);
	font-family: "Bebas Neue", Impact, sans-serif;
	letter-spacing: 0.06em;
	margin: 0 0 0.5rem;
	text-transform: uppercase;
}

.site-footer ul {
	list-style: none;
	margin: 0;
	padding: 0;
}

.site-footer a { color: inherit; }

.site-footer-bottom {
	border-top: 1px solid rgba(242, 233, 215, 0.25);
	font-size: 0.85rem;
	margin: 0 auto;
	max-width: 1180px;
	padding: 0.8rem 1.25rem;
}

@media (max-width: 980px) {
	.site-header-inner {
		align-items: flex-start;
		display: block;
	}

	.main-navigation { margin-top: 0.9rem; }

	.brand-logo {
		max-width: min(360px, 86vw);
	}

	.hscout-hero,
	.hscout-newsletter,
	.hscout-two-col,
	.site-footer-inner {
		grid-template-columns: 1fr;
	}

	.hscout-card-grid,
	.hscout-drop-list,
	.hscout-category-grid {
		grid-template-columns: repeat(2, minmax(0, 1fr));
	}
}

@media (max-width: 620px) {
	body { font-size: 16px; }

	.hscout-card-grid,
	.hscout-drop-list,
	.hscout-category-grid,
	.hscout-seasonal-cards {
		grid-template-columns: 1fr;
	}

	.hscout-newsletter form { display: block; }

	.hscout-newsletter input {
		margin-bottom: 0.75rem;
		min-width: 0;
		width: 100%;
	}
}
