/* ============================================================
   WordPress overrides for Craften Interiors theme
   Loaded after theme.css + pages.css; fixes WP-only edge cases
   and mobile responsive issues.
   ============================================================ */

/* ============================================================
   0. GLOBAL: Remove diamond dots from all eyebrows sitewide
   ============================================================ */
.eyebrow::before {
	display: none !important;
}
.diamond {
	display: none !important;
}

/* ============================================================
   1. Search overlay
   ============================================================ */
.craften-search-overlay {
	display: none;
	background: var(--c-cream, #f5f1e8);
	border-bottom: 1px solid rgba(0,0,0,.08);
}
.craften-search-overlay.open { display: block; }
.craften-search-overlay .search-form {
	max-width: 1200px;
	margin: 0 auto;
	padding: 18px 24px;
	display: flex;
	gap: 12px;
	align-items: center;
}
.craften-search-overlay .search-form input[type=search] {
	flex: 1;
	padding: 12px 16px;
	border: 1px solid rgba(0,0,0,.12);
	border-radius: 999px;
	background: #fff;
	font: inherit;
}

/* ============================================================
   2. Logo — desktop and mobile, always on white bg
   ============================================================ */
.logo-mark-img,
.nav-mobile-logo {
	display: inline-flex;
	align-items: center;
	justify-content: center;
}
.ci-logo-img {
	display: block;
	height: 80px;
	width: auto;
	max-width: 260px;
	object-fit: contain;
}
/* Desktop topbar: white background behind logo, matching mobile */
.topbar .logo.logo-flat {
	padding: 0 !important;
	gap: 0 !important;
	background: #ffffff;
	border-radius: 0;
	padding: 8px 24px 8px 0 !important;
	margin-left: -24px;
	padding-left: 24px !important;
	position: relative;
	clip-path: polygon(0 0, calc(100% - 20px) 0, 100% 100%, 0 100%);
}
.topbar .logo::after,
.logo-flat::after { display: none !important; }
.logo-text { display: none !important; }

.nav-mobile-logo { display: none; }
.nav-mobile-logo .ci-logo-img { height: 44px; max-width: 160px; }

/* ============================================================
   3. Mobile header — SPLIT design: white logo + dark nav tools
      Matching reference screenshot exactly
   ============================================================ */
@media (max-width: 900px) {
	.topbar { display: none !important; }

	.nav {
		position: relative;
		overflow: visible;
		border-bottom: 2px solid var(--c-gold, #c4a35a);
	}
	.nav .nav-inner.container-wide {
		display: flex !important;
		align-items: stretch !important;
		justify-content: space-between;
		gap: 0 !important;
		padding-left: 0 !important;
		padding-right: 0 !important;
		padding-top: 0 !important;
		padding-bottom: 0 !important;
		min-height: 68px;
		max-width: 100% !important;
	}

	/* Left: logo on white background with angled right edge */
	.nav-mobile-logo {
		display: flex !important;
		align-items: center;
		justify-content: center;
		background: #ffffff;
		padding: 6px 20px 6px 14px;
		position: relative;
		z-index: 2;
		clip-path: polygon(0 0, calc(100% - 20px) 0, 100% 100%, 0 100%);
		padding-right: 36px;
		min-width: 140px;
	}
	.nav-mobile-logo .ci-logo-img {
		height: 60px;
		max-width: 180px;
		object-fit: contain;
	}

	/* Right: dark bg, pill CTA + bordered hamburger */
	.nav-tools {
		display: flex;
		align-items: center;
		gap: 10px !important;
		margin-left: auto;
		padding: 8px 14px 8px 0;
	}
	.nav-cta {
		padding: 12px 22px !important;
		font-size: 14px !important;
		white-space: nowrap;
		border: 1.5px solid var(--c-gold, #c4a35a) !important;
		border-radius: 999px !important;
		color: #fff !important;
		background: transparent !important;
		font-weight: 600;
		letter-spacing: 0.01em;
	}
	.nav-cta:hover { background: var(--c-olive, #5e6b2e) !important; }

	.nav-toggle {
		display: inline-flex !important;
		align-items: center; justify-content: center;
		width: 48px; height: 48px;
		border: 1.5px solid var(--c-gold, #c4a35a);
		border-radius: 12px;
		background: rgba(255,255,255,.05);
		color: #fff;
		cursor: pointer;
	}
	.nav-toggle:hover { background: rgba(197,165,103,.15); }

	.nav-search { display: none !important; }
}

/* ============================================================
   4. Top bar hide on tablet
   ============================================================ */
@media (max-width: 1100px) {
	.topbar-contacts { display: none !important; }
	.topbar-social   { display: none !important; }
	.topbar-inner    { grid-template-columns: 1fr auto !important; }
}

/* ============================================================
   5. Nav menu dropdowns (WP sub-menu support)
   ============================================================ */
.nav-menu, .nav-menu ul { list-style: none; padding: 0; margin: 0; }
.nav-menu { position: relative; }
.nav-menu > li { position: relative; }
.nav-menu > li.menu-item-has-children > a::after {
	content: "";
	display: inline-block;
	width: 6px; height: 6px;
	margin-left: 8px;
	border-right: 1.5px solid currentColor;
	border-bottom: 1.5px solid currentColor;
	transform: translateY(-2px) rotate(45deg);
	opacity: .6;
	transition: transform .2s;
}
.nav-menu .sub-menu {
	position: absolute; top: 100%; left: -16px; min-width: 240px;
	background: var(--c-dark, #2a2e1f);
	border: 1px solid rgba(196, 163, 90, .25);
	border-radius: 12px; padding: 10px 0; margin-top: 6px;
	box-shadow: 0 16px 40px rgba(0,0,0,.35);
	opacity: 0; visibility: hidden; transform: translateY(6px);
	transition: opacity .18s, transform .18s, visibility .18s;
	z-index: 200;
}
.nav-menu > li:hover > .sub-menu,
.nav-menu > li:focus-within > .sub-menu {
	opacity: 1; visibility: visible; transform: translateY(0);
}
.nav-menu .sub-menu li { display: block; width: 100%; }
.nav-menu .sub-menu a {
	display: block; padding: 10px 20px;
	color: rgba(255,255,255,.82); font-size: 14px; font-weight: 500;
	white-space: nowrap; text-decoration: none;
	transition: color .15s, background .15s;
}
.nav-menu .sub-menu a:hover { color: var(--c-gold, #c4a35a); background: rgba(255,255,255,.04); }

/* ============================================================
   6. Mobile menu drawer
   ============================================================ */
.nav-toggle { display: none; }
.nav-toggle .ic-close { display: none; }
.nav-toggle.is-open .ic-open { display: none; }
.nav-toggle.is-open .ic-close { display: inline-block; }

@media (max-width: 900px) {
	.nav-menu {
		display: none; position: fixed;
		top: 64px; left: 0; right: 0; bottom: 0;
		background: var(--c-dark, #2a2e1f);
		flex-direction: column; gap: 0;
		padding: 18px 22px 32px; overflow-y: auto; z-index: 90;
		border-top: 1px solid rgba(196,163,90,.25);
	}
	.nav-menu.open { display: flex; }
	.nav-menu > li { border-bottom: 1px solid rgba(255,255,255,.06); }
	.nav-menu > li > a {
		display: flex; align-items: center; justify-content: space-between;
		padding: 16px 4px !important; font-size: 16px !important; color: #fff !important;
	}
	.nav-menu > li.menu-item-has-children > a::after { margin-left: auto; transform: rotate(45deg); }
	.nav-menu > li.submenu-open > a::after { transform: rotate(225deg); }
	.nav-menu .sub-menu {
		position: static; opacity: 1; visibility: visible; transform: none;
		background: transparent; border: 0; box-shadow: none;
		padding: 0 0 12px 14px; margin: 0; min-width: 0;
		max-height: 0; overflow: hidden; transition: max-height .25s;
	}
	.nav-menu > li.submenu-open .sub-menu { max-height: 600px; }
	.nav-menu .sub-menu a {
		padding: 10px 0 !important; color: rgba(255,255,255,.7) !important; font-size: 14px !important;
	}
	body.craften-nav-open { overflow: hidden; }
}

/* ============================================================
   7. Hero — mobile: hide hero image, side-by-side CTAs
   ============================================================ */
@media (max-width: 900px) {
	.hero-art { display: none !important; }
	.hero-inner {
		grid-template-columns: 1fr !important;
		padding-left: 18px !important; padding-right: 18px !important;
	}
	.hero { padding-block: 36px 28px !important; }
	.hero-left { padding: 0 !important; max-width: 100% !important; }
	.hero-left::before { display: none !important; }
}
@media (max-width: 760px) {
	.hero-title .outline {
		-webkit-text-stroke: 0 !important;
		color: var(--c-ink, #1f2417) !important; font-weight: 800 !important;
	}
	.hero-title {
		text-align: center !important; font-size: 36px !important;
		line-height: 1.1 !important; word-break: break-word;
	}
	.hero-tag, .hero-left .eyebrow, .hero-sub { text-align: center !important; }
	.hero-tag, .hero-left .eyebrow.boxed { display: inline-flex; }
	.hero-left { text-align: center; }

	/* CTA buttons: stay side by side, text stays inside */
	.hero-ctas {
		display: flex !important; flex-direction: row !important;
		flex-wrap: nowrap !important; gap: 8px !important;
		justify-content: center !important; align-items: stretch; width: 100%;
	}
	.hero-ctas .btn {
		flex: 1 1 0; min-width: 0;
		padding: 12px 10px !important; font-size: 12px !important;
		white-space: nowrap; text-align: center; justify-content: center;
		overflow: hidden; text-overflow: ellipsis; gap: 4px !important;
	}
	.hero-ctas .btn span[aria-hidden] { font-size: 11px; flex-shrink: 0; }
}

/* ============================================================
   8. Section titles centered on mobile
   ============================================================ */
@media (max-width: 900px) {
	.mission-content, .mission-content h2, .mission-content p,
	.mission-content .eyebrow, .mission-content .mission-text,
	.mission-copy, .mission-copy h2, .mission-copy p, .mission-copy .eyebrow,
	.why-inner > div, .why-inner h2, .why-inner p, .why-inner .eyebrow,
	.why-text, .about-text, .about-text h2, .about-text p, .about-text .eyebrow,
	.section-head, .section-head h2, .section-head p, .section-head .eyebrow,
	.services-head, .services-head h2, .services-head .eyebrow,
	.testimonials-side, .testimonials-side h2, .testimonials-side .eyebrow {
		text-align: center !important;
	}
	.mission-content .eyebrow, .mission-copy .eyebrow,
	.why-inner .eyebrow, .about-text .eyebrow,
	.section-head .eyebrow, .services-head .eyebrow,
	.testimonials-side .eyebrow {
		display: inline-flex !important; justify-content: center !important;
	}
	.mission-inner, .why-inner, .about-grid, .services-head {
		grid-template-columns: 1fr !important;
	}
	.mission-inner, .why-inner {
		display: flex !important; flex-direction: column; gap: 32px;
	}
	.services-head {
		display: flex !important; flex-direction: column; gap: 20px; align-items: center;
	}
	.services-head > div { width: 100%; }
	.mission-checks, .about-text ul, .svc-main ul.bullets, .why-features-row {
		display: inline-flex !important; flex-direction: column;
		align-items: flex-start; text-align: left; gap: 10px;
		margin-left: auto; margin-right: auto;
	}
	.mission-checks { display: inline-flex !important; }
	.mission-bottom, .about-cta-row, .svc-cta-row {
		flex-direction: column; align-items: center; gap: 16px;
	}
	.why-progress-head { justify-content: center !important; text-align: center; }
	.why-features { width: 100%; }
}

/* ============================================================
   9. Section images — display on mobile (fix About page)
   ============================================================ */
.mission-art .mission-img {
	width: 100%;
	aspect-ratio: 4 / 3;
	border-radius: var(--r-image, 40px);
	overflow: hidden;
	background-size: cover;
	background-position: center;
	box-shadow: var(--shadow-card);
}

@media (max-width: 900px) {
	.mission-art .mission-img {
		width: 100%;
		min-height: 220px;
		aspect-ratio: 4 / 3;
	}
	.why-art { width: 100%; aspect-ratio: 16 / 10; }
	.why-art img { width: 100%; height: 100%; object-fit: cover; }
}

/* ============================================================
  10. Breadcrumbs
   ============================================================ */
.breadcrumbs {
	display: inline-flex !important; flex-wrap: wrap;
	justify-content: center; gap: 6px 8px !important; font-size: 12px;
}
.breadcrumbs > * { flex: 0 0 auto !important; }
.breadcrumbs .sep { margin: 0 !important; opacity: .8; }
@media (max-width: 760px) {
	.breadcrumbs { font-size: 11px; gap: 4px 6px !important; }
	.page-header h1 { font-size: 32px !important; line-height: 1.15; }
	.page-header { padding: 40px 18px 44px !important; }
	.page-header-inner { padding: 0 !important; }
}

/* ============================================================
  11. Testimonial slider — FIX empty second card bug
   ============================================================ */
.craften-slider { position: relative; padding: 0; }
.craften-slider-viewport { overflow: hidden; }
.craften-slider-track {
	display: flex; gap: 24px;
	transition: transform .35s cubic-bezier(.45,.05,.2,1);
	will-change: transform;
	overflow: visible !important;
	scroll-snap-type: none !important;
}
.craften-slider-track > * { flex: 0 0 calc((100% - 24px) / 2); min-width: 0; }
@media (max-width: 900px) {
	.craften-slider-track { gap: 0; }
	.craften-slider-track > * { flex: 0 0 100% !important; }
}

.testimonial-track-wrap { overflow: hidden; width: 100%; max-width: 100%; }
.testimonial-track {
	display: flex !important;
	grid-template-columns: none !important;
	grid-auto-flow: unset !important;
	grid-auto-columns: unset !important;
	overflow: visible !important;
	overflow-x: visible !important;
	scroll-snap-type: none !important;
	-webkit-overflow-scrolling: auto !important;
	scrollbar-width: none !important;
	gap: 24px;
	transition: transform .35s cubic-bezier(.45,.05,.2,1);
	will-change: transform;
}
.testimonial-track > .testimonial-card {
	flex: 0 0 calc(50% - 12px);
	min-width: 0; max-width: calc(50% - 12px);
	box-sizing: border-box;
}

@media (max-width: 900px) {
	.testimonial-track {
		gap: 0 !important;
		overflow: visible !important;
		overflow-x: visible !important;
		scroll-snap-type: none !important;
	}
	.testimonial-track > .testimonial-card {
		flex: 0 0 100% !important;
		min-width: 0; max-width: 100% !important;
		width: 100%; box-sizing: border-box;
		scroll-snap-align: none !important;
	}
}

.testimonial-dots { display: flex; justify-content: center; gap: 8px; margin-top: 18px; }
@media (min-width: 900px) { .testimonial-dots { display: none !important; } }

.craften-slider-controls {
	display: flex; align-items: center; justify-content: center; gap: 18px; margin-top: 28px;
}
.craften-slider-prev, .craften-slider-next {
	width: 44px; height: 44px; border-radius: 50%;
	border: 1.5px solid var(--c-gold, #c4a35a);
	background: transparent; color: var(--c-gold, #c4a35a);
	cursor: pointer; display: inline-flex; align-items: center; justify-content: center;
	transition: background .2s, color .2s;
}
.craften-slider-prev:hover, .craften-slider-next:hover {
	background: var(--c-gold, #c4a35a); color: #fff;
}
.craften-slider-dots { display: inline-flex; gap: 8px; }
.craften-slider-dot {
	width: 8px; height: 8px; border-radius: 50%;
	border: 0; padding: 0; background: rgba(196,163,90,.35); cursor: pointer; transition: all .2s;
}
.craften-slider-dot.is-active { background: var(--c-gold, #c4a35a); width: 24px; border-radius: 4px; }

.testimonial-card .head img, .review-card .head img {
	width: 56px !important; height: 56px !important;
	flex: 0 0 56px; border-radius: 50%; object-fit: cover;
}
.testimonial-card .head, .review-card .head {
	display: flex; gap: 12px; align-items: center; flex-wrap: nowrap;
}

/* ============================================================
  12. Hero images
   ============================================================ */
.hero-art .img-back img,
.hero-art .img-front img {
	width: 100%; height: 100%; object-fit: cover; display: block;
}

/* ============================================================
  13. Footer
   ============================================================ */
.footer-grid > .footer-card,
.footer-grid > .footer-services {
	border: 1px solid rgba(196, 163, 90, .35);
	border-radius: 18px; padding: 28px 26px;
	background: rgba(255,255,255,.015);
}
.footer-card p { color: var(--c-text-soft, #cfc8b5); font-size: 14px; line-height: 1.7; margin-bottom: 18px; }
@media (max-width: 900px) {
	.footer-grid { grid-template-columns: 1fr !important; gap: 18px !important; }
	.footer-grid > .footer-card { padding: 22px 20px; }
}

/* ============================================================
  14. Service detail mobile
   ============================================================ */
@media (max-width: 760px) {
	.svc-side { gap: 14px; }
	.svc-side > * { width: 100%; }
}

/* ============================================================
  15. Universal mobile: prevent horizontal scroll
   ============================================================ */
@media (max-width: 900px) {
	html, body { overflow-x: hidden; max-width: 100%; }
	.container, .container-wide {
		padding-left: 18px !important; padding-right: 18px !important;
		max-width: 100% !important; box-sizing: border-box;
	}
	/* Nav header must have zero padding for the split design — 
	   MUST use longhand to beat the universal .container-wide longhand */
	.nav .container-wide.nav-inner {
		padding-left: 0 !important;
		padding-right: 0 !important;
		padding-top: 0 !important;
		padding-bottom: 0 !important;
		margin: 0 !important;
		max-width: 100% !important;
	}
	section, .section, .cta-row, .cta-row-inner { max-width: 100%; box-sizing: border-box; }
	.cta-row-inner {
		grid-template-columns: 1fr !important;
		display: flex !important; flex-direction: column; gap: 28px !important;
		padding-left: 18px !important; padding-right: 18px !important;
		max-width: 100% !important;
	}
	.contact-form-card, .testimonials-side {
		width: 100% !important; max-width: 100% !important;
		box-sizing: border-box; margin: 0 !important;
	}
	.contact-form-card {
		padding: 26px 22px !important; border-radius: 22px !important;
	}
	.contact-form-card .form-grid {
		grid-template-columns: 1fr !important; gap: 14px !important;
	}
	.contact-form-card input,
	.contact-form-card select,
	.contact-form-card textarea {
		width: 100% !important; max-width: 100% !important; box-sizing: border-box;
	}
}

/* ============================================================
  16. Video embed responsive + media uploader admin styling
   ============================================================ */
.craften-video-embed {
	position: relative; width: 100%; padding-bottom: 56.25%;
	height: 0; overflow: hidden; border-radius: var(--r-card, 26px); margin-block: 24px;
}
.craften-video-embed iframe,
.craften-video-embed video {
	position: absolute; top: 0; left: 0;
	width: 100%; height: 100%; border: 0;
	border-radius: var(--r-card, 26px);
}

/* ============================================================
  17. Video Showcase section — dark bg, side-by-side on desktop
   ============================================================ */
.video-showcase {
	background: var(--c-dark, #2a2c1f);
	color: #fff;
	position: relative;
	overflow: hidden;
}
.video-showcase-pattern {
	position: absolute; inset: 0;
	background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='400' height='400' viewBox='0 0 400 400'><g fill='none' stroke='%23c5a567' stroke-width='0.5' opacity='0.12'><path d='M200 80 C 120 80, 80 140, 100 200 C 80 260, 120 320, 200 320 C 280 320, 320 260, 300 200 C 320 140, 280 80, 200 80 Z'/></g></svg>");
	background-size: 320px 320px;
	pointer-events: none;
}
.video-showcase-inner {
	display: grid;
	grid-template-columns: 1fr 1.2fr;
	gap: 60px;
	align-items: center;
	position: relative;
	z-index: 2;
}
.video-showcase-text h2 { color: #fff; margin-bottom: 18px; }
.video-showcase-text p {
	color: var(--c-muted-on-dark, #b9bca6);
	font-size: 16px; line-height: 1.7;
	margin-bottom: 28px;
	max-width: 480px;
}
.video-showcase-player .craften-video-embed {
	border: 1.5px solid var(--c-gold, #c4a35a);
	border-radius: var(--r-card, 26px);
	box-shadow: 0 30px 60px -20px rgba(0,0,0,.4);
	margin: 0;
}
@media (max-width: 900px) {
	.video-showcase-inner {
		grid-template-columns: 1fr !important;
		gap: 28px;
		text-align: center;
	}
	.video-showcase-text p { margin-inline: auto; }
	.video-showcase-text .btn { margin-inline: auto; }
}

/* ============================================================
  18. Gallery — horizontal carousel slider with lightbox
   ============================================================ */
.gallery-showcase {
	background: var(--c-cream, #efe9dc);
	position: relative;
	overflow: hidden;
}
.gallery-head {
	display: flex;
	justify-content: space-between;
	align-items: end;
	gap: 40px;
	margin-bottom: 40px;
}
.gallery-nav { display: flex; gap: 12px; }
.gallery-nav button {
	width: 56px; height: 56px;
	border-radius: var(--r-pill, 999px);
	background: #fff;
	border: 1.5px solid var(--c-gold, #c4a35a);
	color: var(--c-ink, #1f221a);
	display: grid; place-items: center;
	cursor: pointer;
	transition: background .2s, color .2s;
}
.gallery-nav button:hover { background: var(--c-olive, #5e6b2e); color: #fff; }

.gallery-track-wrap {
	overflow: hidden;
	position: relative;
	margin-inline: calc(var(--gutter, 24px) * -1);
	padding-inline: var(--gutter, 24px);
}
.gallery-track {
	display: flex;
	gap: 20px;
	transition: transform .4s cubic-bezier(.45,.05,.2,1);
	will-change: transform;
	overflow: visible !important;
	scroll-snap-type: none !important;
}
.gallery-card {
	flex: 0 0 320px;
	position: relative;
	border-radius: var(--r-card, 26px);
	overflow: hidden;
	aspect-ratio: 4 / 5;
	background: var(--c-cream-2, #e6dec9);
	cursor: pointer;
	border: 1px solid rgba(197,165,103,.3);
	text-decoration: none;
	scroll-snap-align: start;
}
.gallery-card img {
	width: 100%; height: 100%;
	object-fit: cover;
	transition: transform .4s ease, filter .4s ease;
}
.gallery-card:hover img {
	transform: scale(1.06);
	filter: brightness(.82);
}
.gallery-zoom {
	position: absolute;
	top: 50%; left: 50%;
	transform: translate(-50%, -50%) scale(0);
	width: 52px; height: 52px;
	background: var(--c-olive, #5e6b2e);
	border: 1.5px solid var(--c-gold, #c4a35a);
	border-radius: 50%;
	display: grid; place-items: center;
	color: #fff;
	transition: transform .3s ease;
	z-index: 2;
}
.gallery-card:hover .gallery-zoom {
	transform: translate(-50%, -50%) scale(1);
}
@media (max-width: 900px) {
	.gallery-card { flex: 0 0 280px; }
	.gallery-head { flex-direction: column; align-items: flex-start; gap: 20px; }
}

/* Lightbox */
.craften-lightbox {
	position: fixed;
	inset: 0;
	background: rgba(20,22,14,.92);
	z-index: 9999;
	display: none;
	align-items: center;
	justify-content: center;
	padding: 40px;
}
.craften-lightbox.is-open {
	display: flex;
}
.craften-lightbox .lightbox-img {
	max-width: 90vw;
	max-height: 85vh;
	border-radius: 16px;
	box-shadow: 0 40px 80px -30px rgba(0,0,0,.6);
	border: 2px solid var(--c-gold, #c4a35a);
	object-fit: contain;
}
.lightbox-close {
	position: absolute;
	top: 20px; right: 24px;
	width: 48px; height: 48px;
	background: var(--c-olive, #5e6b2e);
	border: 1.5px solid var(--c-gold, #c4a35a);
	border-radius: 50%;
	color: #fff;
	font-size: 24px;
	display: grid; place-items: center;
	cursor: pointer;
	z-index: 10;
	transition: background .2s;
}
.lightbox-close:hover { background: var(--c-olive-700, #3e4a1f); }
.lightbox-prev,
.lightbox-next {
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	width: 48px; height: 48px;
	background: rgba(255,255,255,.1);
	border: 1.5px solid var(--c-gold, #c4a35a);
	border-radius: 50%;
	color: #fff;
	display: grid; place-items: center;
	cursor: pointer;
	transition: background .2s;
	z-index: 10;
}
.lightbox-prev { left: 20px; }
.lightbox-next { right: 20px; }
.lightbox-prev:hover,
.lightbox-next:hover { background: var(--c-olive, #5e6b2e); }

/* ============================================================
  19. Mission art — "Years of Experience" mobile redesign
      Overlay badge on the image instead of detached bar
   ============================================================ */
@media (max-width: 900px) {
	.mission-art {
		position: relative !important;
		height: auto !important;
		min-height: auto !important;
	}
	.mission-art .main-img {
		position: relative !important;
		inset: unset !important;
		width: 100%;
		aspect-ratio: 4 / 3;
		border-radius: var(--r-image, 40px);
		overflow: hidden;
	}
	/* Years pill: overlay on bottom-left of image */
	.mission-art .years-pill {
		position: absolute !important;
		left: 16px !important;
		bottom: 16px !important;
		right: auto !important;
		top: auto !important;
		width: auto !important;
		height: auto !important;
		padding: 14px 20px;
		border-radius: 16px;
		margin-top: 0;
		display: flex;
		align-items: center;
		gap: 12px;
		font-size: 14px;
		z-index: 4;
		backdrop-filter: blur(8px);
		-webkit-backdrop-filter: blur(8px);
		background: rgba(94,107,46,.9);
	}
	.mission-art .years-pill span {
		writing-mode: horizontal-tb !important;
		transform: none !important;
		font-size: 13px;
	}
	/* Years number: overlay badge on bottom-right of image */
	.mission-art .years-num {
		position: absolute !important;
		right: 16px !important;
		bottom: 16px !important;
		left: auto !important;
		top: auto !important;
		transform: none !important;
		width: 64px !important;
		height: 64px !important;
		font-size: 22px !important;
		flex-shrink: 0;
		border: 2px solid var(--c-gold, #c4a35a);
		z-index: 4;
		box-shadow: 0 8px 20px rgba(0,0,0,.2);
	}
}
