/* Just Catered editorial system. */

:root {
	--jc-ink: #1f1d1a;
	--jc-muted: #8a847a;
	--jc-soft-ink: #4a4640;
	--jc-line: #d8cfbf;
	--jc-line-soft: #e8e0d0;
	--jc-paper: #f7f3ec;
	--jc-white: #ffffff;
	--jc-soft: #efe8db;
	--jc-accent: #c8553d;
	--jc-red: #c8553d;
	--jc-accent-soft: #f0d4cb;
	--jc-serif: "Fraunces", Georgia, "Times New Roman", serif;
	--jc-sans: "Inter", Nunito, Arial, sans-serif;
}

body {
	font-family: var(--jc-sans);
	color: var(--jc-ink);
	background: var(--jc-paper);
}

.jc-shell,
.jc-directorist-shell {
	background: var(--jc-paper);
}

.jc-shell > .elementor-container,
.jc-directorist-shell > .elementor-container,
.jc-section,
.jc-page-hero,
.jc-search-panel,
.jc-site-header,
.jc-site-footer,
.jc-listing-grid,
.jc-journal-grid {
	max-width: 1180px;
	margin-left: auto;
	margin-right: auto;
}

.jc-announcement {
	background: var(--jc-ink);
	color: var(--jc-paper);
	text-align: center;
	padding: 8px 16px;
	font-size: 12px;
	letter-spacing: 0;
}

.jc-announcement a {
	color: var(--jc-accent-soft);
	text-decoration: none;
	border-bottom: 1px solid var(--jc-accent-soft);
	margin-left: 8px;
}

.jc-site-header {
	position: sticky;
	top: 0;
	z-index: 100;
	padding: 24px 0;
	border-bottom: 1px solid var(--jc-line-soft);
	background: var(--jc-paper);
}

.jc-header-inner {
	max-width: 1280px;
	margin: 0 auto;
	padding: 0 24px;
	display: grid;
	grid-template-columns: 1fr auto 1fr;
	align-items: center;
	gap: 32px;
}

.jc-brand {
	color: var(--jc-ink);
	text-decoration: none;
	font-family: var(--jc-serif);
	font-size: 24px;
	font-weight: 500;
	letter-spacing: 0;
	text-align: center;
}

.jc-nav-primary,
.jc-nav-secondary,
.jc-site-footer nav {
	display: flex;
	align-items: center;
	flex-wrap: wrap;
	gap: 32px;
}

.jc-nav-secondary {
	justify-content: flex-end;
}

.jc-nav-primary a,
.jc-nav-secondary a,
.jc-site-footer a {
	color: var(--jc-ink);
	text-decoration: none;
	font-size: 13px;
	font-weight: 400;
	letter-spacing: 0;
}

.jc-submit-link {
	background: var(--jc-ink);
	color: var(--jc-paper) !important;
	border-radius: 8px;
	padding: 9px 18px;
	font-weight: 600 !important;
}

.jc-hero,
.jc-page-hero {
	padding: 92px 20px 58px;
}

.jc-hero-home {
	min-height: 0;
	display: grid;
	place-items: center;
	text-align: center;
	border-bottom: 1px solid var(--jc-line-soft);
	background: var(--jc-paper);
	color: var(--jc-ink);
	padding-top: 96px;
	padding-bottom: 72px;
}

.jc-hero-copy {
	max-width: 860px;
	margin: 0 auto;
}

.jc-eyebrow {
	display: block;
	margin: 0 0 10px;
	text-transform: uppercase;
	font-size: 12px;
	font-weight: 800;
	letter-spacing: 0;
	color: var(--jc-accent);
}

.jc-hero-home .jc-eyebrow {
	color: var(--jc-muted);
}

.jc-hero h1,
.jc-page-hero h1,
.jc-section h2 {
	margin: 0 0 18px;
	font-family: var(--jc-serif);
	font-weight: 400;
	line-height: 1.03;
	letter-spacing: 0;
	color: inherit;
}

.jc-hero h1 {
	max-width: 820px;
	margin-left: auto;
	margin-right: auto;
	font-size: 76px;
	line-height: 1.02;
}

.jc-rotating-word {
	position: relative;
	display: inline-block;
	color: var(--jc-red);
	font-style: italic;
	font-weight: 400;
}

.jc-rotating-word::after {
	content: "";
	position: absolute;
	left: 0;
	right: 0;
	bottom: 6px;
	height: 7px;
	background: var(--jc-accent-soft);
	z-index: -1;
}

.jc-hero-kicker {
	margin: 0 auto 10px;
	font-family: var(--jc-serif);
	font-style: italic;
	font-weight: 300;
	font-size: 22px;
	color: var(--jc-soft-ink);
}

.jc-hero-actions {
	display: flex;
	justify-content: center;
	flex-wrap: wrap;
	gap: 12px;
	margin: 30px 0 18px;
}

.jc-pill {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: 48px;
	padding: 12px 24px;
	border: 1px solid var(--jc-ink);
	border-radius: 8px;
	background: transparent;
	color: var(--jc-ink);
	text-decoration: none;
	font-weight: 600;
}

.jc-pill-dark {
	background: var(--jc-ink);
	color: #fff;
}

.jc-hero-trust {
	margin: 0 auto;
	color: var(--jc-muted);
	font-size: 14px;
}

.jc-hero-trust span {
	padding: 0 8px;
	color: var(--jc-red);
}

.jc-page-hero h1 {
	font-size: 54px;
	max-width: 920px;
}

.jc-page-hero h2,
.jc-longform h2 {
	margin: 42px 0 12px;
	font-family: Georgia, "Times New Roman", serif;
	font-size: 34px;
	font-weight: 500;
	line-height: 1.15;
}

