/**
 * Terra Theme Custom Styles
 *
 * Custom CSS for organic shapes, animations, and styles not expressible in theme.json
 *
 * @package Terra
 * @since 1.0.0
 */

/* ==========================================================================
   CSS Custom Properties
   ========================================================================== */

:root {
	/* HSL Color Values for manipulation */
	--terra-hsl-background: 40 33% 98%;
	--terra-hsl-foreground: 45 10% 16%;
	--terra-hsl-primary: 117 12% 38%;
	--terra-hsl-primary-foreground: 120 10% 95%;
	--terra-hsl-secondary: 28 43% 56%;
	--terra-hsl-secondary-foreground: 0 0% 100%;
	--terra-hsl-muted: 30 18% 92%;
	--terra-hsl-muted-foreground: 45 8% 45%;
	--terra-hsl-accent: 35 27% 85%;
	--terra-hsl-border: 30 17% 84%;

	/* Animation Timing */
	--terra-transition-base: 300ms ease;
	--terra-transition-fast: 150ms ease;
	--terra-transition-slow: 500ms ease;

	/* Z-index Scale */
	--terra-z-grain: 9999;
	--terra-z-float: 50;
	--terra-z-nav: 100;
	--terra-z-modal: 1000;
}

/* ==========================================================================
   Grain Texture Overlay
   ========================================================================== */

.grain-overlay {
	position: fixed;
	inset: 0;
	pointer-events: none;
	z-index: var(--terra-z-grain);
	opacity: 0.04;
	background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.8' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)'/%3E%3C/svg%3E");
	background-repeat: repeat;
}

/* ==========================================================================
   Organic Blob Shapes (4 variants)
   ========================================================================== */

.organic-blob-1 {
	border-radius: 60% 40% 30% 70% / 60% 30% 70% 40%;
}

.organic-blob-2 {
	border-radius: 30% 70% 70% 30% / 30% 30% 70% 70%;
}

.organic-blob-3 {
	border-radius: 70% 30% 50% 50% / 30% 50% 50% 70%;
}

.organic-blob-4 {
	border-radius: 40% 60% 60% 40% / 70% 30% 70% 30%;
}

/* ==========================================================================
   Organic Radius Variants (6 variants for cards)
   ========================================================================== */

.organic-radius-1 {
	border-radius: 2rem 3rem 2.5rem 1.5rem;
}

.organic-radius-2 {
	border-radius: 1.5rem 2.5rem 3rem 2rem;
}

.organic-radius-3 {
	border-radius: 3rem 2rem 1.5rem 2.5rem;
}

.organic-radius-4 {
	border-radius: 2.5rem 1.5rem 2rem 3rem;
}

.organic-radius-5 {
	border-radius: 2rem 2rem 3rem 3rem;
}

.organic-radius-6 {
	border-radius: 3rem 3rem 2rem 2rem;
}

/* ==========================================================================
   Shadow Utilities
   ========================================================================== */

.has-shadow-soft {
	box-shadow: 0 4px 20px -2px rgba(93, 112, 82, 0.15);
}

.has-shadow-float {
	box-shadow: 0 10px 40px -10px rgba(193, 140, 93, 0.2);
}

.has-shadow-float-hover {
	box-shadow: 0 20px 40px -10px rgba(93, 112, 82, 0.15);
}

.has-shadow-card {
	box-shadow: 0 1px 3px rgba(0, 0, 0, 0.08), 0 4px 12px rgba(0, 0, 0, 0.04);
}

/* Shadow on hover */
.shadow-float-hover {
	transition: box-shadow var(--terra-transition-base), transform var(--terra-transition-base);
}

.shadow-float-hover:hover {
	box-shadow: 0 20px 40px -10px rgba(93, 112, 82, 0.15);
	transform: translateY(-4px);
}

/* ==========================================================================
   Floating Navigation
   ========================================================================== */

