/*
 * Jo-Bloom — structural frontend styles.
 * Only layout/skeleton + responsive behaviour live here.
 * All colours, typography, spacing, borders, radius and shadows are
 * generated by Elementor from the widget controls, so editors can
 * override 100% of the look from the panel.
 */

/* ---------------------------------------------------------------- HEADER */
.jobloom-header {
	display: flex;
	align-items: center;
	justify-content: space-between;
	width: 100%;
	z-index: 100;
	transition: box-shadow .3s ease, background-color .3s ease, backdrop-filter .3s ease, padding .3s ease;
}
.jobloom-header.jobloom-is-sticky {
	position: -webkit-sticky;
	position: sticky;
	top: 0;
	z-index: 999;
}
.jobloom-header.jobloom-scrolled {
	box-shadow: 0 6px 22px rgba(0,0,0,0.22);
	backdrop-filter: saturate(140%) blur(8px);
	-webkit-backdrop-filter: saturate(140%) blur(8px);
}
/* Floating mode applied by JS once user scrolls past the header's initial
 * position. Position becomes fixed so it stays reliably even if a parent
 * has overflow:hidden, with a slide-down reveal. */
.jobloom-header.jobloom-floating {
	position: fixed !important;
	top: 0;
	left: 0;
	right: 0;
	z-index: 9999;
	animation: jb-header-slide .45s cubic-bezier(.16,1,.3,1);
}
@keyframes jb-header-slide {
	from { transform: translateY(-100%); opacity: .4; }
	to   { transform: translateY(0); opacity: 1; }
}
.jobloom-header-spacer { display: none; width: 100%; }
.jobloom-header-spacer.is-active { display: block; }
.jobloom-header__logo img { transition: max-height .3s ease; }
.jobloom-header__left {
	display: flex;
	align-items: baseline;
	gap: 8px;
}
.jobloom-header__brand {
	text-decoration: none;
	display: inline-flex;
	align-items: baseline;
	gap: 8px;
}
.jobloom-header__menu {
	display: flex;
	align-items: center;
	transition: opacity .28s ease, transform .28s ease, visibility .28s ease;
}
.jobloom-header__nav {
	display: flex;
	align-items: center;
	list-style: none;
	margin: 0;
	padding: 0;
	gap: inherit;
}
.jobloom-header__nav li { margin: 0; }
.jobloom-header__menu a {
	text-decoration: none;
	white-space: nowrap;
}
.jobloom-header__toggle {
	display: none;
	background: none;
	border: 0;
	cursor: pointer;
	padding: 6px;
	line-height: 0;
}
.jobloom-header__toggle span {
	display: block;
	width: 22px;
	height: 2px;
	margin: 4px 0;
	background: currentColor;
	border-radius: 2px;
	transition: transform .3s cubic-bezier(.4,0,.2,1), opacity .2s ease;
	transform-origin: center;
}

/* Header responsive — collapse the menu into an animated toggle */
@media (max-width: 1024px) {
	.jobloom-header.jobloom-collapse-mobile {
		position: relative;
	}
	.jobloom-header.jobloom-collapse-mobile .jobloom-header__toggle {
		display: block;
	}
	.jobloom-header.jobloom-collapse-mobile .jobloom-header__menu {
		position: absolute;
		left: 0;
		right: 0;
		top: 100%;
		flex-direction: column;
		align-items: stretch;
		background: var(--jb-mobile-bg, #1A1714);
		padding: 12px 24px 18px;
		gap: 4px;
		/* animated hidden state */
		opacity: 0;
		visibility: hidden;
		transform: translateY(-10px);
		pointer-events: none;
		box-shadow: 0 12px 24px rgba(0,0,0,.18);
	}
	.jobloom-header.jobloom-collapse-mobile .jobloom-header__nav {
		flex-direction: column;
		align-items: stretch;
	}
	.jobloom-header.jobloom-collapse-mobile .jobloom-header__nav li { padding: 4px 0; }
	.jobloom-header.jobloom-collapse-mobile.jobloom-menu-open .jobloom-header__menu {
		opacity: 1;
		visibility: visible;
		transform: translateY(0);
		pointer-events: auto;
	}
	/* hamburger → X */
	.jobloom-header.jobloom-collapse-mobile.jobloom-menu-open .jobloom-header__toggle span:nth-child(1) {
		transform: translateY(6px) rotate(45deg);
	}
	.jobloom-header.jobloom-collapse-mobile.jobloom-menu-open .jobloom-header__toggle span:nth-child(2) {
		opacity: 0;
		transform: scaleX(0);
	}
	.jobloom-header.jobloom-collapse-mobile.jobloom-menu-open .jobloom-header__toggle span:nth-child(3) {
		transform: translateY(-6px) rotate(-45deg);
	}
}

/* ---------------------------------------------------------------- FOOTER */
.jobloom-footer {
	display: grid;
	width: 100%;
}
.jobloom-footer__social {
	display: flex;
	flex-wrap: wrap;
}
.jobloom-footer__social a,
.jobloom-footer__col a {
	text-decoration: none;
}
.jobloom-footer__col a,
.jobloom-footer__line {
	display: block;
}
.jobloom-footer__list {
	list-style: none;
	margin: 0;
	padding: 0;
}
.jobloom-footer__list li { margin: 0; }
.jobloom-footer__list a { display: block; }
.jobloom-footer-bottom {
	display: flex;
	align-items: center;
	justify-content: space-between;
	flex-wrap: wrap;
	width: 100%;
}
.jobloom-footer-bottom p {
	margin: 0;
}
@media (max-width: 760px) {
	.jobloom-footer {
		grid-template-columns: 1fr !important;
	}
	.jobloom-footer-bottom {
		flex-direction: column;
		align-items: flex-start;
		gap: 4px;
	}
}

/* ------------------------------------------------------------------- 404 */
.jobloom-404 {
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	text-align: center;
	width: 100%;
}
.jobloom-404__actions {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: center;
}
.jobloom-404__links {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: center;
}
.jobloom-404 a {
	text-decoration: none;
}