.jc-page-hero h3,
.jc-longform h3 {
	margin: 26px 0 10px;
	font-size: 20px;
	line-height: 1.3;
}

.jc-hero p,
.jc-page-hero p,
.jc-section p {
	max-width: 760px;
	color: inherit;
	font-size: 18px;
	line-height: 1.7;
}

.jc-page-hero p,
.jc-section p {
	color: var(--jc-muted);
}

.jc-search-panel {
	display: grid;
	grid-template-columns: 1.2fr 1fr 1fr auto;
	gap: 12px;
	padding: 22px 20px 36px;
}

.jc-search-panel label {
	display: grid;
	gap: 6px;
	color: var(--jc-muted);
	font-size: 12px;
	font-weight: 800;
	text-transform: uppercase;
	letter-spacing: 0;
}

.jc-search-panel input,
.jc-search-panel select,
.jc-form input,
.jc-form select,
.jc-form textarea {
	width: 100%;
	border: 1px solid var(--jc-line);
	border-radius: 6px;
	background: #fff;
	color: var(--jc-ink);
	min-height: 48px;
	padding: 12px 13px;
	font: inherit;
}

.jc-search-panel button,
.jc-form button {
	align-self: end;
	min-height: 48px;
	border: 1px solid var(--jc-ink);
	border-radius: 6px;
	background: var(--jc-ink);
	color: #fff;
	padding: 12px 22px;
	font-weight: 800;
	cursor: pointer;
}

.jc-section {
	padding: 68px 20px 30px;
	text-align: center;
}

.jc-cities-section {
	padding-top: 68px;
	border-bottom: 1px solid var(--jc-line-soft);
}

.jc-occasions-section {
	border-bottom: 0;
}

.jc-section h2 {
	font-size: 42px;
	max-width: 760px;
	margin-left: auto;
	margin-right: auto;
	letter-spacing: 0;
}

.jc-section p {
	margin-left: auto;
	margin-right: auto;
	font-family: var(--jc-serif);
	font-style: italic;
	font-weight: 300;
}

.jc-category-grid,
.jc-city-card-grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 22px;
}

.jc-category-grid a,
.jc-city-card-grid a {
	position: relative;
	display: block;
	overflow: hidden;
	min-height: 310px;
	border-radius: 8px;
	color: #fff;
	text-decoration: none;
	background: var(--jc-ink);
}

.jc-category-grid img,
.jc-city-card-grid img {
	width: 100%;
	height: 100%;
	position: absolute;
	inset: 0;
	object-fit: cover;
	opacity: 0.74;
	transition: transform 220ms ease;
}

.jc-category-grid span,
.jc-city-card-grid span {
	position: absolute;
	left: 22px;
	bottom: 20px;
	z-index: 1;
	font-family: Georgia, "Times New Roman", serif;
	font-size: 32px;
	line-height: 1.05;
}

.jc-category-grid a:hover img,
.jc-city-card-grid a:hover img {
	transform: scale(1.03);
}

.jc-city-grid,
.jc-category-strip {
	display: grid;
	grid-template-columns: repeat(5, minmax(0, 1fr));
	gap: 10px;
}

.jc-occasion-grid {
	display: grid;
	grid-template-columns: repeat(4, minmax(0, 1fr));
	gap: 16px;
	margin-top: 28px;
}

.jc-occasion-card {
	position: relative;
	display: block;
	min-height: 220px;
	overflow: hidden;
	border-radius: 8px;
	background: var(--jc-ink);
	color: #fff;
	text-decoration: none;
}

.jc-occasion-card img {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
	opacity: 0.76;
	transition: transform 220ms ease;
}

.jc-occasion-card span {
	position: absolute;
	left: 16px;
	right: 16px;
	bottom: 16px;
	font-family: Georgia, "Times New Roman", serif;
	font-size: 25px;
	line-height: 1.08;
}

.jc-occasion-card:hover img {
	transform: scale(1.03);
}

.jc-city-grid a,
.jc-category-strip a {
	display: grid;
	place-items: center;
	min-height: 88px;
	border: 1px solid var(--jc-line);
	border-radius: 8px;
	background: var(--jc-white);
	color: var(--jc-ink);
	text-decoration: none;
	text-align: center;
	font-weight: 800;
	padding: 16px;
}

.jc-home-search-section .jc-search-panel {
	padding-top: 0;
	padding-bottom: 68px;
}

.jc-home-search-section {
	border-bottom: 1px solid var(--jc-line-soft);
}

.jc-listing-grid,
.jc-journal-grid {
	display: grid;
	grid-template-columns: repeat(3, minmax(0, 1fr));
	gap: 26px;
	padding: 0 20px 58px;
}

.jc-listing-card,
.jc-journal-card a {
	display: block;
	color: var(--jc-ink);
	text-decoration: none;
	background: var(--jc-white);
	border: 1px solid var(--jc-line-soft);
	border-radius: 8px;
	overflow: hidden;
	height: 100%;
}

.jc-listing-card img,
.jc-journal-card img {
	width: 100%;
	height: 245px;
	object-fit: cover;
	display: block;
}

.jc-listing-card span,
.jc-journal-card span {
	display: block;
	margin: 18px 18px 8px;
	color: var(--jc-accent);
	text-transform: uppercase;
	font-size: 12px;
	font-weight: 800;
	letter-spacing: 0;
}

.jc-listing-card h3,
.jc-journal-card h2 {
	margin: 0 18px 10px;
	font-family: var(--jc-serif);
	font-size: 28px;
	font-weight: 500;
	line-height: 1.12;
}

.jc-listing-card p,
.jc-journal-card p {
	margin: 0 18px 22px;
	color: var(--jc-muted);
	font-size: 15px;
	line-height: 1.6;
}

