/**
 * SK Platform — Professional frontend styles
 * Inspired by Vivid+Co, Beam Ker, Ahsan Danish, Squarespace Forma
 */

:root {
	--sk-primary: #2563eb;
	--sk-primary-dark: #1d4ed8;
	--sk-secondary: #7c3aed;
	--sk-accent: #0ea5e9;
	--sk-dark: #0a0f1a;
	--sk-dark-soft: #0f1623;
	--sk-dark-mid: #151d2e;
	--sk-muted: #64748b;
	--sk-muted-light: #94a3b8;
	--sk-light: #151d2e;
	--sk-light-soft: #1e293b;
	--sk-border: #1e293b;
	--sk-radius: 10px;
	--sk-radius-lg: 16px;
	--sk-shadow: 0 4px 6px -1px rgb(0 0 0 / 0.07), 0 2px 4px -2px rgb(0 0 0 / 0.05);
	--sk-shadow-lg: 0 20px 25px -5px rgb(0 0 0 / 0.08), 0 8px 10px -6px rgb(0 0 0 / 0.04);
	--sk-font-display: 'DM Serif Display', Georgia, serif;
	--sk-font-body: 'DM Sans', system-ui, -apple-system, sans-serif;
}

/* Typography */
.sk-home-page {
	font-family: var(--sk-font-body);
}

.sk-home-page h1,
.sk-home-page h2,
.sk-home-page h3 {
	font-family: var(--sk-font-display);
	font-weight: 400;
}

/* Container */
.sk-container {
	width: 100%;
	max-width: 1200px;
	margin: 0 auto;
	padding: 0 1.5rem;
}

@media (min-width: 768px) {
	.sk-container { padding: 0 2rem; }
}

.sk-section-label {
	display: inline-block;
	font-size: 0.75rem;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.12em;
	color: var(--sk-primary);
	margin-bottom: 0.75rem;
}

.sk-philosophy .sk-section-label,
.sk-process .sk-section-label {
	color: #60a5fa;
}

.sk-section-label--center {
	display: block;
	text-align: center;
	margin-bottom: 0.5rem;
}

/* Buttons */
.sk-btn {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 0.5rem;
	padding: 0.75rem 1.5rem;
	font-weight: 600;
	font-size: 1rem;
	line-height: 1.5;
	border-radius: var(--sk-radius);
	text-decoration: none;
	transition: all 0.2s;
	cursor: pointer;
	border: 2px solid transparent;
}

.sk-btn--primary {
	background: var(--sk-primary);
	color: white;
	border-color: var(--sk-primary);
}

.sk-btn--primary:hover {
	background: var(--sk-primary-dark);
	border-color: var(--sk-primary-dark);
	color: white;
	transform: translateY(-1px);
}

.sk-btn--secondary {
	background: var(--sk-secondary);
	color: white;
	border-color: var(--sk-secondary);
}

.sk-btn--secondary:hover {
	background: #6d28d9;
	border-color: #6d28d9;
	color: white;
}

.sk-btn--outline {
	background: transparent;
	color: var(--sk-primary);
	border-color: var(--sk-primary);
}

.sk-btn--outline:hover {
	background: var(--sk-primary);
	color: white;
}

.sk-btn--lg {
	padding: 1rem 2rem;
	font-size: 1.0625rem;
}

.sk-btn--light {
	color: rgba(255, 255, 255, 0.95) !important;
	border-color: rgba(255, 255, 255, 0.5) !important;
}

.sk-btn--light:hover {
	background: rgba(255, 255, 255, 0.15) !important;
	color: white !important;
	border-color: white !important;
}

.sk-btn--white {
	background: white !important;
	color: var(--sk-primary) !important;
	border-color: white !important;
}

.sk-btn--white:hover {
	background: rgba(255, 255, 255, 0.9) !important;
	color: var(--sk-primary-dark) !important;
	border-color: rgba(255, 255, 255, 0.9) !important;
	transform: translateY(-1px);
}

/* Badge */
.sk-badge {
	display: inline-block;
	padding: 0.35rem 0.75rem;
	font-size: 0.75rem;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.05em;
	background: rgba(79, 70, 229, 0.1);
	color: var(--sk-primary);
	border-radius: 9999px;
	margin-bottom: 1rem;
}

