/**
 * Commit Sites Landing Pattern Styles
 *
 * @package CommitSitesLandingPattern
 * @version 1.0.0
 */

/* ==========================================================================
   Hide admin bar on landing pages
   ========================================================================== */

body:has(.cslp-landing) #wpadminbar {
	display: none !important;
}

body:has(.cslp-landing).admin-bar {
	margin-top: 0 !important;
}

html:has(.cslp-landing) {
	margin-top: 0 !important;
}

/* ==========================================================================
   Hide page title on landing pages
   ========================================================================== */

.cslp-landing ~ .entry-title,
.cslp-landing ~ h1.page-title,
.page .cslp-landing ~ h1,
body:has(.cslp-landing) .entry-title,
body:has(.cslp-landing) .page-title,
body:has(.cslp-landing) header.entry-header,
body:has(.cslp-landing) .wp-block-post-title {
	display: none !important;
}

/* Hide title in editor */
.editor-styles-wrapper .cslp-landing + .editor-post-title,
.editor-styles-wrapper:has(.cslp-landing) .editor-post-title {
	display: none !important;
}

/* ==========================================================================
   Full-width Layout Override (Theme compatibility)
   ========================================================================== */

/* Main container - full width */
.cslp-landing,
.cslp-landing.wp-block-group {
	max-width: 100% !important;
	width: 100% !important;
	padding-left: 0 !important;
	padding-right: 0 !important;
	margin-left: 0 !important;
	margin-right: 0 !important;
}

/* All inner groups - consistent max-width */
.cslp-landing .wp-block-group {
	max-width: 100% !important;
	width: 100% !important;
}

/* Sections with content - centered with max-width */
.cslp-landing .cslp-section,
.cslp-landing .cslp-outcomes,
.cslp-landing .cslp-process,
.cslp-landing .cslp-packages,
.cslp-landing .cslp-references,
.cslp-landing .cslp-cases,
.cslp-landing .cslp-faq {
	max-width: var(--cslp-max-width) !important;
	width: 100% !important;
	margin-left: auto !important;
	margin-right: auto !important;
	padding-left: 2rem !important;
	padding-right: 2rem !important;
}

/* Full-width background sections (hero, proof, lead magnet, footer, final cta, process) */
.cslp-landing .cslp-hero,
.cslp-landing .cslp-proof-strip,
.cslp-landing .cslp-lead-magnet,
.cslp-landing .cslp-final-cta,
.cslp-landing .cslp-footer,
.cslp-landing .cslp-process {
	max-width: 100vw !important;
	width: 100vw !important;
	margin-left: calc(-50vw + 50%) !important;
	margin-right: calc(-50vw + 50%) !important;
	padding-left: calc(50vw - 50%) !important;
	padding-right: calc(50vw - 50%) !important;
}

/* Columns - ensure they stretch */
.cslp-landing .wp-block-columns {
	max-width: 100% !important;
	width: 100% !important;
	gap: 2rem;
}

.cslp-landing .wp-block-column {
	flex-basis: 0 !important;
	flex-grow: 1 !important;
	min-width: 0 !important;
}

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

:root {
	--cslp-primary: #2563eb;
	--cslp-primary-dark: #1d4ed8;
	--cslp-primary-light: #3b82f6;
	--cslp-secondary: #64748b;
	--cslp-text: #1e293b;
	--cslp-text-light: #475569;
	--cslp-text-muted: #94a3b8;
	--cslp-bg: #ffffff;
	--cslp-bg-alt: #f8fafc;
	--cslp-bg-dark: #0f172a;
	--cslp-border: #e2e8f0;
	--cslp-radius: 8px;
	--cslp-radius-lg: 16px;
	--cslp-shadow: 0 4px 6px -1px rgb(0 0 0 / 0.1), 0 2px 4px -2px rgb(0 0 0 / 0.1);
	--cslp-shadow-lg: 0 10px 15px -3px rgb(0 0 0 / 0.1), 0 4px 6px -4px rgb(0 0 0 / 0.1);
	--cslp-max-width: 1200px;
	--cslp-section-spacing: 5rem;
	--cslp-transition: 0.2s ease;
}