.jc-form {
	max-width: 780px;
	display: grid;
	gap: 16px;
}

.jc-form label {
	display: grid;
	gap: 7px;
	font-weight: 800;
}

.jc-site-footer.jc-footer-editorial {
	max-width: none;
	margin: 64px 0 0;
	padding: 52px 52px 34px;
	background: #0d2b28;
	color: #d8e0d8;
	border-top: 0;
}

.jc-footer-grid {
	max-width: 1320px;
	margin: 0 auto;
	display: grid;
	grid-template-columns: 1.25fr 1fr 1.15fr 2fr;
	gap: 64px;
}

.jc-footer-col h2 {
	margin: 0 0 30px;
	font-family: var(--jc-serif);
	font-size: 31px;
	font-weight: 400;
	line-height: 1;
	color: #dce6df;
}

.jc-footer-col p,
.jc-footer-col a {
	color: rgba(229, 236, 231, 0.78);
}

.jc-footer-col p {
	max-width: 420px;
	margin: 0 0 20px;
	font-size: 12px;
	font-weight: 600;
	line-height: 1.55;
	letter-spacing: 0.22em;
	text-transform: uppercase;
}

.jc-footer-links {
	display: grid;
	align-content: start;
	gap: 18px;
}

.jc-footer-links a {
	display: block;
	font-size: 12px;
	font-weight: 700;
	letter-spacing: 0.28em;
	text-transform: uppercase;
}

.jc-footer-social {
	display: flex;
	gap: 30px;
	margin-top: 82px;
	color: rgba(229, 236, 231, 0.65);
	font-size: 16px;
	font-weight: 700;
}

.jc-footer-newsletter form {
	display: grid;
	grid-template-columns: 1fr auto;
	gap: 0;
	margin-bottom: 12px;
}

.jc-footer-newsletter input {
	min-height: 42px;
	border: 0;
	border-radius: 0;
	background: #f7f3ec;
	color: #1f1d1a;
	padding: 12px 16px;
	font-size: 12px;
	font-weight: 700;
	letter-spacing: 0.12em;
	text-transform: uppercase;
}

.jc-footer-newsletter button {
	min-height: 42px;
	border: 0;
	border-radius: 0;
	background: #171717;
	color: #f7f3ec;
	padding: 0 18px;
	font-size: 12px;
	font-weight: 800;
	letter-spacing: 0.08em;
	cursor: pointer;
}

.jc-footer-bottom {
	max-width: 1320px;
	margin: 76px auto 0;
	display: flex;
	justify-content: space-between;
	gap: 24px;
	color: rgba(229, 236, 231, 0.62);
	font-size: 11px;
	font-weight: 800;
	letter-spacing: 0.24em;
	text-transform: uppercase;
}

.jc-directorist-shell .directorist-container,
.jc-directorist-shell .directorist-content-active {
	padding-top: 16px;
}

@media (max-width: 900px) {
	.jc-footer-grid {
		grid-template-columns: 1fr 1fr;
		gap: 40px;
	}

	.jc-footer-bottom {
		flex-direction: column;
		margin-top: 48px;
	}

	.jc-header-inner {
		grid-template-columns: 1fr;
		justify-items: center;
		gap: 16px;
	}

	.jc-nav-primary,
	.jc-nav-secondary {
		justify-content: center;
		gap: 16px;
	}

	.jc-hero h1,
	.jc-page-hero h1 {
		font-size: 42px;
	}

	.jc-search-panel,
	.jc-category-grid,
	.jc-city-card-grid,
	.jc-occasion-grid,
	.jc-city-grid,
	.jc-category-strip,
	.jc-listing-grid,
	.jc-journal-grid {
		grid-template-columns: 1fr;
	}

	.jc-hero-home {
		min-height: 0;
	}

	.jc-occasion-card {
		min-height: 260px;
	}
}

@media (max-width: 560px) {
	.jc-site-header nav {
		gap: 12px;
	}

	.jc-site-header a,
	.jc-site-footer a {
		font-size: 12px;
	}

	.jc-site-footer.jc-footer-editorial {
		padding: 42px 22px 28px;
	}

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

	.jc-footer-social {
		margin-top: 34px;
	}

	.jc-footer-newsletter form {
		grid-template-columns: 1fr;
		gap: 8px;
	}

	.jc-hero,
	.jc-page-hero {
		padding-top: 58px;
	}

	.jc-hero h1,
	.jc-page-hero h1 {
		font-size: 36px;
	}

	.jc-section h2 {
		font-size: 34px;
	}
}

/* Pixel-closer homepage mockup renderer. Scoped so it does not rewrite Directorist pages. */
.jc-mockup-home-section .elementor-container,
.jc-mockup-home-section .elementor-column,
.jc-mockup-home-section .elementor-widget-wrap,
.jc-mockup-home-section .elementor-widget-container {
	max-width: none !important;
	width: 100% !important;
	margin: 0 !important;
	padding: 0 !important;
}

.jc-mockup-home-section {
	background: #f7f3ec;
}

.jc-mockup-home {
	--cream: #f7f3ec;
	--cream-deep: #efe8db;
	--ink: #1f1d1a;
	--ink-soft: #4a4640;
	--ink-muted: #8a847a;
	--rule: #d8cfbf;
	--rule-soft: #e8e0d0;
	--accent: #c8553d;
	--accent-deep: #a8412c;
	--accent-soft: #f0d4cb;
	--paper: #ffffff;
	--serif: "Fraunces", Georgia, serif;
	--sans: "Inter", -apple-system, BlinkMacSystemFont, sans-serif;
	--space-2: 0.5rem;
	--space-3: 1rem;
	--space-4: 1.5rem;
	--space-5: 2rem;
	--space-6: 3rem;
	--space-7: 4.5rem;
	--space-8: 6rem;
	--max-width: 1280px;
	--content-width: 1120px;
	width: 100%;
	background: var(--cream);
	color: var(--ink);
	font-family: var(--sans);
	line-height: 1.5;
	-webkit-font-smoothing: antialiased;
}

