/**
 * SkunkPages Patterns - Scoped Styles
 * 
 * These styles ensure SkunkPages patterns look consistent 
 * regardless of the active WordPress theme.
 * 
 * All styles are scoped to .skunkpages-pattern to prevent 
 * theme interference.
 */

/* Global Reset for SkunkPages Patterns */
.skunkpages-pattern {
	/* Reset and isolation */
	*, *::before, *::after {
		box-sizing: border-box;
	}
	
	/* Typography baseline */
	font-family: system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Oxygen, Ubuntu, Cantarell, sans-serif;
	line-height: 1.5;
	color: #111827;
	position: relative;
	isolation: isolate;
}

/* Typography Reset */
.skunkpages-pattern h1,
.skunkpages-pattern h2,
.skunkpages-pattern h3,
.skunkpages-pattern h4,
.skunkpages-pattern h5,
.skunkpages-pattern h6 {
	font-family: inherit;
	font-weight: 700;
	line-height: 1.2;
	margin: 0;
	color: #111827;
}

.skunkpages-pattern p {
	font-family: inherit;
	line-height: 1.6;
	margin: 0;
	color: inherit;
}

.skunkpages-pattern a {
	color: inherit;
	text-decoration: none;
	transition: all 0.2s ease;
}

.skunkpages-pattern a:hover {
	text-decoration: none;
}

.skunkpages-pattern img {
	max-width: 100%;
	height: auto;
	display: block;
}

/* WordPress Block Overrides */
.skunkpages-pattern .wp-block-group {
	box-sizing: border-box;
}

.skunkpages-pattern .wp-block-group.alignfull {
	width: 100vw;
	max-width: 100vw;
	margin-left: calc(50% - 50vw);
	margin-right: calc(50% - 50vw);
}

.skunkpages-pattern .wp-block-group.alignwide {
	max-width: 1200px;
	margin-left: auto;
	margin-right: auto;
}

.skunkpages-pattern .wp-block-columns {
	display: flex;
	flex-wrap: wrap;
	gap: 2rem;
}

.skunkpages-pattern .wp-block-column {
	flex: 1;
	min-width: 0;
}

/* Button Styling */
.skunkpages-pattern .wp-block-button__link {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	font-family: inherit;
	font-weight: 600;
	font-size: 1rem;
	line-height: 1.5;
	text-decoration: none !important;
	border: none;
	outline: none;
	cursor: pointer;
	transition: all 0.2s ease;
	box-shadow: none !important;
	border-radius: 0.375rem;
	padding: 0.75rem 1.5rem;
}

.skunkpages-pattern .wp-block-button__link:hover {
	text-decoration: none !important;
	transform: translateY(-1px);
}

.skunkpages-pattern .wp-block-button__link:focus {
	outline: 2px solid #3b82f6;
	outline-offset: 2px;
}

.skunkpages-pattern .wp-block-button__link:active {
	transform: translateY(0);
}

/* Primary Button */
.skunkpages-pattern .wp-block-button__link.has-accent-background-color,
.skunkpages-pattern .wp-block-button__link[style*="background-color:#E50914"],
.skunkpages-pattern .wp-block-button__link[style*="background:linear-gradient"] {
	background-color: #E50914;
	color: #ffffff;
}

.skunkpages-pattern .wp-block-button__link.has-accent-background-color:hover,
.skunkpages-pattern .wp-block-button__link[style*="background-color:#E50914"]:hover {
	background-color: #cc080f;
	box-shadow: 0 8px 20px rgba(229, 9, 20, 0.3);
}

/* Secondary Button */
.skunkpages-pattern .wp-block-button__link.has-border-color {
	background-color: transparent;
	border: 2px solid currentColor;
}

.skunkpages-pattern .wp-block-button__link.has-border-color:hover {
	background-color: #f9fafb;
}

/* Form Elements */
.skunkpages-pattern input[type="text"],
.skunkpages-pattern input[type="email"],
.skunkpages-pattern input[type="tel"],
.skunkpages-pattern input[type="url"],
.skunkpages-pattern textarea {
	font-family: inherit;
	font-size: 1rem;
	line-height: 1.5;
	border: 2px solid #e5e7eb;
	border-radius: 0.375rem;
	padding: 0.75rem 1rem;
	width: 100%;
	background: #ffffff;
	color: #111827;
	transition: border-color 0.2s ease, box-shadow 0.2s ease;
}

.skunkpages-pattern input[type="text"]:focus,
.skunkpages-pattern input[type="email"]:focus,
.skunkpages-pattern input[type="tel"]:focus,
.skunkpages-pattern input[type="url"]:focus,
.skunkpages-pattern textarea:focus {
	outline: none;
	border-color: #3b82f6;
	box-shadow: 0 0 0 3px rgba(59, 130, 246, 0.1);
}

.skunkpages-pattern input::placeholder,
.skunkpages-pattern textarea::placeholder {
	color: #9ca3af;
	opacity: 1;
}

/* Color Overrides for Theme Compatibility */
.skunkpages-pattern .has-white-color {
	color: #ffffff !important;
}