/* ==========================================================================
   Base / Reset
   ========================================================================== */

.cslp-landing {
	font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen-Sans, Ubuntu, Cantarell, "Helvetica Neue", sans-serif;
	color: var(--cslp-text);
	line-height: 1.6;
}

.cslp-landing *,
.cslp-landing *::before,
.cslp-landing *::after {
	box-sizing: border-box;
}

/* ==========================================================================
   Section Base
   ========================================================================== */

.cslp-section {
	padding: var(--cslp-section-spacing) 1.5rem;
}

.cslp-section-title {
	font-size: clamp(1.75rem, 4vw, 2.5rem);
	font-weight: 700;
	margin-bottom: 1rem;
	color: var(--cslp-text);
}

.cslp-section-subtitle {
	font-size: 1.125rem;
	color: var(--cslp-text-light);
	margin-bottom: 3rem;
	max-width: 600px;
	margin-left: auto;
	margin-right: auto;
}

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

.cslp-hero {
	background: linear-gradient(135deg, var(--cslp-bg) 0%, var(--cslp-bg-alt) 100%);
	padding: 6rem 2rem;
}

/* Hero inner content centering */
.cslp-hero > .wp-block-heading,
.cslp-hero > .wp-block-paragraph,
.cslp-hero > .wp-block-buttons,
.cslp-hero .cslp-hero-title,
.cslp-hero .cslp-hero-subtitle,
.cslp-hero .cslp-hero-buttons {
	max-width: var(--cslp-max-width);
	margin-left: auto;
	margin-right: auto;
	padding-left: 2rem;
	text-align: center;
}

.cslp-hero-title {
	font-size: clamp(2rem, 5vw, 3.5rem);
	font-weight: 800;
	line-height: 1.2;
	margin-bottom: 1.5rem;
	color: var(--cslp-text);
	max-width: 900px;
	margin-left: auto;
	margin-right: auto;
}

.cslp-hero-subtitle {
	font-size: clamp(1.125rem, 2vw, 1.375rem);
	color: var(--cslp-text-light);
	margin-bottom: 2.5rem;
	max-width: 700px;
	margin-left: auto;
	margin-right: auto;
}

.cslp-hero-buttons {
	gap: 1rem;
}

.cslp-hero-buttons .wp-block-button__link {
	padding: 1rem 2rem;
	font-size: 1.125rem;
	font-weight: 600;
	border-radius: var(--cslp-radius);
	transition: all var(--cslp-transition);
}

.cslp-cta-primary .wp-block-button__link {
	background: var(--cslp-primary);
	color: var(--cslp-bg);
	border: 2px solid var(--cslp-primary);
}

.cslp-cta-primary .wp-block-button__link:hover {
	background: var(--cslp-primary-dark);
	border-color: var(--cslp-primary-dark);
	transform: translateY(-2px);
	box-shadow: var(--cslp-shadow-lg);
}

.cslp-cta-secondary .wp-block-button__link {
	background: transparent;
	color: var(--cslp-primary);
	border: 2px solid var(--cslp-primary);
}

.cslp-cta-secondary .wp-block-button__link:hover {
	background: var(--cslp-primary);
	color: var(--cslp-bg);
}

/* ==========================================================================
   Proof Strip
   ========================================================================== */

.cslp-proof-strip {
	background: var(--cslp-bg-dark);
	padding: 2rem 2rem;
}

.cslp-proof-strip > .wp-block-columns,
.cslp-proof-strip .cslp-proof-columns {
	max-width: var(--cslp-max-width) !important;
	margin-left: auto !important;
	margin-right: auto !important;
}

.cslp-proof-columns {
	display: grid !important;
	grid-template-columns: repeat(4, 1fr) !important;
	gap: 1rem;
	max-width: var(--cslp-max-width);
	margin: 0 auto;
	width: 100% !important;
}

.cslp-proof-item {
	color: var(--cslp-bg);
	font-size: 0.95rem;
	font-weight: 500;
	margin: 0;
	padding: 0.5rem;
}

/* ==========================================================================
   Cards (Outcomes, References, Cases)
   ========================================================================== */