.jc-mockup-home * {
	box-sizing: border-box;
}

.jc-mockup-home a {
	color: inherit;
	text-decoration: none;
}

.jc-mockup-home img {
	max-width: 100%;
	display: block;
}

.jc-mockup-home .content-container {
	max-width: var(--content-width);
	margin: 0 auto;
	padding: 0 var(--space-4);
}

.jc-mockup-home .eyebrow,
.jc-mockup-home .hero-eyebrow {
	font-family: var(--sans);
	font-size: 0.7rem;
	font-weight: 500;
	text-transform: uppercase;
	letter-spacing: 0.18em;
	color: var(--ink-muted);
}

.jc-mockup-home .view-all-link,
.jc-mockup-home .closing-link,
.jc-mockup-home .city-cta {
	font-size: 0.85rem;
	font-weight: 500;
	color: var(--ink);
	border-bottom: 1px solid var(--ink);
	padding-bottom: 2px;
	transition: all 0.2s;
}

.jc-mockup-home .view-all-link:hover,
.jc-mockup-home .closing-link:hover,
.jc-mockup-home .city-cta:hover {
	color: var(--accent);
	border-color: var(--accent);
}

.jc-mockup-home .announcement {
	background: var(--ink);
	color: var(--cream);
	text-align: center;
	padding: var(--space-2) var(--space-3);
	font-size: 0.75rem;
	letter-spacing: 0.06em;
	font-weight: 400;
}

.jc-mockup-home .announcement a {
	color: var(--accent-soft);
	border-bottom: 1px solid var(--accent-soft);
	margin-left: var(--space-2);
}

.jc-mockup-home .site-header {
	padding: var(--space-4) 0;
	border-bottom: 1px solid var(--rule-soft);
	position: sticky;
	top: 0;
	background: var(--cream);
	z-index: 100;
}

.jc-mockup-home .header-inner {
	max-width: var(--max-width);
	margin: 0 auto;
	padding: 0 var(--space-4);
	display: grid;
	grid-template-columns: 1fr auto 1fr;
	align-items: center;
	gap: var(--space-5);
}

.jc-mockup-home .nav-primary,
.jc-mockup-home .nav-secondary {
	display: flex;
	gap: var(--space-5);
	align-items: center;
}

.jc-mockup-home .nav-secondary {
	justify-content: flex-end;
}

.jc-mockup-home .nav-primary a,
.jc-mockup-home .nav-secondary a {
	font-size: 0.82rem;
	font-weight: 400;
	letter-spacing: 0.02em;
	color: var(--ink-soft);
	transition: color 0.2s;
}

.jc-mockup-home .nav-primary a:hover,
.jc-mockup-home .nav-secondary a:hover {
	color: var(--accent);
}

.jc-mockup-home .brand {
	font-family: var(--serif);
	font-size: 1.5rem;
	font-weight: 500;
	letter-spacing: 0;
	text-align: center;
	color: var(--ink);
}

.jc-mockup-home .submit-link {
	font-size: 0.78rem;
	font-weight: 500;
	color: var(--cream) !important;
	background: var(--ink);
	padding: 8px 18px;
	border-radius: 8px;
	transition: all 0.2s;
}

.jc-mockup-home .submit-link:hover {
	background: var(--accent);
}

.jc-mockup-home .hero {
	padding: var(--space-8) 0 var(--space-7);
	text-align: center;
	border-bottom: 1px solid var(--rule-soft);
}

.jc-mockup-home .hero-eyebrow {
	margin-bottom: var(--space-4);
	display: inline-block;
}

.jc-mockup-home .hero-headline {
	font-family: var(--serif);
	font-weight: 400;
	font-size: clamp(2.75rem, 7vw, 5.25rem);
	line-height: 1.02;
	letter-spacing: 0;
	color: var(--ink);
	margin: 0 auto var(--space-5);
	max-width: 18ch;
}

.jc-mockup-home .rotating-word {
	font-style: italic;
	color: var(--accent);
	font-weight: 400;
	display: inline-block;
	position: relative;
}

.jc-mockup-home .rotating-word::after {
	content: "";
	position: absolute;
	left: 0;
	right: 0;
	bottom: 0.08em;
	height: 0.05em;
	background: var(--accent-soft);
	z-index: -1;
}

.jc-mockup-home .hero-kicker {
	font-family: var(--serif);
	font-weight: 400;
	font-size: clamp(1.3rem, 2.3vw, 1.75rem);
	line-height: 1.25;
	color: var(--ink);
	margin: 0 auto var(--space-3);
}

.jc-mockup-home .hero-sub {
	font-family: var(--serif);
	font-weight: 300;
	font-size: clamp(1.05rem, 1.6vw, 1.25rem);
	line-height: 1.5;
	color: var(--ink-soft);
	max-width: 38rem;
	margin: 0 auto var(--space-6);
	font-style: italic;
}

.jc-mockup-home .hero-ctas {
	display: flex;
	gap: var(--space-3);
	justify-content: center;
	flex-wrap: wrap;
	margin-bottom: var(--space-5);
}

.jc-mockup-home .btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: var(--space-2);
	padding: var(--space-3) var(--space-5);
	min-height: 48px;
	font-size: 0.9rem;
	font-weight: 500;
	letter-spacing: 0.02em;
	border-radius: 8px;
	border: 1px solid var(--ink);
	transition: all 0.2s;
	cursor: pointer;
	font-family: var(--sans);
}

