/**
 * WrapNova Custom Styles
 * Minimal CSS — design tokens live in theme.json.
 */

/* =========================================================================
   Hero Video Cover — full-height layout with nav at top, content centered
   ========================================================================= */

.wrapnova-hero-video {
	position: relative;
	padding: 0 !important;
	margin: 0 !important;
}

.wrapnova-hero-video > .wp-block-cover__inner-container {
	display: flex;
	flex-direction: column;
	min-height: 100vh;
	max-width: 100% !important;
	width: 100%;
	padding: 0;
}

.wrapnova-hero-video .wrapnova-announcement {
	flex-shrink: 0;
	width: 100%;
}

.wrapnova-hero-video .wrapnova-nav-bar {
	flex-shrink: 0;
	width: 100%;
}

.wrapnova-hero-video .wrapnova-hero-content {
	flex: 1;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
}

/* Hero H1 — styled to match the original paragraph */
.wrapnova-hero-h1 {
	font-family: 'Lato', sans-serif;
	font-weight: 400;
	line-height: 1.6;
}

/* =========================================================================
   Announcement Bar — flush full-width, no gaps
   ========================================================================= */

.wrapnova-announcement {
	z-index: 10;
	margin: 0 !important;
	border-radius: 0 !important;
}

.wrapnova-announcement p {
	margin: 0;
}

/* =========================================================================
   Navigation Bar — 20% black opacity bg, three-column: links | logo | button
   ========================================================================= */

.wrapnova-nav-bar {
	background: rgba(0, 0, 0, 0.2) !important;
	margin-top: 0 !important;
	overflow: visible !important;
}

.wrapnova-nav-bar .wp-block-group,
.wrapnova-nav-bar .wp-block-columns,
.wrapnova-nav-bar .wp-block-column,
.wrapnova-nav-bar .wp-block-navigation {
	overflow: visible !important;
}

.wrapnova-nav-inner {
	align-items: center;
	min-width: 100%;
	overflow: visible !important;
}

.wrapnova-nav-inner > * {
	flex: 1;
}

.wrapnova-nav-inner > *:nth-child(2) {
	display: flex;
	justify-content: center;
	flex: 0 0 auto;
}

.wrapnova-nav-inner > *:last-child {
	display: flex;
	justify-content: flex-end;
}

/* Nav link sizing & colour */
.wrapnova-nav-inner .wp-block-navigation .wp-block-navigation-item a {
	font-size: var(--wp--preset--font-size--medium);
	padding: 0.5em 0.75em;
	color: #fff !important;
}

.wrapnova-nav-inner .wp-block-navigation .wp-block-navigation-item a:hover {
	color: var(--wp--preset--color--secondary) !important;
}

/* Nav logo */
.wrapnova-nav-logo {
	display: flex;
	align-items: center;
	justify-content: center;
	line-height: 0;
}

.wrapnova-nav-logo img {
	width: 100px;
	height: auto;
}

/* Ensure site-logo block also centers in nav */
.wrapnova-nav-inner .wp-block-site-logo {
	margin: 0;
}

/* =========================================================================
   Current Page / Active Menu Item
   ========================================================================= */

.wrapnova-nav-inner .wp-block-navigation-item.current-menu-item > a,
.wrapnova-nav-inner .wp-block-navigation-item.current_page_item > a,
.wrapnova-nav-inner .wp-block-navigation-item a[aria-current="page"] {
	text-decoration: underline;
	text-underline-offset: 6px;
	text-decoration-thickness: 2px;
	text-decoration-color: var(--wp--preset--color--secondary);
	color: var(--wp--preset--color--secondary) !important;
}

/* =========================================================================
   Dropdown / Submenu Styles
   ========================================================================= */

/* Ensure submenu containers are visible on hover */
.wrapnova-nav-inner .wp-block-navigation-item {
	position: relative;
}

.wrapnova-nav-inner .wp-block-navigation__submenu-container,
.wrapnova-nav-inner .wp-block-navigation-submenu .wp-block-navigation__submenu-container,
.wrapnova-nav-inner .wp-block-navigation-item > .wp-block-navigation__submenu-container,
.wp-block-navigation .wp-block-navigation__submenu-container {
	display: none;
	position: absolute !important;
	top: 100% !important;
	left: 0 !important;
	z-index: 100;
	background: rgba(0, 0, 0, 0.2) !important;
	background-color: rgba(0, 0, 0, 0.2) !important;
	backdrop-filter: blur(12px);
	-webkit-backdrop-filter: blur(12px);
	border: 1px solid rgba(255, 255, 255, 0.1) !important;
	border-radius: 6px;
	padding: 0.5em 0;
	min-width: 220px;
	margin-top: 0 !important;
	box-shadow: 0 8px 24px rgba(0, 0, 0, 0.4);
	flex-direction: column;
	width: max-content;
}

/* Show submenu on hover or click */
.wrapnova-nav-inner .wp-block-navigation-item:hover > .wp-block-navigation__submenu-container,
.wrapnova-nav-inner .wp-block-navigation-item:focus-within > .wp-block-navigation__submenu-container,
.wrapnova-nav-inner .wp-block-navigation-item.has-child.is-menu-open > .wp-block-navigation__submenu-container,
.wrapnova-nav-inner .wp-block-navigation-item[aria-expanded="true"] > .wp-block-navigation__submenu-container {
	display: flex !important;
	position: absolute !important;
	top: 100% !important;
	left: 0 !important;
}

/* Submenu items */
.wrapnova-nav-inner .wp-block-navigation__submenu-container .wp-block-navigation-item {
	width: 100%;
}

.wrapnova-nav-inner .wp-block-navigation__submenu-container .wp-block-navigation-item a {
	display: block;
	width: 100%;
	font-size: var(--wp--preset--font-size--small);
	padding: 0.6em 1.2em;
	color: var(--wp--preset--color--heading);
	text-decoration: none;
	transition: color 0.2s ease, background 0.2s ease;
	white-space: nowrap;
}

