/* ═══════════════════════════════════════════
   VIRTUODENT DESIGN SYSTEM
   Injected by virtuodent-elementor-widgets plugin
═══════════════════════════════════════════ */

:root {
	--vd-navy: #0B1D3A;
	--vd-navy-light: #132D54;
	--vd-navy-dark: #06101F;
	--vd-white: #FFFFFF;
	--vd-off-white: #F8F9FC;
	--vd-gold: #C9A84C;
	--vd-gold-light: #E0C97A;
	--vd-gold-dark: #A88A2E;
	--vd-gray-100: #F3F4F6;
	--vd-gray-200: #E5E7EB;
	--vd-gray-300: #D1D5DB;
	--vd-gray-400: #9CA3AF;
	--vd-gray-500: #6B7280;
	--vd-gray-600: #4B5563;
	--vd-gray-700: #374151;
	--vd-gray-800: #1F2937;
	--vd-text-primary: #0B1D3A;
	--vd-text-secondary: #4B5563;
	--vd-text-light: #9CA3AF;
	--vd-shadow-sm: 0 1px 3px rgba(11,29,58,.08);
	--vd-shadow-md: 0 4px 20px rgba(11,29,58,.1);
	--vd-shadow-lg: 0 12px 40px rgba(11,29,58,.15);
	--vd-radius-sm: 6px;
	--vd-radius-md: 12px;
	--vd-radius-lg: 20px;
	--vd-radius-xl: 28px;
	--vd-transition: .35s cubic-bezier(.4,0,.2,1);
	--vd-font-display: 'Playfair Display', Georgia, serif;
	--vd-font-body: 'DM Sans', system-ui, sans-serif;
}

/* ═══════════════════════════════════════════
   SHARED SECTION STYLES
═══════════════════════════════════════════ */

.vd-section {
	padding: 100px 0;
	font-family: var(--vd-font-body);
	color: var(--vd-text-primary);
	line-height: 1.7;
	-webkit-font-smoothing: antialiased;
}

.vd-container {
	max-width: 1200px;
	margin: 0 auto;
	padding: 0 24px;
}

.vd-section-header {
	text-align: center;
	margin-bottom: 60px;
}

.vd-section-label {
	font-family: var(--vd-font-body);
	font-size: .75rem;
	font-weight: 600;
	letter-spacing: 3px;
	text-transform: uppercase;
	color: var(--vd-gold);
	margin-bottom: 12px;
	display: block;
}

.vd-section-title {
	font-family: var(--vd-font-display);
	font-size: clamp(1.8rem, 4vw, 2.8rem);
	font-weight: 700;
	line-height: 1.2;
	color: var(--vd-navy);
	margin-bottom: 16px;
}

.vd-section-subtitle {
	font-size: 1.05rem;
	color: var(--vd-text-secondary);
	max-width: 560px;
	line-height: 1.7;
	margin: 0 auto;
}

/* ═══════════════════════════════════════════
   SCROLL REVEAL ANIMATION
═══════════════════════════════════════════ */

.vd-reveal {
	opacity: 0;
	transform: translateY(40px);
	transition: opacity .7s cubic-bezier(.4,0,.2,1), transform .7s cubic-bezier(.4,0,.2,1);
}

.vd-reveal.vd-visible {
	opacity: 1;
	transform: translateY(0);
}

/* Staggered card animation */
.vd-services-grid .vd-service-card:nth-child(1) { transition-delay: 0s; }
.vd-services-grid .vd-service-card:nth-child(2) { transition-delay: .07s; }
.vd-services-grid .vd-service-card:nth-child(3) { transition-delay: .14s; }
.vd-services-grid .vd-service-card:nth-child(4) { transition-delay: .21s; }
.vd-services-grid .vd-service-card:nth-child(5) { transition-delay: .28s; }
.vd-services-grid .vd-service-card:nth-child(6) { transition-delay: .35s; }
.vd-services-grid .vd-service-card:nth-child(7) { transition-delay: .42s; }
.vd-services-grid .vd-service-card:nth-child(8) { transition-delay: .49s; }
.vd-services-grid .vd-service-card:nth-child(9) { transition-delay: .56s; }

/* No animation mode */
.vd-no-animation .vd-reveal {
	opacity: 1;
	transform: none;
	transition: none;
}

/* ═══════════════════════════════════════════
   SERVICES WIDGET
═══════════════════════════════════════════ */

.vd-services {
	background: var(--vd-off-white);
}

.vd-services-grid {
	display: grid;
	grid-template-columns: repeat(auto-fill, minmax(var(--vd-card-min-width, 260px), 1fr));
	gap: var(--vd-grid-gap, 24px);
}

.vd-service-card {
	background: var(--vd-white);
	border-radius: var(--vd-radius-md);
	padding: 36px 28px;
	transition: all var(--vd-transition);
	border: 1px solid transparent;
	position: relative;
	overflow: hidden;
}

.vd-service-card::before {
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 3px;
	background: var(--vd-accent-color, var(--vd-gold));
	transform: scaleX(0);
	transform-origin: left;
	transition: transform var(--vd-transition);
}

.vd-service-card:hover::before {
	transform: scaleX(1);
}

.vd-service-card:hover {
	border-color: rgba(201,168,76,.2);
	box-shadow: var(--vd-shadow-md);
	transform: translateY(-4px);
}

.vd-service-icon {
	width: 56px;
	height: 56px;
	border-radius: var(--vd-radius-sm);
	background: rgba(201,168,76,.1);
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 1.3rem;
	color: var(--vd-gold-dark);
	margin-bottom: 20px;
}

.vd-service-card h3 {
	font-family: var(--vd-font-display);
	font-size: 1.12rem;
	font-weight: 600;
	margin-bottom: 10px;
	color: var(--vd-text-primary);
}

.vd-service-card p {
	font-size: .9rem;
	color: var(--vd-text-secondary);
	line-height: 1.6;
	margin: 0;
}

/* ═══════════════════════════════════════════
   RESPONSIVE
═══════════════════════════════════════════ */

@media (max-width: 768px) {
	.vd-section {
		padding: 70px 0;
	}
}

@media (max-width: 480px) {
	.vd-section-title {
		font-size: 1.6rem;
	}
}