.jc-mockup-home .btn-primary {
	background: var(--ink);
	color: var(--cream);
}

.jc-mockup-home .btn-primary:hover {
	background: var(--accent);
	border-color: var(--accent);
}

.jc-mockup-home .btn-secondary {
	background: transparent;
	color: var(--ink);
}

.jc-mockup-home .btn-secondary:hover {
	background: var(--ink);
	color: var(--cream);
}

.jc-mockup-home .hero-trust {
	font-size: 0.78rem;
	color: var(--ink-muted);
	letter-spacing: 0.02em;
}

.jc-mockup-home .hero-trust .dot {
	margin: 0 var(--space-2);
	color: var(--rule);
}

.jc-mockup-home .occasions,
.jc-mockup-home .featured,
.jc-mockup-home .journal,
.jc-mockup-home .cities,
.jc-mockup-home .newsletter,
.jc-mockup-home .closing {
	padding: var(--space-7) 0;
	border-bottom: 1px solid var(--rule-soft);
}

.jc-mockup-home .jc-hosting-intro,
.jc-mockup-home .jc-featured-intro,
.jc-mockup-home .jc-journal-intro {
	padding-bottom: 0;
	border-bottom: 0;
}

.jc-home-search-widget-section .jc-mockup-home .jc-search-panel,
.jc-home-search-widget-section .jc-search-panel {
	margin-bottom: var(--space-7);
}

.jc-mockup-home-section .featured-grid {
	padding-bottom: 0;
}

.jc-mockup-home-section .journal-grid {
	padding-bottom: 0;
}

.jc-mockup-home .section-header {
	text-align: center;
	margin-bottom: var(--space-6);
}

.jc-mockup-home .section-header .eyebrow {
	display: block;
	margin-bottom: var(--space-2);
}

.jc-mockup-home .section-header h2 {
	font-family: var(--serif);
	font-weight: 400;
	font-size: clamp(2rem, 4.2vw, 2.75rem);
	line-height: 1.1;
	letter-spacing: 0;
	color: var(--ink);
	margin: 0 0 var(--space-3);
}

.jc-mockup-home .section-header p {
	font-family: var(--serif);
	font-style: italic;
	font-weight: 300;
	color: var(--ink-soft);
	font-size: 1.05rem;
	max-width: 32rem;
	margin: 0 auto;
}

.jc-mockup-home .city-link-grid {
	display: grid;
	grid-template-columns: repeat(5, minmax(0, 1fr));
	gap: var(--space-3);
}

.jc-mockup-home .city-link-grid a {
	display: grid;
	place-items: center;
	min-height: 92px;
	background: var(--paper);
	border: 1px solid var(--rule-soft);
	border-radius: 4px;
	font-family: var(--serif);
	font-size: 1.15rem;
	font-weight: 500;
	color: var(--ink);
	transition: all 0.2s;
	text-align: center;
	padding: var(--space-3);
}

.jc-mockup-home .city-link-grid a:hover {
	transform: translateY(-3px);
	border-color: var(--ink);
	box-shadow: 0 8px 24px rgba(31, 29, 26, 0.08);
}

.jc-mockup-home .jc-search-panel {
	display: grid;
	grid-template-columns: 1.2fr 1fr 1fr auto;
	gap: var(--space-3);
	max-width: var(--content-width);
	margin: 0 auto;
	padding: var(--space-4);
	background: var(--paper);
	border: 1px solid var(--rule-soft);
	border-radius: 4px;
	box-shadow: 0 8px 24px rgba(31, 29, 26, 0.04);
}

.jc-mockup-home .jc-search-panel label {
	display: grid;
	gap: 7px;
	color: var(--ink-muted);
	font-size: 0.68rem;
	font-weight: 500;
	text-transform: uppercase;
	letter-spacing: 0.12em;
	text-align: left;
}

.jc-mockup-home .jc-search-panel input,
.jc-mockup-home .jc-search-panel select {
	width: 100%;
	border: 1px solid var(--rule);
	border-radius: 4px;
	background: var(--cream);
	color: var(--ink);
	min-height: 48px;
	padding: 12px 13px;
	font: inherit;
	outline: none;
}

.jc-mockup-home .jc-search-panel button {
	align-self: end;
	min-height: 48px;
	border: 1px solid var(--ink);
	border-radius: 8px;
	background: var(--ink);
	color: var(--cream);
	padding: 12px 24px;
	font-weight: 500;
	cursor: pointer;
}

.jc-mockup-home .featured-grid {
	display: grid;
	grid-template-columns: 2fr 1fr 1fr;
	gap: var(--space-4);
	max-width: var(--content-width);
	margin: 0 auto;
}

.jc-mockup-home .caterer-card {
	background: var(--paper);
	border: 1px solid var(--rule-soft);
	overflow: hidden;
	transition: all 0.3s;
	display: flex;
	flex-direction: column;
	text-decoration: none;
	color: inherit;
	border-radius: 0;
}

.jc-mockup-home .caterer-card:hover {
	border-color: var(--ink);
	box-shadow: 0 6px 20px rgba(31, 29, 26, 0.06);
}

.jc-mockup-home .caterer-card.feature {
	grid-row: span 2;
}

.jc-mockup-home .caterer-image {
	aspect-ratio: 4 / 3;
	background-size: cover;
	background-position: center;
	background-color: var(--cream-deep);
	position: relative;
}

.jc-mockup-home .caterer-card.feature .caterer-image {
	aspect-ratio: 4 / 3.4;
}

.jc-mockup-home .caterer-tag {
	position: absolute;
	top: var(--space-3);
	left: var(--space-3);
	background: var(--cream);
	color: var(--ink);
	padding: 4px 10px;
	font-size: 0.65rem;
	text-transform: uppercase;
	letter-spacing: 0.12em;
	font-weight: 500;
	border-radius: 2px;
}