.wrapnova-nav-inner .wp-block-navigation__submenu-container .wp-block-navigation-item a:hover {
	color: var(--wp--preset--color--secondary);
	background: rgba(255, 255, 255, 0.05);
}

/* Active item in submenu */
.wrapnova-nav-inner .wp-block-navigation__submenu-container .current-menu-item > a,
.wrapnova-nav-inner .wp-block-navigation__submenu-container a[aria-current="page"] {
	color: var(--wp--preset--color--secondary) !important;
}

/* Submenu chevron icon */
.wrapnova-nav-inner .wp-block-navigation__submenu-icon {
	fill: var(--wp--preset--color--heading);
	width: 10px;
	height: 10px;
}

.wrapnova-nav-inner .wp-block-navigation-item:hover > .wp-block-navigation__submenu-icon {
	fill: var(--wp--preset--color--secondary);
}

/* Nested submenus (second level+) open to the right */
.wrapnova-nav-inner .wp-block-navigation__submenu-container .wp-block-navigation__submenu-container {
	top: 0 !important;
	left: 100%;
	margin-top: 0;
	margin-left: 0;
}

/* =========================================================================
   Hero Logo
   ========================================================================= */

.wrapnova-hero-logo {
	width: 100%;
	height: 80px;
	margin-left: auto;
	margin-right: auto;
}

.wrapnova-hero-logo img {
	width: 100%;
	height: 100%;
	object-fit: contain;
}

/* =========================================================================
   Satisfied Customers — Google Reviews
   ========================================================================= */

.wrapnova-reviews-title {
	font-family: 'Michroma', sans-serif;
}

/* Summary badge */
.wrapnova-reviews-summary {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 0.75em;
	margin-bottom: var(--wp--preset--spacing--50);
}

.wrapnova-reviews-google-badge {
	display: flex;
	align-items: center;
	gap: 0.5em;
}

.wrapnova-reviews-rating-text {
	color: var(--wp--preset--color--heading);
	font-size: var(--wp--preset--font-size--medium);
	font-weight: 600;
}

.wrapnova-reviews-stars {
	display: flex;
	align-items: center;
	gap: 0.4em;
}

.wrapnova-reviews-score {
	color: #FBBC04;
	font-size: var(--wp--preset--font-size--x-large);
	font-weight: 700;
	margin-right: 0.15em;
}

.wrapnova-reviews-count {
	color: var(--wp--preset--color--muted);
	font-size: var(--wp--preset--font-size--small);
	margin-left: 0.5em;
	text-decoration: underline;
	text-underline-offset: 3px;
	transition: color 0.2s ease;
}

.wrapnova-reviews-count:hover {
	color: var(--wp--preset--color--secondary);
}

/* Reviews grid */
.wrapnova-reviews-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: var(--wp--preset--spacing--30);
	max-width: 1200px;
	margin: 0 auto;
}

/* Individual card */
.wrapnova-review-card {
	background: rgba(255, 255, 255, 0.03);
	border: 1px solid rgba(255, 255, 255, 0.08);
	border-radius: 10px;
	padding: var(--wp--preset--spacing--40);
	transition: border-color 0.2s ease;
}

.wrapnova-review-card:hover {
	border-color: rgba(18, 239, 255, 0.2);
}

.wrapnova-review-header {
	display: flex;
	align-items: center;
	gap: 0.75em;
	margin-bottom: 0.75em;
}

.wrapnova-review-avatar {
	width: 40px;
	height: 40px;
	border-radius: 50%;
	background: var(--wp--preset--color--secondary);
	color: var(--wp--preset--color--black);
	display: flex;
	align-items: center;
	justify-content: center;
	font-weight: 700;
	font-size: 16px;
	flex-shrink: 0;
}

.wrapnova-review-meta {
	display: flex;
	flex-direction: column;
}

.wrapnova-review-name {
	color: var(--wp--preset--color--heading);
	font-weight: 600;
	font-size: var(--wp--preset--font-size--small);
}

.wrapnova-review-date {
	color: var(--wp--preset--color--muted);
	font-size: 12px;
}

.wrapnova-review-stars {
	display: flex;
	gap: 2px;
	margin-bottom: 0.75em;
}

.wrapnova-review-text {
	color: var(--wp--preset--color--copy);
	font-size: var(--wp--preset--font-size--small);
	line-height: 1.6;
	margin: 0;
}

/* Read More Reviews button */
.wrapnova-reviews-cta {
	text-align: center;
	margin-top: var(--wp--preset--spacing--50);
}

.wrapnova-reviews-button {
	display: inline-block;
	padding: 0.85em 2.5em;
	border: 2px solid var(--wp--preset--color--secondary);
	border-radius: 6px;
	color: var(--wp--preset--color--secondary);
	font-size: var(--wp--preset--font-size--medium);
	font-weight: 600;
	text-decoration: none;
	transition: background 0.2s ease, color 0.2s ease;
}

.wrapnova-reviews-button:hover {
	background: var(--wp--preset--color--secondary);
	color: var(--wp--preset--color--black);
}

/* =========================================================================
   Our Popular Services
   ========================================================================= */

/* =========================================================================
   YouTube Section
   ========================================================================= */

.wrapnova-youtube-title {
	font-family: 'Michroma', sans-serif;
}

.wrapnova-youtube-embed {
	position: relative;
	width: 100%;
	padding-bottom: 28.125%;
	border-radius: 10px;
	overflow: hidden;
}

@media (max-width: 768px) {
	.wrapnova-youtube-embed {
		padding-bottom: 56.25%;
	}
}

.wrapnova-youtube-embed iframe {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
}

.wrapnova-youtube-channel-link {
	display: inline-block;
	padding: 0.75em 2em;
	border: 2px solid var(--wp--preset--color--secondary);
	border-radius: 6px;
	color: var(--wp--preset--color--secondary) !important;
	font-weight: 600;
	text-decoration: none !important;
	transition: background 0.2s ease, color 0.2s ease;
}

