/* ============================================================
   DEL PUERTO REFRIGERACIÓN Y EQUIPOS — Custom Styles
   Theme: Blocksy Child
   Version: 2.0.0 — Rediseño profesional
   ============================================================ */

/* ============================================================
   1. CSS VARIABLES / DESIGN TOKENS
   ============================================================ */
:root {
	/* Brand Colors */
	--dp-primary: #1a3a5c;
	--dp-primary-light: #234b73;
	--dp-primary-dark: #112840;
	--dp-secondary: #2980b9;
	--dp-secondary-light: #3498db;
	--dp-accent: #e67e22;
	--dp-accent-hover: #d35400;
	--dp-accent-light: #f0a04b;

	/* Neutrals */
	--dp-dark: #0c1a2a;
	--dp-text: #1e2a3a;
	--dp-text-light: #6c7a89;
	--dp-gray: #8e99a4;
	--dp-border: #dce6f0;
	--dp-light: #f0f6fc;
	--dp-lighter: #f7fafd;
	--dp-white: #ffffff;

	/* Functional */
	--dp-success: #27ae60;
	--dp-error: #e74c3c;
	--dp-warning: #f39c12;
	--dp-info: #2980b9;

	/* Spacing */
	--dp-section-padding: 80px;
	--dp-section-padding-mobile: 48px;
	--dp-container-max: 1200px;

	/* Radius */
	--dp-radius-sm: 6px;
	--dp-radius: 10px;
	--dp-radius-lg: 16px;
	--dp-radius-xl: 24px;

	/* Shadows */
	--dp-shadow-sm: 0 2px 8px rgba(26, 58, 92, 0.06);
	--dp-shadow: 0 4px 20px rgba(26, 58, 92, 0.08);
	--dp-shadow-lg: 0 8px 40px rgba(26, 58, 92, 0.12);
	--dp-shadow-hover: 0 8px 32px rgba(26, 58, 92, 0.15);

	/* Transitions */
	--dp-transition: all 0.3s ease;
	--dp-transition-fast: all 0.15s ease;
}

/* ============================================================
   2. GLOBAL / TYPOGRAPHY
   ============================================================ */
body.dp-theme {
	font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
	color: var(--dp-text);
	line-height: 1.7;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}

body.dp-theme h1,
body.dp-theme h2,
body.dp-theme h3,
body.dp-theme h4,
body.dp-theme h5,
body.dp-theme h6 {
	font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
	color: var(--dp-primary);
	font-weight: 700;
	line-height: 1.25;
}

body.dp-theme h1 { font-size: clamp(2rem, 4vw, 3rem); }
body.dp-theme h2 { font-size: clamp(1.5rem, 3vw, 2.25rem); }
body.dp-theme h3 { font-size: clamp(1.25rem, 2.5vw, 1.75rem); }

body.dp-theme a {
	color: var(--dp-secondary);
	transition: var(--dp-transition-fast);
}
body.dp-theme a:hover {
	color: var(--dp-accent);
}

/* ============================================================
   3. HEADER — Sólido, profesional, con CTAs visibles
   ============================================================ */
.ct-header {
	border-bottom: none;
	box-shadow: 0 2px 16px rgba(26, 58, 92, 0.10);
}

/* Top bar — datos de contacto rápido */
[data-row="top"] {
	background: linear-gradient(90deg, var(--dp-primary-dark) 0%, var(--dp-primary) 100%) !important;
	--theme-text-color: rgba(255, 255, 255, 0.9) !important;
	--theme-link-initial-color: rgba(255, 255, 255, 0.85) !important;
	--theme-link-hover-color: var(--dp-accent-light) !important;
	--theme-icon-color: rgba(255, 255, 255, 0.8) !important;
	--theme-icon-hover-color: var(--dp-accent-light) !important;
	color: rgba(255, 255, 255, 0.9) !important;
	font-size: 13px;
	letter-spacing: 0.02em;
	border-bottom: 1px solid rgba(255, 255, 255, 0.08);
}

[data-row="top"] a {
	color: rgba(255, 255, 255, 0.85) !important;
}
[data-row="top"] a:hover {
	color: var(--dp-accent-light) !important;
}

[data-row="top"] .ct-social-box a {
	color: rgba(255, 255, 255, 0.85) !important;
}
[data-row="top"] .ct-social-box a:hover {
	color: var(--dp-accent-light) !important;
}

/* Main header row — fondo sólido blanco */
[data-row="middle"] {
	background-color: var(--dp-white) !important;
	box-shadow: none;
	padding-top: 4px;
	padding-bottom: 4px;
}

/* Navigation links — más presencia */
.ct-header nav[id="header-menu"] > ul > li > a {
	font-weight: 600;
	font-size: 15px;
	letter-spacing: 0.01em;
	color: var(--dp-primary);
	transition: var(--dp-transition-fast);
	position: relative;
	text-transform: none;
}

.ct-header nav[id="header-menu"] > ul > li > a:hover,
.ct-header nav[id="header-menu"] > ul > li.current-menu-item > a {
	color: var(--dp-accent);
}

/* Active link underline — animada */
.ct-header nav[id="header-menu"] > ul > li > a::after {
	content: '';
	position: absolute;
	bottom: -2px;
	left: 50%;
	width: 0;
	height: 2.5px;
	background: var(--dp-accent);
	transition: var(--dp-transition);
	transform: translateX(-50%);
	border-radius: 2px;
}
.ct-header nav[id="header-menu"] > ul > li > a:hover::after,
.ct-header nav[id="header-menu"] > ul > li.current-menu-item > a::after {
	width: 100%;
}

/* Header CTA button — Cotización (naranja, prominente) */
.ct-header .ct-button,
.ct-header .ct-button-ghost,
.ct-header [data-id="button"] .ct-button {
	background-color: var(--dp-accent) !important;
	color: var(--dp-white) !important;
	border: none !important;
	border-radius: var(--dp-radius-sm);
	font-weight: 700;
	padding: 10px 22px;
	transition: var(--dp-transition);
	font-size: 14px;
	text-transform: none;
	letter-spacing: 0;
	box-shadow: 0 2px 10px rgba(230, 126, 34, 0.25);
}
.ct-header .ct-button:hover,
.ct-header [data-id="button"] .ct-button:hover {
	background-color: var(--dp-accent-hover) !important;
	transform: translateY(-1px);
	box-shadow: 0 4px 16px rgba(230, 126, 34, 0.35);
}

/* Header secondary CTA (WhatsApp verde) */
.ct-header [data-id="button_2"] .ct-button,
.ct-header .dp-header-whatsapp {
	background-color: #25d366 !important;
	color: var(--dp-white) !important;
	border: none !important;
	border-radius: var(--dp-radius-sm);
	font-weight: 700;
	padding: 10px 20px;
	font-size: 14px;
	box-shadow: 0 2px 10px rgba(37, 211, 102, 0.25);
}
.ct-header [data-id="button_2"] .ct-button:hover,
.ct-header .dp-header-whatsapp:hover {
	background-color: #1da851 !important;
	transform: translateY(-1px);
	box-shadow: 0 4px 16px rgba(37, 211, 102, 0.35);
}

/* Cart icon badge */
.ct-header .ct-cart-icon .ct-count {
	background-color: var(--dp-accent);
	color: var(--dp-white);
}

/* Search icon */
.ct-header [data-id="search"] {
	color: var(--dp-primary);
}

/* Sticky header — profesional + blur */
[data-sticky-row="middle"] {
	background-color: rgba(255, 255, 255, 0.98) !important;
	backdrop-filter: blur(12px);
	-webkit-backdrop-filter: blur(12px);
	box-shadow: 0 2px 20px rgba(26, 58, 92, 0.12);
}

/* Mobile menu */
#mobile-menu {
	background-color: var(--dp-white);
}
#mobile-menu a {
	color: var(--dp-primary);
	font-weight: 600;
}

/* Mobile header — compact */
@media (max-width: 999px) {
	.ct-header .ct-button {
		padding: 8px 16px;
		font-size: 13px;
	}
}

/* ============================================================
   4. FOOTER — Completo, confiable, con identidad industrial
   ============================================================ */

footer.ct-footer,
.ct-footer,
footer#footer,
#footer {
	background: var(--dp-dark) !important;
	background-image:
		radial-gradient(ellipse at 20% 0%, rgba(41, 128, 185, 0.08) 0%, transparent 50%),
		radial-gradient(ellipse at 80% 100%, rgba(230, 126, 34, 0.05) 0%, transparent 50%) !important;
	--theme-palette-color-6: var(--dp-dark) !important;
	--theme-text-color: rgba(255, 255, 255, 0.75) !important;
	--theme-heading-color: var(--dp-white) !important;
	--theme-link-initial-color: rgba(255, 255, 255, 0.7) !important;
	--theme-link-hover-color: var(--dp-accent-light) !important;
	--theme-icon-color: var(--dp-white) !important;
	--theme-icon-hover-color: var(--dp-accent-light) !important;
	color: rgba(255, 255, 255, 0.8);
	position: relative;
	border-top: 3px solid transparent;
	border-image: linear-gradient(90deg, var(--dp-secondary), var(--dp-accent), var(--dp-secondary)) 1;
}

/* Subtle dot pattern overlay — industrial texture */
footer.ct-footer::after,
.ct-footer::after {
	content: '';
	position: absolute;
	inset: 0;
	background-image: radial-gradient(rgba(255, 255, 255, 0.025) 1px, transparent 1px);
	background-size: 20px 20px;
	pointer-events: none;
	z-index: 0;
}

/* Ensure footer content sits above pseudo-elements */
.ct-footer > *,
#footer > * {
	position: relative;
	z-index: 1;
}

/* Footer top row — newsletter or branding bar */
#footer [data-row="top"],
.ct-footer [data-row="top"] {
	background-color: rgba(255, 255, 255, 0.03) !important;
	border-bottom: 1px solid rgba(255, 255, 255, 0.06);
	padding-top: 40px !important;
	padding-bottom: 40px !important;
}

/* Footer middle row — main content area */
#footer [data-row="middle"],
.ct-footer [data-row="middle"] {
	background-color: transparent !important;
	padding-top: 48px !important;
	padding-bottom: 40px !important;
}

/* Force dark on all rows */
#footer [data-row],
.ct-footer [data-row] {
	--theme-text-color: rgba(255, 255, 255, 0.75) !important;
	--theme-heading-color: var(--dp-white) !important;
	--theme-link-initial-color: rgba(255, 255, 255, 0.7) !important;
	--theme-link-hover-color: var(--dp-accent-light) !important;
	--theme-icon-color: var(--dp-white) !important;
	--theme-icon-hover-color: var(--dp-accent-light) !important;
}

/* Footer widget titles — uppercase, accented */
.ct-footer .widget-title,
.ct-footer h4,
.ct-footer [class*="widget"] .widget-title {
	color: var(--dp-white) !important;
	--theme-heading-color: var(--dp-white) !important;
	font-size: 14px;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	margin-bottom: 20px;
	padding-bottom: 12px;
	position: relative;
	border-bottom: none;
}