.jc-mockup-home .caterer-body {
	padding: var(--space-4);
	display: flex;
	flex-direction: column;
	flex: 1;
}

.jc-mockup-home .caterer-card.feature .caterer-body {
	padding: var(--space-5);
}

.jc-mockup-home .caterer-meta {
	font-size: 0.68rem;
	text-transform: uppercase;
	letter-spacing: 0.12em;
	color: var(--ink-muted);
	margin-bottom: var(--space-2);
	font-weight: 500;
}

.jc-mockup-home .caterer-name {
	font-family: var(--serif);
	font-weight: 500;
	font-size: 1.15rem;
	letter-spacing: 0;
	margin: 0 0 var(--space-2);
	line-height: 1.2;
}

.jc-mockup-home .caterer-card.feature .caterer-name {
	font-size: 1.5rem;
	font-weight: 400;
}

.jc-mockup-home .caterer-desc {
	font-size: 0.88rem;
	color: var(--ink-soft);
	line-height: 1.55;
	flex: 1;
	margin: 0;
}

.jc-mockup-home .caterer-card.feature .caterer-desc {
	font-family: var(--serif);
	font-style: italic;
	font-weight: 300;
	font-size: 1rem;
	line-height: 1.6;
}

.jc-mockup-home .caterer-footer {
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding-top: var(--space-3);
	border-top: 1px solid var(--rule-soft);
	font-size: 0.75rem;
	color: var(--ink-muted);
	text-transform: uppercase;
	letter-spacing: 0.08em;
	font-weight: 500;
	margin-top: var(--space-4);
	gap: var(--space-3);
}

.jc-mockup-home .caterer-link {
	color: var(--ink);
	border-bottom: 1px solid var(--ink);
	padding-bottom: 1px;
}

.jc-mockup-home .featured-footer,
.jc-mockup-home .journal-footer {
	text-align: center;
	margin-top: var(--space-6);
}

.jc-mockup-home .journal-grid {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: var(--space-4);
	max-width: var(--content-width);
	margin: 0 auto;
}

.jc-mockup-home .article-card {
	display: block;
	text-decoration: none;
	color: inherit;
	transition: all 0.3s;
}

.jc-mockup-home .article-card:hover .article-title {
	color: var(--accent);
}

.jc-mockup-home .article-image {
	aspect-ratio: 3 / 2;
	background-size: cover;
	background-position: center;
	background-color: var(--cream-deep);
	margin-bottom: var(--space-3);
	border-radius: 2px;
}

.jc-mockup-home .article-tag {
	font-size: 0.65rem;
	text-transform: uppercase;
	letter-spacing: 0.15em;
	color: var(--ink-muted);
	margin-bottom: var(--space-2);
	font-weight: 500;
}

.jc-mockup-home .article-title {
	font-family: var(--serif);
	font-weight: 500;
	font-size: 1.05rem;
	line-height: 1.3;
	letter-spacing: 0;
	margin: 0 0 var(--space-2);
	transition: color 0.2s;
}

.jc-mockup-home .article-desc {
	font-size: 0.85rem;
	color: var(--ink-soft);
	line-height: 1.5;
	margin: 0;
}

.jc-mockup-home .newsletter-inner,
.jc-mockup-home .closing-inner {
	text-align: center;
	max-width: 36rem;
	margin: 0 auto;
}

.jc-mockup-home .newsletter-inner .eyebrow {
	display: block;
	margin-bottom: var(--space-2);
}

.jc-mockup-home .newsletter-inner h2,
.jc-mockup-home .closing-inner h2 {
	font-family: var(--serif);
	font-weight: 400;
	font-size: clamp(1.75rem, 3.5vw, 2.25rem);
	letter-spacing: 0;
	margin: 0 0 var(--space-3);
}

.jc-mockup-home .newsletter-inner > p,
.jc-mockup-home .closing-inner p {
	font-size: 0.95rem;
	color: var(--ink-soft);
	line-height: 1.6;
	margin: 0 0 var(--space-4);
}

.jc-mockup-home .newsletter-form {
	display: flex;
	gap: var(--space-2);
	max-width: 28rem;
	margin: 0 auto var(--space-3);
}

.jc-mockup-home .newsletter-input {
	flex: 1;
	padding: var(--space-3) var(--space-4);
	border: 1px solid var(--rule);
	border-radius: 8px;
	background: var(--paper);
	font-family: var(--sans);
	font-size: 0.9rem;
	color: var(--ink);
	outline: none;
}

.jc-mockup-home .newsletter-trust {
	font-size: 0.78rem;
	color: var(--ink-muted);
	font-style: italic;
}

.jc-mockup-home .signature {
	font-family: var(--serif);
	font-style: italic;
	font-weight: 400;
	font-size: 1.15rem;
	color: var(--accent);
	margin: var(--space-5) 0 var(--space-4);
}

.jc-mockup-home .site-footer {
	background: var(--ink);
	color: var(--cream);
	padding: var(--space-7) var(--space-4) var(--space-5);
	margin: 0;
}

.jc-mockup-home .site-footer.jc-mockup-footer-slim {
	background: #0d2b28;
	color: #d8e0d8;
	padding: 52px 52px 34px;
}

.jc-mockup-home .footer-grid {
	max-width: 1320px;
	margin: 0 auto;
	display: grid;
	grid-template-columns: 1.25fr 1fr 1.15fr 2fr;
	gap: 64px;
	padding-bottom: 0;
}

.jc-mockup-home .footer-brand {
	font-family: var(--serif);
	font-size: 31px;
	font-weight: 400;
	line-height: 1;
	margin-bottom: 30px;
	color: #dce6df;
}