.wrapnova-youtube-channel-link:hover {
	background: var(--wp--preset--color--secondary);
	color: var(--wp--preset--color--black) !important;
}

/* =========================================================================
   Contact Page
   ========================================================================= */

.wrapnova-contact-title {
	font-family: 'Michroma', sans-serif;
	color: var(--wp--preset--color--heading);
}

.wrapnova-contact-page .wrapnova-contact-form {
	max-width: 100%;
}

.wrapnova-contact-page .wrapnova-form-field input,
.wrapnova-contact-page .wrapnova-form-field textarea,
.wrapnova-contact-page .wrapnova-form-submit button {
	width: 100%;
	box-sizing: border-box;
}

/* Opening hours */
.wrapnova-hours {
	margin: 0;
	padding: 0;
}

.wrapnova-hours-row {
	display: flex;
	justify-content: space-between;
	padding: 0.6em 0;
	border-bottom: 1px solid rgba(255, 255, 255, 0.06);
}

.wrapnova-hours-row:last-child {
	border-bottom: none;
}

.wrapnova-hours dt {
	color: var(--wp--preset--color--heading);
	font-weight: 600;
	font-size: var(--wp--preset--font-size--small);
}

.wrapnova-hours dd {
	color: var(--wp--preset--color--copy);
	margin: 0;
	font-size: var(--wp--preset--font-size--small);
}

/* =========================================================================
   Service Page Hero
   ========================================================================= */

.wrapnova-service-hero {
	display: flex;
	align-items: center;
	justify-content: center;
}

.wrapnova-service-hero-title {
	font-family: 'Michroma', sans-serif;
}

/* =========================================================================
   Features List
   ========================================================================= */

.wrapnova-features-list {
	list-style: none;
	padding: 0;
	margin: 0;
	display: flex;
	flex-direction: column;
	gap: var(--wp--preset--spacing--20);
}

.wrapnova-features-list li {
	color: var(--wp--preset--color--copy);
	font-size: var(--wp--preset--font-size--medium);
	line-height: 1.6;
	padding-left: 1.5em;
	position: relative;
}

.wrapnova-features-list li::before {
	content: '';
	position: absolute;
	left: 0;
	top: 0.5em;
	width: 8px;
	height: 8px;
	background: var(--wp--preset--color--secondary);
	border-radius: 50%;
}

.wrapnova-features-list li strong {
	color: var(--wp--preset--color--heading);
}

/* =========================================================================
   Pricelist
   ========================================================================= */

.wrapnova-pricelist {
	background: var(--wp--preset--color--black);
	padding: var(--wp--preset--spacing--70) var(--wp--preset--spacing--40);
	border-top: 1px solid var(--wp--preset--color--light);
}

.wrapnova-pricelist-inner {
	max-width: 1200px;
	margin: 0 auto;
}

.wrapnova-pricelist-title {
	font-family: 'Michroma', sans-serif;
	font-size: var(--wp--preset--font-size--xx-large);
	color: var(--wp--preset--color--heading);
	text-align: center;
	margin: 0 0 var(--wp--preset--spacing--60) 0;
}

.wrapnova-pricelist-category {
	margin-bottom: var(--wp--preset--spacing--60);
}

.wrapnova-pricelist-category:last-child {
	margin-bottom: 0;
}

.wrapnova-pricelist-cat-title {
	font-family: 'Michroma', sans-serif;
	font-size: var(--wp--preset--font-size--x-large);
	color: var(--wp--preset--color--secondary);
	text-align: center;
	margin: 0 0 var(--wp--preset--spacing--20) 0;
}

.wrapnova-pricelist-note {
	text-align: center;
	color: var(--wp--preset--color--muted);
	font-size: var(--wp--preset--font-size--small);
	max-width: 650px;
	margin: 0 auto var(--wp--preset--spacing--40) auto;
	line-height: 1.6;
}

.wrapnova-pricelist-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: var(--wp--preset--spacing--30);
}

.wrapnova-price-card {
	display: flex;
	flex-direction: column;
	align-items: center;
	text-align: center;
	background: rgba(255, 255, 255, 0.03);
	border: 1px solid rgba(255, 255, 255, 0.08);
	border-radius: 10px;
	padding: var(--wp--preset--spacing--50) var(--wp--preset--spacing--30);
	transition: border-color 0.2s ease;
}

.wrapnova-price-card:hover {
	border-color: rgba(18, 239, 255, 0.25);
}

.wrapnova-price-label {
	font-family: 'Michroma', sans-serif;
	font-size: var(--wp--preset--font-size--medium);
	color: var(--wp--preset--color--heading);
	font-weight: 600;
	margin-bottom: var(--wp--preset--spacing--20);
}

.wrapnova-price-amount {
	font-family: 'Michroma', sans-serif;
	font-size: var(--wp--preset--font-size--xx-large);
	color: var(--wp--preset--color--secondary);
	font-weight: 700;
	margin-bottom: var(--wp--preset--spacing--20);
}

.wrapnova-price-example {
	color: var(--wp--preset--color--muted);
	font-size: var(--wp--preset--font-size--small);
}

/* Quote form field widths */
.wrapnova-contact-form .wrapnova-form-field input,
.wrapnova-contact-form .wrapnova-form-field textarea,
.wrapnova-contact-form .wrapnova-form-submit button {
	width: 100%;
	box-sizing: border-box;
}

/* Quote contact section */
.wrapnova-quote-contact {
	margin-top: var(--wp--preset--spacing--50);
	text-align: center;
}

.wrapnova-whatsapp-link {
	display: inline-flex;
	align-items: center;
	gap: 0.5em;
	padding: 0.75em 2em;
	background: #25D366;
	color: #000;
	border-radius: 6px;
	font-weight: 600;
	font-size: var(--wp--preset--font-size--medium);
	text-decoration: none;
	transition: background 0.2s ease;
}