/* Accent underline on footer titles */
.ct-footer .widget-title::after,
.ct-footer h4::after {
	content: '';
	position: absolute;
	bottom: 0;
	left: 0;
	width: 32px;
	height: 2px;
	background: var(--dp-accent);
	border-radius: 1px;
}

/* Footer links */
.ct-footer a,
.ct-footer .ct-widget a,
.ct-footer .widget a {
	color: rgba(255, 255, 255, 0.65) !important;
	transition: var(--dp-transition-fast);
	font-size: 14px;
}
.ct-footer a:hover,
.ct-footer .ct-widget a:hover,
.ct-footer .widget a:hover {
	color: var(--dp-white) !important;
	padding-left: 3px;
}

.ct-footer .widget ul {
	list-style: none;
	padding: 0;
	margin: 0;
}

.ct-footer .widget ul li {
	padding: 6px 0;
	border-bottom: none;
	position: relative;
}

.ct-footer .widget ul li a::before {
	content: '›';
	margin-right: 8px;
	color: var(--dp-accent);
	font-weight: 700;
	font-size: 15px;
	transition: var(--dp-transition-fast);
}

.ct-footer .widget ul li a:hover::before {
	margin-right: 10px;
}

/* Footer paragraphs — contact data */
.ct-footer p,
.ct-footer .widget p {
	color: rgba(255, 255, 255, 0.65) !important;
	font-size: 14px;
	line-height: 1.7;
}

/* Footer bottom / copyright bar */
.ct-footer [data-row="bottom"],
#footer [data-row="bottom"] {
	background-color: rgba(0, 0, 0, 0.4) !important;
	border-top: 1px solid rgba(255, 255, 255, 0.06);
	font-size: 13px;
	padding-top: 16px !important;
	padding-bottom: 16px !important;
}

/* Copyright text */
.ct-footer [data-row="bottom"] * {
	font-size: 13px;
	color: rgba(255, 255, 255, 0.4) !important;
}

/* --- Footer icons: WHITE SVGs --- */
.ct-footer svg,
.ct-footer [class*="icon"] svg,
.ct-footer .ct-social-box svg,
.ct-footer .wp-block-social-links svg,
.ct-footer .wp-social-link svg,
#footer svg {
	fill: var(--dp-white) !important;
	color: var(--dp-white) !important;
}

.ct-footer a:hover svg,
.ct-footer .ct-social-box a:hover svg,
.ct-footer .wp-social-link:hover svg {
	fill: var(--dp-white) !important;
	color: var(--dp-white) !important;
}

/* --- Social icons (Blocksy) --- */
.ct-footer .ct-social-box a {
	background-color: rgba(255, 255, 255, 0.07);
	border: 1px solid rgba(255, 255, 255, 0.12);
	color: var(--dp-white) !important;
	border-radius: 50%;
	width: 38px;
	height: 38px;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	transition: var(--dp-transition);
}
.ct-footer .ct-social-box a:hover {
	background-color: var(--dp-accent);
	border-color: var(--dp-accent);
	transform: translateY(-3px);
	box-shadow: 0 6px 20px rgba(230, 126, 34, 0.35);
	padding-left: 0 !important;
}

/* --- Social icons (WP block) --- */
.ct-footer .wp-block-social-links {
	padding: 0 !important;
	gap: 10px;
}

.ct-footer .wp-block-social-links .wp-social-link,
.ct-footer .wp-block-social-links .wp-block-social-link {
	background-color: rgba(255, 255, 255, 0.07) !important;
	border: 1px solid rgba(255, 255, 255, 0.12);
	color: var(--dp-white) !important;
	border-radius: 50% !important;
	width: 38px !important;
	height: 38px !important;
	padding: 0 !important;
	display: inline-flex !important;
	align-items: center;
	justify-content: center;
	transition: var(--dp-transition);
}

.ct-footer .wp-block-social-links .wp-social-link a,
.ct-footer .wp-block-social-links .wp-block-social-link a {
	color: var(--dp-white) !important;
	padding: 8px !important;
}

.ct-footer .wp-block-social-links .wp-social-link:hover,
.ct-footer .wp-block-social-links .wp-block-social-link:hover {
	background-color: var(--dp-accent) !important;
	border-color: var(--dp-accent);
	transform: translateY(-3px);
	box-shadow: 0 6px 20px rgba(230, 126, 34, 0.35);
}

/* Footer logo (if present) — white */
.ct-footer .site-logo-container img,
.ct-footer img.custom-logo {
	filter: brightness(0) invert(1);
	opacity: 0.85;
	transition: var(--dp-transition-fast);
}
.ct-footer .site-logo-container:hover img,
.ct-footer img.custom-logo:hover {
	opacity: 1;
}

/* Footer seal / guarantee badges */
.dp-footer-seals {
	display: flex;
	gap: 16px;
	align-items: center;
	flex-wrap: wrap;
	margin-top: 16px;
}

.dp-footer-seal {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	font-size: 12px;
	color: rgba(255, 255, 255, 0.5);
	background: rgba(255, 255, 255, 0.04);
	padding: 6px 12px;
	border-radius: 4px;
	border: 1px solid rgba(255, 255, 255, 0.06);
}

.dp-footer-seal svg {
	width: 14px;
	height: 14px;
	opacity: 0.6;
}

/* ============================================================
   5. HERO / COVER — Impactante, profesional, legible
   ============================================================ */
.dp-hero-section .wp-block-cover {
	min-height: 600px !important;
	border-radius: 0;
	overflow: hidden;
}

.dp-hero-section .wp-block-cover__inner-container {
	max-width: var(--dp-container-max);
	margin: 0 auto;
	padding: 0 24px;
}

/* Hero content — text-only, potente */
.dp-hero-section h1 {
	color: var(--dp-white) !important;
	font-size: clamp(2.25rem, 5vw, 3.5rem) !important;
	font-weight: 800 !important;
	line-height: 1.12 !important;
	margin-bottom: 20px !important;
	text-shadow: 0 2px 30px rgba(0, 0, 0, 0.35);
	max-width: 700px;
}

/* Kicker / pre-title badge */
.dp-hero-kicker {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	background: rgba(230, 126, 34, 0.9);
	color: var(--dp-white);
	font-size: 13px;
	font-weight: 700;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	padding: 6px 16px;
	border-radius: 4px;
	margin-bottom: 20px;
}

.dp-hero-section p {
	color: rgba(255, 255, 255, 0.92) !important;
	font-size: clamp(1rem, 2vw, 1.2rem) !important;
	max-width: 560px;
	line-height: 1.7;
}

.dp-hero-section .wp-block-buttons {
	margin-top: 32px !important;
	gap: 16px;
}

/* Mascot — background accent, not protagonist */
.dp-hero-mascot {
	position: absolute;
	right: 0;
	bottom: 0;
	width: 200px;
	opacity: 0.15;
	pointer-events: none;
	z-index: 0;
}

.dp-hero-mascot img {
	width: 100%;
	height: auto;
	filter: brightness(0) invert(1);
}

/* Mini hero for inner pages */
.dp-hero-mini .wp-block-cover {
	min-height: 320px !important;
}

.wp-block-cover .wp-block-buttons {
	gap: 16px;
}

/* Force center alignment on mini hero */
.dp-hero-mini .wp-block-cover__inner-container {
	text-align: center !important;
}

.dp-hero-mini h1 {
	margin-left: auto !important;
	margin-right: auto !important;
}

.dp-hero-mini .wp-block-cover__inner-container p {
	text-align: center !important;
	margin-left: auto !important;
	margin-right: auto !important;
}

/* ============================================================
   6. TRUST BADGES / VALUE PROPS — Premium Glassmorphism
   ============================================================ */
.dp-trust-badges {
	background: var(--dp-light);
	padding: 40px 0 !important;
	border-top: 3px solid var(--dp-accent);
}

.dp-trust-badges .wp-block-column {
	text-align: center;
	padding: 24px 16px;
}

.dp-trust-badges .dp-badge-icon {
	width: 56px;
	height: 56px;
	background: var(--dp-primary);
	border-radius: 50%;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	margin-bottom: 14px;
	color: var(--dp-white);
	font-size: 24px;
}

.dp-trust-badges h4 {
	font-size: 15px !important;
	font-weight: 700 !important;
	margin-bottom: 6px !important;
	color: var(--dp-primary) !important;
}

.dp-trust-badges p {
	font-size: 13px !important;
	color: var(--dp-text-light) !important;
	margin: 0 !important;
}

/* --- Trust Badges Dynamic (shortcode) --- */
.dp-trust-badges-wrap {
	background: var(--dp-light);
	border-top: 3px solid var(--dp-accent);
}

.dp-trust-badges-dynamic {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 0;
	max-width: var(--dp-container-max, 1200px);
	margin-left: auto;
	margin-right: auto;
	padding: 40px 20px;
}

.dp-badge-item {
	text-align: center;
	padding: 24px 16px;
}

.dp-badge-icon {
	width: 56px;
	height: 56px;
	background: var(--dp-primary);
	border-radius: 50%;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	margin-bottom: 14px;
	color: var(--dp-white);
}

.dp-badge-icon svg {
	width: 26px;
	height: 26px;
	stroke: currentColor;
}

.dp-badge-title {
	font-size: 15px !important;
	font-weight: 700 !important;
	margin-bottom: 6px !important;
	color: var(--dp-primary) !important;
}

.dp-badge-desc {
	font-size: 13px !important;
	color: var(--dp-text-light) !important;
	margin: 0 !important;
}

/* ============================================================
   7. CATEGORIES GRID
   ============================================================ */
.dp-categories-section {
	padding: var(--dp-section-padding) 0;
}

.dp-section-title {
	text-align: center;
	margin-bottom: 12px;
}

.dp-section-subtitle {
	text-align: center;
	color: var(--dp-text-light);
	max-width: 600px;
	margin: 0 auto 48px auto;
}

.dp-categories-section .wp-block-column {
	background: var(--dp-white);
	border-radius: var(--dp-radius);
	overflow: hidden;
	box-shadow: var(--dp-shadow-sm);
	transition: var(--dp-transition);
	border: 1px solid var(--dp-border);
}

.dp-categories-section .wp-block-column:hover {
	transform: translateY(-6px);
	box-shadow: var(--dp-shadow-hover);
	border-color: var(--dp-secondary-light);
}

.dp-categories-section .wp-block-column figure {
	margin: 0;
	overflow: hidden;
}

.dp-categories-section .wp-block-column figure img {
	transition: var(--dp-transition);
	width: 100%;
	height: 200px;
	object-fit: cover;
}

.dp-categories-section .wp-block-column:hover figure img {
	transform: scale(1.05);
}

.dp-categories-section .wp-block-column h3 {
	font-size: 16px !important;
	padding: 16px 20px 4px;
	margin: 0 !important;
}

.dp-categories-section .wp-block-column p {
	padding: 0 20px 20px;
	font-size: 14px;
	color: var(--dp-text-light);
	margin: 0;
}

/* --- Categories Grid Dynamic (shortcode) --- */
.dp-categories-grid-dynamic {
	display: grid;
	gap: 24px;
}

.dp-categories-grid-dynamic.dp-cols-3 {
	grid-template-columns: repeat(3, 1fr);
}

.dp-categories-grid-dynamic.dp-cols-2 {
	grid-template-columns: repeat(2, 1fr);
}

