/* Jumper Bee — Event Types: Graduation Parties template (layered on homepage-v2.css) */

.jb-event--graduation-parties {
	--grad-navy:         #1e2a55;
	--grad-navy-soft:    #dee3f1;
	--grad-navy-deep:    #0f1833;
	--grad-gold:         #e6b43a;
	--grad-gold-soft:    #fbeecc;
	--grad-gold-deep:    #7a5a0e;
	--grad-crimson:      #b82b3c;
	--grad-crimson-soft: #f7d7db;
	--grad-crimson-deep: #6d111c;
	--grad-forest:       #2f7d5b;
	--grad-forest-soft:  #dcefe5;
	--grad-forest-deep:  #154a33;
	--grad-royal:        #5a3b97;
	--grad-royal-soft:   #e5dcf2;
	--grad-royal-deep:   #331d5e;
	--grad-cream:        #fbf7ee;
	--grad-cream-soft:   #fffcf4;
	--grad-ink:          #14162c;
}

/* 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; }

/* Eyebrow */
.jb-event--graduation-parties .jb-eyebrow {
	text-transform: uppercase;
	letter-spacing: .12em;
	font-size: .78rem;
	font-weight: 700;
	color: var(--grad-crimson-deep);
	margin: 0 0 .5rem;
}
.jb-hero--grad .jb-eyebrow { color: var(--grad-gold-soft); }