.wrapnova-whatsapp-link:hover {
	background: #1fb855;
	color: #000;
}

.wrapnova-whatsapp-link svg {
	flex-shrink: 0;
}

.wrapnova-quote-details {
	margin-top: var(--wp--preset--spacing--40);
}

.wrapnova-quote-brand {
	font-family: 'Michroma', sans-serif;
	font-size: var(--wp--preset--font-size--large);
	color: var(--wp--preset--color--heading);
	margin: 0 0 var(--wp--preset--spacing--10) 0;
}

.wrapnova-quote-address {
	color: var(--wp--preset--color--copy);
	font-size: var(--wp--preset--font-size--small);
	margin: 0 0 var(--wp--preset--spacing--10) 0;
}

.wrapnova-quote-phone {
	margin: 0;
}

.wrapnova-quote-phone a {
	color: var(--wp--preset--color--secondary);
	font-size: var(--wp--preset--font-size--large);
	font-weight: 700;
	text-decoration: none;
}

.wrapnova-quote-phone a:hover {
	text-decoration: underline;
}

.wrapnova-pricelist-grid--single {
	grid-template-columns: 1fr;
	max-width: 400px;
	margin-left: auto;
	margin-right: auto;
}

.wrapnova-pricelist-grid--centered {
	grid-template-columns: repeat(2, 1fr);
	max-width: 700px;
	margin-left: auto;
	margin-right: auto;
}

@media (max-width: 768px) {
	.wrapnova-pricelist-grid,
	.wrapnova-pricelist-grid--centered {
		grid-template-columns: 1fr;
	}
}

/* =========================================================================
   Project Slider
   ========================================================================= */

.wrapnova-project-slider-section {
	background: var(--wp--preset--color--black);
	padding: var(--wp--preset--spacing--70) var(--wp--preset--spacing--40);
	border-top: 1px solid var(--wp--preset--color--light);
}

.wrapnova-project-slider-inner {
	max-width: 1200px;
	margin: 0 auto;
}

.wrapnova-project-slider-title {
	font-family: 'Michroma', sans-serif;
	font-size: var(--wp--preset--font-size--xx-large);
	color: var(--wp--preset--color--heading);
	text-align: center;
	margin: 0 0 var(--wp--preset--spacing--50) 0;
}

.wrapnova-slider {
	position: relative;
	overflow: hidden;
	border-radius: 10px;
}

.wrapnova-slider-track {
	display: flex;
	transition: transform 0.4s ease;
}

.wrapnova-slide {
	min-width: 100%;
	flex-shrink: 0;
}

.wrapnova-slide img {
	width: 100%;
	height: 750px;
	display: block;
	object-fit: cover;
}

@media (max-width: 768px) {
	.wrapnova-slide img {
		height: 300px;
	}
}

.wrapnova-slider-btn {
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	background: rgba(0, 0, 0, 0.5);
	border: none;
	color: #fff;
	font-size: 2.5rem;
	cursor: pointer;
	z-index: 5;
	padding: 0.25rem 0.75rem;
	line-height: 1;
	border-radius: 6px;
	transition: background 0.2s ease, color 0.2s ease;
}

.wrapnova-slider-btn:hover {
	background: var(--wp--preset--color--secondary);
	color: var(--wp--preset--color--black);
}

.wrapnova-slider-prev { left: 1rem; }
.wrapnova-slider-next { right: 1rem; }

.wrapnova-slider-dots {
	display: flex;
	justify-content: center;
	gap: 8px;
	padding: var(--wp--preset--spacing--30) 0 0;
}

.wrapnova-slider-dot {
	width: 10px;
	height: 10px;
	border-radius: 50%;
	background: rgba(255, 255, 255, 0.2);
	border: none;
	cursor: pointer;
	padding: 0;
	transition: background 0.2s ease;
}

.wrapnova-slider-dot.is-active {
	background: var(--wp--preset--color--secondary);
}

/* =========================================================================
   Get in Touch
   ========================================================================= */

.wrapnova-git-title {
	font-family: 'Michroma', sans-serif;
	color: var(--wp--preset--color--heading);
	white-space: nowrap;
}

.wrapnova-get-in-touch .wp-block-button__link {
	border: none !important;
}

/* =========================================================================
   Google Map
   ========================================================================= */

.wrapnova-map {
	width: 100%;
	line-height: 0;
	margin: 0;
}

.wrapnova-map iframe {
	width: 100%;
	height: 450px;
	display: block;
}

/* =========================================================================
   Why Choose Us
   ========================================================================= */

.wrapnova-why-title {
	font-family: 'Michroma', sans-serif;
}

/* =========================================================================
   Latest Posts
   ========================================================================= */

.wrapnova-latest-posts-title {
	font-family: 'Michroma', sans-serif;
	color: var(--wp--preset--color--heading);
}

.wrapnova-latest-posts .wp-block-post-featured-image,
.wp-block-query .wp-block-post-featured-image {
	overflow: hidden;
	border-radius: 8px;
}

.wrapnova-latest-posts .wp-block-post-featured-image img,
.wp-block-query .wp-block-post-featured-image img {
	transition: transform 0.3s ease;
}

.wrapnova-latest-posts .wp-block-post-featured-image:hover img,
.wp-block-query .wp-block-post-featured-image:hover img {
	transform: scale(1.05);
}

/* =========================================================================
   Image Gallery
   ========================================================================= */

.wrapnova-gallery-title {
	font-family: 'Michroma', sans-serif;
}

.wrapnova-gallery-grid {
	display: grid;
	grid-template-columns: repeat(5, 1fr);
	gap: 6px;
	max-width: 1200px;
	margin: 0 auto;
}

.wrapnova-gallery-item {
	position: relative;
	display: block;
	overflow: hidden;
	border-radius: 6px;
	aspect-ratio: 1 / 1;
	cursor: pointer;
}