/* Hero — Fluid, editorial style with Vivid+Co-inspired animated background */
.sk-hero {
	position: relative;
	background: #0a0f1a;
	background: linear-gradient(165deg, #060a12 0%, #0a0f1a 35%, #0f1623 70%, #151d2e 100%);
	color: white;
	padding: 5rem 0 6rem;
	overflow: hidden;
}

/* Animated gradient orbs — Vivid+Co style */
.sk-hero__animated-bg {
	position: absolute;
	inset: 0;
	z-index: 0;
	pointer-events: none;
	overflow: hidden;
}

.sk-hero__orb-wrapper {
	position: absolute;
	will-change: transform;
}

.sk-hero__orb {
	position: absolute;
	border-radius: 50%;
	filter: blur(70px);
	opacity: 0.7;
	will-change: transform;
}

.sk-hero__orb-wrapper--1 { top: -10%; right: -5%; }
.sk-hero__orb-wrapper--2 { bottom: -15%; left: -8%; }
.sk-hero__orb-wrapper--3 { top: 40%; left: 50%; transform: translate(-50%, -50%); }
.sk-hero__orb-wrapper--4 { top: 60%; right: 15%; }

.sk-hero__orb--1 {
	width:  clamp(300px, 40vw, 500px);
	height: clamp(300px, 40vw, 500px);
	background: radial-gradient(circle, rgba(37, 99, 235, 0.5) 0%, rgba(37, 99, 235, 0.2) 40%, transparent 70%);
	top: 0; left: 0;
	animation: sk-orb-float-1 18s ease-in-out infinite;
}

.sk-hero__orb--2 {
	width:  clamp(250px, 35vw, 420px);
	height: clamp(250px, 35vw, 420px);
	background: radial-gradient(circle, rgba(124, 58, 237, 0.45) 0%, rgba(124, 58, 237, 0.15) 40%, transparent 70%);
	bottom: 0; left: 0;
	animation: sk-orb-float-2 22s ease-in-out infinite;
}

.sk-hero__orb--3 {
	width:  clamp(180px, 25vw, 320px);
	height: clamp(180px, 25vw, 320px);
	background: radial-gradient(circle, rgba(14, 165, 233, 0.4) 0%, rgba(14, 165, 233, 0.12) 50%, transparent 70%);
	top: 50%; left: 50%;
	transform: translate(-50%, -50%);
	animation: sk-orb-float-3 20s ease-in-out infinite;
}

.sk-hero__orb--4 {
	width:  clamp(200px, 28vw, 360px);
	height: clamp(200px, 28vw, 360px);
	background: radial-gradient(circle, rgba(37, 99, 235, 0.35) 0%, rgba(37, 99, 235, 0.1) 50%, transparent 70%);
	top: 0; right: 0;
	animation: sk-orb-float-4 25s ease-in-out infinite;
}

/* Subtle grid overlay */
.sk-hero__grid {
	position: absolute;
	inset: 0;
	background-image:
		linear-gradient(rgba(255, 255, 255, 0.02) 1px, transparent 1px),
		linear-gradient(90deg, rgba(255, 255, 255, 0.02) 1px, transparent 1px);
	background-size: 60px 60px;
	opacity: 0.6;
}

@keyframes sk-orb-float-1 {
	0%, 100% { transform: translate(0, 0) scale(1); }
	33% { transform: translate(-20px, 30px) scale(1.05); }
	66% { transform: translate(15px, -20px) scale(0.98); }
}

@keyframes sk-orb-float-2 {
	0%, 100% { transform: translate(0, 0) scale(1); }
	25% { transform: translate(25px, -25px) scale(1.03); }
	50% { transform: translate(-15px, 20px) scale(0.97); }
	75% { transform: translate(10px, 15px) scale(1.02); }
}

@keyframes sk-orb-float-3 {
	0%, 100% { transform: translate(-50%, -50%) scale(1); }
	50% { transform: translate(calc(-50% + 25px), calc(-50% - 20px)) scale(1.08); }
}

@keyframes sk-orb-float-4 {
	0%, 100% { transform: translate(0, 0); }
	33% { transform: translate(-30px, -15px); }
	66% { transform: translate(20px, 25px); }
}

@media (prefers-reduced-motion: reduce) {
	.sk-hero__orb { animation: none; }
	.sk-hero__orb-wrapper { transition: none; }
}

.sk-hero .sk-container {
	position: relative;
	z-index: 1;
}

.sk-hero__inner {
	position: relative;
	display: grid;
	gap: 2.5rem;
	align-items: center;
}

@media (min-width: 992px) {
	.sk-hero__inner {
		grid-template-columns: 1.1fr 0.9fr;
		gap: 4rem;
	}
	.sk-hero { padding: 6rem 0 8rem; }
}

.sk-hero__badge {
	display: inline-block;
	padding: 0.4rem 1rem;
	font-size: 0.7rem;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.15em;
	background: rgba(255, 255, 255, 0.08);
	border: 1px solid rgba(255, 255, 255, 0.15);
	border-radius: 9999px;
	margin-bottom: 1.25rem;
	color: rgba(255, 255, 255, 0.9);
}

.sk-hero__title {
	font-family: var(--sk-font-display);
	font-size: clamp(2.5rem, 6vw, 4rem);
	font-weight: 400;
	line-height: 1.1;
	letter-spacing: -0.02em;
	margin: 0 0 1.25rem;
}

.sk-hero__title-line {
	display: block;
}

.sk-hero__tagline {
	font-size: 1.125rem;
	color: rgba(255, 255, 255, 0.8);
	line-height: 1.7;
	margin: 0 0 1.75rem;
	max-width: 34rem;
}

.sk-hero__cta {
	display: flex;
	flex-wrap: wrap;
	gap: 1rem;
}

.sk-hero__visual {
	display: none;
}

@media (min-width: 992px) {
	.sk-hero__visual { display: block; }
}

.sk-hero__visual-placeholder {
	border-radius: var(--sk-radius-lg);
	overflow: hidden;
	box-shadow: 0 25px 50px -12px rgb(0 0 0 / 0.35);
	border: 1px solid rgba(255, 255, 255, 0.06);
}

.sk-hero__visual-placeholder svg {
	display: block;
	width: 100%;
	height: auto;
}

/* Stats — Ahsan Danish inspired */
.sk-stats {
	padding: 3rem 0;
	background: var(--sk-dark-soft);
	border-bottom: 1px solid rgba(255, 255, 255, 0.06);
}

.sk-stats__grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: 2rem;
	text-align: center;
}