.dp-categories-grid-dynamic.dp-cols-4 {
	grid-template-columns: repeat(4, 1fr);
}

/* --- Slider shared styles --- */
.dp-slider-container {
	position: relative;
	overflow: clip;
}

.dp-categories-slider,
.dp-products-slider {
	padding-bottom: 48px;
	padding-top: 10px;
	padding-inline: 4px;
	overflow: clip visible;
}

.dp-categories-slider .swiper-wrapper,
.dp-products-slider .swiper-wrapper {
	padding-top: 2px;
}

.dp-categories-slider .swiper-slide,
.dp-products-slider .swiper-slide {
	height: auto;
}

/* Swiper nav arrows */
.dp-slider-container .swiper-button-prev,
.dp-slider-container .swiper-button-next {
	width: 42px;
	height: 42px;
	background: var(--dp-white);
	border-radius: 50%;
	box-shadow: 0 2px 12px rgba(0,0,0,0.12);
	transition: var(--dp-transition);
	top: calc(50% - 24px);
}

.dp-slider-container .swiper-button-prev:hover,
.dp-slider-container .swiper-button-next:hover {
	background: var(--dp-primary);
	box-shadow: 0 4px 16px rgba(0,0,0,0.2);
}

.dp-slider-container .swiper-button-prev::after,
.dp-slider-container .swiper-button-next::after {
	font-size: 16px;
	font-weight: 700;
	color: var(--dp-primary);
	transition: var(--dp-transition);
}

.dp-slider-container .swiper-button-prev:hover::after,
.dp-slider-container .swiper-button-next:hover::after {
	color: var(--dp-white);
}

/* Swiper pagination dots */
.dp-slider-container .swiper-pagination-bullet {
	width: 10px;
	height: 10px;
	background: var(--dp-gray);
	opacity: 0.4;
	transition: var(--dp-transition);
}

.dp-slider-container .swiper-pagination-bullet-active {
	background: var(--dp-accent);
	opacity: 1;
	width: 24px;
	border-radius: 5px;
}

.dp-cat-card {
	display: block;
	background: var(--dp-white);
	border-radius: var(--dp-radius);
	overflow: hidden;
	box-shadow: var(--dp-shadow-sm);
	transition: var(--dp-transition);
	border: 1px solid var(--dp-border);
	text-decoration: none;
	color: inherit;
}

.dp-cat-card:hover {
	transform: translateY(-6px);
	box-shadow: var(--dp-shadow-hover);
	border-color: var(--dp-secondary-light);
	text-decoration: none;
	color: inherit;
}

.dp-cat-card-img {
	overflow: hidden;
	aspect-ratio: 4 / 3;
}

.dp-cat-card-img img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: var(--dp-transition);
}

.dp-cat-card:hover .dp-cat-card-img img {
	transform: scale(1.05);
}

.dp-cat-card-body {
	padding: 16px 20px 20px;
	display: flex;
	flex-wrap: wrap;
	align-items: baseline;
	gap: 4px 8px;
}

.dp-cat-card-title {
	font-size: 16px !important;
	font-weight: 700 !important;
	margin: 0 !important;
	color: var(--dp-primary);
	width: 100%;
}

.dp-cat-card-count {
	font-size: 13px;
	color: var(--dp-text-light);
}

.dp-cat-card-arrow {
	font-size: 14px;
	color: var(--dp-accent);
	margin-left: auto;
	font-weight: 600;
	transition: var(--dp-transition);
}

.dp-cat-card:hover .dp-cat-card-arrow {
	transform: translateX(4px);
}

/* --- Product Slider cards --- */
.dp-product-card {
	background: var(--dp-white);
	border-radius: var(--dp-radius);
	overflow: hidden;
	box-shadow: var(--dp-shadow-sm);
	border: 1px solid var(--dp-border);
	transition: var(--dp-transition);
	height: 100%;
	display: flex;
	flex-direction: column;
}

.dp-product-card:hover {
	transform: translateY(-6px);
	box-shadow: var(--dp-shadow-hover);
	border-color: var(--dp-secondary-light);
}

.dp-product-card-img {
	position: relative;
	overflow: hidden;
	aspect-ratio: 1;
	background: var(--dp-light);
}

.dp-product-card-img img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: var(--dp-transition);
}

.dp-product-card:hover .dp-product-card-img img {
	transform: scale(1.05);
}

.dp-product-badge {
	position: absolute;
	top: 12px;
	left: 12px;
	background: var(--dp-accent);
	color: var(--dp-white);
	font-size: 12px;
	font-weight: 700;
	padding: 4px 12px;
	border-radius: 20px;
	z-index: 1;
	text-transform: uppercase;
	letter-spacing: 0.5px;
}

.dp-product-card-body {
	padding: 16px 20px 20px;
	display: flex;
	flex-direction: column;
	flex: 1;
	gap: 8px;
}

.dp-product-card-title {
	font-size: 15px;
	font-weight: 600;
	color: var(--dp-primary);
	text-decoration: none;
	line-height: 1.4;
	display: -webkit-box;
	-webkit-line-clamp: 2;
	-webkit-box-orient: vertical;
	overflow: hidden;
}

.dp-product-card-title:hover {
	color: var(--dp-secondary);
}

.dp-product-card-price {
	font-size: 18px;
	font-weight: 700;
	color: var(--dp-primary);
	margin-top: auto;
}

.dp-product-card-price del {
	font-size: 14px;
	color: var(--dp-text-light);
	font-weight: 400;
}

.dp-product-card-price ins {
	text-decoration: none;
	color: var(--dp-accent);
}

.dp-product-card a.dp-product-card-btn {
	display: inline-block;
	text-align: center;
	background: var(--dp-primary);
	color: var(--dp-white);
	padding: 10px 16px;
	border-radius: var(--dp-radius-sm);
	font-size: 13px;
	font-weight: 600;
	text-decoration: none;
	transition: var(--dp-transition);
	margin-top: 4px;
}

.dp-product-card a.dp-product-card-btn:hover {
	background: var(--dp-accent);
	color: var(--dp-white);
	transform: translateY(-1px);
}

/* ============================================================
   8. PRODUCT CARDS / WOOCOMMERCE
   ============================================================ */
.dp-products-section {
	padding: var(--dp-section-padding) 0;
	background: var(--dp-lighter);
}

/* Product card styling */
.dp-products-section .products li.product,
.woocommerce ul.products li.product {
	background: var(--dp-white);
	border-radius: var(--dp-radius);
	overflow: hidden;
	box-shadow: var(--dp-shadow-sm);
	transition: var(--dp-transition);
	border: 1px solid var(--dp-border);
	padding-bottom: 20px;
}

.woocommerce ul.products li.product:hover {
	transform: translateY(-4px);
	box-shadow: var(--dp-shadow-hover);
}

.woocommerce ul.products li.product .woocommerce-loop-product__title {
	font-size: 15px;
	font-weight: 600;
	color: var(--dp-primary);
	padding: 12px 16px 4px;
}

.woocommerce ul.products li.product .price {
	color: var(--dp-secondary);
	font-weight: 700;
	font-size: 18px;
	padding: 0 16px;
}

.woocommerce ul.products li.product .price del {
	color: var(--dp-gray);
	font-size: 14px;
	font-weight: 400;
}

.woocommerce ul.products li.product .price ins {
	color: var(--dp-accent);
	text-decoration: none;
	font-weight: 700;
}

.woocommerce ul.products li.product .button,
.woocommerce ul.products li.product .add_to_cart_button {
	background-color: var(--dp-primary) !important;
	color: var(--dp-white) !important;
	border-radius: var(--dp-radius-sm);
	font-weight: 600;
	font-size: 13px;
	padding: 10px 20px;
	margin: 8px 16px 0;
	transition: var(--dp-transition);
	border: none;
	text-transform: none;
	letter-spacing: 0;
}

.woocommerce ul.products li.product .button:hover,
.woocommerce ul.products li.product .add_to_cart_button:hover {
	background-color: var(--dp-accent) !important;
	transform: translateY(-1px);
}

/* Sale badge */
.woocommerce span.onsale {
	background-color: var(--dp-accent);
	color: var(--dp-white);
	font-weight: 700;
	border-radius: var(--dp-radius-sm);
	padding: 4px 12px;
	font-size: 13px;
	line-height: 1.5;
	min-height: auto;
	min-width: auto;
}

/* Product images */
.woocommerce ul.products li.product a img {
	border-radius: 0;
	transition: var(--dp-transition);
}
.woocommerce ul.products li.product:hover a img {
	opacity: 0.92;
}

/* Star rating */
.woocommerce .star-rating span::before {
	color: var(--dp-accent);
}

/* Single product page */
.single-product .summary .price {
	color: var(--dp-secondary);
	font-size: 28px;
	font-weight: 700;
}

.single-product .single_add_to_cart_button {
	background-color: var(--dp-accent) !important;
	color: var(--dp-white) !important;
	border-radius: var(--dp-radius-sm);
	font-weight: 700;
	font-size: 16px;
	padding: 14px 36px;
	transition: var(--dp-transition);
	border: none;
	text-transform: none;
}

.single-product .single_add_to_cart_button:hover {
	background-color: var(--dp-accent-hover) !important;
	transform: translateY(-2px);
	box-shadow: var(--dp-shadow);
}

/* Shop page */
.woocommerce-result-count {
	color: var(--dp-text-light);
}

.woocommerce-ordering select {
	border: 1px solid var(--dp-border);
	border-radius: var(--dp-radius-sm);
	padding: 8px 12px;
}

/* ============================================================
   9. CTA SECTIONS
   ============================================================ */
.dp-cta-section {
	background: linear-gradient(135deg, var(--dp-primary) 0%, var(--dp-primary-dark) 100%);
	padding: 64px 0;
	text-align: center;
}

.dp-cta-section h2 {
	color: var(--dp-white) !important;
	font-size: clamp(1.5rem, 3vw, 2rem) !important;
	margin-bottom: 12px !important;
}

.dp-cta-section p {
	color: rgba(255, 255, 255, 0.85) !important;
	font-size: 17px;
	max-width: 600px;
	margin: 0 auto 28px auto;
}

.dp-cta-section .wp-block-button__link {
	background-color: var(--dp-accent) !important;
	color: var(--dp-white) !important;
	font-weight: 700;
	font-size: 16px;
	padding: 16px 40px;
	border-radius: var(--dp-radius-sm);
	transition: var(--dp-transition);
	border: none;
}
.dp-cta-section .wp-block-button__link:hover {
	background-color: var(--dp-accent-hover) !important;
	transform: translateY(-2px);
	box-shadow: 0 6px 24px rgba(230, 126, 34, 0.4);
}

/* Secondary CTA variant */
.dp-cta-light {
	background: var(--dp-light);
}
.dp-cta-light h2 {
	color: var(--dp-primary) !important;
}
.dp-cta-light p {
	color: var(--dp-text-light) !important;
}

/* ============================================================
   10. FAQ SECTION — Menor protagonismo
   ============================================================ */
.dp-faq-section {
	padding: 64px 0 72px !important;
	background: var(--dp-lighter);
}

