/**
 * MG Elementor Addons - Design System
 *
 * Global CSS variables and design tokens for consistent styling across all widgets.
 * This file should be loaded before widget-specific styles.
 *
 * @package MG_Elementor_Addons
 * @since 1.0.0
 */

:root {
	/* ============================================
	   SPACING SCALE
	   ============================================ */
	--mg-spacing-xs: 0.5rem;    /* 8px */
	--mg-spacing-sm: 0.75rem;  /* 12px */
	--mg-spacing-md: 1rem;      /* 16px */
	--mg-spacing-lg: 1.5rem;    /* 24px */
	--mg-spacing-xl: 2rem;      /* 32px */
	--mg-spacing-2xl: 3rem;     /* 48px */
	--mg-spacing-3xl: 4rem;     /* 64px */
	--mg-spacing-4xl: 6rem;     /* 96px */

	/* ============================================
	   TYPOGRAPHY SCALE
	   ============================================ */
	--mg-font-size-xs: 0.75rem;   /* 12px */
	--mg-font-size-sm: 0.875rem; /* 14px */
	--mg-font-size-base: 1rem;    /* 16px */
	--mg-font-size-lg: 1.125rem;  /* 18px */
	--mg-font-size-xl: 1.25rem;   /* 20px */
	--mg-font-size-2xl: 1.5rem;   /* 24px */
	--mg-font-size-3xl: 1.875rem; /* 30px */
	--mg-font-size-4xl: 2.25rem;  /* 36px */
	--mg-font-size-5xl: 3rem;     /* 48px */
	--mg-font-size-6xl: 3.75rem;  /* 60px */

	--mg-line-height-tight: 1.2;
	--mg-line-height-normal: 1.5;
	--mg-line-height-relaxed: 1.6;
	--mg-line-height-loose: 1.75;

	--mg-font-weight-normal: 400;
	--mg-font-weight-medium: 500;
	--mg-font-weight-semibold: 600;
	--mg-font-weight-bold: 700;

	/* ============================================
	   COLOR SYSTEM
	   ============================================ */
	/* Primary Brand Colors */
	--mg-color-primary: #FF6B35;
	--mg-color-primary-dark: #E55A2B;
	--mg-color-primary-light: #FF8C5A;

	/* Neutral Colors */
	--mg-color-white: #FFFFFF;
	--mg-color-gray-50: #F9FAFB;
	--mg-color-gray-100: #F3F4F6;
	--mg-color-gray-200: #E5E7EB;
	--mg-color-gray-300: #D1D5DB;
	--mg-color-gray-400: #9CA3AF;
	--mg-color-gray-500: #6B7280;
	--mg-color-gray-600: #4B5563;
	--mg-color-gray-700: #374151;
	--mg-color-gray-800: #1F2937;
	--mg-color-gray-900: #111827;
	--mg-color-black: #000000;

	/* Semantic Colors */
	--mg-color-success: #10B981;
	--mg-color-success-light: #D1FAE5;
	--mg-color-success-dark: #065F46;
	--mg-color-error: #EF4444;
	--mg-color-error-light: #FEE2E2;
	--mg-color-warning: #F59E0B;
	--mg-color-info: #3B82F6;

	/* Text Colors */
	--mg-color-text-primary: var(--mg-color-gray-900);
	--mg-color-text-secondary: var(--mg-color-gray-600);
	--mg-color-text-muted: var(--mg-color-gray-500);
	--mg-color-text-inverse: var(--mg-color-white);

	/* Background Colors */
	--mg-color-bg-primary: var(--mg-color-white);
	--mg-color-bg-secondary: var(--mg-color-gray-50);
	--mg-color-bg-tertiary: var(--mg-color-gray-100);

	/* ============================================
	   BORDER & SHADOW SYSTEM
	   ============================================ */
	--mg-border-width-thin: 1px;
	--mg-border-width-medium: 2px;
	--mg-border-width-thick: 3px;

	--mg-border-radius-sm: 0.25rem;  /* 4px */
	--mg-border-radius-md: 0.5rem;   /* 8px */
	--mg-border-radius-lg: 0.75rem;  /* 12px */
	--mg-border-radius-xl: 1rem;     /* 16px */
	--mg-border-radius-full: 9999px;

	--mg-shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, 0.05);
	--mg-shadow-md: 0 4px 6px -1px rgba(0, 0, 0, 0.1), 0 2px 4px -1px rgba(0, 0, 0, 0.06);
	--mg-shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, 0.1), 0 4px 6px -2px rgba(0, 0, 0, 0.05);
	--mg-shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, 0.1), 0 10px 10px -5px rgba(0, 0, 0, 0.04);
	--mg-shadow-2xl: 0 25px 50px -12px rgba(0, 0, 0, 0.25);

	/* ============================================
	   BUTTON SYSTEM
	   ============================================ */
	--mg-button-padding-y: 0.875rem;   /* 14px */
	--mg-button-padding-x: 1.75rem;     /* 28px */
	--mg-button-padding-y-sm: 0.625rem; /* 10px */
	--mg-button-padding-x-sm: 1.25rem;  /* 20px */
	--mg-button-padding-y-lg: 1rem;     /* 16px */
	--mg-button-padding-x-lg: 2rem;     /* 32px */

	--mg-button-font-size: var(--mg-font-size-base);
	--mg-button-font-weight: var(--mg-font-weight-semibold);
	--mg-button-border-radius: var(--mg-border-radius-md);
	--mg-button-border-width: var(--mg-border-width-medium);
	--mg-button-transition: all 0.3s ease;

	/* ============================================
	   CARD SYSTEM
	   ============================================ */
	--mg-card-padding: var(--mg-spacing-xl);
	--mg-card-background: var(--mg-color-bg-primary);
	--mg-card-border-color: var(--mg-color-gray-200);
	--mg-card-border-width: var(--mg-border-width-thin);
	--mg-card-border-radius: var(--mg-border-radius-lg);
	--mg-card-shadow: var(--mg-shadow-md);

	/* ============================================
	   RESPONSIVE BREAKPOINTS
	   ============================================ */
	/* These are for reference - use in @media queries */
	/* Mobile: < 768px (default, mobile-first) */
	/* Tablet: >= 768px */
	/* Desktop: >= 1024px */
	/* Large Desktop: >= 1280px */

	/* ============================================
	   TRANSITIONS & ANIMATIONS
	   ============================================ */
	--mg-transition-fast: 0.15s ease;
	--mg-transition-base: 0.3s ease;
	--mg-transition-slow: 0.5s ease;

	/* ============================================
	   Z-INDEX SCALE
	   ============================================ */
	--mg-z-index-dropdown: 1000;
	--mg-z-index-sticky: 1020;
	--mg-z-index-fixed: 1030;
	--mg-z-index-modal-backdrop: 1040;
	--mg-z-index-modal: 1050;
	--mg-z-index-popover: 1060;
	--mg-z-index-tooltip: 1070;
}