.floating-nav {
	position: fixed;
	top: 1.5rem;
	left: 50%;
	transform: translateX(-50%);
	z-index: var(--terra-z-nav);
	background: rgba(253, 252, 248, 0.9);
	backdrop-filter: blur(12px);
	-webkit-backdrop-filter: blur(12px);
	border: 1px solid rgba(93, 112, 82, 0.1);
	border-radius: 9999px;
	padding: 0.75rem 1.5rem;
	box-shadow: 0 4px 20px -2px rgba(93, 112, 82, 0.15);
}

.floating-nav .wp-block-navigation__container {
	gap: 2rem;
}

.floating-nav .wp-block-navigation-item a {
	font-weight: 500;
	color: var(--wp--preset--color--bark);
	transition: color var(--terra-transition-base);
}

.floating-nav .wp-block-navigation-item a:hover {
	color: var(--wp--preset--color--moss);
}

/* Floating nav with scrolled state */
.floating-nav.is-scrolled {
	background: rgba(253, 252, 248, 0.95);
	box-shadow: 0 10px 40px -10px rgba(93, 112, 82, 0.2);
}

/* ==========================================================================
   Animations
   ========================================================================== */

/* Gentle Bob Animation */
@keyframes terra-bob {
	0%, 100% {
		transform: translateY(0);
	}
	50% {
		transform: translateY(-10px);
	}
}

.animate-bob {
	animation: terra-bob 4s ease-in-out infinite;
}

/* Gentle Spin Animation */
@keyframes terra-spin-slow {
	from {
		transform: rotate(0deg);
	}
	to {
		transform: rotate(360deg);
	}
}

.animate-spin-slow {
	animation: terra-spin-slow 20s linear infinite;
}

/* Fade In Up */
@keyframes terra-fade-in-up {
	from {
		opacity: 0;
		transform: translateY(20px);
	}
	to {
		opacity: 1;
		transform: translateY(0);
	}
}

.animate-fade-in-up {
	animation: terra-fade-in-up 0.6s ease-out forwards;
}

/* Fade In */
@keyframes terra-fade-in {
	from {
		opacity: 0;
	}
	to {
		opacity: 1;
	}
}

.animate-fade-in {
	animation: terra-fade-in 0.5s ease-out forwards;
}

/* Scale In */
@keyframes terra-scale-in {
	from {
		opacity: 0;
		transform: scale(0.95);
	}
	to {
		opacity: 1;
		transform: scale(1);
	}
}

.animate-scale-in {
	animation: terra-scale-in 0.5s ease-out forwards;
}

/* ==========================================================================
   Section Styles
   ========================================================================== */

.section-padding {
	padding-top: 6rem;
	padding-bottom: 6rem;
}

@media (max-width: 768px) {
	.section-padding {
		padding-top: 4rem;
		padding-bottom: 4rem;
	}
}

/* ==========================================================================
   Card Styles
   ========================================================================== */

.feature-card {
	background: var(--wp--preset--color--rice);
	padding: 2rem;
	transition: box-shadow var(--terra-transition-base), transform var(--terra-transition-base);
}

.feature-card:hover {
	box-shadow: 0 20px 40px -10px rgba(93, 112, 82, 0.15);
	transform: translateY(-4px);
}

/* Testimonial Card */
.testimonial-card {
	background: var(--wp--preset--color--rice);
	padding: 2rem;
	border: 1px solid var(--wp--preset--color--stone);
	border-radius: 1.5rem;
}

/* Blog Card */
.blog-card {
	background: var(--wp--preset--color--rice);
	border-radius: 1.5rem;
	overflow: hidden;
	transition: box-shadow var(--terra-transition-base), transform var(--terra-transition-base);
}

.blog-card:hover {
	box-shadow: 0 10px 40px -10px rgba(193, 140, 93, 0.2);
	transform: translateY(-4px);
}

.blog-card .wp-block-post-featured-image {
	margin: 0;
}

.blog-card .wp-block-post-featured-image img {
	width: 100%;
	height: 200px;
	object-fit: cover;
}

/* ==========================================================================
   Stat Counter
   ========================================================================== */

.stat-item {
	text-align: center;
}

.stat-number {
	font-family: var(--wp--preset--font-family--fraunces);
	font-size: var(--wp--preset--font-size--giant);
	font-weight: 700;
	color: var(--wp--preset--color--moss);
	line-height: 1;
}