.dp-faq-section .dp-section-title {
	font-size: clamp(1.25rem, 2.5vw, 1.6rem) !important;
}

.dp-faq-section details {
	border: 1px solid var(--dp-border);
	border-radius: var(--dp-radius);
	margin-bottom: 10px;
	transition: var(--dp-transition);
	overflow: hidden;
	background: var(--dp-white);
}

.dp-faq-section details:hover {
	border-color: var(--dp-secondary-light);
}

.dp-faq-section details[open] {
	border-color: var(--dp-secondary);
	box-shadow: var(--dp-shadow-sm);
}

.dp-faq-section details summary {
	padding: 16px 22px;
	font-weight: 600;
	font-size: 15px;
	color: var(--dp-primary);
	cursor: pointer;
	list-style: none;
	display: flex;
	align-items: center;
	justify-content: space-between;
	transition: var(--dp-transition-fast);
}

.dp-faq-section details summary::-webkit-details-marker {
	display: none;
}

.dp-faq-section details summary::after {
	content: '+';
	font-size: 20px;
	font-weight: 300;
	color: var(--dp-accent);
	transition: var(--dp-transition);
	flex-shrink: 0;
	margin-left: 16px;
}

.dp-faq-section details[open] summary::after {
	content: '−';
}

.dp-faq-section details[open] summary {
	border-bottom: 1px solid var(--dp-border);
	background: var(--dp-lighter);
}

.dp-faq-section details > div,
.dp-faq-section details > p {
	padding: 16px 22px;
	color: var(--dp-text-light);
	line-height: 1.7;
	font-size: 14px;
}

/* ============================================================
   11. NEWSLETTER SECTION
   ============================================================ */
.dp-newsletter-section {
	background: linear-gradient(135deg, var(--dp-secondary) 0%, var(--dp-primary) 100%);
	padding: 80px 24px !important;
	text-align: center;
	position: relative;
	margin-bottom: 0 !important;
}

.dp-newsletter-section h2 {
	color: var(--dp-white) !important;
	margin-bottom: 8px !important;
}

.dp-newsletter-section p {
	color: rgba(255, 255, 255, 0.85) !important;
	margin-bottom: 28px;
}

.dp-newsletter-section form {
	max-width: 500px;
	margin: 0 auto;
	display: flex;
	gap: 10px;
}

.dp-newsletter-section input[type="email"] {
	flex: 1;
	padding: 14px 20px;
	border: 2px solid rgba(255, 255, 255, 0.3);
	border-radius: var(--dp-radius-sm);
	background: rgba(255, 255, 255, 0.15);
	color: var(--dp-white);
	font-size: 15px;
	outline: none;
	transition: var(--dp-transition);
	box-sizing: border-box;
	height: 50px;
}
.dp-newsletter-section input[type="email"]::placeholder {
	color: rgba(255, 255, 255, 0.6);
}
.dp-newsletter-section input[type="email"]:focus {
	border-color: var(--dp-accent-light);
	background: rgba(255, 255, 255, 0.2);
}

.dp-newsletter-section button,
.dp-newsletter-section input[type="submit"] {
	background: var(--dp-accent);
	color: var(--dp-white);
	border: none;
	padding: 14px 28px;
	border-radius: var(--dp-radius-sm);
	font-weight: 700;
	font-size: 15px;
	cursor: pointer;
	transition: var(--dp-transition);
	box-sizing: border-box;
	height: 50px;
}
.dp-newsletter-section button:hover,
.dp-newsletter-section input[type="submit"]:hover {
	background: var(--dp-accent-hover);
	transform: translateY(-1px);
}

/* ============================================================
   12. ABOUT PAGE
   ============================================================ */
.dp-about-section {
	padding: var(--dp-section-padding) 0;
}

.dp-about-story {
	padding: var(--dp-section-padding) 0;
}

.dp-about-story .wp-block-media-text {
	gap: 48px;
}

.dp-values-grid .wp-block-column {
	background: var(--dp-white);
	border-radius: var(--dp-radius);
	padding: 36px 28px;
	text-align: center;
	box-shadow: var(--dp-shadow-sm);
	border: 1px solid var(--dp-border);
	transition: var(--dp-transition);
}

.dp-values-grid .wp-block-column:hover {
	transform: translateY(-4px);
	box-shadow: var(--dp-shadow);
	border-color: var(--dp-secondary-light);
}

.dp-values-grid .dp-value-icon {
	font-size: 40px;
	margin-bottom: 16px;
	display: block;
}

.dp-values-grid h3 {
	font-size: 18px !important;
	margin-bottom: 10px !important;
}

.dp-values-grid p {
	color: var(--dp-text-light);
	font-size: 14px;
}

/* Stats / Numbers — Premium Counters */
.dp-stats-section {
	background: linear-gradient(135deg, var(--dp-primary-dark) 0%, var(--dp-primary) 50%, var(--dp-primary-light) 100%);
	padding: 72px 0;
	position: relative;
	overflow: hidden;
}

/* Diagonal industrial texture */
.dp-stats-section::before {
	content: '';
	position: absolute;
	inset: 0;
	background-image:
		repeating-linear-gradient(
			45deg,
			transparent,
			transparent 60px,
			rgba(255, 255, 255, 0.02) 60px,
			rgba(255, 255, 255, 0.02) 61px
		);
	pointer-events: none;
}

/* Glow accents */
.dp-stats-section::after {
	content: '';
	position: absolute;
	inset: 0;
	background:
		radial-gradient(circle at 10% 50%, rgba(230, 126, 34, 0.1) 0%, transparent 40%),
		radial-gradient(circle at 90% 50%, rgba(41, 128, 185, 0.1) 0%, transparent 40%);
	pointer-events: none;
}

.dp-stats-section .wp-block-columns {
	position: relative;
	z-index: 1;
}

.dp-stats-section .wp-block-column {
	text-align: center;
	padding: 28px 20px;
	position: relative;
}

/* Vertical luminous divider between stats */
.dp-stats-section .wp-block-column + .wp-block-column::before {
	content: '';
	position: absolute;
	left: 0;
	top: 15%;
	height: 70%;
	width: 1px;
	background: linear-gradient(180deg, transparent, rgba(230, 126, 34, 0.4), rgba(41, 128, 185, 0.3), transparent);
}

.dp-stats-section .dp-stat-number {
	font-size: clamp(2.5rem, 5vw, 3.5rem);
	font-weight: 800;
	background: linear-gradient(135deg, var(--dp-accent-light), var(--dp-accent), #f5b041);
	-webkit-background-clip: text;
	-webkit-text-fill-color: transparent;
	background-clip: text;
	line-height: 1.15;
	margin-bottom: 8px;
	filter: drop-shadow(0 2px 8px rgba(230, 126, 34, 0.25));
}

.dp-stats-section h4,
.dp-stats-section p {
	color: rgba(255, 255, 255, 0.75) !important;
	font-size: 15px;
	font-weight: 500;
	margin: 0 !important;
	letter-spacing: 0.01em;
}

/* ============================================================
   13. CONTACT PAGE
   ============================================================ */
.dp-contact-section {
	padding: var(--dp-section-padding) 0;
}

.dp-contact-info {
	background: var(--dp-light);
	border-radius: var(--dp-radius);
	padding: 36px;
}

.dp-contact-info h3 {
	font-size: 20px !important;
	margin-bottom: 24px !important;
}

.dp-contact-item {
	display: flex;
	align-items: flex-start;
	gap: 14px;
	margin-bottom: 20px;
	padding-bottom: 20px;
	border-bottom: 1px solid var(--dp-border);
}

.dp-contact-item:last-child {
	border-bottom: none;
	margin-bottom: 0;
	padding-bottom: 0;
}

.dp-contact-item-icon {
	width: 44px;
	height: 44px;
	background: var(--dp-primary);
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	color: var(--dp-white);
	font-size: 18px;
	flex-shrink: 0;
}

.dp-contact-item h4 {
	font-size: 14px !important;
	margin: 0 0 4px 0 !important;
	color: var(--dp-primary) !important;
}

.dp-contact-item p {
	margin: 0 !important;
	color: var(--dp-text-light);
	font-size: 14px;
}

/* Contact form styling */
.dp-contact-section .wpcf7,
.dp-contact-section .wpforms-container {
	background: var(--dp-white);
	border-radius: var(--dp-radius);
	padding: 36px;
	box-shadow: var(--dp-shadow-sm);
	border: 1px solid var(--dp-border);
}

.dp-contact-section input[type="text"],
.dp-contact-section input[type="email"],
.dp-contact-section input[type="tel"],
.dp-contact-section textarea,
.dp-contact-section select {
	border: 1px solid var(--dp-border);
	border-radius: var(--dp-radius-sm);
	padding: 12px 16px;
	font-size: 15px;
	transition: var(--dp-transition-fast);
	width: 100%;
	font-family: inherit;
}

.dp-contact-section input:focus,
.dp-contact-section textarea:focus,
.dp-contact-section select:focus {
	border-color: var(--dp-secondary);
	outline: none;
	box-shadow: 0 0 0 3px rgba(41, 128, 185, 0.12);
}

.dp-contact-section input[type="submit"],
.dp-contact-section button[type="submit"] {
	background: var(--dp-accent);
	color: var(--dp-white);
	border: none;
	border-radius: var(--dp-radius-sm);
	padding: 14px 36px;
	font-size: 16px;
	font-weight: 700;
	cursor: pointer;
	transition: var(--dp-transition);
}

.dp-contact-section input[type="submit"]:hover,
.dp-contact-section button[type="submit"]:hover {
	background: var(--dp-accent-hover);
	transform: translateY(-2px);
	box-shadow: var(--dp-shadow);
}

/* Map container */
.dp-map-section {
	margin-top: 48px;
}

.dp-map-section iframe {
	border-radius: var(--dp-radius);
	border: 1px solid var(--dp-border);
}

/* ============================================================
   14. BUTTONS (Global)
   ============================================================ */
.wp-block-button__link {
	border-radius: var(--dp-radius-sm);
	font-weight: 600;
	font-size: 15px;
	padding: 14px 32px;
	transition: var(--dp-transition);
}

/* Primary button */
.dp-btn-primary .wp-block-button__link,
.is-style-fill .wp-block-button__link {
	background-color: var(--dp-accent) !important;
	color: var(--dp-white) !important;
	border: none;
}
.dp-btn-primary .wp-block-button__link:hover,
.is-style-fill .wp-block-button__link:hover {
	background-color: var(--dp-accent-hover) !important;
	transform: translateY(-2px);
	box-shadow: 0 4px 16px rgba(230, 126, 34, 0.35);
}

/* Outline button */
.dp-btn-outline .wp-block-button__link,
.is-style-outline .wp-block-button__link {
	background-color: transparent !important;
	color: var(--dp-white) !important;
	border: 2px solid var(--dp-white) !important;
}
.dp-btn-outline .wp-block-button__link:hover,
.is-style-outline .wp-block-button__link:hover {
	background-color: var(--dp-white) !important;
	color: var(--dp-primary) !important;
}

/* Dark variant */
.dp-btn-dark .wp-block-button__link {
	background-color: var(--dp-primary) !important;
	color: var(--dp-white) !important;
}
.dp-btn-dark .wp-block-button__link:hover {
	background-color: var(--dp-primary-light) !important;
	transform: translateY(-2px);
}

/* ============================================================
   15. ABOUT BRIEF (for Home page)
   ============================================================ */
.dp-about-brief {
	padding: 80px 0 100px !important;
	background: var(--dp-light) !important;
	background-color: var(--dp-light) !important;
	position: relative;
	overflow: visible;
}

/* Wave transition removed — clean separation */

.dp-about-brief .wp-block-media-text__content h2 {
	color: var(--dp-primary);
	position: relative;
	padding-bottom: 16px;
	margin-bottom: 20px;
}

.dp-about-brief .wp-block-media-text__content h2::after {
	content: '';
	position: absolute;
	bottom: 0;
	left: 0;
	width: 60px;
	height: 3px;
	background: var(--dp-accent);
	border-radius: 2px;
}

.dp-about-brief .wp-block-media-text__media img {
	border-radius: var(--dp-radius);
}

/* ============================================================
   NEW-1. BRANDS / PARTNERS LOGO BAR
   ============================================================ */
.dp-brands-section {
	padding: 48px 0 !important;
	background: var(--dp-white);
	border-bottom: 1px solid var(--dp-border);
}

.dp-brands-label {
	text-align: center;
	font-size: 13px;
	text-transform: uppercase;
	letter-spacing: 0.1em;
	color: var(--dp-gray);
	font-weight: 600;
	margin-bottom: 28px;
}

.dp-brands-logos {
	display: flex;
	align-items: center;
	justify-content: center;
	flex-wrap: wrap;
	gap: 32px 48px;
	max-width: var(--dp-container-max);
	margin: 0 auto;
	padding: 0 20px;
}

.dp-brands-logos img,
.dp-brands-logos .wp-block-image img {
	height: 44px;
	width: auto;
	object-fit: contain;
	filter: grayscale(100%) opacity(0.5);
	transition: var(--dp-transition);
}

.dp-brands-logos img:hover,
.dp-brands-logos .wp-block-image:hover img {
	filter: grayscale(0%) opacity(1);
}

/* Swiper brands variant */
.dp-brands-slider .swiper-slide {
	display: flex;
	align-items: center;
	justify-content: center;
	height: 60px;
}

.dp-brands-slider .swiper-slide img {
	height: 40px;
	width: auto;
	object-fit: contain;
	filter: grayscale(100%) opacity(0.45);
	transition: var(--dp-transition);
}

.dp-brands-slider .swiper-slide:hover img {
	filter: grayscale(0%) opacity(1);
}

/* Brand name badges (fallback when no logos uploaded) */
.dp-brand-badge {
	display: inline-flex;
	align-items: center;
	padding: 8px 20px;
	background: var(--dp-lighter);
	border: 1px solid var(--dp-border);
	border-radius: var(--dp-radius-sm);
	font-size: 14px;
	font-weight: 600;
	color: var(--dp-primary);
	letter-spacing: 0.02em;
	transition: var(--dp-transition);
}

.dp-brand-badge:hover {
	background: var(--dp-secondary);
	color: var(--dp-white);
	border-color: var(--dp-secondary);
}

/* ============================================================
   NEW-2. SECTORS / INDUSTRIES SERVED
   ============================================================ */
.dp-sectors-section {
	padding: var(--dp-section-padding) 0 !important;
	background: var(--dp-white);
}

.dp-sectors-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 24px;
	max-width: var(--dp-container-max);
	margin: 0 auto;
	padding: 0 20px;
}