/* Force 3-column grid for card sections */
.cslp-outcome-cards,
.cslp-reference-cards,
.cslp-process-steps {
	display: grid !important;
	grid-template-columns: repeat(3, 1fr) !important;
	gap: 2rem !important;
	width: 100% !important;
}

/* Force 2-column grid for testimonials */
.cslp-case-cards {
	display: grid !important;
	grid-template-columns: repeat(2, 1fr) !important;
	gap: 2rem !important;
	width: 100% !important;
}

.cslp-card,
.cslp-reference-card,
.cslp-case-card {
	background: var(--cslp-bg);
	border: 1px solid var(--cslp-border);
	border-radius: var(--cslp-radius-lg);
	padding: 2rem;
	transition: all var(--cslp-transition);
	width: 100% !important;
	max-width: 100% !important;
}

.cslp-card:hover,
.cslp-reference-card:hover {
	box-shadow: var(--cslp-shadow-lg);
	transform: translateY(-4px);
}

.cslp-card-title,
.cslp-reference-title {
	font-size: 1.25rem;
	font-weight: 600;
	margin-bottom: 1rem;
	color: var(--cslp-text);
}

/* ==========================================================================
   Process Steps
   ========================================================================== */

.cslp-process {
	background: var(--cslp-bg-alt);
}

/* Process inner content centering */
.cslp-process > .wp-block-heading,
.cslp-process > .wp-block-columns,
.cslp-process .cslp-process-steps {
	max-width: var(--cslp-max-width);
	margin-left: auto;
	margin-right: auto;
}

.cslp-step {
	text-align: center;
	padding: 2rem;
}

.cslp-step-number {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 60px;
	height: 60px;
	background: var(--cslp-primary);
	color: var(--cslp-bg);
	border-radius: 50%;
	font-size: 1.5rem;
	font-weight: 700;
	margin-bottom: 1rem;
}

.cslp-step-title {
	font-size: 1.25rem;
	font-weight: 600;
	margin-bottom: 1rem;
}

/* ==========================================================================
   Package Cards
   ========================================================================== */

.cslp-package-cards {
	gap: 2rem;
}

/* Force 3-column grid for packages */
.cslp-package-cards {
	display: grid !important;
	grid-template-columns: repeat(3, 1fr) !important;
	gap: 2rem !important;
	width: 100% !important;
	align-items: start;
}

.cslp-package-card {
	background: var(--cslp-bg);
	border: 1px solid var(--cslp-border);
	border-radius: var(--cslp-radius-lg);
	padding: 2.5rem 2rem;
	text-align: center;
	transition: all var(--cslp-transition);
	position: relative;
	width: 100% !important;
	max-width: 100% !important;
}

.cslp-package-card:hover {
	box-shadow: var(--cslp-shadow-lg);
	transform: translateY(-4px);
}

.cslp-package-featured {
	border: 2px solid var(--cslp-primary);
	transform: scale(1.02);
}

.cslp-package-featured:hover {
	transform: scale(1.02) translateY(-4px);
}

.cslp-package-badge {
	position: absolute;
	top: -12px;
	left: 50%;
	transform: translateX(-50%);
	background: var(--cslp-primary);
	color: var(--cslp-bg);
	padding: 0.25rem 1rem;
	border-radius: 999px;
	font-size: 0.875rem;
	font-weight: 600;
	white-space: nowrap;
}

.cslp-package-name {
	font-size: 1.5rem;
	font-weight: 700;
	margin-bottom: 0.5rem;
}

.cslp-package-price {
	font-size: 2rem;
	font-weight: 800;
	color: var(--cslp-primary);
	margin-bottom: 1.5rem;
}

.cslp-package-features {
	text-align: left;
	margin-bottom: 2rem;
	padding-left: 1.25rem;
}

.cslp-package-features li {
	padding: 0.5rem 0;
	color: var(--cslp-text-light);
	border-bottom: 1px solid var(--cslp-border);
}

.cslp-package-features li:last-child {
	border-bottom: none;
}