.wrapnova-gallery-item img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: transform 0.3s ease;
}

.wrapnova-gallery-item:hover img {
	transform: scale(1.05);
}

.wrapnova-gallery-overlay {
	position: absolute;
	inset: 0;
	display: flex;
	align-items: center;
	justify-content: center;
	background: rgba(0, 0, 0, 0.4);
	color: #fff;
	opacity: 0;
	transition: opacity 0.3s ease;
}

.wrapnova-gallery-item:hover .wrapnova-gallery-overlay {
	opacity: 1;
}

/* Lightbox */
.wrapnova-lightbox {
	display: none;
	position: fixed;
	inset: 0;
	z-index: 9999;
	background: rgba(0, 0, 0, 0.95);
	align-items: center;
	justify-content: center;
}

.wrapnova-lightbox.is-active {
	display: flex;
}

.wrapnova-lightbox-content {
	max-width: 90vw;
	max-height: 90vh;
	display: flex;
	align-items: center;
	justify-content: center;
}

.wrapnova-lightbox-content img {
	max-width: 100%;
	max-height: 90vh;
	object-fit: contain;
	border-radius: 6px;
}

.wrapnova-lightbox-close {
	position: absolute;
	top: 1rem;
	right: 1.5rem;
	background: none;
	border: none;
	color: #fff;
	font-size: 2.5rem;
	cursor: pointer;
	z-index: 10;
	line-height: 1;
	transition: color 0.2s ease;
}

.wrapnova-lightbox-close:hover {
	color: var(--wp--preset--color--secondary);
}

.wrapnova-lightbox-prev,
.wrapnova-lightbox-next {
	position: absolute;
	top: 50%;
	transform: translateY(-50%);
	background: none;
	border: none;
	color: #fff;
	font-size: 3rem;
	cursor: pointer;
	z-index: 10;
	padding: 0.5rem;
	line-height: 1;
	transition: color 0.2s ease;
}

.wrapnova-lightbox-prev { left: 1rem; }
.wrapnova-lightbox-next { right: 1rem; }

.wrapnova-lightbox-prev:hover,
.wrapnova-lightbox-next:hover {
	color: var(--wp--preset--color--secondary);
}

@media (max-width: 900px) {
	.wrapnova-gallery-grid {
		grid-template-columns: repeat(3, 1fr);
	}
}

@media (max-width: 500px) {
	.wrapnova-gallery-grid {
		grid-template-columns: repeat(2, 1fr);
	}
}

/* =========================================================================
   Video Showcase — two videos side by side
   ========================================================================= */

.wrapnova-video-card {
	display: flex;
	flex-direction: column;
}

.wrapnova-video-embed {
	position: relative;
	width: 100%;
	padding-bottom: 56.25%;
	border-radius: 10px;
	overflow: hidden;
}

.wrapnova-video-embed iframe {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
}

.wrapnova-video-title {
	font-family: 'Michroma', sans-serif;
	font-size: var(--wp--preset--font-size--large);
	color: var(--wp--preset--color--heading);
	margin: var(--wp--preset--spacing--30) 0 var(--wp--preset--spacing--10) 0;
}

.wrapnova-video-desc {
	color: var(--wp--preset--color--copy);
	font-size: var(--wp--preset--font-size--small);
	line-height: 1.6;
	margin: 0;
}

/* =========================================================================
   Finance Banner
   ========================================================================= */

.wrapnova-finance-banner .wp-block-button.is-style-outline .wp-block-button__link:hover {
	background: var(--wp--preset--color--black) !important;
	color: var(--wp--preset--color--secondary) !important;
	border-color: var(--wp--preset--color--black) !important;
}

/* =========================================================================
   Alloy Wheel Refurbishment
   ========================================================================= */

.wrapnova-alloy-section {
	margin-bottom: 0 !important;
	padding-bottom: 0 !important;
}

.wrapnova-alloy-section + * {
	margin-top: 0 !important;
}

.wrapnova-alloy-title {
	font-family: 'Michroma', sans-serif;
}

.wrapnova-alloy-image {
	border-radius: 10px;
	overflow: hidden;
	line-height: 0;
	height: 100%;
	max-height: 600px;
}

.wrapnova-alloy-image img {
	width: 100%;
	height: 80%;
	object-fit: cover;
	border-radius: 10px;
	transition: transform 0.3s ease;
}

.wrapnova-alloy-image:hover img {
	transform: scale(1.05);
}

@media (max-width: 768px) {
	.wrapnova-alloy-image {
		height: auto;
	}

	.wrapnova-alloy-image img {
		height: auto;
	}
}

/* =========================================================================
   Service Banners — Parallax scroll-reveal panels
   ========================================================================= */

.wrapnova-service-banner {
	position: relative;
	width: 100%;
	min-height: 70vh;
	display: flex;
	align-items: center;
	justify-content: center;
	overflow: hidden;
	clip-path: inset(0);
}

.wrapnova-banner-img {
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	height: 100vh;
	object-fit: cover;
	object-position: center;
	z-index: 0;
}

.wrapnova-banner-overlay {
	position: absolute;
	inset: 0;
	background: rgba(0, 0, 0, 0.5);
	z-index: 1;
}

.wrapnova-banner-content {
	position: relative;
	z-index: 2;
	text-align: center;
	padding: var(--wp--preset--spacing--40);
}

.wrapnova-banner-title {
	font-family: 'Michroma', sans-serif;
	font-size: clamp(2rem, 5vw, 3.5rem);
	font-weight: 700;
	color: #fff;
	letter-spacing: -0.02em;
	margin: 0 0 var(--wp--preset--spacing--40) 0;
}

.wrapnova-banner-button {
	display: inline-block;
	padding: 0.85em 2.5em;
	border: 2px solid var(--wp--preset--color--secondary);
	border-radius: 6px;
	color: var(--wp--preset--color--secondary);
	font-size: var(--wp--preset--font-size--medium);
	font-weight: 600;
	text-decoration: none;
	transition: background 0.2s ease, color 0.2s ease;
}