.stat-label {
	font-family: var(--wp--preset--font-family--nunito);
	font-size: var(--wp--preset--font-size--medium);
	color: var(--wp--preset--color--dried);
	margin-top: 0.5rem;
}

/* ==========================================================================
   Step Cards (How It Works)
   ========================================================================== */

.step-card {
	position: relative;
	text-align: center;
	padding: 2rem;
}

.step-number {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 3rem;
	height: 3rem;
	background: var(--wp--preset--color--moss);
	color: var(--wp--preset--color--rice);
	border-radius: 50%;
	font-family: var(--wp--preset--font-family--fraunces);
	font-weight: 700;
	font-size: var(--wp--preset--font-size--large);
	margin-bottom: 1rem;
}

.step-connector {
	position: absolute;
	top: 3.5rem;
	left: calc(50% + 3rem);
	width: calc(100% - 6rem);
	height: 2px;
	background: linear-gradient(90deg, var(--wp--preset--color--moss) 0%, var(--wp--preset--color--clay) 100%);
}

.step-connector svg {
	position: absolute;
	right: -8px;
	top: -4px;
}

/* ==========================================================================
   Benefits Section
   ========================================================================== */

.benefits-image {
	position: relative;
}

.benefits-image .organic-blob {
	position: absolute;
	inset: -1rem;
	z-index: -1;
}

/* Checklist */
.benefits-checklist {
	list-style: none;
	padding: 0;
	margin: 0;
}

.benefits-checklist li {
	display: flex;
	align-items: flex-start;
	gap: 1rem;
	margin-bottom: 1rem;
}

.benefits-checklist li::before {
	content: "";
	display: inline-block;
	width: 1.5rem;
	height: 1.5rem;
	min-width: 1.5rem;
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%235D7052' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M22 11.08V12a10 10 0 1 1-5.93-9.14'/%3E%3Cpolyline points='22 4 12 14.01 9 11.01'/%3E%3C/svg%3E");
	background-size: contain;
	background-repeat: no-repeat;
	margin-top: 0.125rem;
}

/* ==========================================================================
   CTA Section
   ========================================================================== */

.cta-section {
	background: linear-gradient(135deg, var(--wp--preset--color--moss) 0%, var(--wp--preset--color--moss-600) 100%);
	position: relative;
	overflow: hidden;
}

.cta-section::before {
	content: "";
	position: absolute;
	inset: 0;
	background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.8' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)'/%3E%3C/svg%3E");
	background-repeat: repeat;
	opacity: 0.03;
	pointer-events: none;
}

.cta-section .wp-block-heading {
	color: var(--wp--preset--color--rice);
}

.cta-section p {
	color: rgba(253, 252, 248, 0.9);
}

/* ==========================================================================
   Button Variations
   ========================================================================== */

.wp-block-button.is-style-outline .wp-block-button__link {
	background: transparent;
	border: 2px solid var(--wp--preset--color--moss);
	color: var(--wp--preset--color--moss);
}

.wp-block-button.is-style-outline .wp-block-button__link:hover {
	background: var(--wp--preset--color--moss);
	color: var(--wp--preset--color--rice);
}

/* Secondary button style */
.wp-block-button.is-style-secondary .wp-block-button__link {
	background: var(--wp--preset--color--clay);
	color: var(--wp--preset--color--rice);
}

.wp-block-button.is-style-secondary .wp-block-button__link:hover {
	background: var(--wp--preset--color--clay-600);
}

/* Ghost button for dark backgrounds */
.wp-block-button.is-style-ghost .wp-block-button__link {
	background: transparent;
	border: 2px solid var(--wp--preset--color--rice);
	color: var(--wp--preset--color--rice);
}

.wp-block-button.is-style-ghost .wp-block-button__link:hover {
	background: var(--wp--preset--color--rice);
	color: var(--wp--preset--color--moss);
}

/* ==========================================================================
   Footer Styles
   ========================================================================== */

.site-footer {
	background: var(--wp--preset--color--loam);
	color: var(--wp--preset--color--timber);
	padding-top: 4rem;
	padding-bottom: 2rem;
}