.dp-sector-card {
	background: var(--dp-lighter);
	border: 1px solid var(--dp-border);
	border-radius: var(--dp-radius);
	padding: 36px 28px;
	text-align: center;
	transition: var(--dp-transition);
	position: relative;
	overflow: hidden;
}

.dp-sector-card::before {
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	height: 3px;
	background: var(--dp-accent);
	transform: scaleX(0);
	transition: var(--dp-transition);
}

.dp-sector-card:hover {
	transform: translateY(-4px);
	box-shadow: var(--dp-shadow);
	border-color: var(--dp-secondary-light);
}

.dp-sector-card:hover::before {
	transform: scaleX(1);
}

.dp-sector-icon {
	width: 64px;
	height: 64px;
	background: var(--dp-primary);
	border-radius: var(--dp-radius);
	display: inline-flex;
	align-items: center;
	justify-content: center;
	margin-bottom: 20px;
	color: var(--dp-white);
	font-size: 28px;
}

.dp-sector-icon svg {
	width: 30px;
	height: 30px;
	stroke: currentColor;
	fill: none;
}

.dp-sector-card h3 {
	font-size: 17px !important;
	margin-bottom: 10px !important;
	color: var(--dp-primary) !important;
}

.dp-sector-card p {
	font-size: 14px;
	color: var(--dp-text-light);
	line-height: 1.6;
	margin: 0;
}

/* ============================================================
   NEW-3. HOW WE WORK — Process Steps — Premium
   ============================================================ */
.dp-process-section {
	padding: var(--dp-section-padding) 0 !important;
	background: var(--dp-primary);
	position: relative;
	overflow: hidden;
}

.dp-process-section::before {
	content: '';
	position: absolute;
	inset: 0;
	background:
		radial-gradient(ellipse at 20% 50%, rgba(41, 128, 185, 0.15), transparent 60%),
		radial-gradient(ellipse at 80% 20%, rgba(230, 126, 34, 0.08), transparent 50%);
	pointer-events: none;
}

/* Grid pattern overlay */
.dp-process-section::after {
	content: '';
	position: absolute;
	inset: 0;
	background-image:
		linear-gradient(rgba(255, 255, 255, 0.02) 1px, transparent 1px),
		linear-gradient(90deg, rgba(255, 255, 255, 0.02) 1px, transparent 1px);
	background-size: 60px 60px;
	pointer-events: none;
}

.dp-process-section h2 {
	color: var(--dp-white) !important;
}

.dp-process-section .dp-section-subtitle {
	color: rgba(255, 255, 255, 0.7) !important;
}

.dp-process-steps {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 32px;
	max-width: var(--dp-container-max);
	margin: 0 auto;
	padding: 0 20px;
	position: relative;
	z-index: 1;
}

/* Horizontal connector line */
.dp-process-connector {
	position: absolute;
	top: 48px;
	left: calc(12.5% + 16px);
	right: calc(12.5% + 16px);
	height: 2px;
	background: linear-gradient(90deg, var(--dp-accent), var(--dp-secondary-light), var(--dp-accent));
	opacity: 0.3;
	z-index: 0;
}

.dp-process-step {
	text-align: center;
	position: relative;
	z-index: 1;
	padding: 0 8px;
	animation: dp-fadeInUp 0.5s ease both;
	animation-delay: var(--step-delay, 0s);
}

.dp-step-number-wrap {
	position: relative;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	margin-bottom: 24px;
}

.dp-step-number {
	width: 80px;
	height: 80px;
	border-radius: 50%;
	background: rgba(255, 255, 255, 0.06);
	backdrop-filter: blur(8px);
	-webkit-backdrop-filter: blur(8px);
	border: 2px solid rgba(230, 126, 34, 0.5);
	display: inline-flex;
	align-items: center;
	justify-content: center;
	font-size: 26px;
	font-weight: 800;
	color: var(--dp-accent-light);
	transition: var(--dp-transition);
	position: relative;
	z-index: 1;
	box-shadow: 0 0 20px rgba(230, 126, 34, 0.1);
}

.dp-process-step:hover .dp-step-number {
	background: var(--dp-accent);
	color: var(--dp-white);
	transform: scale(1.12);
	border-color: var(--dp-accent);
	box-shadow: 0 0 32px rgba(230, 126, 34, 0.35);
}

/* Mini icon below the number */
.dp-step-icon-mini {
	position: absolute;
	bottom: -8px;
	right: -4px;
	width: 28px;
	height: 28px;
	background: var(--dp-secondary);
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	color: var(--dp-white);
	box-shadow: 0 2px 8px rgba(0, 0, 0, 0.2);
	z-index: 2;
}

.dp-step-icon-mini svg {
	width: 14px;
	height: 14px;
	stroke: currentColor;
	fill: none;
}

.dp-process-step h3 {
	font-size: 17px !important;
	color: var(--dp-white) !important;
	margin-bottom: 8px !important;
	font-weight: 700;
}

.dp-process-step p {
	font-size: 14px;
	color: rgba(255, 255, 255, 0.6);
	line-height: 1.65;
}

/* ============================================================
   NEW-4. TESTIMONIALS
   ============================================================ */
.dp-testimonials-section {
	padding: var(--dp-section-padding) 0 !important;
	background: var(--dp-lighter);
}

.dp-testimonials-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 28px;
	max-width: var(--dp-container-max);
	margin: 0 auto;
	padding: 0 20px;
}

.dp-testimonial-card {
	background: var(--dp-white);
	border-radius: var(--dp-radius);
	padding: 32px 28px;
	box-shadow: var(--dp-shadow-sm);
	border: 1px solid var(--dp-border);
	position: relative;
	transition: var(--dp-transition);
}

.dp-testimonial-card:hover {
	transform: translateY(-4px);
	box-shadow: var(--dp-shadow);
}

/* Quote mark decorative */
.dp-testimonial-card::before {
	content: '"';
	position: absolute;
	top: 16px;
	right: 24px;
	font-size: 56px;
	line-height: 1;
	font-family: Georgia, serif;
	color: var(--dp-accent);
	opacity: 0.15;
}

.dp-testimonial-stars {
	color: var(--dp-accent);
	font-size: 16px;
	margin-bottom: 12px;
	letter-spacing: 2px;
}

.dp-testimonial-text {
	font-size: 14px;
	color: var(--dp-text-light);
	line-height: 1.7;
	margin-bottom: 20px;
	font-style: italic;
}

.dp-testimonial-author {
	display: flex;
	align-items: center;
	gap: 12px;
}

.dp-testimonial-avatar {
	width: 44px;
	height: 44px;
	border-radius: 50%;
	background: var(--dp-primary);
	color: var(--dp-white);
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 16px;
	font-weight: 700;
	flex-shrink: 0;
}

.dp-testimonial-name {
	font-size: 15px;
	font-weight: 600;
	color: var(--dp-primary);
	line-height: 1.3;
}

.dp-testimonial-role {
	font-size: 13px;
	color: var(--dp-text-light);
}

/* ============================================================
   NEW-5. GUARANTEES & SUPPORT
   ============================================================ */
.dp-guarantees-section {
	padding: 64px 0 !important;
	background: var(--dp-white);
	border-top: 1px solid var(--dp-border);
	border-bottom: 1px solid var(--dp-border);
}

.dp-guarantees-grid {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 24px;
	max-width: var(--dp-container-max);
	margin: 0 auto;
	padding: 0 20px;
}

.dp-guarantee-item {
	display: flex;
	align-items: flex-start;
	gap: 16px;
	padding: 20px;
}

.dp-guarantee-icon {
	width: 48px;
	height: 48px;
	min-width: 48px;
	background: linear-gradient(135deg, var(--dp-primary) 0%, var(--dp-secondary) 100%);
	border-radius: var(--dp-radius-sm);
	display: flex;
	align-items: center;
	justify-content: center;
	color: var(--dp-white);
}