.wrapnova-banner-button:hover {
	background: var(--wp--preset--color--secondary);
	color: var(--wp--preset--color--black);
}

@media (max-width: 768px) {
	.wrapnova-service-banner {
		min-height: 50vh;
		clip-path: none;
	}

	.wrapnova-banner-img {
		position: absolute;
		height: 100%;
	}
}

/* =========================================================================
   Our Popular Services
   ========================================================================= */

.wrapnova-services-title {
	font-family: 'Michroma', sans-serif;
}

.wrapnova-service-card {
	background: rgba(255, 255, 255, 0.03);
	transition: border-color 0.2s ease;
	height: 100%;
}

.wrapnova-short-video {
	max-width: 100%;
	margin-left: auto;
	margin-right: auto;
	border-radius: 10px;
	overflow: hidden;
}

.wrapnova-short-video iframe {
	display: block !important;
	width: 100% !important;
	height: 700px !important;
	border: 0 !important;
	border-radius: 10px;
}

@media (max-width: 768px) {
	.wrapnova-short-video iframe {
		height: 500px !important;
	}
}

.wrapnova-service-card:hover {
	border-color: rgba(18, 239, 255, 0.2) !important;
}

@media (max-width: 900px) {
	.wrapnova-reviews-grid {
		grid-template-columns: repeat(2, 1fr);
	}
}

@media (max-width: 600px) {
	.wrapnova-reviews-grid {
		grid-template-columns: 1fr;
	}
}

/* =========================================================================
   Request Info Section
   ========================================================================= */

.wrapnova-request-info > h2,
.wrapnova-request-info > .wp-block-heading {
	font-family: 'Michroma', sans-serif;
}

/* =========================================================================
   Contact Form — Request Some Info
   ========================================================================= */

.wrapnova-contact-form {
	display: flex;
	flex-direction: column;
	gap: var(--wp--preset--spacing--30);
}

.wrapnova-form-field label {
	display: block;
	color: var(--wp--preset--color--heading);
	font-size: var(--wp--preset--font-size--small);
	font-weight: 600;
	margin-bottom: 0.4em;
}

.wrapnova-form-field input[type="text"],
.wrapnova-form-field input[type="email"],
.wrapnova-form-field input[type="tel"],
.wrapnova-form-field textarea {
	width: 100%;
	padding: 0.75em 1em;
	background: rgba(255, 255, 255, 0.05);
	border: 1px solid rgba(255, 255, 255, 0.15);
	border-radius: 6px;
	color: var(--wp--preset--color--heading);
	font-family: inherit;
	font-size: var(--wp--preset--font-size--medium);
	transition: border-color 0.2s ease;
}

.wrapnova-form-field input::placeholder,
.wrapnova-form-field textarea::placeholder {
	color: var(--wp--preset--color--muted);
}

.wrapnova-form-field input:focus,
.wrapnova-form-field textarea:focus {
	outline: none;
	border-color: var(--wp--preset--color--secondary);
}

.wrapnova-form-field textarea {
	resize: vertical;
}

/* Checkbox */
.wrapnova-form-checkbox label {
	display: flex;
	align-items: flex-start;
	gap: 0.6em;
	font-weight: 400;
	color: var(--wp--preset--color--copy);
	cursor: pointer;
}

.wrapnova-form-checkbox input[type="checkbox"] {
	width: 18px;
	height: 18px;
	margin-top: 0.15em;
	flex-shrink: 0;
	accent-color: var(--wp--preset--color--secondary);
	cursor: pointer;
}

/* Submit button */
.wrapnova-form-submit button {
	display: inline-block;
	width: 100%;
	padding: 0.85em 2em;
	background: var(--wp--preset--color--secondary);
	color: var(--wp--preset--color--black);
	border: none;
	border-radius: 6px;
	font-family: inherit;
	font-size: var(--wp--preset--font-size--medium);
	font-weight: 700;
	cursor: pointer;
	transition: background 0.2s ease, transform 0.1s ease;
}

.wrapnova-form-submit button:hover {
	background: #0fd8e8;
}

.wrapnova-form-submit button:active {
	transform: scale(0.98);
}

/* reCAPTCHA notice */
.wrapnova-form-recaptcha {
	font-size: 12px;
	color: var(--wp--preset--color--muted);
	text-align: center;
	margin-top: var(--wp--preset--spacing--20);
	line-height: 1.5;
}

.wrapnova-form-recaptcha a {
	color: var(--wp--preset--color--secondary);
	text-decoration: underline;
}

/* Form status messages */
.wrapnova-form-message {
	padding: 1em 1.2em;
	border-radius: 6px;
	font-size: var(--wp--preset--font-size--medium);
	font-weight: 600;
	margin-bottom: var(--wp--preset--spacing--30);
	text-align: center;
}

.wrapnova-form-success {
	background: rgba(34, 197, 94, 0.12);
	border: 1px solid rgba(34, 197, 94, 0.4);
	color: #22c55e;
}

.wrapnova-form-error {
	background: rgba(239, 68, 68, 0.12);
	border: 1px solid rgba(239, 68, 68, 0.4);
	color: #ef4444;
}

/* Form loading / sending state */
.wrapnova-form-progress {
	width: 100%;
	height: 4px;
	background: rgba(255, 255, 255, 0.08);
	border-radius: 4px;
	overflow: hidden;
	margin-bottom: var(--wp--preset--spacing--30);
}

.wrapnova-form-progress-bar {
	height: 100%;
	width: 0;
	background: var(--wp--preset--color--secondary);
	border-radius: 4px;
	animation: wrapnova-progress 2s ease-in-out forwards;
}

@keyframes wrapnova-progress {
	0%   { width: 0; }
	30%  { width: 50%; }
	60%  { width: 80%; }
	100% { width: 95%; }
}