/* Hero — classroom-banner wash: navy, gold, crimson, royal */
.jb-hero--grad {
	min-height: 0;
	background:
		radial-gradient(ellipse at 84% 18%, rgba(230,180,58,.55), transparent 55%),
		radial-gradient(ellipse at 12% 78%, rgba(184,43,60,.55), transparent 58%),
		radial-gradient(ellipse at 60% 52%, rgba(90,59,151,.45), transparent 60%),
		radial-gradient(ellipse at 30% 15%, rgba(47,125,91,.4), transparent 55%),
		linear-gradient(180deg, #0f1833 0%, #1e2a55 50%, #331d5e 100%);
}

/* Hero form override — crimson submit with navy hover */
.jb-event--graduation-parties .jb-hero__form button,
.jb-event--graduation-parties .jb-hero__form input[type="submit"],
.jb-event--graduation-parties .jb-hero__form .frm_button_submit {
	background: var(--grad-crimson-deep);
}
.jb-event--graduation-parties .jb-hero__form button:hover,
.jb-event--graduation-parties .jb-hero__form input[type="submit"]:hover,
.jb-event--graduation-parties .jb-hero__form .frm_button_submit:hover { background: var(--grad-navy-deep); }

/* Intro */
.jb-grad-intro { background: #fff; text-align: center; }
.jb-grad-intro p { font-size: 1.08rem; }
.jb-home .jb-grad-intro .jb-intro__cta { margin-top: 1.5rem; font-weight: 600; font-size: 1.05rem; }

/* Grids */
.jb-grid--2 { display: grid; gap: 1.25rem; grid-template-columns: 1fr; }
@media (min-width: 768px) { .jb-grid--2 { grid-template-columns: repeat(2, 1fr); gap: 1.5rem; } }
@media (min-width: 900px) {
	.jb-two-col--reverse { grid-template-columns: 1fr 1fr; }
	.jb-two-col--reverse > :first-child { order: 2; }
	.jb-two-col--reverse > :last-child { order: 1; }
}

/* Grad cards — rotating accent (navy / gold / crimson / forest / royal) */
.jb-card--grad {
	display: flex;
	flex-direction: column;
	gap: .5rem;
	background: #fff;
	border-radius: var(--jb-radius);
	padding: 1.5rem;
	border-top: 4px solid var(--grad-navy);
	box-shadow: var(--jb-shadow);
	transition: transform .2s ease, box-shadow .2s ease;
}
.jb-card--grad:hover {
	transform: translateY(-3px);
	box-shadow: var(--jb-shadow-lg);
}
.jb-card--grad h3 { margin: .25rem 0 .4rem; }
.jb-card--grad p { margin: 0; color: var(--jb-text); }
.jb-card--grad .jb-card__icon {
	width: 52px;
	height: 52px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	border-radius: 12px;
	background: var(--grad-navy-soft);
	color: var(--grad-navy-deep);
}
.jb-card--grad .jb-card__icon .jb-icon { width: 28px; height: 28px; }

.jb-card--grad.jb-card--accent-1 { border-top-color: var(--grad-gold); }
.jb-card--grad.jb-card--accent-1 .jb-card__icon { background: var(--grad-gold-soft); color: var(--grad-gold-deep); }

.jb-card--grad.jb-card--accent-2 { border-top-color: var(--grad-crimson); }
.jb-card--grad.jb-card--accent-2 .jb-card__icon { background: var(--grad-crimson-soft); color: var(--grad-crimson-deep); }

.jb-card--grad.jb-card--accent-3 { border-top-color: var(--grad-forest); }
.jb-card--grad.jb-card--accent-3 .jb-card__icon { background: var(--grad-forest-soft); color: var(--grad-forest-deep); }

.jb-card--grad.jb-card--accent-4 { border-top-color: var(--grad-royal); }
.jb-card--grad.jb-card--accent-4 .jb-card__icon { background: var(--grad-royal-soft); color: var(--grad-royal-deep); }

/* Section rhythm */
.jb-grad-core      { background: var(--grad-cream); }
.jb-grad-types     { background: #fff; }
.jb-grad-signature { background: var(--grad-navy-soft); }
.jb-grad-styling   { background: var(--grad-cream-soft); }
.jb-grad-flow      { background: #fff; }
.jb-areas          { background: var(--grad-gold-soft); }
.jb-grad-faq       { background: var(--grad-cream); }

/* Signature figure frame — gold trim, mortarboard-tassel accent */
.jb-grad-signature__figure {
	margin: 0;
	border: 4px solid var(--grad-gold);
	border-radius: var(--jb-radius-lg);
	overflow: hidden;
	box-shadow: 0 14px 40px rgba(122,90,14,.22);
}
.jb-grad-signature__figure img { width: 100%; height: auto; display: block; }

/* Core figure frame — crimson trim */
.jb-grad-core .jb-events__figure {
	margin: 0;
	border: 4px solid var(--grad-crimson);
	border-radius: var(--jb-radius-lg);
	overflow: hidden;
	box-shadow: 0 14px 40px rgba(184,43,60,.24);
}
.jb-grad-core .jb-events__figure img { width: 100%; height: auto; display: block; }

/* Top school-banner stripe — navy / gold / crimson / forest / royal */
.jb-grad-core,
.jb-grad-signature {
	position: relative;
}
.jb-grad-core::before,
.jb-grad-signature::before {
	content: "";
	display: block;
	height: 6px;
	background:
		linear-gradient(
			90deg,
			var(--grad-navy)    0 20%,
			var(--grad-gold)    20% 40%,
			var(--grad-crimson) 40% 60%,
			var(--grad-forest)  60% 80%,
			var(--grad-royal)   80% 100%
		);
	position: absolute;
	top: 0; left: 0; right: 0;
}

/* Lead + fine */
.jb-home .jb-event--graduation-parties .jb-lead,
.jb-event--graduation-parties .jb-lead {
	font-size: 1.1rem;
	color: var(--jb-text);
	max-width: 820px;
	margin: 0 0 1.75rem;
}
.jb-home .jb-event--graduation-parties .jb-fine,
.jb-event--graduation-parties .jb-fine {
	font-size: .9rem;
	color: #555;
	margin: 2.25rem 0 0;
	font-style: italic;
}

/* Checklist — card-style with navy ticks */
.jb-home .jb-event--graduation-parties .jb-checklist,
.jb-event--graduation-parties .jb-checklist {
	list-style: none;
	padding: 0;
	margin: 0 0 1.75rem;
	display: grid;
	gap: .75rem;
	grid-template-columns: 1fr;
}
@media (min-width: 720px) {
	.jb-event--graduation-parties .jb-checklist--two { grid-template-columns: 1fr 1fr; gap: .9rem 1.25rem; }
}
.jb-event--graduation-parties .jb-checklist li {
	position: relative;
	padding: .85rem 1rem .85rem 3rem;
	background: #fff;
	border: 1px solid var(--jb-gray-2);
	border-radius: var(--jb-radius);
	box-shadow: 0 2px 6px rgba(30,42,85,.07);
	line-height: 1.5;
}
.jb-event--graduation-parties .jb-checklist li::before {
	content: "\2713";
	position: absolute;
	left: .9rem;
	top: .95rem;
	width: 1.45rem;
	height: 1.45rem;
	border-radius: 50%;
	background: var(--grad-navy);
	color: #fff;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: .85rem;
	font-weight: 800;
	line-height: 1;
}
.jb-event--graduation-parties .jb-checklist strong { color: var(--jb-black); }

/* Flow section — gold ticks */
.jb-grad-flow .jb-checklist li::before {
	background: var(--grad-gold-deep);
}

/* FAQ */
.jb-grad-faq .jb-faq { display: grid; gap: .75rem; max-width: 860px; margin: 0 auto; }
.jb-grad-faq h2 { text-align: center; margin-bottom: 2rem; }
.jb-grad-faq .jb-faq__item {
	background: #fff;
	border-radius: var(--jb-radius);
	box-shadow: var(--jb-shadow);
	padding: 1rem 1.25rem;
	border-left: 4px solid var(--grad-gold);
}
.jb-grad-faq .jb-faq__item summary {
	cursor: pointer;
	font-weight: 700;
	font-size: 1.05rem;
	color: var(--jb-black);
	list-style: none;
	position: relative;
	padding-right: 2rem;
}
.jb-grad-faq .jb-faq__item summary::-webkit-details-marker { display: none; }
.jb-grad-faq .jb-faq__item summary::after {
	content: "+";
	position: absolute;
	right: 0;
	top: 50%;
	transform: translateY(-50%);
	font-size: 1.4rem;
	line-height: 1;
	color: var(--grad-crimson-deep);
	font-weight: 800;
}
.jb-grad-faq .jb-faq__item[open] summary::after { content: "\2212"; }
.jb-grad-faq .jb-faq__item p { margin: .75rem 0 0; color: var(--jb-text); }

/* Final CTA — navy to crimson to gold, banner-style */
.jb-grad-cta {
	background: linear-gradient(135deg, var(--grad-navy-deep) 0%, var(--grad-navy) 30%, var(--grad-royal) 55%, var(--grad-crimson) 80%, var(--grad-crimson-deep) 100%);
	color: #fff;
	text-align: center;
}
.jb-grad-cta h2 { color: #fff; }
.jb-grad-cta p { color: rgba(255,255,255,.97); max-width: 720px; margin: 0 auto 1.25rem; }
.jb-grad-cta .jb-hero__cta { justify-content: center; }
.jb-grad-cta a:not(.jb-btn) {
	color: var(--grad-gold-soft);
	text-decoration: underline;
	text-decoration-thickness: 2px;
}
.jb-grad-cta a.jb-btn.jb-btn--primary { background: var(--grad-gold); color: var(--grad-ink); border-color: var(--grad-gold); }
.jb-grad-cta a.jb-btn.jb-btn--primary:hover { background: var(--grad-gold-soft); color: var(--grad-gold-deep); border-color: var(--grad-gold-soft); }
.jb-grad-cta a.jb-btn.jb-btn--secondary { border-color: #fff; color: #fff; background: transparent; }
.jb-grad-cta a.jb-btn.jb-btn--secondary:hover { background: #fff; color: var(--grad-crimson-deep); }
