/* Location pages — parent /location/ index and per-city children.
   Depends on homepage-v2.css (root vars, .jb-container, .jb-card, .jb-feature,
   .jb-grid, .jb-two-col, .jb-cities used by cities-grid partial). */

/* ---------- Breadcrumbs ---------- */
.jb-crumbs {
	background: var(--jb-bg-soft);
	font-size: .9rem;
	padding: .9rem 0;
	border-bottom: 1px solid var(--jb-gray-2);
}
.jb-crumbs ol { list-style: none; margin: 0; padding: 0; display: flex; flex-wrap: wrap; gap: .4rem; }
.jb-crumbs li + li::before { content: "/"; color: var(--jb-gray-2); margin-right: .4rem; }
.jb-crumbs a { color: var(--jb-blue-deep); text-decoration: none; }
.jb-crumbs a:hover { text-decoration: underline; }
.jb-crumbs [aria-current="page"] { color: var(--jb-text); font-weight: 600; }

/* ---------- Alternating section backgrounds ---------- */
.jb-location--city .jb-city__intro,
.jb-location--city .jb-city__rentals,
.jb-location--city .jb-city__events,
.jb-location--city .jb-city__area { background: #fff; }

.jb-location--city .jb-city__why,
.jb-location--city .jb-city__venues,
.jb-location--city .jb-city__delivery,
.jb-location--city .jb-city__faq { background: var(--jb-bg-soft); }

.jb-location--city .jb-city__seasons {
	background:
		radial-gradient(ellipse at 15% 20%, rgba(0,166,255,.08), transparent 55%),
		linear-gradient(180deg, #fff 0%, var(--jb-bg-soft) 100%);
}

/* ---------- HERO (shared) ---------- */
.jb-location__hero,
.jb-city__hero {
	background:
		radial-gradient(ellipse at 85% 10%, rgba(0,166,255,.22), transparent 55%),
		linear-gradient(180deg, var(--jb-bg-dark) 0%, var(--jb-bg-dark-2) 100%);
	color: #fff;
	padding: clamp(3.5rem, 6vw, 5.5rem) 0;
	position: relative;
	overflow: hidden;
}
.jb-home .jb-location__hero h1,
.jb-home .jb-city__hero h1 {
	color: #fff;
	margin: .5rem 0 1rem;
	max-width: 18ch;
}
.jb-home .jb-city__hero h1::after {
	content: "";
	display: block;
	width: 110px;
	height: 7px;
	background: var(--jb-blue);
	border-radius: 4px;
	margin-top: 1rem;
}
.jb-city__eyebrow {
	display: inline-block;
	text-transform: uppercase;
	letter-spacing: .14em;
	font-size: .8rem;
	font-weight: 800;
	color: var(--jb-blue);
	margin: 0 0 .5rem;
}
.jb-city__sub {
	color: rgba(255,255,255,.9);
	font-size: clamp(1.05rem, 1.8vw, 1.25rem);
	max-width: 50ch;
	margin: 0 0 1.5rem;
	line-height: 1.5;
}
.jb-city__hero-cta {
	display: flex;
	gap: .75rem;
	flex-wrap: wrap;
	margin: 0;
}
.jb-city__hero-figure {
	margin: 0;
	border-radius: var(--jb-radius-lg);
	overflow: hidden;
	box-shadow: 0 30px 80px rgba(0,0,0,.5);
	border: 1px solid rgba(255,255,255,.12);
}
.jb-city__hero-figure img { width: 100%; height: auto; display: block; }

/* ---------- /location/ index hero ---------- */
.jb-location__intro { margin-top: 1rem; font-size: 1.05rem; color: rgba(255,255,255,.9); }
.jb-location__intro p { margin: 0 0 1rem; }
.jb-home .jb-location__intro > a:not(.jb-btn),
.jb-home .jb-location__hero p > a:not(.jb-btn),
.jb-home .jb-city__hero p > a:not(.jb-btn) {
	color: var(--jb-blue);
	text-decoration: underline;
	text-decoration-thickness: 2px;
	text-underline-offset: 3px;
}
.jb-home .jb-location__hero p > a:not(.jb-btn):hover,
.jb-home .jb-city__hero p > a:not(.jb-btn):hover { color: #7fd4ff; }

.jb-location__cities h2 { margin: 0 0 1.25rem; }
.jb-location__cta { margin-top: 1.5rem; color: var(--jb-text); text-align: center; font-weight: 600; }

/* ---------- Shared prose container ---------- */
.jb-city__prose p { margin: 0 0 1rem; line-height: 1.65; font-size: 1.05rem; }

/* ---------- Intro ---------- */
.jb-city__intro .jb-city__prose p:first-of-type::first-letter {
	font-family: var(--jb-font-head);
	font-size: 2.6rem;
	float: left;
	line-height: 1;
	padding: .25rem .55rem 0 0;
	color: var(--jb-blue);
	font-weight: 800;
}

/* ---------- Why section (reuses .jb-feature) ---------- */
.jb-city__why .jb-feature {
	border-bottom: 6px solid var(--jb-blue);
	text-align: left;
	padding: 1.5rem 1.75rem;
}
.jb-city__why .jb-feature:nth-child(2n) { border-bottom-color: var(--jb-pink); }
.jb-city__why .jb-feature:nth-child(3n) { border-bottom-color: var(--jb-yellow-deep); }
.jb-city__why .jb-feature__icon {
	width: 56px;
	height: 56px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	background: linear-gradient(135deg, #e6f4ff 0%, #d0ebff 100%);
	border-radius: 14px;
	margin-bottom: .75rem;
}
.jb-city__why .jb-feature__icon svg {
	width: 28px;
	height: 28px;
	color: var(--jb-blue-deep);
}
.jb-city__why .jb-feature h3 { margin: .5rem 0 .35rem; color: var(--jb-black); }
.jb-city__why .jb-feature p { margin: 0; font-size: .98rem; line-height: 1.55; color: var(--jb-text); }

/* ---------- Rentals (reuses .jb-card) ---------- */
.jb-city__rentals h2 { margin-bottom: 1.5rem; }

/* ---------- Venues ---------- */
.jb-city__section-intro,
.jb-city__section-outro {
	max-width: 72ch;
	margin: 0 0 1.5rem;
	font-size: 1.05rem;
	line-height: 1.6;
}
.jb-home .jb-city__section-outro {
	margin: 2.5rem auto 0;
	max-width: 60ch;
	text-align: center;
	font-style: italic;
	color: var(--jb-text);
}
.jb-city__venue-list {
	list-style: none;
	margin: 0;
	padding: 0;
	display: grid;
	gap: 1rem;
	grid-template-columns: 1fr;
}
@media (min-width: 720px) { .jb-city__venue-list { grid-template-columns: 1fr 1fr; } }
.jb-city__venue {
	background: #fff;
	border-radius: var(--jb-radius);
	padding: 1.1rem 1.3rem;
	border: 1px solid rgba(13,27,61,.08);
	border-left: 4px solid var(--jb-blue);
	box-shadow: 0 3px 10px rgba(13,27,61,.04);
	transition: transform .15s, box-shadow .15s;
}
.jb-city__venue:hover { transform: translateY(-2px); box-shadow: 0 10px 24px rgba(13,27,61,.1); }
.jb-city__venue:nth-child(5n+2) { border-left-color: var(--jb-pink); }
.jb-city__venue:nth-child(5n+3) { border-left-color: var(--jb-yellow-deep); }
.jb-city__venue:nth-child(5n+4) { border-left-color: var(--jb-purple); }
.jb-city__venue:nth-child(5n+5) { border-left-color: var(--jb-teal); }
.jb-city__venue h3 {
	margin: 0 0 .25rem;
	font-size: 1.05rem;
	color: var(--jb-black);
}
.jb-city__venue p { margin: 0; font-size: .95rem; color: var(--jb-text); line-height: 1.5; }

/* ---------- Events ---------- */
.jb-city__event-grid {
	list-style: none;
	margin: 0;
	padding: 0;
	display: grid;
	gap: 1rem;
	grid-template-columns: 1fr;
}
@media (min-width: 640px) { .jb-city__event-grid { grid-template-columns: 1fr 1fr; } }
@media (min-width: 1000px) { .jb-city__event-grid { grid-template-columns: 1fr 1fr 1fr; } }
.jb-city__event {
	display: flex;
	gap: 1rem;
	align-items: flex-start;
	padding: 1.1rem 1.25rem;
	background: var(--jb-bg-soft);
	border-radius: var(--jb-radius);
	border: 1px solid rgba(0,166,255,.14);
}
.jb-city__event-icon {
	flex: 0 0 auto;
	width: 46px;
	height: 46px;
	border-radius: 12px;
	background: linear-gradient(135deg, var(--jb-blue) 0%, var(--jb-blue-deep) 100%);
	display: inline-flex;
	align-items: center;
	justify-content: center;
	color: #fff;
	box-shadow: 0 4px 12px rgba(0,166,255,.35);
}
.jb-city__event-icon svg { width: 22px; height: 22px; color: #fff; }
.jb-city__event h3 { margin: 0 0 .2rem; font-size: 1.02rem; color: var(--jb-black); }
.jb-city__event p { margin: 0; font-size: .93rem; color: var(--jb-text); line-height: 1.5; }

/* ---------- Seasons ---------- */
.jb-city__season-grid {
	list-style: none;
	margin: 1rem 0 0;
	padding: 0;
	display: grid;
	gap: 1.25rem;
	grid-template-columns: 1fr;
}
@media (min-width: 640px) { .jb-city__season-grid { grid-template-columns: 1fr 1fr; } }
@media (min-width: 1000px) { .jb-city__season-grid { grid-template-columns: repeat(4, 1fr); } }
.jb-city__season {
	background: #fff;
	border-radius: var(--jb-radius-lg);
	padding: 1.5rem 1.35rem;
	border: 1px solid rgba(13,27,61,.08);
	box-shadow: 0 4px 14px rgba(13,27,61,.05);
	position: relative;
	overflow: hidden;
	transition: transform .15s, box-shadow .15s;
}
.jb-city__season::before {
	content: "";
	position: absolute;
	top: 0; left: 0; right: 0;
	height: 4px;
	background: linear-gradient(90deg, var(--jb-blue), var(--jb-pink));
}
.jb-city__season:nth-child(2)::before { background: linear-gradient(90deg, var(--jb-yellow), var(--jb-pink)); }
.jb-city__season:nth-child(3)::before { background: linear-gradient(90deg, var(--jb-red), var(--jb-yellow-deep)); }
.jb-city__season:nth-child(4)::before { background: linear-gradient(90deg, var(--jb-teal), var(--jb-blue)); }
.jb-city__season:hover { transform: translateY(-3px); box-shadow: 0 14px 32px rgba(13,27,61,.1); }
.jb-city__season-icon {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 52px;
	height: 52px;
	border-radius: 14px;
	background: linear-gradient(135deg, #e6f4ff 0%, #d0ebff 100%);
	margin-bottom: .75rem;
}
.jb-city__season-icon svg {
	width: 26px;
	height: 26px;
	color: var(--jb-blue-deep);
}
.jb-city__season:nth-child(2) .jb-city__season-icon { background: linear-gradient(135deg, #fff5d6 0%, #ffe99a 100%); }
.jb-city__season:nth-child(2) .jb-city__season-icon svg { color: #c88b00; }
.jb-city__season:nth-child(3) .jb-city__season-icon { background: linear-gradient(135deg, #ffe4cc 0%, #ffcfa3 100%); }
.jb-city__season:nth-child(3) .jb-city__season-icon svg { color: #b24a00; }
.jb-city__season:nth-child(4) .jb-city__season-icon { background: linear-gradient(135deg, #d9fbf6 0%, #a8e8df 100%); }
.jb-city__season:nth-child(4) .jb-city__season-icon svg { color: #087c6f; }
.jb-city__season h3 {
	margin: 0 0 .15rem;
	font-size: 1.15rem;
	color: var(--jb-black);
}
.jb-city__season-months {
	margin: 0 0 .5rem;
	font-size: .8rem;
	font-weight: 700;
	letter-spacing: .1em;
	text-transform: uppercase;
	color: var(--jb-blue-deep);
}
.jb-city__season p { margin: 0 0 .5rem; font-size: .95rem; line-height: 1.5; color: var(--jb-text); }
.jb-city__season .jb-link { margin: .25rem 0 0; padding: 0; }

/* ---------- Delivery ---------- */
.jb-city__delivery-figure {
	margin: 0;
	border-radius: var(--jb-radius-lg);
	overflow: hidden;
	box-shadow: 0 20px 50px rgba(13,27,61,.18);
}
.jb-city__delivery-figure img { width: 100%; height: auto; display: block; }
.jb-city__check-list {
	list-style: none;
	padding: 0;
	margin: 0 0 1.25rem;
}
.jb-city__check-list li {
	position: relative;
	padding: .4rem 0 .4rem 2rem;
	line-height: 1.45;
	font-size: 1rem;
}
.jb-city__check-list li::before {
	content: "";
	position: absolute;
	left: 0;
	top: .55rem;
	width: 20px;
	height: 20px;
	border-radius: 50%;
	background: var(--jb-blue) url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'><polyline points='20 6 9 17 4 12'/></svg>") center/12px no-repeat;
}
.jb-city__specs {
	margin: 0;
	display: grid;
	gap: .75rem;
}
.jb-city__specs dt {
	font-family: var(--jb-font-head);
	font-weight: 800;
	text-transform: uppercase;
	letter-spacing: .1em;
	font-size: .78rem;
	color: var(--jb-blue-deep);
	margin-bottom: .15rem;
}
.jb-city__specs dd { margin: 0 0 .25rem; line-height: 1.55; color: var(--jb-text); font-size: .98rem; }

/* ---------- Service area ---------- */
.jb-city__area-cols {
	display: grid;
	gap: 1.25rem;
	grid-template-columns: 1fr;
	margin: 1rem 0;
}
@media (min-width: 680px) { .jb-city__area-cols { grid-template-columns: 1fr 1fr; } }
.jb-city__area-cols > div {
	background: var(--jb-bg-soft);
	padding: 1.1rem 1.3rem;
	border-radius: var(--jb-radius);
	border-left: 4px solid var(--jb-blue);
}
.jb-city__area-cols h3 { margin: 0 0 .35rem; font-size: 1.05rem; color: var(--jb-black); }
.jb-city__area-cols p { margin: 0; font-size: .98rem; line-height: 1.55; }
.jb-city__callout {
	background: #fff;
	border: 2px solid var(--jb-yellow);
	padding: 1rem 1.2rem;
	border-radius: var(--jb-radius);
	font-weight: 600;
	color: var(--jb-black);
}

/* ---------- FAQ accordion ---------- */
.jb-faq-list { display: grid; gap: .75rem; margin-top: 1rem; }
.jb-faq {
	background: #fff;
	border: 1px solid rgba(13,27,61,.08);
	border-radius: var(--jb-radius);
	box-shadow: 0 2px 8px rgba(13,27,61,.04);
	overflow: hidden;
	transition: box-shadow .2s, border-color .2s;
}
.jb-faq[open] {
	box-shadow: 0 12px 28px rgba(13,27,61,.08);
	border-color: rgba(0,166,255,.35);
}
.jb-faq summary {
	cursor: pointer;
	list-style: none;
	padding: 1rem 1.25rem;
	font-family: var(--jb-font-head);
	font-weight: 700;
	font-size: 1.05rem;
	color: var(--jb-black);
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 1rem;
	user-select: none;
}
.jb-faq summary::-webkit-details-marker { display: none; }
.jb-faq summary::after {
	content: "";
	flex: 0 0 auto;
	width: 28px;
	height: 28px;
	border-radius: 50%;
	background: var(--jb-bg-soft) url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%230077cc' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'><path d='M12 5v14M5 12h14'/></svg>") center/16px no-repeat;
	transition: transform .2s, background-color .2s;
}
.jb-faq[open] summary::after {
	background: var(--jb-blue) url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='2.8' stroke-linecap='round' stroke-linejoin='round'><path d='M5 12h14'/></svg>") center/16px no-repeat;
	transform: rotate(180deg);
}
.jb-faq summary:hover { background: var(--jb-bg-soft); }
.jb-faq__answer {
	padding: 0 1.25rem 1.1rem;
	color: var(--jb-text);
	line-height: 1.65;
	font-size: 1rem;
	border-top: 1px solid rgba(13,27,61,.06);
}
.jb-faq__answer p { margin: 1rem 0 0; }

/* ---------- Closing CTA ---------- */
.jb-city__closing-cta { background: #fff; }
.jb-city__cta-box {
	background:
		radial-gradient(ellipse at 85% 10%, rgba(255,212,0,.18), transparent 55%),
		linear-gradient(135deg, var(--jb-bg-dark) 0%, var(--jb-bg-dark-2) 100%);
	color: #fff;
	padding: clamp(2rem, 4vw, 3rem);
	border-radius: var(--jb-radius-lg);
	text-align: center;
	box-shadow: 0 20px 50px rgba(13,27,61,.2);
}
.jb-home .jb-city__cta-box h2 { color: #fff; margin: 0 0 .75rem; }
.jb-city__cta-box p { color: rgba(255,255,255,.88); max-width: 56ch; margin: 0 auto 1rem; font-size: 1.05rem; }
.jb-home .jb-city__cta-box p > a:not(.jb-btn) { color: var(--jb-yellow); text-decoration-color: var(--jb-yellow); }
.jb-home .jb-city__cta-box p > a:not(.jb-btn):hover { color: #fff; }
.jb-city__closing-links {
	display: flex;
	gap: .75rem;
	justify-content: center;
	flex-wrap: wrap;
	margin: 1.25rem 0 .5rem;
}
.jb-city__footnote {
	margin-top: 1rem;
	font-size: .88rem;
	color: rgba(255,255,255,.6);
	font-style: italic;
}

/* ---------- Two-col balance ---------- */
.jb-city__hero .jb-two-col,
.jb-city__delivery .jb-two-col {
	gap: 2.5rem;
}
@media (min-width: 860px) {
	.jb-city__hero .jb-two-col { grid-template-columns: minmax(0, 1.1fr) minmax(280px, 1fr); }
}