.dp-guarantee-icon svg {
	width: 24px;
	height: 24px;
	stroke: currentColor;
	fill: none;
}

.dp-guarantee-item h4 {
	font-size: 15px !important;
	margin: 0 0 4px !important;
	color: var(--dp-primary) !important;
}

.dp-guarantee-item p {
	font-size: 13px;
	color: var(--dp-text-light);
	line-height: 1.5;
	margin: 0;
}

/* ============================================================
   NEW-6. WHATSAPP CHAT WIDGET
   ============================================================ */
.dp-wa-widget {
	position: fixed;
	bottom: 24px;
	right: 24px;
	z-index: 9999;
	display: flex;
	flex-direction: column;
	align-items: flex-end;
	gap: 14px;
	pointer-events: none;
}

.dp-wa-fab,
.dp-wa-open .dp-wa-popup {
	pointer-events: auto;
}

/* FAB button */
.dp-wa-fab {
	width: 60px;
	height: 60px;
	border-radius: 50%;
	background-color: #25d366;
	border: none;
	cursor: pointer;
	display: flex;
	align-items: center;
	justify-content: center;
	box-shadow: 0 4px 20px rgba(37, 211, 102, 0.4);
	transition: var(--dp-transition);
	position: relative;
}

.dp-wa-fab:hover {
	transform: scale(1.08) translateY(-2px);
	box-shadow: 0 6px 28px rgba(37, 211, 102, 0.5);
	background-color: #1da851;
}

.dp-wa-fab svg {
	width: 30px;
	height: 30px;
	fill: var(--dp-white);
	transition: transform 0.3s ease, opacity 0.3s ease;
}

.dp-wa-fab .dp-wa-fab-icon {
	opacity: 1;
	transform: scale(1);
}

.dp-wa-fab .dp-wa-fab-close {
	position: absolute;
	opacity: 0;
	transform: scale(0) rotate(-90deg);
}

.dp-wa-open .dp-wa-fab .dp-wa-fab-icon {
	opacity: 0;
	transform: scale(0) rotate(90deg);
}

.dp-wa-open .dp-wa-fab .dp-wa-fab-close {
	opacity: 1;
	transform: scale(1) rotate(0deg);
}

/* Popup card */
.dp-wa-popup {
	width: 340px;
	background: var(--dp-white);
	border-radius: var(--dp-radius-lg);
	box-shadow: 0 8px 40px rgba(0, 0, 0, 0.18);
	overflow: hidden;
	transform: scale(0.8) translateY(20px);
	opacity: 0;
	pointer-events: none;
	transition: transform 0.3s cubic-bezier(0.34, 1.56, 0.64, 1), opacity 0.25s ease;
	transform-origin: bottom right;
}

.dp-wa-open .dp-wa-popup {
	transform: scale(1) translateY(0);
	opacity: 1;
	pointer-events: auto;
}

/* Header */
.dp-wa-popup-header {
	background: #075e54;
	padding: 16px 18px;
	display: flex;
	align-items: center;
	gap: 12px;
}

.dp-wa-popup-avatar {
	width: 42px;
	height: 42px;
	border-radius: 50%;
	background: #128c7e;
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
}

.dp-wa-popup-info {
	flex: 1;
	min-width: 0;
}

.dp-wa-popup-info strong {
	color: var(--dp-white);
	font-size: 14px;
	display: block;
	line-height: 1.3;
}

.dp-wa-popup-info span {
	color: rgba(255, 255, 255, 0.7);
	font-size: 12px;
}

.dp-wa-popup-close {
	background: none;
	border: none;
	color: rgba(255, 255, 255, 0.7);
	font-size: 24px;
	cursor: pointer;
	padding: 0 4px;
	line-height: 1;
	transition: var(--dp-transition-fast);
}

.dp-wa-popup-close:hover {
	color: var(--dp-white);
}

/* Body — chat bubble */
.dp-wa-popup-body {
	padding: 20px 18px;
	background: #e5ddd5;
	background-image: url("data:image/svg+xml,%3Csvg width='60' height='60' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M30 5c1 0 2 1 2 2s-1 2-2 2-2-1-2-2 1-2 2-2' fill='%23d1c7b7' fill-opacity='.12'/%3E%3C/svg%3E");
}

.dp-wa-bubble {
	background: var(--dp-white);
	border-radius: 0 12px 12px 12px;
	padding: 12px 16px;
	font-size: 14px;
	line-height: 1.55;
	color: var(--dp-text);
	box-shadow: 0 1px 2px rgba(0, 0, 0, 0.08);
	max-width: 90%;
	position: relative;
}

.dp-wa-bubble::before {
	content: '';
	position: absolute;
	top: 0;
	left: -8px;
	width: 0;
	height: 0;
	border-top: 8px solid var(--dp-white);
	border-left: 8px solid transparent;
}

/* Footer — input area */
.dp-wa-popup-footer {
	padding: 12px 14px;
	background: var(--dp-white);
	display: flex;
	align-items: flex-end;
	gap: 10px;
	border-top: 1px solid var(--dp-border);
}

.dp-wa-input {
	flex: 1;
	border: 1px solid var(--dp-border);
	border-radius: 20px;
	padding: 10px 16px;
	font-size: 14px;
	font-family: inherit;
	resize: none;
	outline: none;
	line-height: 1.4;
	max-height: 80px;
	transition: var(--dp-transition-fast);
	color: var(--dp-text);
}

.dp-wa-input:focus {
	border-color: #25d366;
	box-shadow: 0 0 0 2px rgba(37, 211, 102, 0.15);
}

.dp-wa-input::placeholder {
	color: var(--dp-gray);
}

.dp-wa-send {
	width: 40px;
	height: 40px;
	min-width: 40px;
	border-radius: 50%;
	background: #25d366;
	border: none;
	cursor: pointer;
	display: flex;
	align-items: center;
	justify-content: center;
	transition: var(--dp-transition);
}

.dp-wa-send:hover {
	background: #1da851;
	transform: scale(1.08);
}

/* ============================================================
   NEW-7. SECTION UTILITIES
   ============================================================ */

/* Section title with decorative accent bar */
.dp-section-title-decorated {
	text-align: center;
	position: relative;
	padding-bottom: 16px;
	margin-bottom: 12px;
}

.dp-section-title-decorated::after {
	content: '';
	position: absolute;
	bottom: 0;
	left: 50%;
	transform: translateX(-50%);
	width: 48px;
	height: 3px;
	background: var(--dp-accent);
	border-radius: 2px;
}

/* Industrial background textures */
.dp-bg-blueprint {
	background-color: var(--dp-lighter);
	background-image:
		linear-gradient(rgba(26, 58, 92, 0.03) 1px, transparent 1px),
		linear-gradient(90deg, rgba(26, 58, 92, 0.03) 1px, transparent 1px);
	background-size: 40px 40px;
}

.dp-bg-frost {
	background: linear-gradient(180deg, var(--dp-lighter) 0%, var(--dp-white) 100%);
	position: relative;
}

.dp-bg-frost::before {
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	height: 100%;
	background:
		radial-gradient(ellipse at 10% 0%, rgba(41, 128, 185, 0.05), transparent 40%),
		radial-gradient(ellipse at 90% 100%, rgba(41, 128, 185, 0.04), transparent 40%);
	pointer-events: none;
}

/* ============================================================
   16. ANIMATIONS
   ============================================================ */
@keyframes dp-fadeInUp {
	from {
		opacity: 0;
		transform: translateY(20px);
	}
	to {
		opacity: 1;
		transform: translateY(0);
	}
}

@keyframes dp-fadeIn {
	from { opacity: 0; }
	to { opacity: 1; }
}

.dp-animate {
	animation: dp-fadeInUp 0.6s ease forwards;
}

/* Subtle pulse for CTAs */
@keyframes dp-pulse {
	0%, 100% { box-shadow: 0 0 0 0 rgba(230, 126, 34, 0.4); }
	50% { box-shadow: 0 0 0 10px rgba(230, 126, 34, 0); }
}

.dp-pulse {
	animation: dp-pulse 2s infinite;
}

/* Mascot floating animation */
@keyframes dp-float {
	0%, 100% {
		transform: translateY(0);
	}
	50% {
		transform: translateY(-12px);
	}
}

/* Mascot entrance — slide up + fade in */
@keyframes dp-mascotEntrance {
	from {
		opacity: 0;
		transform: translateY(60px);
	}
	to {
		opacity: 1;
		transform: translateY(0);
	}
}

/* ============================================================
   17. BREADCRUMBS
   ============================================================ */
.ct-breadcrumbs {
	font-size: 13px;
	color: var(--dp-text-light);
	padding: 12px 0;
}

.ct-breadcrumbs a {
	color: var(--dp-secondary);
}

.ct-breadcrumbs a:hover {
	color: var(--dp-accent);
}

/* ============================================================
   18. WOOCOMMERCE PAGES (Cart, Checkout)
   ============================================================ */
.woocommerce-cart .wc-proceed-to-checkout .checkout-button,
.woocommerce-checkout #place_order {
	background-color: var(--dp-accent) !important;
	color: var(--dp-white) !important;
	border: none;
	border-radius: var(--dp-radius-sm);
	font-weight: 700;
	font-size: 16px;
	padding: 16px 32px;
	transition: var(--dp-transition);
}

.woocommerce-cart .wc-proceed-to-checkout .checkout-button:hover,
.woocommerce-checkout #place_order:hover {
	background-color: var(--dp-accent-hover) !important;
	transform: translateY(-1px);
	box-shadow: var(--dp-shadow);
}

.woocommerce table.shop_table {
	border-radius: var(--dp-radius);
	overflow: hidden;
	border: 1px solid var(--dp-border);
}

.woocommerce table.shop_table th {
	background: var(--dp-light);
	color: var(--dp-primary);
	font-weight: 600;
}

/* Coupon field */
.woocommerce .coupon .input-text {
	border-radius: var(--dp-radius-sm);
	border: 1px solid var(--dp-border);
	padding: 10px 14px;
}

.woocommerce .coupon .button {
	background-color: var(--dp-primary) !important;
	color: var(--dp-white) !important;
	border-radius: var(--dp-radius-sm);
	border: none;
	font-weight: 600;
}

/* ============================================================
   19. MISCELLANEOUS
   ============================================================ */

/* Scrollbar styling */
::-webkit-scrollbar {
	width: 10px;
}
::-webkit-scrollbar-track {
	background: var(--dp-light);
}
::-webkit-scrollbar-thumb {
	background: var(--dp-gray);
	border-radius: 5px;
}
::-webkit-scrollbar-thumb:hover {
	background: var(--dp-primary);
}

/* Selection color */
::selection {
	background: var(--dp-secondary);
	color: var(--dp-white);
}

/* Pagination */
.ct-pagination .page-numbers {
	border-radius: var(--dp-radius-sm);
	transition: var(--dp-transition-fast);
}

.ct-pagination .page-numbers.current,
.ct-pagination .page-numbers:hover {
	background-color: var(--dp-primary);
	color: var(--dp-white);
}

/* Blocksy notice styling */
.woocommerce-message {
	border-top-color: var(--dp-success);
}