.site-footer .wp-block-heading {
	color: var(--wp--preset--color--rice);
	font-family: var(--wp--preset--font-family--nunito);
	font-size: var(--wp--preset--font-size--medium);
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.05em;
	margin-bottom: 1.5rem;
}

.site-footer a {
	color: var(--wp--preset--color--timber);
	text-decoration: none;
	transition: color var(--terra-transition-base);
}

.site-footer a:hover {
	color: var(--wp--preset--color--clay);
}

.footer-bottom {
	border-top: 1px solid rgba(222, 216, 207, 0.2);
	padding-top: 2rem;
	margin-top: 3rem;
}

/* Social Links */
.social-links {
	display: flex;
	gap: 1rem;
}

.social-links a {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 2.5rem;
	height: 2.5rem;
	background: rgba(222, 216, 207, 0.1);
	border-radius: 50%;
	transition: background var(--terra-transition-base);
}

.social-links a:hover {
	background: var(--wp--preset--color--moss);
	color: var(--wp--preset--color--rice);
}

/* ==========================================================================
   Blog Post Tags
   ========================================================================== */

.post-tags {
	display: flex;
	flex-wrap: wrap;
	gap: 0.5rem;
	margin-bottom: 1rem;
}

.post-tag {
	display: inline-block;
	padding: 0.25rem 0.75rem;
	background: var(--wp--preset--color--mist);
	color: var(--wp--preset--color--moss);
	border-radius: 9999px;
	font-size: var(--wp--preset--font-size--xsmall);
	font-weight: 500;
	text-transform: uppercase;
	letter-spacing: 0.05em;
}

/* ==========================================================================
   Hero Section
   ========================================================================== */

.hero-section {
	position: relative;
	min-height: 90vh;
	display: flex;
	align-items: center;
	overflow: hidden;
}

.hero-blob {
	position: absolute;
	opacity: 0.5;
}

.hero-blob-1 {
	top: 10%;
	right: 10%;
	width: 400px;
	height: 400px;
	background: linear-gradient(135deg, var(--wp--preset--color--moss-100) 0%, var(--wp--preset--color--moss-200) 100%);
	animation: terra-spin-slow 30s linear infinite;
}

.hero-blob-2 {
	bottom: 10%;
	left: 5%;
	width: 300px;
	height: 300px;
	background: linear-gradient(135deg, var(--wp--preset--color--clay-100) 0%, var(--wp--preset--color--clay-200) 100%);
	animation: terra-bob 6s ease-in-out infinite;
}

.hero-content {
	position: relative;
	z-index: 1;
}

/* ==========================================================================
   Image Styles
   ========================================================================== */

img.organic-blob-1,
img.organic-blob-2,
img.organic-blob-3,
img.organic-blob-4 {
	object-fit: cover;
}

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

@media (max-width: 782px) {
	.floating-nav {
		left: 1rem;
		right: 1rem;
		transform: none;
		border-radius: 1rem;
		padding: 0.5rem 1rem;
	}

	.floating-nav .wp-block-navigation__container {
		gap: 1rem;
	}

	.stat-number {
		font-size: var(--wp--preset--font-size--huge);
	}

	.step-connector {
		display: none;
	}

	.hero-section {
		min-height: auto;
		padding-top: 8rem;
		padding-bottom: 4rem;
	}

	.hero-blob {
		opacity: 0.3;
	}
}

/* ==========================================================================
   Utility Classes
   ========================================================================== */

.text-center {
	text-align: center;
}

.text-moss {
	color: var(--wp--preset--color--moss);
}

.text-clay {
	color: var(--wp--preset--color--clay);
}

.text-dried {
	color: var(--wp--preset--color--dried);
}

.bg-rice {
	background-color: var(--wp--preset--color--rice);
}

.bg-stone {
	background-color: var(--wp--preset--color--stone);
}

.bg-mist {
	background-color: var(--wp--preset--color--mist);
}

/* ==========================================================================
   Print Styles
   ========================================================================== */

@media print {
	.grain-overlay,
	.floating-nav,
	.hero-blob {
		display: none !important;
	}

	.site-footer {
		background: transparent;
		color: inherit;
	}
}