.jc-mockup-home .footer-tagline {
	font-size: 12px;
	color: rgba(229, 236, 231, 0.78);
	opacity: 1;
	line-height: 1.55;
	letter-spacing: 0.22em;
	text-transform: uppercase;
	max-width: 22rem;
}

.jc-mockup-home .footer-social {
	display: flex;
	gap: 30px;
	margin-top: 82px;
	color: rgba(229, 236, 231, 0.65);
	font-size: 16px;
	font-weight: 700;
}

.jc-mockup-home .footer-col h4 {
	font-family: var(--serif);
	font-size: 31px;
	text-transform: uppercase;
	letter-spacing: 0;
	margin: 0 0 30px;
	color: #dce6df;
	font-weight: 400;
	text-transform: none;
}

.jc-mockup-home .footer-col ul {
	list-style: none;
	margin: 0;
	padding: 0;
}

.jc-mockup-home .footer-col li {
	margin-bottom: 18px;
}

.jc-mockup-home .footer-col a,
.jc-mockup-home .footer-col p {
	font-size: 12px;
	color: rgba(229, 236, 231, 0.78);
	opacity: 1;
	font-weight: 700;
	letter-spacing: 0.28em;
	text-transform: uppercase;
	line-height: 1.55;
	transition: opacity 0.2s;
}

.jc-mockup-home .footer-col a:hover {
	opacity: 1;
	color: var(--accent-soft);
}

.jc-mockup-home .footer-newsletter form {
	display: grid;
	grid-template-columns: 1fr auto;
	margin-bottom: 12px;
}

.jc-mockup-home .footer-newsletter input {
	min-height: 42px;
	border: 0;
	border-radius: 0;
	background: #f7f3ec;
	color: #1f1d1a;
	padding: 12px 16px;
	font-size: 12px;
	font-weight: 700;
	letter-spacing: 0.12em;
	text-transform: uppercase;
}

.jc-mockup-home .footer-newsletter button {
	min-height: 42px;
	border: 0;
	border-radius: 0;
	background: #171717;
	color: #f7f3ec;
	padding: 0 18px;
	font-size: 12px;
	font-weight: 800;
	letter-spacing: 0.08em;
	cursor: pointer;
}

.jc-mockup-home .footer-bottom {
	max-width: 1320px;
	margin: 0 auto;
	padding: 76px 0 0;
	border-top: 0;
	display: flex;
	justify-content: space-between;
	align-items: center;
	color: rgba(229, 236, 231, 0.62);
	font-size: 11px;
	font-weight: 800;
	letter-spacing: 0.24em;
	text-transform: uppercase;
	opacity: 1;
}

.jc-mockup-home .footer-bottom a {
	margin-left: var(--space-4);
	color: var(--cream);
}

@media (max-width: 1024px) {
	.jc-mockup-home .city-link-grid,
	.jc-mockup-home .journal-grid {
		grid-template-columns: repeat(2, 1fr);
	}

	.jc-mockup-home .featured-grid {
		grid-template-columns: 1fr 1fr;
	}

	.jc-mockup-home .caterer-card.feature {
		grid-column: span 2;
		grid-row: auto;
	}

	.jc-mockup-home .caterer-card.feature .caterer-image {
		aspect-ratio: 16 / 8;
	}

	.jc-mockup-home .footer-grid {
		grid-template-columns: 1fr 1fr;
	}

	.jc-mockup-home .jc-search-panel {
		grid-template-columns: 1fr 1fr;
	}
}

@media (max-width: 700px) {
	.jc-mockup-home .header-inner {
		grid-template-columns: 1fr auto;
		padding: var(--space-3);
	}

	.jc-mockup-home .nav-primary {
		display: none;
	}

	.jc-mockup-home .nav-secondary .submit-link {
		display: none;
	}

	.jc-mockup-home .brand {
		font-size: 1.25rem;
		text-align: left;
		grid-column: 1 / 2;
	}

	.jc-mockup-home .hero {
		padding: var(--space-6) 0;
	}

	.jc-mockup-home .occasions,
	.jc-mockup-home .featured,
	.jc-mockup-home .journal,
	.jc-mockup-home .cities,
	.jc-mockup-home .newsletter,
	.jc-mockup-home .closing {
		padding: var(--space-6) 0;
	}

	.jc-mockup-home .city-link-grid,
	.jc-mockup-home .featured-grid,
	.jc-mockup-home .journal-grid,
	.jc-mockup-home .jc-search-panel {
		grid-template-columns: 1fr;
	}

	.jc-mockup-home .caterer-card.feature {
		grid-column: auto;
	}

	.jc-mockup-home .journal-grid,
	.jc-mockup-home .footer-grid {
		grid-template-columns: 1fr;
	}

	.jc-mockup-home .footer-bottom {
		flex-direction: column;
		gap: var(--space-3);
	}

	.jc-mockup-home .newsletter-form {
		flex-direction: column;
	}
}

/* Long-form Journal article template inspired by The Scout Guide editorial guides. */
.jc-blog-template-section .elementor-container,
.jc-blog-template-section .elementor-column,
.jc-blog-template-section .elementor-widget-wrap,
.jc-blog-template-section .elementor-widget-container {
	max-width: none !important;
	width: 100% !important;
	margin: 0 !important;
	padding: 0 !important;
}

.jc-editorial-article {
	--article-paper: #f7f3ec;
	--article-ink: #1f1d1a;
	--article-soft: #4a4640;
	--article-muted: #8a847a;
	--article-rule: #d8cfbf;
	--article-rule-soft: #e8e0d0;
	--article-accent: #c8553d;
	--article-white: #ffffff;
	--article-serif: "Fraunces", Georgia, serif;
	--article-sans: "Inter", -apple-system, BlinkMacSystemFont, sans-serif;
	background: var(--article-paper);
	color: var(--article-ink);
	font-family: var(--article-sans);
}