@media (min-width: 640px) {
	.sk-stats__grid {
		grid-template-columns: repeat(3, 1fr);
	}
}

.sk-stat__number {
	display: block;
	font-family: var(--sk-font-display);
	font-size: clamp(2rem, 4vw, 2.75rem);
	font-weight: 400;
	color: #60a5fa;
	line-height: 1.2;
	margin-bottom: 0.25rem;
}

.sk-stat__label {
	font-size: 0.875rem;
	font-weight: 500;
	color: rgba(255, 255, 255, 0.6);
	text-transform: uppercase;
	letter-spacing: 0.05em;
}

/* Philosophy — Beam Ker / Vivid+Co */
.sk-philosophy {
	padding: 5rem 0;
	background: var(--sk-dark-mid);
}

.sk-philosophy__inner {
	max-width: 680px;
}

.sk-philosophy__title {
	font-family: var(--sk-font-display);
	font-size: clamp(1.75rem, 3.5vw, 2.5rem);
	font-weight: 400;
	line-height: 1.25;
	margin: 0 0 1.25rem;
	color: #fff;
}

.sk-philosophy__text {
	font-size: 1.0625rem;
	line-height: 1.75;
	margin: 0 0 1rem;
	color: rgba(255, 255, 255, 0.85);
}

.sk-philosophy__text--muted {
	color: rgba(255, 255, 255, 0.6);
}

/* Process — Beam Ker CLARIFY · INTENT · CONTINUITY */
.sk-process {
	padding: 5rem 0;
	background: var(--sk-dark-soft);
	text-align: center;
}

.sk-section-title {
	font-family: var(--sk-font-display);
	font-size: clamp(1.5rem, 3vw, 2.25rem);
	font-weight: 400;
	text-align: center;
	margin: 0 0 1rem;
	color: #fff;
}

.sk-process__intro {
	font-size: 1.0625rem;
	color: rgba(255, 255, 255, 0.7);
	max-width: 560px;
	margin: 0 auto 2.5rem;
	line-height: 1.65;
}