.woocommerce-error {
	border-top-color: var(--dp-error);
}

/* Back to top button */
.ct-back-to-top {
	background-color: var(--dp-primary) !important;
	color: var(--dp-white) !important;
	border-radius: 50% !important;
	box-shadow: var(--dp-shadow);
	transition: var(--dp-transition);
}
.ct-back-to-top:hover {
	background-color: var(--dp-accent) !important;
	transform: translateY(-3px);
}

/* ============================================================
   20. RESPONSIVE
   ============================================================ */
@media (max-width: 999px) {
	.dp-hero-section .wp-block-cover {
		min-height: auto !important;
	}

	.dp-hero-section h1 {
		font-size: clamp(1.75rem, 4vw, 2.5rem) !important;
	}

	.dp-hero-mascot {
		width: 120px;
		opacity: 0.1;
	}

	.dp-trust-badges .wp-block-columns {
		flex-wrap: wrap;
	}

	.dp-trust-badges .wp-block-column {
		flex-basis: 50% !important;
	}

	.dp-categories-section .wp-block-columns {
		flex-wrap: wrap;
	}

	.dp-categories-section .wp-block-column {
		flex-basis: calc(50% - 16px) !important;
	}

	/* Dynamic components */
	.dp-trust-badges-dynamic {
		grid-template-columns: repeat(2, 1fr);
	}

	/* Slider arrows hidden on tablet */
	.dp-slider-container .swiper-button-prev,
	.dp-slider-container .swiper-button-next {
		display: none;
	}

	.dp-stats-section .wp-block-column {
		flex-basis: 50% !important;
	}

	/* Hide stat dividers on tablet */
	.dp-stats-section .wp-block-column + .wp-block-column::before {
		display: none;
	}

	/* New sections tablet */
	.dp-sectors-grid {
		grid-template-columns: repeat(2, 1fr);
	}

	.dp-process-steps {
		grid-template-columns: repeat(2, 1fr);
		gap: 24px;
	}

	/* Hide horizontal connector on tablet */
	.dp-process-connector {
		display: none;
	}

	.dp-process-steps::before {
		display: none;
	}

	.dp-testimonials-grid {
		grid-template-columns: repeat(2, 1fr);
	}

	.dp-guarantees-grid {
		grid-template-columns: repeat(2, 1fr);
	}
}

@media (max-width: 689px) {
	:root {
		--dp-section-padding: 48px;
	}

	.dp-hero-section .wp-block-cover {
		min-height: auto !important;
		padding: 48px 16px !important;
	}

	.dp-hero-section h1 {
		font-size: 1.6rem !important;
	}

	.dp-hero-mascot {
		display: none;
	}

	.dp-trust-badges .wp-block-column {
		flex-basis: 100% !important;
		padding: 16px;
	}

	.dp-categories-section .wp-block-column {
		flex-basis: 100% !important;
	}

	/* Dynamic components */
	.dp-trust-badges-dynamic {
		grid-template-columns: 1fr;
	}

	.dp-stats-section .wp-block-column {
		flex-basis: 100% !important;
		padding: 12px;
	}

	.dp-stats-section .wp-block-column + .wp-block-column::before {
		display: none;
	}

	.dp-newsletter-section form {
		flex-direction: column;
	}

	.dp-contact-section .wp-block-columns {
		flex-direction: column-reverse;
	}

	/* New sections mobile */
	.dp-sectors-grid {
		grid-template-columns: 1fr;
	}

	.dp-process-steps {
		grid-template-columns: 1fr;
		gap: 20px;
	}

	.dp-process-connector {
		display: none;
	}

	.dp-testimonials-grid {
		grid-template-columns: 1fr;
	}

	.dp-guarantees-grid {
		grid-template-columns: 1fr;
	}

	.dp-brands-logos {
		gap: 20px 32px;
	}

	.dp-brands-logos img,
	.dp-brands-logos .wp-block-image img {
		height: 32px;
	}

	/* WooCommerce mobile */
	.woocommerce ul.products[class*="columns-"] li.product {
		width: 100% !important;
		margin-right: 0 !important;
	}

	/* WhatsApp widget mobile */
	.dp-wa-fab {
		width: 52px;
		height: 52px;
	}

	.dp-wa-fab svg {
		width: 26px;
		height: 26px;
	}

	.dp-wa-popup {
		width: calc(100vw - 32px);
		max-width: 340px;
	}
}

/* ============================================================
   21. HEADER INLINE SEARCH (replaces Blocksy modal search)
   ============================================================ */
.dp-header-search {
	display: flex;
	align-items: center;
	flex: 1;
	max-width: 80%;
}

.dp-header-search-form {
	display: flex;
	align-items: center;
	position: relative;
	width: 100%;
}

.dp-header-search-input {
	width: 100%;
	padding: 8px 40px 8px 14px;
	border: 1px solid var(--dp-border);
	border-radius: 4px;
	background: var(--dp-white);
	font-size: 14px;
	line-height: 1.4;
	color: var(--dp-text);
	outline: none;
	transition: border-color 0.2s, box-shadow 0.2s;
	box-sizing: border-box;
}

.dp-header-search-input::placeholder {
	color: var(--dp-gray);
}

.dp-header-search-input:focus {
	border-color: var(--dp-secondary);
	box-shadow: 0 0 0 2px rgba(41, 128, 185, 0.15);
}

.dp-header-search-btn {
	position: absolute;
	right: 0;
	top: 0;
	bottom: 0;
	display: flex;
	align-items: center;
	justify-content: center;
	width: 40px;
	padding: 0;
	border: none;
	border-radius: 0 4px 4px 0;
	background: var(--dp-secondary);
	color: var(--dp-white);
	cursor: pointer;
	transition: background 0.2s;
}

.dp-header-search-btn svg {
	width: 16px;
	height: 16px;
	display: block;
	fill: currentColor;
}

.dp-header-search-btn:hover {
	background: var(--dp-primary);
}

/* Hide the Blocksy search modal since we no longer trigger it */
#search-modal {
	display: none !important;
}

@media (max-width: 689px) {
	.dp-header-search {
		max-width: 100%;
	}
}

/* ============================================================
   22. SIDEBAR — Shop Categories Navigation
   ============================================================ */

/*
 * Actual rendered HTML:
 *   .ct-sidebar > .ct-widget.widget_nav_menu
 *     > h2.widget-title
 *     > div.menu-*-container > ul.widget-menu > li.menu-item > a
 */

/* ── Widget card ─────────────────────────────────── */
.ct-sidebar .ct-widget.widget_nav_menu {
	background: var(--dp-white);
	border: 1px solid var(--dp-border);
	border-radius: var(--dp-radius-lg);
	padding: 0 !important;
	box-shadow: var(--dp-shadow);
	overflow: hidden;
	text-align: left;
}

/* Gradient accent bar */
.ct-sidebar .ct-widget.widget_nav_menu::before {
	content: '';
	display: block;
	height: 4px;
	background: linear-gradient(90deg, var(--dp-primary) 0%, var(--dp-secondary) 50%, var(--dp-accent) 100%);
}

/* ── Widget title — clickable collapse header ────── */
.ct-sidebar .ct-widget.widget_nav_menu .widget-title {
	font-size: 13px !important;
	font-weight: 700 !important;
	color: var(--dp-primary) !important;
	text-transform: uppercase;
	letter-spacing: 0.08em;
	padding: 16px 20px !important;
	margin: 0 !important;
	border-bottom: 1px solid var(--dp-border);
	background: var(--dp-lighter);
	display: flex !important;
	align-items: center;
	gap: 10px;
	cursor: pointer;
	user-select: none;
	text-align: left;
}

/* Grid icon */
.ct-sidebar .ct-widget.widget_nav_menu .widget-title::before {
	content: '';
	display: inline-block;
	width: 18px;
	height: 18px;
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='18' height='18' viewBox='0 0 24 24' fill='none' stroke='%232980b9' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Crect x='3' y='3' width='7' height='7'/%3E%3Crect x='14' y='3' width='7' height='7'/%3E%3Crect x='14' y='14' width='7' height='7'/%3E%3Crect x='3' y='14' width='7' height='7'/%3E%3C/svg%3E");
	background-size: contain;
	background-repeat: no-repeat;
	flex-shrink: 0;
}

/* Chevron indicator */
.ct-sidebar .ct-widget.widget_nav_menu .widget-title::after {
	content: '';
	display: inline-block;
	width: 12px;
	height: 12px;
	margin-left: auto;
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12' fill='none' stroke='%231a3a5c' stroke-width='2' stroke-linecap='round'%3E%3Cpolyline points='3,4.5 6,7.5 9,4.5'/%3E%3C/svg%3E");
	background-size: contain;
	background-repeat: no-repeat;
	flex-shrink: 0;
	transition: transform 0.3s ease;
}

/* Rotated chevron when collapsed */
.ct-sidebar .ct-widget.widget_nav_menu.dp-widget-collapsed .widget-title::after {
	transform: rotate(-90deg);
}

/* ── List wrapper (animated collapse target) ─────── */
.ct-sidebar .ct-widget.widget_nav_menu .dp-cat-list-wrap {
	overflow: hidden;
}

/* ── Menu list ───────────────────────────────────── */
.ct-sidebar .ct-widget.widget_nav_menu ul.menu,
.ct-sidebar .ct-widget.widget_nav_menu ul.widget-menu {
	list-style: none !important;
	padding: 6px 0 !important;
	margin: 0 !important;
	text-align: left;
}

/* ── Menu items ──────────────────────────────────── */
.ct-sidebar .ct-widget.widget_nav_menu ul.menu > li,
.ct-sidebar .ct-widget.widget_nav_menu ul.widget-menu > li {
	margin: 0;
	padding: 0;
	border-bottom: 1px solid rgba(220, 230, 240, 0.4);
}

.ct-sidebar .ct-widget.widget_nav_menu ul.menu > li:last-child,
.ct-sidebar .ct-widget.widget_nav_menu ul.widget-menu > li:last-child {
	border-bottom: none;
}

/* ── Menu links ──────────────────────────────────── */
.ct-sidebar .ct-widget.widget_nav_menu ul.menu li a,
.ct-sidebar .ct-widget.widget_nav_menu ul.widget-menu li a {
	display: flex !important;
	align-items: center;
	gap: 10px;
	padding: 11px 20px !important;
	color: var(--dp-text) !important;
	font-size: 13.5px !important;
	font-weight: 500 !important;
	text-decoration: none !important;
	transition: all 0.2s ease;
	border-left: 3px solid transparent;
	line-height: 1.4;
}

/* Dot indicator */
.ct-sidebar .ct-widget.widget_nav_menu ul.menu > li > a::before,
.ct-sidebar .ct-widget.widget_nav_menu ul.widget-menu > li > a::before {
	content: '';
	width: 7px;
	height: 7px;
	min-width: 7px;
	border-radius: 2px;
	background: var(--dp-border);
	transition: all 0.2s ease;
	flex-shrink: 0;
}

/* ── Hover state ─────────────────────────────────── */
.ct-sidebar .ct-widget.widget_nav_menu ul.menu li a:hover,
.ct-sidebar .ct-widget.widget_nav_menu ul.widget-menu li a:hover {
	background: rgba(41, 128, 185, 0.05);
	color: var(--dp-secondary) !important;
	border-left-color: var(--dp-secondary);
}