.jc-editorial-article a {
	color: inherit;
	text-decoration: none;
}

.jc-article-hero {
	max-width: 920px;
	margin: 0 auto;
	padding: 92px 24px 44px;
	text-align: center;
}

.jc-article-kicker {
	margin: 0 0 18px;
	color: var(--article-muted);
	font-size: 12px;
	font-weight: 600;
	letter-spacing: 0.16em;
	text-transform: uppercase;
}

.jc-article-hero h1 {
	margin: 0 0 28px;
	font-family: var(--article-serif);
	font-size: clamp(3rem, 7vw, 6.2rem);
	font-weight: 400;
	line-height: 0.98;
	letter-spacing: 0;
	color: var(--article-ink);
}

.jc-article-dek {
	max-width: 760px;
	margin: 0 auto 18px;
	font-family: var(--article-serif);
	font-size: clamp(1.1rem, 1.7vw, 1.35rem);
	font-style: italic;
	font-weight: 300;
	line-height: 1.65;
	color: var(--article-soft);
}

.jc-article-body {
	max-width: 760px;
	margin: 0 auto;
	padding: 0 24px 72px;
}

.jc-article-rule {
	height: 1px;
	background: var(--article-rule);
	margin: 34px 0;
}

.jc-article-body h2 {
	margin: 0;
	font-family: var(--article-serif);
	font-size: clamp(2.1rem, 4vw, 3.6rem);
	font-weight: 400;
	line-height: 1.05;
	color: var(--article-ink);
	text-align: center;
}

.jc-article-entry {
	margin: 0 0 48px;
}

.jc-article-entry-image {
	display: block;
	width: 100%;
	aspect-ratio: 4 / 3;
	background-size: cover;
	background-position: center;
	background-color: var(--article-rule-soft);
	margin: 0 0 22px;
}

.jc-article-entry h3 {
	margin: 0 0 8px;
	font-family: var(--article-serif);
	font-size: clamp(1.45rem, 2.5vw, 2rem);
	font-weight: 500;
	line-height: 1.15;
	color: var(--article-ink);
}

.jc-article-entry h3 a {
	border-bottom: 1px solid transparent;
}

.jc-article-entry h3 a:hover {
	color: var(--article-accent);
	border-color: var(--article-accent);
}

.jc-article-location {
	margin: 0 0 14px;
	color: var(--article-muted);
	font-size: 14px;
	font-weight: 600;
	letter-spacing: 0.04em;
}

.jc-article-entry p {
	margin: 0 0 14px;
	color: var(--article-soft);
	font-size: 17px;
	line-height: 1.7;
}

.jc-article-entry-links {
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
	color: var(--article-accent) !important;
	font-size: 14px !important;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.08em;
}

.jc-article-entry-links a {
	border-bottom: 1px solid currentColor;
}

.jc-article-directory-link {
	margin: 52px 0 0;
	padding-top: 34px;
	border-top: 1px solid var(--article-rule);
	color: var(--article-soft);
	font-family: var(--article-serif);
	font-size: 21px;
	font-style: italic;
	line-height: 1.6;
	text-align: center;
}

.jc-article-directory-link a {
	color: var(--article-accent);
	border-bottom: 1px solid var(--article-accent);
}

.jc-article-newsletter {
	max-width: 760px;
	margin: 0 auto 76px;
	padding: 42px 24px;
	text-align: center;
	border-top: 1px solid var(--article-rule);
	border-bottom: 1px solid var(--article-rule);
}

.jc-article-newsletter h2,
.jc-article-related h2 {
	margin: 0 0 24px;
	font-family: var(--article-serif);
	font-size: clamp(1.8rem, 3vw, 2.5rem);
	font-weight: 400;
	line-height: 1.1;
	color: var(--article-ink);
	text-align: center;
}

.jc-article-button {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	min-height: 48px;
	padding: 12px 24px;
	border: 1px solid var(--article-ink);
	border-radius: 8px;
	background: var(--article-ink);
	color: var(--article-paper) !important;
	font-size: 14px;
	font-weight: 600;
}

.jc-article-related {
	max-width: 1120px;
	margin: 0 auto;
	padding: 0 24px 88px;
}

.jc-article-related .journal-grid {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 24px;
}

.jc-article-related .article-image {
	aspect-ratio: 3 / 2;
	background-size: cover;
	background-position: center;
	background-color: var(--article-rule-soft);
	margin-bottom: 16px;
}

.jc-article-related .article-tag {
	margin-bottom: 8px;
	color: var(--article-muted);
	font-size: 11px;
	font-weight: 600;
	letter-spacing: 0.14em;
	text-transform: uppercase;
}

.jc-article-related .article-title {
	margin: 0 0 8px;
	font-family: var(--article-serif);
	font-size: 20px;
	font-weight: 500;
	line-height: 1.25;
}

.jc-article-related .article-desc {
	margin: 0;
	color: var(--article-soft);
	font-size: 14px;
	line-height: 1.6;
}

.jc-editorial-article .jc-site-footer {
	max-width: none;
	margin-top: 0;
}

@media (max-width: 900px) {
	.jc-article-hero {
		padding-top: 64px;
	}

	.jc-article-related .journal-grid {
		grid-template-columns: repeat(2, 1fr);
	}
}

@media (max-width: 640px) {
	.jc-article-hero h1 {
		font-size: 42px;
	}

	.jc-article-body,
	.jc-article-hero,
	.jc-article-newsletter,
	.jc-article-related {
		padding-left: 18px;
		padding-right: 18px;
	}

	.jc-article-related .journal-grid {
		grid-template-columns: 1fr;
	}
}