.wrapnova-form-sending {
	opacity: 0.6;
	pointer-events: none;
}

.wrapnova-sending-dots::after {
	content: '';
	animation: wrapnova-dots 1.4s steps(4, end) infinite;
}

@keyframes wrapnova-dots {
	0%  { content: ''; }
	25% { content: '.'; }
	50% { content: '..'; }
	75% { content: '...'; }
}

/* =========================================================================
   Breadcrumbs
   ========================================================================= */

.wrapnova-breadcrumbs {
	margin-bottom: var(--wp--preset--spacing--40);
	font-size: var(--wp--preset--font-size--small);
	color: var(--wp--preset--color--muted);
}

.wrapnova-breadcrumbs ol {
	display: flex;
	flex-wrap: wrap;
	gap: 0;
	list-style: none;
	margin: 0;
	padding: 0;
}

.wrapnova-breadcrumbs li {
	display: inline;
}

.wrapnova-breadcrumbs a {
	color: var(--wp--preset--color--secondary);
	text-decoration: none;
}

.wrapnova-breadcrumbs a:hover {
	text-decoration: underline;
}

.wrapnova-breadcrumbs__sep {
	margin: 0 0.35em;
	color: var(--wp--preset--color--muted);
}

/* =========================================================================
   Footer Navigation
   ========================================================================= */

.wrapnova-footer-nav {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: 0.5em 1.5em;
	padding: 0 0 var(--wp--preset--spacing--30) 0;
	margin: 0 auto var(--wp--preset--spacing--30) auto;
	border-bottom: 1px solid rgba(255, 255, 255, 0.06);
	list-style: none;
	max-width: var(--wp--style--global--content-size, 650px);
}

.wrapnova-footer-nav a {
	color: var(--wp--preset--color--muted);
	font-size: var(--wp--preset--font-size--small);
	text-decoration: none;
	transition: color 0.2s ease;
	white-space: nowrap;
}

.wrapnova-footer-nav a:hover {
	color: var(--wp--preset--color--secondary);
}

/* =========================================================================
   Accessibility
   ========================================================================= */

.skip-link {
	position: absolute;
	top: -100%;
	left: 0;
	z-index: 999;
	padding: 0.5em 1em;
	background: var(--wp--preset--color--secondary);
	color: var(--wp--preset--color--black);
	text-decoration: none;
	font-weight: 600;
}

.skip-link:focus {
	top: 0;
}

:focus-visible {
	outline: 2px solid var(--wp--preset--color--secondary);
	outline-offset: 2px;
}

/* =========================================================================
   Global
   ========================================================================= */

html {
	scroll-behavior: smooth;
}

img {
	max-width: 100%;
	height: auto;
}

/* Post navigation links */
.wp-block-post-navigation-link {
	text-decoration: none;
}

.wp-block-post-navigation-link:hover {
	text-decoration: underline;
}

/* Outline buttons */
.wp-block-button.is-style-outline .wp-block-button__link {
	background: transparent;
	transition: background 0.2s ease, color 0.2s ease;
}

.wp-block-button.is-style-outline .wp-block-button__link:hover {
	background: var(--wp--preset--color--secondary) !important;
	color: var(--wp--preset--color--black) !important;
	border-color: var(--wp--preset--color--secondary) !important;
}

/* Selection */
::selection {
	background: var(--wp--preset--color--secondary);
	color: var(--wp--preset--color--black);
}

/* Scrollbar */
::-webkit-scrollbar {
	width: 8px;
}

::-webkit-scrollbar-track {
	background: var(--wp--preset--color--black);
}

::-webkit-scrollbar-thumb {
	background: var(--wp--preset--color--light);
	border-radius: 4px;
}

::-webkit-scrollbar-thumb:hover {
	background: var(--wp--preset--color--muted);
}

/* =========================================================================
   Responsive
   ========================================================================= */

@media (max-width: 768px) {
	.wrapnova-nav-logo img {
		width: 70px;
	}

	.wrapnova-nav-inner {
		gap: var(--wp--preset--spacing--20);
	}

	.wrapnova-hero-content {
		padding-left: var(--wp--preset--spacing--30);
		padding-right: var(--wp--preset--spacing--30);
	}
}

/* =========================================================================
   Desktop Nav — click-to-toggle dropdowns, absolute positioned
   ========================================================================= */

@media (min-width: 600px) {
  /* Submenu parent items: flex row so link + arrow inline */
  .wrapnova-nav-inner .wp-block-navigation-submenu.has-child {
    position: relative !important;
  }

  /* Hide WP hover-based dropdowns — our JS controls visibility */
  .wrapnova-nav-inner .has-child:not(.wn-open) > .wp-block-navigation__submenu-container {
    height: 0 !important;
    width: 0 !important;
    opacity: 0 !important;
    visibility: hidden !important;
    overflow: hidden !important;
    min-width: 0 !important;
  }

  /* Also block hover-show from WP core */
  .wrapnova-nav-inner .has-child:not(.wn-open):hover > .wp-block-navigation__submenu-container,
  .wrapnova-nav-inner .has-child:not(.wn-open):focus-within > .wp-block-navigation__submenu-container {
    height: 0 !important;
    width: 0 !important;
    opacity: 0 !important;
    visibility: hidden !important;
    overflow: hidden !important;
  }

  /* Show dropdown when our .wn-open is applied — absolute, overlaps content below */
  .wrapnova-nav-inner .has-child.wn-open > .wp-block-navigation__submenu-container {
    height: auto !important;
    width: auto !important;
    min-width: 220px !important;
    opacity: 1 !important;
    visibility: visible !important;
    overflow: visible !important;
    position: absolute !important;
    top: 100% !important;
    left: 0 !important;
    z-index: 100 !important;
    background: rgba(0, 0, 0, 0.2) !important;
    backdrop-filter: blur(12px) !important;
    -webkit-backdrop-filter: blur(12px) !important;
    border: 1px solid rgba(255, 255, 255, 0.1) !important;
    border-radius: 6px !important;
    padding: 0.5em 0 !important;
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.4) !important;
  }

  /* Arrow icon — cyan, 18px, inline */
  .wrapnova-nav-inner .wp-block-navigation__submenu-icon svg {
    width: 18px !important;
    height: 18px !important;
    stroke: var(--wp--preset--color--secondary) !important;
    stroke-width: 2 !important;
    transition: transform 0.25s ease !important;
  }

  .wrapnova-nav-inner .has-child.wn-open > .wp-block-navigation__submenu-icon svg {
    transform: rotate(180deg) !important;
  }
}