.ct-sidebar .ct-widget.widget_nav_menu ul.menu > li > a:hover::before,
.ct-sidebar .ct-widget.widget_nav_menu ul.widget-menu > li > a:hover::before {
	background: var(--dp-secondary);
	border-radius: 50%;
}

/* ── Active / current page ───────────────────────── */
.ct-sidebar .ct-widget.widget_nav_menu ul.menu li.current-menu-item > a,
.ct-sidebar .ct-widget.widget_nav_menu ul.menu li.current_page_item > a,
.ct-sidebar .ct-widget.widget_nav_menu ul.widget-menu li.current-menu-item > a,
.ct-sidebar .ct-widget.widget_nav_menu ul.widget-menu li.current_page_item > a {
	background: rgba(41, 128, 185, 0.06) !important;
	color: var(--dp-secondary) !important;
	font-weight: 700 !important;
	border-left-color: var(--dp-accent) !important;
}

.ct-sidebar .ct-widget.widget_nav_menu ul.menu li.current-menu-item > a::before,
.ct-sidebar .ct-widget.widget_nav_menu ul.menu li.current_page_item > a::before,
.ct-sidebar .ct-widget.widget_nav_menu ul.widget-menu li.current-menu-item > a::before,
.ct-sidebar .ct-widget.widget_nav_menu ul.widget-menu li.current_page_item > a::before {
	background: var(--dp-accent);
	border-radius: 50%;
}

/* ── Sub-menus (if any children exist) ───────────── */
.ct-sidebar .ct-widget.widget_nav_menu ul.menu .sub-menu,
.ct-sidebar .ct-widget.widget_nav_menu ul.widget-menu .sub-menu {
	padding: 4px 0 4px 0 !important;
	margin: 0 0 0 20px !important;
	border-left: 2px solid var(--dp-border);
	list-style: none !important;
}

.ct-sidebar .ct-widget.widget_nav_menu ul.menu .sub-menu li a {
	font-size: 12.5px !important;
	color: var(--dp-text-light) !important;
	padding: 8px 14px 8px 16px !important;
}

.ct-sidebar .ct-widget.widget_nav_menu ul.menu .sub-menu li a::before {
	content: '';
	width: 5px;
	height: 5px;
	min-width: 5px;
	border-radius: 50%;
	background: var(--dp-border);
	flex-shrink: 0;
}

.ct-sidebar .ct-widget.widget_nav_menu ul.menu .sub-menu li a:hover {
	color: var(--dp-secondary) !important;
}

.ct-sidebar .ct-widget.widget_nav_menu ul.menu .sub-menu li a:hover::before {
	background: var(--dp-secondary);
}

/* ============================================================
   23. SHOP HERO BANNER
   ============================================================ */
.dp-shop-hero {
	position: relative;
	min-height: 260px;
	display: flex;
	align-items: center;
	justify-content: flex-start;
	text-align: left;
	background-color: var(--dp-primary);
	background-image: url('data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" width="400" height="400"><rect fill="%231a3a5c"/><circle cx="200" cy="200" r="180" fill="%23234b73" opacity="0.3"/></svg>');
	background-size: cover;
	background-position: center;
	overflow: hidden;
	margin-bottom: 48px;
	border-radius: var(--dp-radius);
}

/* Use an actual image if available — set via inline style or Customizer */
.dp-shop-hero[style*="background-image"] {
	background-blend-mode: overlay;
}

.dp-shop-hero-overlay {
	position: absolute;
	inset: 0;
	background: linear-gradient(
		135deg,
		rgba(17, 40, 64, 0.88) 0%,
		rgba(26, 58, 92, 0.80) 50%,
		rgba(41, 128, 185, 0.65) 100%
	);
	z-index: 1;
}

.dp-shop-hero-content {
	position: relative;
	z-index: 2;
	max-width: 680px;
	padding: 56px 48px;
}

.dp-shop-hero-content .dp-hero-kicker {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	background: rgba(230, 126, 34, 0.9);
	color: var(--dp-white);
	font-size: 13px;
	font-weight: 700;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	padding: 6px 16px;
	border-radius: 4px;
	margin-bottom: 20px;
}

.dp-shop-hero-content h1 {
	color: var(--dp-white) !important;
	font-size: clamp(1.75rem, 4vw, 2.75rem) !important;
	font-weight: 800 !important;
	line-height: 1.15 !important;
	margin-bottom: 16px !important;
	text-shadow: 0 2px 20px rgba(0, 0, 0, 0.3);
}

.dp-shop-hero-content p {
	color: rgba(255, 255, 255, 0.88) !important;
	font-size: clamp(0.95rem, 1.8vw, 1.1rem) !important;
	line-height: 1.7;
	margin: 0;
	max-width: 540px;
}

/* ============================================================
   24. SHOP HOMEPAGE — Custom sections layout
   ============================================================ */

/* Hide default product loop on shop root */
body.dp-shop-root .woocommerce-result-count,
body.dp-shop-root .woocommerce-ordering {
	display: none !important;
}

body.dp-shop-root ul.products {
	display: none !important;
}

body.dp-shop-root .woocommerce-pagination {
	display: none !important;
}

/* Homepage wrapper — stays inside sidebar layout */
.dp-shop-homepage {
	width: 100%;
}

/* Each section */
.dp-shop-section {
	padding: 0px 0;
	margin-bottom:50px;
}

.dp-shop-section-alt {
	background: var(--dp-light);
	border-radius: var(--dp-radius);
	padding: 48px 24px;
	margin-bottom: 50px;
}

.dp-shop-section-alt > .dp-shop-section-header,
.dp-shop-section-alt > .dp-slider-container {
	max-width: 100%;
}

.dp-shop-section-brands {
	background: var(--dp-white);
	text-align: center;
}

.dp-shop-section-trust {
	padding-top: 32px;
	padding-bottom: 32px;
}

/* Section headers — inline layout: icon | title + subtitle */
.dp-shop-section-header {
	display: flex;
	align-items: center;
	gap: 16px;
	margin-bottom: 28px;
	padding-bottom: 20px;
	border-bottom: 1px solid var(--dp-border);
}

/* Section icon — compact circle */
.dp-section-icon {
	display: flex;
	align-items: center;
	justify-content: center;
	width: 44px;
	height: 44px;
	min-width: 44px;
	border-radius: 10px;
	background: var(--dp-light);
	color: var(--dp-secondary);
	transition: var(--dp-transition);
}

.dp-section-icon svg {
	width: 22px;
	height: 22px;
}

.dp-section-icon-sale {
	background: #fef3e6;
	color: var(--dp-accent);
}

.dp-section-icon-star {
	background: #fffbe6;
	color: #d4a017;
}

.dp-section-icon-grid {
	background: #eef6ff;
	color: var(--dp-secondary);
}

.dp-shop-section-header h2 {
	font-size: clamp(1.15rem, 2.2vw, 1.4rem) !important;
	font-weight: 700 !important;
	color: var(--dp-primary) !important;
	margin: 0 !important;
	line-height: 1.3;
}

.dp-shop-section-header h2::after {
	display: none;
}

.dp-shop-section-header p {
	font-size: 14px;
	color: var(--dp-text-light);
	margin: 2px 0 0;
	line-height: 1.4;
}

/* Brands placeholder */
.dp-brands-placeholder {
	padding: 40px 24px;
	background: var(--dp-lighter);
	border: 2px dashed var(--dp-border);
	border-radius: var(--dp-radius);
	max-width: 800px;
	margin: 0 auto;
}

.dp-brands-note {
	color: var(--dp-text-light);
	font-size: 14px;
}

.dp-brands-note code {
	background: var(--dp-light);
	padding: 2px 8px;
	border-radius: 4px;
	font-size: 13px;
}

/* CTA section at bottom of shop homepage */
.dp-shop-cta {
	text-align: center;
}

.dp-shop-cta-inner {
	background: linear-gradient(135deg, var(--dp-primary) 0%, var(--dp-primary-dark) 100%);
	border-radius: var(--dp-radius-lg);
	padding: 56px 32px;
	max-width: 800px;
	margin: 0 auto;
}

.dp-shop-cta-inner h2 {
	color: var(--dp-white) !important;
	font-size: clamp(1.35rem, 2.5vw, 1.75rem) !important;
	margin-bottom: 12px !important;
}

.dp-shop-cta-inner p {
	color: rgba(255, 255, 255, 0.85) !important;
	font-size: 16px;
	max-width: 520px;
	margin: 0 auto 28px auto;
}

.dp-shop-cta-buttons {
	display: flex;
	gap: 16px;
	justify-content: center;
	flex-wrap: wrap;
}

.dp-btn {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	padding: 14px 32px;
	border-radius: var(--dp-radius-sm);
	font-size: 15px;
	font-weight: 700;
	text-decoration: none !important;
	transition: var(--dp-transition);
	cursor: pointer;
	border: none;
}

.dp-btn-accent {
	background: var(--dp-accent);
	color: var(--dp-white) !important;
}

.dp-btn-accent:hover {
	background: var(--dp-accent-hover);
	color: var(--dp-white) !important;
	transform: translateY(-2px);
	box-shadow: 0 6px 24px rgba(230, 126, 34, 0.4);
}

.dp-btn-wa {
	background: #25d366;
	color: var(--dp-white) !important;
}

.dp-btn-wa:hover {
	background: #1da851;
	color: var(--dp-white) !important;
	transform: translateY(-2px);
	box-shadow: 0 6px 24px rgba(37, 211, 102, 0.4);
}

/* Hide Blocksy default hero on shop root page (we have our own) */
body.dp-shop-root .hero-section {
	display: none !important;
}



/* ============================================================
   25. RESPONSIVE — Sidebar & Shop Homepage
   ============================================================ */
@media (max-width: 999px) {
	.dp-shop-hero {
		min-height: 260px;
	}

	.dp-shop-hero-content {
		padding: 40px 20px;
	}

	.dp-shop-section {
		padding: 40px 16px;
	}

	.dp-shop-cta-inner {
		padding: 40px 20px;
	}
}

@media (max-width: 689px) {
	.dp-shop-hero {
		min-height: 220px;
		text-align: center;
		justify-content: center;
	}

	.dp-shop-hero-content {
		padding: 32px 16px;
	}

	.dp-shop-section-header {
		flex-direction: column;
		text-align: center;
		gap: 10px;
	}

	.dp-shop-section {
		padding: 32px 12px;
	}

	.dp-shop-cta-buttons {
		flex-direction: column;
		align-items: center;
	}

	.dp-btn {
		width: 100%;
		max-width: 300px;
		justify-content: center;
	}

	.ct-sidebar .ct-widget.widget_product_categories,
	.ct-sidebar .ct-widget.widget_block {
		padding: 16px 18px;
	}
}

/* ============================================================
   26. PRINT
   ============================================================ */
@media print {
	.ct-header,
	.ct-footer,
	.ct-back-to-top,
	.dp-cta-section,
	.dp-newsletter-section {
		display: none !important;
	}

	body {
		font-size: 12pt;
		color: #000;
	}
}