.skunkpages-pattern .has-white-background-color {
	background-color: #ffffff !important;
}

.skunkpages-pattern .has-contrast-color {
	color: #111827 !important;
}

.skunkpages-pattern .has-accent-color {
	color: #E50914 !important;
}

.skunkpages-pattern .has-accent-background-color {
	background-color: #E50914 !important;
}

.skunkpages-pattern .has-gray-50-background-color {
	background-color: #f9fafb !important;
}

.skunkpages-pattern .has-gray-100-background-color {
	background-color: #f3f4f6 !important;
}

.skunkpages-pattern .has-gray-200-background-color {
	background-color: #e5e7eb !important;
}

.skunkpages-pattern .has-gray-300-color {
	color: #d1d5db !important;
}

.skunkpages-pattern .has-gray-400-color {
	color: #9ca3af !important;
}

.skunkpages-pattern .has-gray-500-color {
	color: #6b7280 !important;
}

.skunkpages-pattern .has-gray-600-color {
	color: #4b5563 !important;
}

.skunkpages-pattern .has-gray-700-color {
	color: #374151 !important;
}

/* Gradient Backgrounds */
.skunkpages-pattern [style*="background:linear-gradient"],
.skunkpages-pattern [style*="background: linear-gradient"] {
	background-attachment: local;
}

/* Shadow Classes */
.skunkpages-pattern .has-shadow-sm {
	box-shadow: 0 1px 2px 0 rgba(0, 0, 0, 0.05);
}

.skunkpages-pattern .has-shadow-md {
	box-shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.1), 0 2px 4px -1px rgba(0, 0, 0, 0.06);
}

.skunkpages-pattern .has-shadow-lg {
	box-shadow: 0 10px 15px -3px rgba(0, 0, 0, 0.1), 0 4px 6px -2px rgba(0, 0, 0, 0.05);
}

.skunkpages-pattern .has-shadow-xl {
	box-shadow: 0 20px 25px -5px rgba(0, 0, 0, 0.1), 0 10px 10px -5px rgba(0, 0, 0, 0.04);
}

/* Responsive Design */
@media (max-width: 768px) {
	.skunkpages-pattern .wp-block-columns {
		flex-direction: column;
		gap: 1.5rem;
	}
	
	.skunkpages-pattern .wp-block-column {
		flex-basis: 100% !important;
		width: 100% !important;
	}
	
	.skunkpages-pattern h1 {
		font-size: 2.5rem !important;
	}
	
	.skunkpages-pattern h2 {
		font-size: 2rem !important;
	}
	
	.skunkpages-pattern h3 {
		font-size: 1.5rem !important;
	}
	
	.skunkpages-pattern .wp-block-group[style*="padding"] {
		padding-left: 1rem !important;
		padding-right: 1rem !important;
	}
}

@media (max-width: 640px) {
	.skunkpages-pattern h1 {
		font-size: 2rem !important;
	}
	
	.skunkpages-pattern h2 {
		font-size: 1.75rem !important;
	}
	
	.skunkpages-pattern .wp-block-button__link {
		width: 100%;
		justify-content: center;
	}
	
	.skunkpages-pattern .wp-block-buttons {
		flex-direction: column;
		gap: 0.75rem;
	}
	
	.skunkpages-pattern .wp-block-buttons .wp-block-button {
		width: 100%;
	}
}

/* Print Styles */
@media print {
	.skunkpages-pattern {
		background: white !important;
		color: black !important;
	}
	
	.skunkpages-pattern .wp-block-button {
		display: none !important;
	}
	
	.skunkpages-pattern [style*="background:linear-gradient"],
	.skunkpages-pattern [style*="background: linear-gradient"] {
		background: white !important;
	}
}

/* Performance Optimizations */
.skunkpages-pattern {
	contain: layout;
	will-change: auto;
}

.skunkpages-pattern img {
	loading: lazy;
}

.skunkpages-pattern .wp-block-button__link {
	contain: layout;
}

/* Accessibility Improvements */
.skunkpages-pattern :focus-visible {
	outline: 2px solid #3b82f6;
	outline-offset: 2px;
}

.skunkpages-pattern .wp-block-button__link:focus-visible {
	outline: 2px solid rgba(255, 255, 255, 0.8);
	outline-offset: 2px;
}

/* High Contrast Mode Support */
@media (prefers-contrast: high) {
	.skunkpages-pattern {
		border: 1px solid;
	}
	
	.skunkpages-pattern .wp-block-button__link {
		border: 2px solid;
	}
}

/* Reduced Motion Support */
@media (prefers-reduced-motion: reduce) {
	.skunkpages-pattern *,
	.skunkpages-pattern *::before,
	.skunkpages-pattern *::after {
		animation-duration: 0.01ms !important;
		animation-iteration-count: 1 !important;
		transition-duration: 0.01ms !important;
		scroll-behavior: auto !important;
	}
	
	.skunkpages-pattern .wp-block-button__link:hover {
		transform: none;
	}
}