/* ============================================
   SHARED WIDGET BASE STYLES
   ============================================ */

/* Widget Container */
.mg-widget {
	width: 100%;
	position: relative;
}

/* Widget Header */
.mg-widget__header {
	text-align: center;
	margin-bottom: var(--mg-spacing-2xl);
}

.mg-widget__eyebrow {
	font-size: var(--mg-font-size-sm);
	font-weight: var(--mg-font-weight-semibold);
	text-transform: uppercase;
	letter-spacing: 0.05em;
	color: var(--mg-color-primary);
	margin-bottom: var(--mg-spacing-sm);
	line-height: var(--mg-line-height-normal);
}

.mg-widget__heading {
	font-size: var(--mg-font-size-4xl);
	font-weight: var(--mg-font-weight-bold);
	color: var(--mg-color-text-primary);
	margin: 0 0 var(--mg-spacing-md) 0;
	line-height: var(--mg-line-height-tight);
}

.mg-widget__subhead {
	font-size: var(--mg-font-size-lg);
	color: var(--mg-color-text-secondary);
	line-height: var(--mg-line-height-relaxed);
	margin: 0;
}

/* Widget CTA Group */
.mg-widget__cta-group {
	display: flex;
	flex-wrap: wrap;
	gap: var(--mg-spacing-md);
	justify-content: center;
	margin-top: var(--mg-spacing-xl);
}

.mg-widget__cta {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	padding: var(--mg-button-padding-y) var(--mg-button-padding-x);
	font-size: var(--mg-button-font-size);
	font-weight: var(--mg-button-font-weight);
	text-decoration: none;
	border-radius: var(--mg-button-border-radius);
	border: var(--mg-button-border-width) solid transparent;
	transition: var(--mg-button-transition);
	cursor: pointer;
	white-space: nowrap;
}

.mg-widget__cta--primary {
	background-color: var(--mg-color-primary);
	color: var(--mg-color-text-inverse);
	border-color: var(--mg-color-primary);
}

.mg-widget__cta--primary:hover {
	background-color: var(--mg-color-primary-dark);
	border-color: var(--mg-color-primary-dark);
	color: var(--mg-color-text-inverse);
	transform: translateY(-2px);
	box-shadow: var(--mg-shadow-lg);
}

.mg-widget__cta--secondary {
	background-color: transparent;
	color: var(--mg-color-primary);
	border-color: var(--mg-color-primary);
}

.mg-widget__cta--secondary:hover {
	background-color: var(--mg-color-primary);
	color: var(--mg-color-text-inverse);
}

/* Widget Card */
.mg-widget__card {
	background: var(--mg-card-background);
	border: var(--mg-card-border-width) solid var(--mg-card-border-color);
	border-radius: var(--mg-card-border-radius);
	padding: var(--mg-card-padding);
	box-shadow: var(--mg-card-shadow);
	transition: var(--mg-transition-base);
}

.mg-widget__card:hover {
	box-shadow: var(--mg-shadow-lg);
	transform: translateY(-2px);
}

/* ============================================
   RESPONSIVE ADJUSTMENTS
   ============================================ */

/* Tablet and up */
@media (min-width: 768px) {
	.mg-widget__heading {
		font-size: var(--mg-font-size-5xl);
	}

	.mg-widget__subhead {
		font-size: var(--mg-font-size-xl);
	}
}

/* Desktop and up */
@media (min-width: 1024px) {
	.mg-widget__heading {
		font-size: var(--mg-font-size-6xl);
	}
}