/* =========================================================================
   Mobile Navigation Overlay
   ========================================================================= */

.wp-block-navigation .wp-block-navigation__responsive-container.is-menu-open.is-menu-open {
  background-color: rgba(0, 0, 0, 0.96) !important;
  backdrop-filter: blur(20px) !important;
  -webkit-backdrop-filter: blur(20px) !important;
  animation: wrapnova-slideDown 0.35s ease forwards !important;
  padding: 0 !important;
}

@keyframes wrapnova-slideDown {
  from { opacity: 0; transform: translateY(-30px); }
  to { opacity: 1; transform: translateY(0); }
}

.wp-block-navigation .wp-block-navigation__responsive-container-close.wp-block-navigation__responsive-container-close {
  top: 1.25rem !important;
  right: 1.25rem !important;
  color: #fff !important;
}

.wp-block-navigation .wp-block-navigation__responsive-container-close svg {
  width: 28px !important;
  height: 28px !important;
  fill: #fff !important;
}

.wp-block-navigation .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation__responsive-container-content.wp-block-navigation__responsive-container-content {
  align-items: center !important;
  padding: 5rem 2rem 2.5rem !important;
  gap: 0 !important;
}

.wp-block-navigation .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation-item.wp-block-navigation-item {
  width: 100% !important;
  text-align: center !important;
  align-items: center !important;
}

.wp-block-navigation .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation__container > .wp-block-navigation-item + .wp-block-navigation-item {
  border-top: 1px solid rgba(255, 255, 255, 0.08);
}

.wp-block-navigation .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation-item__content.wp-block-navigation-item__content {
  display: block !important;
  text-align: center !important;
  font-size: 1.15rem !important;
  font-weight: 500 !important;
  color: #fff !important;
  padding: 0.9rem 1rem !important;
}

.wp-block-navigation .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation-item__content:hover {
  color: var(--wp--preset--color--secondary) !important;
}

.wp-block-navigation .wp-block-navigation__responsive-container.is-menu-open .current-menu-item > .wp-block-navigation-item__content,
.wp-block-navigation .wp-block-navigation__responsive-container.is-menu-open [aria-current="page"] {
  color: var(--wp--preset--color--secondary) !important;
}

/* Mobile submenus — hidden by default, shown via .wn-open */
.wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation-submenu.has-child > .wp-block-navigation__submenu-container.wp-block-navigation__submenu-container.wp-block-navigation__submenu-container {
  height: 0 !important;
  overflow: hidden !important;
  opacity: 0 !important;
  padding: 0 !important;
  visibility: hidden !important;
  min-width: 0 !important;
  border: none !important;
}

.wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation-submenu.has-child.wn-open > .wp-block-navigation__submenu-container.wp-block-navigation__submenu-container.wp-block-navigation__submenu-container {
  height: auto !important;
  overflow: visible !important;
  opacity: 1 !important;
  visibility: visible !important;
  padding: 0.5rem 0 !important;
  min-width: 100% !important;
  position: static !important;
  background: rgba(255, 255, 255, 0.04) !important;
}

/* Mobile submenu links centred */
.wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation-submenu.has-child {
  align-items: center !important;
  text-align: center !important;
  justify-content: center !important;
}

.wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation__submenu-container .wp-block-navigation-item {
  text-align: center !important;
}

.wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation__submenu-container .wp-block-navigation-item a {
  text-align: center !important;
  justify-content: center !important;
}

/* Mobile arrow icon */
.wp-block-navigation .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation__submenu-icon.wp-block-navigation__submenu-icon.wp-block-navigation__submenu-icon {
  display: inline-flex !important;
  width: auto !important;
  height: auto !important;
}

.wp-block-navigation .wp-block-navigation__responsive-container.is-menu-open .wp-block-navigation__submenu-icon svg {
  width: 16px !important;
  height: 16px !important;
  stroke: var(--wp--preset--color--secondary) !important;
  stroke-width: 2 !important;
}

.wp-block-navigation__responsive-container-open {
  color: #fff !important;
}

.wp-block-navigation__responsive-container-open svg {
  fill: #fff !important;
}

/* =========================================================================
   Page title — Michroma font
   ========================================================================= */

.wp-block-post-title {
  font-family: 'Michroma', sans-serif !important;
  text-align: center;
  color: var(--wp--preset--color--heading);
}

/* =========================================================================
   Nav overflow fix — allow dropdowns to escape container
   ========================================================================= */

.wrapnova-nav-bar,
.wrapnova-nav-bar.is-layout-constrained,
.wrapnova-nav-inner,
.wp-block-navigation,
.wp-block-navigation.is-layout-flex,
.wp-block-navigation__container {
  overflow: visible !important;
}

/* =========================================================================
   Stats Counter
   ========================================================================= */

.wrapnova-pricelist-grid.wrapnova-stats-grid {
	grid-template-columns: repeat(4, 1fr) !important;
}

@media (max-width: 900px) {
	.wrapnova-pricelist-grid.wrapnova-stats-grid {
		grid-template-columns: repeat(2, 1fr)!important;
	}
}

@media (max-width: 480px) {
	.wrapnova-pricelist-grid.wrapnova-stats-grid {
		grid-template-columns: 1fr!important;
	}
}