.cslp-package-cta .wp-block-button__link {
	background: var(--cslp-primary);
	color: var(--cslp-bg);
	padding: 1rem;
	font-weight: 600;
	border-radius: var(--cslp-radius);
	transition: all var(--cslp-transition);
}

.cslp-package-cta .wp-block-button__link:hover {
	background: var(--cslp-primary-dark);
}

/* ==========================================================================
   Case Studies / Testimonials
   ========================================================================== */

.cslp-case-card {
	background: var(--cslp-bg-alt);
}

.cslp-case-quote {
	font-size: 1.125rem;
	font-style: italic;
	color: var(--cslp-text);
	margin-bottom: 1rem;
	line-height: 1.7;
}

.cslp-case-author {
	font-size: 0.95rem;
	font-weight: 600;
	color: var(--cslp-text-muted);
}

/* ==========================================================================
   Lead Magnet
   ========================================================================== */

.cslp-lead-magnet {
	background: linear-gradient(135deg, var(--cslp-primary) 0%, var(--cslp-primary-dark) 100%);
	color: var(--cslp-bg);
	text-align: center;
}

/* Lead magnet inner content centering */
.cslp-lead-magnet > .wp-block-heading,
.cslp-lead-magnet > .wp-block-paragraph,
.cslp-lead-magnet > .wp-block-buttons {
	max-width: var(--cslp-max-width);
	margin-left: auto;
	margin-right: auto;
}

.cslp-lead-magnet .cslp-section-title {
	color: var(--cslp-bg);
}

.cslp-lead-magnet-text {
	font-size: 1.125rem;
	max-width: 600px;
	margin: 0 auto 2rem;
	opacity: 0.95;
}

.cslp-lead-magnet .cslp-cta-primary .wp-block-button__link {
	background: var(--cslp-bg);
	color: var(--cslp-primary);
	border-color: var(--cslp-bg);
}

.cslp-lead-magnet .cslp-cta-primary .wp-block-button__link:hover {
	background: var(--cslp-bg-alt);
	transform: translateY(-2px);
}

/* ==========================================================================
   FAQ Section
   ========================================================================== */

.cslp-faq .wp-block-details {
	border-bottom: 1px solid var(--cslp-border);
	padding: 0;
	margin-bottom: 0;
}

.cslp-faq .wp-block-details summary {
	font-size: 1.125rem;
	font-weight: 600;
	padding: 1.25rem 0;
	cursor: pointer;
	list-style: none;
	display: flex;
	justify-content: space-between;
	align-items: center;
	color: var(--cslp-text);
	transition: color var(--cslp-transition);
}

.cslp-faq .wp-block-details summary::-webkit-details-marker {
	display: none;
}

.cslp-faq .wp-block-details summary::after {
	content: "+";
	font-size: 1.5rem;
	font-weight: 300;
	color: var(--cslp-primary);
	transition: transform var(--cslp-transition);
}

.cslp-faq .wp-block-details[open] summary::after {
	transform: rotate(45deg);
}

.cslp-faq .wp-block-details summary:hover {
	color: var(--cslp-primary);
}

.cslp-faq .wp-block-details p {
	padding: 0 0 1.25rem;
	color: var(--cslp-text-light);
	line-height: 1.7;
}

/* ==========================================================================
   Final CTA
   ========================================================================== */

.cslp-final-cta {
	background: var(--cslp-bg-alt);
	text-align: center;
}

/* Final CTA inner content centering */
.cslp-final-cta > .wp-block-heading,
.cslp-final-cta > .wp-block-paragraph,
.cslp-final-cta > .wp-block-buttons {
	max-width: var(--cslp-max-width);
	margin-left: auto;
	margin-right: auto;
}

.cslp-final-cta-text {
	font-size: 1.125rem;
	max-width: 600px;
	margin: 0 auto 2rem;
	color: var(--cslp-text-light);
}

.cslp-final-cta-buttons {
	gap: 1rem;
	justify-content: center;
}

.cslp-final-cta-buttons .wp-block-button__link {
	padding: 1rem 2rem;
	font-size: 1.125rem;
	font-weight: 600;
	border-radius: var(--cslp-radius);
}

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