.sk-process__grid {
	display: flex;
	flex-wrap: wrap;
	align-items: flex-start;
	justify-content: center;
	gap: 1.5rem 2rem;
	margin-bottom: 2rem;
}

.sk-process__item {
	flex: 1 1 200px;
	max-width: 260px;
	text-align: left;
}

.sk-process__phase {
	display: block;
	font-family: var(--sk-font-display);
	font-size: 1.5rem;
	font-weight: 400;
	color: #60a5fa;
	margin-bottom: 0.5rem;
}

.sk-process__item p {
	margin: 0;
	font-size: 0.9375rem;
	color: rgba(255, 255, 255, 0.7);
	line-height: 1.6;
}

.sk-process__divider {
	color: rgba(255, 255, 255, 0.2);
	font-size: 1.5rem;
	align-self: center;
}

@media (max-width: 767px) {
	.sk-process__divider { display: none; }
}

.sk-process__cta {
	margin-top: 1rem;
}

/* Services — Vivid+Co grid */
.sk-services {
	padding: 5rem 0;
	background: var(--sk-dark-mid);
}

.sk-services .sk-section-label { color: #60a5fa; }
.sk-services .sk-section-title { color: #fff; }

.sk-services__grid {
	display: grid;
	gap: 2rem;
	margin-top: 2rem;
}

@media (min-width: 768px) {
	.sk-services__grid {
		grid-template-columns: repeat(3, 1fr);
		gap: 2.5rem;
	}
}

.sk-service-card {
	background: rgba(255, 255, 255, 0.03);
	border: 1px solid rgba(255, 255, 255, 0.08);
	border-radius: var(--sk-radius-lg);
	padding: 2rem;
	transition: all 0.25s ease;
}

.sk-service-card:hover {
	box-shadow: 0 20px 40px -15px rgba(0, 0, 0, 0.4);
	border-color: rgba(96, 165, 250, 0.3);
	transform: translateY(-3px);
}

.sk-service-card__icon {
	width: 52px;
	height: 52px;
	display: flex;
	align-items: center;
	justify-content: center;
	background: linear-gradient(135deg, rgba(37, 99, 235, 0.2) 0%, rgba(124, 58, 237, 0.15) 100%);
	color: #60a5fa;
	border-radius: var(--sk-radius);
	margin-bottom: 1.25rem;
}

.sk-service-card__icon svg {
	width: 26px;
	height: 26px;
}

.sk-service-card h3 {
	font-family: var(--sk-font-display);
	font-size: 1.35rem;
	font-weight: 400;
	margin: 0 0 0.75rem;
	color: #fff;
}

.sk-service-card p {
	margin: 0;
	font-size: 0.9375rem;
	color: rgba(255, 255, 255, 0.7);
	line-height: 1.65;
}

/* Testimonials — Ahsan Danish */
.sk-testimonials {
	padding: 5rem 0;
	background: var(--sk-dark);
	color: white;
}

.sk-testimonials .sk-section-label { color: #60a5fa; }
.sk-section-title--light {
	color: white !important;
	margin-bottom: 2rem;
}

.sk-testimonials__grid {
	display: grid;
	gap: 2rem;
	margin-top: 2rem;
}

@media (min-width: 768px) {
	.sk-testimonials__grid {
		grid-template-columns: repeat(2, 1fr);
		gap: 2.5rem;
	}
}

.sk-testimonial {
	margin: 0;
	padding: 2rem;
	background: rgba(255, 255, 255, 0.04);
	border: 1px solid rgba(255, 255, 255, 0.08);
	border-radius: var(--sk-radius-lg);
	transition: all 0.25s ease;
}

.sk-testimonial:hover {
	background: rgba(255, 255, 255, 0.06);
	border-color: rgba(255, 255, 255, 0.12);
}

.sk-testimonial__text {
	font-size: 1rem;
	line-height: 1.7;
	margin: 0 0 1.25rem;
	color: rgba(255, 255, 255, 0.9);
	font-style: italic;
}

.sk-testimonial__footer {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 1rem;
}

.sk-testimonial__author {
	font-size: 0.875rem;
	font-weight: 600;
	color: rgba(255, 255, 255, 0.7);
	font-style: normal;
}

.sk-testimonial__rating {
	color: #fbbf24;
	font-size: 0.875rem;
	letter-spacing: 0.05em;
}

/* Features */
.sk-features {
	padding: 4rem 0;
}

.sk-section-title {
	font-size: clamp(1.5rem, 3vw, 2rem);
	font-weight: 700;
	text-align: center;
	margin: 0 0 2.5rem;
	color: var(--sk-dark);
}

.sk-features-grid {
	display: grid;
	gap: 1.5rem;
}

@media (min-width: 768px) {
	.sk-features-grid {
		grid-template-columns: repeat(3, 1fr);
		gap: 2rem;
	}
}

.sk-feature-card {
	background: white;
	border: 1px solid var(--sk-border);
	border-radius: var(--sk-radius-lg);
	padding: 2rem;
	transition: all 0.2s;
}

.sk-feature-card:hover {
	box-shadow: var(--sk-shadow-lg);
	border-color: var(--sk-primary);
	transform: translateY(-2px);
}

.sk-feature-card__icon {
	width: 56px;
	height: 56px;
	display: flex;
	align-items: center;
	justify-content: center;
	background: rgba(79, 70, 229, 0.08);
	color: var(--sk-primary);
	border-radius: var(--sk-radius);
	margin-bottom: 1.25rem;
}

.sk-feature-card h3 {
	font-size: 1.25rem;
	font-weight: 700;
	margin: 0 0 0.5rem;
	color: var(--sk-dark);
}

.sk-feature-card p {
	margin: 0;
	color: var(--sk-muted);
	line-height: 1.6;
}

/* CTA Section */
.sk-cta-section {
	padding: 5rem 0;
	background: var(--sk-dark);
}

.sk-cta-box {
	background: linear-gradient(135deg, rgba(37, 99, 235, 0.9) 0%, rgba(124, 58, 237, 0.85) 100%);
	border: 1px solid rgba(255, 255, 255, 0.1);
	border-radius: var(--sk-radius-lg);
	padding: 4rem 2.5rem;
	text-align: center;
	color: white;
	box-shadow: 0 25px 50px -12px rgba(0, 0, 0, 0.4);
}

.sk-cta-box__title,
.sk-cta-box h2 {
	font-family: var(--sk-font-display);
	font-size: clamp(1.75rem, 3.5vw, 2.5rem);
	font-weight: 400;
	margin: 0 0 0.5rem;
}

.sk-cta-box__subtitle,
.sk-cta-box p {
	margin: 0 0 1.75rem;
	opacity: 0.95;
	font-size: 1.0625rem;
	line-height: 1.6;
}

.sk-cta-box__actions {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: 1rem;
}

.sk-cta-box .sk-btn--outline,
.sk-cta-box .sk-btn--light {
	color: white !important;
	border-color: rgba(255, 255, 255, 0.6) !important;
}

.sk-cta-box .sk-btn--outline:hover,
.sk-cta-box .sk-btn--light:hover {
	background: rgba(255, 255, 255, 0.15) !important;
	color: white !important;
	border-color: white !important;
}

/* Booking Page */
.sk-booking-page {
	padding-bottom: 4rem;
}

.sk-booking-hero {
	background: var(--sk-light);
	border-bottom: 1px solid var(--sk-border);
	padding: 2.5rem 0;
}

.sk-booking-hero__title {
	font-size: clamp(1.75rem, 4vw, 2.25rem);
	font-weight: 700;
	margin: 0 0 0.5rem;
	color: var(--sk-dark);
}

.sk-booking-hero__subtitle {
	margin: 0 0 1rem;
	color: var(--sk-muted);
	line-height: 1.6;
}

.sk-tz-badge {
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
	font-size: 0.875rem;
	color: var(--sk-muted);
}

.sk-tz-badge svg {
	flex-shrink: 0;
	color: var(--sk-primary);
}

.sk-tz-badge__tz {
	font-size: 0.75rem;
	opacity: 0.8;
}

.sk-booking-form-section {
	padding: 2.5rem 0;
}

.sk-booking-form-section .sk-container {
	display: grid;
	gap: 2rem;
}

@media (min-width: 992px) {
	.sk-booking-form-section .sk-container {
		grid-template-columns: 1fr 320px;
	}
}

.sk-booking-form-wrapper {
	background: white;
	border: 1px solid var(--sk-border);
	border-radius: var(--sk-radius-lg);
	padding: 2rem;
	box-shadow: var(--sk-shadow);
}

.sk-booking-sidebar {
	order: -1;
}

@media (min-width: 992px) {
	.sk-booking-sidebar { order: 0; }
}

.sk-booking-info-card {
	background: var(--sk-light);
	border: 1px solid var(--sk-border);
	border-radius: var(--sk-radius);
	padding: 1.5rem;
	position: sticky;
	top: 2rem;
}

.sk-booking-info-card h4 {
	font-size: 1rem;
	font-weight: 700;
	margin: 0 0 1rem;
	color: var(--sk-dark);
}

.sk-booking-info-card ul {
	margin: 0;
	padding: 0;
	list-style: none;
}

.sk-booking-info-card li {
	padding: 0.5rem 0;
	padding-left: 1.5rem;
	position: relative;
	color: var(--sk-muted);
	font-size: 0.9375rem;
}

.sk-booking-info-card li::before {
	content: "";
	position: absolute;
	left: 0;
	top: 1rem;
	width: 6px;
	height: 6px;
	background: var(--sk-primary);
	border-radius: 50%;
}

/* Placeholder (no plugin) */
.sk-booking-placeholder,
.sk-courses-placeholder {
	text-align: center;
	padding: 3rem 2rem;
}

.sk-booking-placeholder__icon,
.sk-courses-placeholder__icon {
	color: var(--sk-muted);
	margin-bottom: 1rem;
}

.sk-booking-placeholder h3,
.sk-courses-placeholder h3 {
	font-size: 1.25rem;
	font-weight: 700;
	margin: 0 0 0.5rem;
	color: var(--sk-dark);
}

.sk-booking-placeholder p,
.sk-courses-placeholder p {
	margin: 0 0 1.5rem;
	color: var(--sk-muted);
}

/* Courses Page */
.sk-courses-page {
	padding-bottom: 4rem;
}

.sk-courses-hero {
	background: var(--sk-light);
	border-bottom: 1px solid var(--sk-border);
	padding: 2.5rem 0;
}

.sk-courses-hero__title {
	font-size: clamp(1.75rem, 4vw, 2.25rem);
	font-weight: 700;
	margin: 0 0 0.5rem;
	color: var(--sk-dark);
}

.sk-courses-hero__subtitle {
	margin: 0;
	color: var(--sk-muted);
	line-height: 1.6;
}

.sk-courses-content {
	padding: 2.5rem 0;
}

/* LearnDash / Tutor grid override */
.sk-courses-content .ld-course-list,
.sk-courses-content .tutor-course-list {
	display: grid;
	gap: 1.5rem;
}

@media (min-width: 768px) {
	.sk-courses-content .ld-course-list,
	.sk-courses-content .tutor-course-list {
		grid-template-columns: repeat(2, 1fr);
	}
}

@media (min-width: 1024px) {
	.sk-courses-content .ld-course-list,
	.sk-courses-content .tutor-course-list {
		grid-template-columns: repeat(3, 1fr);
	}
}

/* -------------------------------------------------------------------------
   Courses template + shortcode: full-width dark shell (Astra / sidebar layouts)
   Pairs with sk-platform-plugin-frontend (plugin sk-frontend.css) for .sk-page--dark UI.
   ------------------------------------------------------------------------- */
body.sk-courses-body,
body.sk-courses-body .site,
body.sk-courses-body .ast-site-wrap {
	background:
		radial-gradient(circle at top left, rgba(124, 92, 255, 0.1), transparent 26%),
		radial-gradient(circle at bottom right, rgba(79, 220, 255, 0.06), transparent 22%),
		linear-gradient(180deg, #05070d 0%, #070b14 42%, #08101c 100%) !important;
	color: #e8f0ff;
}

body.sk-courses-body .entry-content,
body.sk-courses-body .site-content {
	background: transparent !important;
}

body.sk-courses-body #primary,
body.sk-courses-body .site-main,
body.sk-courses-body .content-area {
	width: 100% !important;
	max-width: 100% !important;
	margin-left: 0 !important;
	margin-right: 0 !important;
	float: none !important;
}

body.sk-courses-body .ast-container,
body.sk-courses-body .site-content .ast-container {
	max-width: 100% !important;
}

body.sk-courses-body #secondary,
body.sk-courses-body .widget-area.secondary,
body.sk-courses-body aside.secondary {
	display: none !important;
}

body.sk-courses-body.ast-right-sidebar #primary,
body.sk-courses-body.ast-left-sidebar #primary,
body.sk-courses-body.ast-separate-container #primary,
body.sk-courses-body #primary {
	width: 100% !important;
	max-width: 100% !important;
	float: none !important;
	clear: both !important;
	margin-left: auto !important;
	margin-right: auto !important;
}

body.sk-courses-body .site-content > .ast-container {
	width: 100% !important;
	max-width: min(100%, 1320px) !important;
	margin-left: auto !important;
	margin-right: auto !important;
}

body.sk-courses-body .site-content .ast-row {
	margin-left: 0 !important;
	margin-right: 0 !important;
	justify-content: center !important;
}

body.sk-courses-body .site-content [class*="ast-col-"],
body.sk-courses-body .site-content [class*="ast-width-lg-"],
body.sk-courses-body .site-content [class*="ast-width-md-"] {
	width: 100% !important;
	max-width: 100% !important;
	flex: 0 0 100% !important;
	float: none !important;
}

/* Shortcode inside a normal page: break out of narrow content column */
.sk-courses-page--shortcode.sk-page--dark {
	width: 100vw;
	max-width: 100vw;
	position: relative;
	left: 50%;
	right: auto;
	margin-left: -50vw;
	margin-right: -50vw;
	box-sizing: border-box;
}

/* -------------------------------------------------------------------------
   Courses page — header + full-bleed hero (match SK Booking), centered shell
   ------------------------------------------------------------------------- */
body.sk-courses-body {
	--sk-header-h: 84px;
	--sk-courses-nav-primary: #69a7ff;
	--sk-courses-nav-primary-2: #7c5cff;
}

body.sk-courses-body .site-header,
body.sk-courses-body header.site-header,
body.sk-courses-body .main-header-bar,
body.sk-courses-body .ast-primary-header-bar {
	background: transparent !important;
	border-bottom: 1px solid transparent !important;
	transition: background 0.35s ease, border-color 0.35s ease, backdrop-filter 0.35s ease, box-shadow 0.35s ease;
}

body.sk-courses-body.sk-scrolled .site-header,
body.sk-courses-body.sk-scrolled header.site-header,
body.sk-courses-body.sk-scrolled .main-header-bar,
body.sk-courses-body.sk-scrolled .ast-primary-header-bar {
	background: rgba(5, 10, 20, 0.72) !important;
	backdrop-filter: blur(18px);
	-webkit-backdrop-filter: blur(18px);
	border-color: rgba(255, 255, 255, 0.08) !important;
	box-shadow: 0 12px 40px rgba(0, 0, 0, 0.28);
}

body.sk-courses-body .site-header a,
body.sk-courses-body .main-header-menu > .menu-item > .menu-link,
body.sk-courses-body .ast-builder-menu-1 .menu-link,
body.sk-courses-body .ast-builder-menu-1 .menu-item > .menu-link,
body.sk-courses-body .ast-mobile-popup-trigger,
body.sk-courses-body .ast-header-navigation .menu-link {
	color: #eef5ff !important;
}

body.sk-courses-body .site-header a:hover,
body.sk-courses-body .main-header-menu > .menu-item > .menu-link:hover,
body.sk-courses-body .ast-builder-menu-1 .menu-link:hover {
	color: var(--sk-courses-nav-primary) !important;
}

body.sk-courses-body .ast-mobile-menu-trigger-minimal .ast-mobile-svg,
body.sk-courses-body .ast-mobile-menu-trigger .ast-mobile-svg {
	fill: #eef5ff !important;
}

body.sk-courses-body .ast-header-account-wrap .ast-header-account-type-cta .ast-custom-button-link {
	color: #fff !important;
}

body.sk-courses-body .ast-button,
body.sk-courses-body .menu-item .ast-custom-button-link,
body.sk-courses-body .header-main-layout-1 .ast-builder-button-wrap .ast-custom-button {
	background: linear-gradient(135deg, var(--sk-courses-nav-primary), var(--sk-courses-nav-primary-2)) !important;
	color: #fff !important;
	border: 0 !important;
	border-radius: 999px !important;
	box-shadow: 0 14px 35px rgba(73, 122, 255, 0.35);
}

/* Remove Astra “white bar” behind header on this template */
body.sk-courses-body .ast-primary-header-bar,
body.sk-courses-body .main-header-bar {
	box-shadow: none !important;
}

/* Page wrapper uses full width of primary */
body.sk-courses-body .sk-courses-page {
	overflow-x: clip;
	width: 100%;
	max-width: 100%;
	margin-inline: auto;
}

/* Article / entry: use full content column (fixes left-hugging layout) */
body.sk-courses-body #primary .entry-content,
body.sk-courses-body #primary .site-main,
body.sk-courses-body .site-main .entry-content {
	max-width: 100% !important;
	width: 100% !important;
	margin-left: auto !important;
	margin-right: auto !important;
	float: none !important;
}

body.sk-courses-body .ast-separate-container .ast-article-inner,
body.sk-courses-body .ast-separate-container .ast-article-single {
	background: transparent !important;
	box-shadow: none !important;
	border: none !important;
}

body.sk-courses-body .ast-separate-container .site-main > article {
	padding-left: clamp(12px, 3vw, 24px) !important;
	padding-right: clamp(12px, 3vw, 24px) !important;
}

/* Hero: full viewport width + layered background (same idea as template-booking) */
body.sk-courses-body .sk-courses-hero.sk-section-hero {
	position: relative;
	width: 100vw;
	max-width: 100vw;
	margin-left: calc(50% - 50vw);
	margin-right: calc(50% - 50vw);
	left: auto;
	right: auto;
	padding: calc(var(--sk-header-h, 80px) + 32px) 0 48px;
	overflow: hidden;
	border-bottom: 1px solid rgba(255, 255, 255, 0.06);
	background: transparent !important;
}

body.sk-courses-body .sk-courses-hero__bg {
	position: absolute;
	inset: 0;
	pointer-events: none;
	background:
		radial-gradient(circle at 18% 30%, rgba(105, 167, 255, 0.2), transparent 32%),
		radial-gradient(circle at 82% 20%, rgba(124, 92, 255, 0.18), transparent 28%),
		radial-gradient(circle at 50% 90%, rgba(79, 220, 255, 0.08), transparent 22%),
		linear-gradient(180deg, #05070d 0%, #070c16 55%, transparent 100%);
}

body.sk-courses-body .sk-courses-hero__grid {
	position: absolute;
	inset: 0;
	pointer-events: none;
	background-image:
		linear-gradient(rgba(255, 255, 255, 0.03) 1px, transparent 1px),
		linear-gradient(90deg, rgba(255, 255, 255, 0.03) 1px, transparent 1px);
	background-size: 56px 56px;
	opacity: 0.55;
	mask-image: linear-gradient(180deg, #000 0%, #000 70%, transparent 100%);
	-webkit-mask-image: linear-gradient(180deg, #000 0%, #000 70%, transparent 100%);
}

body.sk-courses-body .sk-courses-hero .sk-container {
	display: flex;
	flex-direction: column;
	align-items: center;
	position: relative;
	z-index: 1;
	width: min(100% - 32px, 1280px);
	margin-inline: auto;
}

body.sk-courses-body .sk-courses-hero__content.sk-section-hero__inner {
	position: relative;
	z-index: 2;
	max-width: 720px;
	margin-left: auto;
	margin-right: auto;
	text-align: center;
	width: 100%;
	align-items: center;
}

/* Course list block: centered column; cards align from the left */
body.sk-courses-body .sk-courses-content .sk-container.sk-courses-content__inner {
	width: min(100% - 32px, 1180px) !important;
	max-width: 1180px !important;
	margin-left: auto !important;
	margin-right: auto !important;
	padding-left: 0;
	padding-right: 0;
}

body.sk-courses-body .sk-courses-content__inner {
	display: flex;
	flex-direction: column;
	align-items: center;
}

body.sk-courses-body .sk-courses-grid-inner {
	width: 100%;
	max-width: 1120px;
	margin-left: auto;
	margin-right: auto;
	text-align: left;
}

body.sk-courses-body .sk-courses-grid-inner .learndash-course-grid .items-wrapper.grid {
	justify-content: start;
	justify-items: stretch;
}