.cslp-footer {
	background: var(--cslp-bg-dark);
	padding: 3rem 2rem;
	text-align: center;
}

/* Footer inner content centering */
.cslp-footer > .wp-block-paragraph {
	max-width: var(--cslp-max-width);
	margin-left: auto;
	margin-right: auto;
}

.cslp-footer-text {
	color: var(--cslp-text-muted);
	font-size: 0.95rem;
	margin-bottom: 1rem;
}

.cslp-footer-links {
	font-size: 0.875rem;
}

.cslp-footer-links a {
	color: var(--cslp-text-muted);
	text-decoration: none;
	transition: color var(--cslp-transition);
}

.cslp-footer-links a:hover {
	color: var(--cslp-bg);
}

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

@media (max-width: 1024px) {
	:root {
		--cslp-section-spacing: 4rem;
	}
}

@media (max-width: 768px) {
	:root {
		--cslp-section-spacing: 3rem;
	}

	.cslp-hero {
		padding: 4rem 1rem;
	}

	/* Proof strip: 2 columns on tablet */
	.cslp-proof-columns {
		display: grid !important;
		grid-template-columns: repeat(2, 1fr) !important;
	}

	/* All card grids: 1 column on tablet */
	.cslp-outcome-cards,
	.cslp-process-steps,
	.cslp-package-cards,
	.cslp-reference-cards,
	.cslp-case-cards {
		grid-template-columns: 1fr !important;
	}

	.cslp-package-featured {
		transform: none;
		order: -1;
	}

	.cslp-package-featured:hover {
		transform: translateY(-4px);
	}
}

@media (max-width: 480px) {
	.cslp-hero {
		padding: 3rem 1rem;
	}

	.cslp-hero-buttons {
		flex-direction: column;
	}

	.cslp-hero-buttons .wp-block-button {
		width: 100%;
	}

	/* Proof strip: 1 column on mobile */
	.cslp-proof-columns {
		grid-template-columns: 1fr !important;
	}

	.cslp-package-card {
		padding: 2rem 1.5rem;
	}

	.cslp-final-cta-buttons {
		flex-direction: column;
	}

	.cslp-final-cta-buttons .wp-block-button {
		width: 100%;
	}
}

/* ==========================================================================
   Editor-specific adjustments
   ========================================================================== */

.editor-styles-wrapper .cslp-landing {
	max-width: 100%;
	margin: 0;
}

.editor-styles-wrapper .cslp-landing > .wp-block-group {
	max-width: 100%;
}

/* Full-width sections in editor */
.editor-styles-wrapper .cslp-hero,
.editor-styles-wrapper .cslp-proof-strip,
.editor-styles-wrapper .cslp-lead-magnet,
.editor-styles-wrapper .cslp-final-cta,
.editor-styles-wrapper .cslp-footer {
	margin-left: calc(-50vw + 50%) !important;
	margin-right: calc(-50vw + 50%) !important;
	padding-left: max(2rem, calc(50vw - 600px)) !important;
	padding-right: max(2rem, calc(50vw - 600px)) !important;
	width: 100vw !important;
	max-width: 100vw !important;
}

/* Ensure backgrounds show in editor */
.editor-styles-wrapper .cslp-hero {
	background: linear-gradient(135deg, var(--cslp-bg) 0%, var(--cslp-bg-alt) 100%) !important;
}

.editor-styles-wrapper .cslp-proof-strip {
	background: var(--cslp-bg-dark) !important;
}

.editor-styles-wrapper .cslp-lead-magnet {
	background: linear-gradient(135deg, var(--cslp-primary) 0%, var(--cslp-primary-dark) 100%) !important;
}

.editor-styles-wrapper .cslp-final-cta {
	background: var(--cslp-bg-alt) !important;
}

.editor-styles-wrapper .cslp-footer {
	background: var(--cslp-bg-dark) !important;
}

.editor-styles-wrapper .cslp-process {
	background: var(--cslp-bg-alt) !important;
}

/* Fix inner content width in editor */
.editor-styles-wrapper .cslp-section {
	max-width: var(--cslp-max-width);
	margin-left: auto;
	margin-right: auto;
}
