/** @format */

@import url("https://fonts.googleapis.com/css2?family=Syne:wght@400;500;600;700;800&family=Inter:ital,opsz,wght@0,14..32,300;0,14..32,400;0,14..32,500;0,14..32,600;0,14..32,700;1,14..32,400&display=swap");

/* iRBbA Devs Website Stylesheet */

/* CSS Variables */
:root {
	--primary-color: #e5e5e5;
	--primary-dark: #a3a3a3;
	--primary-light: #ffffff;
	--secondary-color: #737373;
	--dark-bg: #000000;
	--dark-secondary: #0d0d0d;
	--dark-card: rgba(255, 255, 255, 0.03);
	--light-bg: #f5f5f5;
	--text-dark: #1a1a1a;
	--text-light: #737373;
	--border-color: #e5e5e5;
	--success: #a3a3a3;
	--warning: #737373;
	--info: #d4d4d4;
	--gradient-1: linear-gradient(135deg, #3a3a3a 0%, #1a1a1a 100%);
	--gradient-2: linear-gradient(135deg, #404040 0%, #1a1a1a 100%);
	--shadow-sm: 0 1px 3px rgba(0, 0, 0, 0.25);
	--shadow-md: 0 4px 12px rgba(0, 0, 0, 0.5);
	--shadow-lg: 0 10px 40px rgba(0, 0, 0, 0.7);
	/* ── Monochrome palette ── */
	--neon-blue: #d4d4d4;
	--neon-purple: #a3a3a3;
	--neon-cyan: #e5e5e5;
	--neon-pink: #a3a3a3;
	--neon-green: #c4c4c4;
	--glass-bg: rgba(255, 255, 255, 0.04);
	--glass-bg-hover: rgba(255, 255, 255, 0.07);
	--glass-border: rgba(255, 255, 255, 0.09);
	--glass-border-blue: rgba(255, 255, 255, 0.12);
	--glass-border-cyan: rgba(255, 255, 255, 0.12);
	--glow-blue: 0 0 16px rgba(255, 255, 255, 0.06);
	--glow-cyan: 0 0 16px rgba(255, 255, 255, 0.06);
	--glow-purple: 0 0 16px rgba(255, 255, 255, 0.06);
	--font-display: "Syne", -apple-system, sans-serif;
	--font-body: "Inter", -apple-system, BlinkMacSystemFont, sans-serif;
}

/* =========================================================
   Light Theme — variable overrides + explicit overrides
   ========================================================= */

[data-theme="light"] {
	--dark-bg: #f7f7f7;
	--dark-secondary: #ebebeb;
	--dark-card: rgba(0, 0, 0, 0.03);
	--glass-bg: rgba(0, 0, 0, 0.025);
	--glass-bg-hover: rgba(0, 0, 0, 0.05);
	--glass-border: rgba(0, 0, 0, 0.09);
	--glass-border-blue: rgba(0, 0, 0, 0.12);
	--glass-border-cyan: rgba(0, 0, 0, 0.12);
	--shadow-sm: 0 1px 3px rgba(0, 0, 0, 0.08);
	--shadow-md: 0 4px 12px rgba(0, 0, 0, 0.1);
	--shadow-lg: 0 10px 40px rgba(0, 0, 0, 0.12);
	--text-light: #525252;
	--border-color: #d4d4d4;
}

/* --- Body --- */
[data-theme="light"] body {
	background: #f7f7f7;
	color: #1a1a1a;
}

/* --- Navbar --- */
[data-theme="light"] .navbar-island {
	background: rgba(255, 255, 255, 0.75);
	border-color: rgba(0, 0, 0, 0.1);
}
[data-theme="light"] .navbar.scrolled .navbar-island {
	background: rgba(255, 255, 255, 0.88);
	border-color: rgba(0, 0, 0, 0.08);
}
[data-theme="light"] .nav-link {
	color: rgba(0, 0, 0, 0.65) !important;
}
[data-theme="light"] .nav-link:hover,
[data-theme="light"] .nav-link.active {
	color: #000 !important;
	background: rgba(0, 0, 0, 0.07);
}
[data-theme="light"] .brand-text,
[data-theme="light"] .brand-light {
	color: #000;
}
[data-theme="light"] .navbar-toggler {
	border-color: rgba(0, 0, 0, 0.2);
}
[data-theme="light"] .navbar-toggler-icon {
	filter: invert(1);
}
[data-theme="light"] .nav-cta {
	background: #000;
	color: #fff !important;
	border-color: rgba(0, 0, 0, 0.2);
}
[data-theme="light"] .nav-cta:hover {
	background: #333;
	color: #fff !important;
}

/* --- Hero --- */
[data-theme="light"] .hero-section {
	background: #f7f7f7;
}
[data-theme="light"] .hero-title {
	background: linear-gradient(
		160deg,
		#ffffff 0%,
		rgba(255, 255, 255, 0.7) 100%
	);
	-webkit-background-clip: text;
	background-clip: text;
}
[data-theme="light"] .hero-text {
	color: rgba(255, 255, 255, 0.88);
}

/* --- Hardcoded #000 section backgrounds → #f7f7f7 --- */
[data-theme="light"] .about-hero,
[data-theme="light"] .about-mission,
[data-theme="light"] .about-values,
[data-theme="light"] .prod-hero,
[data-theme="light"] .blg-hero,
[data-theme="light"] .blg-grid,
[data-theme="light"] .blg-filter,
[data-theme="light"] .dmo-hero,
[data-theme="light"] .dmo-form-section,
[data-theme="light"] .dmo-testimonials,
[data-theme="light"] .cnt-faq,
[data-theme="light"] .idx-serve,
[data-theme="light"] .idx-why {
	background: #f7f7f7;
}

[data-theme="light"] .abt-stats-strip {
	background: #ebebeb;
}

/* --- Border lines: rgba white → rgba dark --- */
[data-theme="light"] .abt-stats-strip,
[data-theme="light"] .about-mission,
[data-theme="light"] .about-values,
[data-theme="light"] .blg-filter,
[data-theme="light"] .idx-serve,
[data-theme="light"] .idx-why,
[data-theme="light"] .idx-fp,
[data-theme="light"] .idx-how,
[data-theme="light"] .dmo-form-section,
[data-theme="light"] .dmo-expect,
[data-theme="light"] .dmo-testimonials,
[data-theme="light"] .dmo-contact-strip,
[data-theme="light"] .cnt-cta,
[data-theme="light"] .cnt-faq {
	border-top-color: rgba(0, 0, 0, 0.07);
	border-bottom-color: rgba(0, 0, 0, 0.07);
}
[data-theme="light"] .about-timeline {
	border-left-color: rgba(0, 0, 0, 0.12);
}
[data-theme="light"] .abt-tl-item::before {
	background: #333;
	box-shadow: 0 0 0 3px rgba(0, 0, 0, 0.1);
}
[data-theme="light"] .abt-strip-divider {
	background: rgba(0, 0, 0, 0.1);
}

/* --- Eyebrow / label / tag colors --- */
[data-theme="light"] .about-eyebrow,
[data-theme="light"] .prod-eyebrow {
	color: rgba(0, 0, 0, 0.4);
}
[data-theme="light"] .about-label {
	color: rgba(0, 0, 0, 0.45);
}
[data-theme="light"] .about-tag {
	border-color: rgba(0, 0, 0, 0.15);
	color: rgba(0, 0, 0, 0.55);
	background: rgba(0, 0, 0, 0.04);
}

/* --- Section headings (hardcoded #fff → #0d0d0d) --- */
[data-theme="light"] .about-section-title,
[data-theme="light"] .about-hero-title,
[data-theme="light"] .prod-hero-title,
[data-theme="light"] .blg-hero-title,
[data-theme="light"] .dmo-hero-title,
[data-theme="light"] .idx-section-title,
[data-theme="light"] .idx-fp-name,
[data-theme="light"] .idx-how-title,
[data-theme="light"] .idx-why-title,
[data-theme="light"] .idx-serve-name,
[data-theme="light"] .blg-featured-title,
[data-theme="light"] .blg-nl-title,
[data-theme="light"] .blg-post-title a,
[data-theme="light"] .dmo-expect-title,
[data-theme="light"] .dmo-testimonials-title,
[data-theme="light"] .dmo-cs-title,
[data-theme="light"] .dmo-expect-name,
[data-theme="light"] .cnt-cta-title,
[data-theme="light"] .cnt-faq-title,
[data-theme="light"] .cnt-cta-name,
[data-theme="light"] .abt-tl-content h4,
[data-theme="light"] .abt-value-card h4,
[data-theme="light"] .abt-team-name,
[data-theme="light"] .abt-vision-body h4 {
	color: #0d0d0d;
}

[data-theme="light"] .blg-post-title a:hover {
	color: #000;
}
[data-theme="light"] .section-title {
	background: linear-gradient(160deg, #000 0%, rgba(0, 0, 0, 0.6) 100%);
	-webkit-background-clip: text;
	background-clip: text;
}

/* Keep testimonial heading copy dark in light mode */
[data-theme="light"] .testimonials .section-title {
	background: linear-gradient(160deg, #0d0d0d 0%, rgba(0, 0, 0, 0.62) 100%);
	-webkit-background-clip: text;
	background-clip: text;
}
[data-theme="light"] .testimonials .section-subtitle {
	color: rgba(0, 0, 0, 0.55);
}

/* --- Sub-text / descriptions (rgba white → rgba dark) --- */
[data-theme="light"] .about-hero-sub,
[data-theme="light"] .prod-hero-sub,
[data-theme="light"] .blg-hero-sub,
[data-theme="light"] .dmo-hero-sub {
	color: rgba(0, 0, 0, 0.5);
}
[data-theme="light"] .about-mission-text {
	color: rgba(0, 0, 0, 0.65);
}
[data-theme="light"] .abt-tl-year {
	color: rgba(0, 0, 0, 0.35);
}
[data-theme="light"] .abt-tl-content p,
[data-theme="light"] .abt-value-card p,
[data-theme="light"] .abt-team-bio,
[data-theme="light"] .abt-vision-body p {
	color: rgba(0, 0, 0, 0.55);
}
[data-theme="light"] .abt-team-role {
	color: rgba(0, 0, 0, 0.45);
}
[data-theme="light"] .abt-strip-num {
	color: #0d0d0d;
}
[data-theme="light"] .abt-strip-lbl {
	color: rgba(0, 0, 0, 0.45);
}
[data-theme="light"] .idx-serve-desc,
[data-theme="light"] .idx-why-desc,
[data-theme="light"] .idx-how-desc,
[data-theme="light"] .idx-fp-intro {
	color: rgba(0, 0, 0, 0.5);
}
[data-theme="light"] .blg-featured-excerpt,
[data-theme="light"] .blg-post-excerpt,
[data-theme="light"] .blg-post-meta,
[data-theme="light"] .blg-meta {
	color: rgba(0, 0, 0, 0.5);
}
[data-theme="light"] .blg-nl-sub,
[data-theme="light"] .blg-nl-note {
	color: rgba(0, 0, 0, 0.45);
}
[data-theme="light"] .dmo-expect-desc,
[data-theme="light"] .dmo-cs-sub,
[data-theme="light"] .dmo-step-label {
	color: rgba(0, 0, 0, 0.5);
}
[data-theme="light"] .dmo-step-arrow {
	color: rgba(0, 0, 0, 0.2);
}
[data-theme="light"] .cnt-cta-desc,
[data-theme="light"] .cnt-faq-a {
	color: rgba(0, 0, 0, 0.5);
}

/* Keep final CTA copy dark in light mode */
[data-theme="light"] .final-cta,
[data-theme="light"] .cta-section {
	color: #0d0d0d;
}
[data-theme="light"] .cta-title {
	background: linear-gradient(160deg, #0d0d0d 0%, rgba(0, 0, 0, 0.62) 100%);
	-webkit-background-clip: text;
	background-clip: text;
}
[data-theme="light"] .cta-text {
	color: rgba(0, 0, 0, 0.62);
}

/* --- Number labels (rgba white → rgba dark) --- */
[data-theme="light"] .idx-serve-num,
[data-theme="light"] .idx-why-num,
[data-theme="light"] .idx-how-num,
[data-theme="light"] .blg-post-num,
[data-theme="light"] .dmo-expect-num,
[data-theme="light"] .dmo-step-num,
[data-theme="light"] .cnt-cta-num,
[data-theme="light"] .abt-value-num,
[data-theme="light"] .abt-vision-num {
	color: rgba(0, 0, 0, 0.18);
}

/* --- Grid border lines --- */
[data-theme="light"] .idx-serve-grid,
[data-theme="light"] .idx-why-grid,
[data-theme="light"] .idx-how-steps,
[data-theme="light"] .cnt-cta-grid {
	border-top-color: rgba(0, 0, 0, 0.08);
}
[data-theme="light"] .idx-serve-item {
	border-top-color: rgba(0, 0, 0, 0.08);
	border-right-color: rgba(0, 0, 0, 0.08);
}
[data-theme="light"] .idx-why-item,
[data-theme="light"] .idx-how-step,
[data-theme="light"] .cnt-cta-item {
	border-right-color: rgba(0, 0, 0, 0.08);
}
[data-theme="light"] .dmo-expect-item {
	border-top-color: rgba(0, 0, 0, 0.08);
	border-right-color: rgba(0, 0, 0, 0.08);
}
[data-theme="light"] .idx-serve-item:hover,
[data-theme="light"] .idx-why-item:hover {
	background: rgba(0, 0, 0, 0.03);
}
[data-theme="light"] .cnt-faq-item {
	border-top-color: rgba(0, 0, 0, 0.08);
}
[data-theme="light"] .cnt-faq-item:last-child {
	border-bottom-color: rgba(0, 0, 0, 0.08);
}

/* --- FAQ --- */
[data-theme="light"] .cnt-faq-q {
	color: rgba(0, 0, 0, 0.75);
}
[data-theme="light"] .cnt-faq-item[open] .cnt-faq-q {
	color: #000;
}
[data-theme="light"] .cnt-faq-q::after {
	color: rgba(0, 0, 0, 0.3);
}
[data-theme="light"] .cnt-faq-item[open] .cnt-faq-q::after {
	color: rgba(0, 0, 0, 0.5);
}

/* Keep Upcoming Products section in dark style even in light theme */
[data-theme="light"] .prod-upcoming {
	background: #000;
	border-top-color: rgba(255, 255, 255, 0.07);
}
[data-theme="light"] .prod-upcoming .about-label {
	color: rgba(255, 255, 255, 0.45);
}
[data-theme="light"] .prod-upcoming .about-section-title {
	color: #fff;
}
[data-theme="light"] .prod-upcoming-sub {
	color: rgba(255, 255, 255, 0.5);
}
[data-theme="light"] .prod-upcoming-item {
	border-top-color: rgba(255, 255, 255, 0.08);
}
[data-theme="light"] .prod-upcoming-item:last-child {
	border-bottom-color: rgba(255, 255, 255, 0.08);
}
[data-theme="light"] .prod-upcoming-icon {
	color: rgba(255, 255, 255, 0.5);
}
[data-theme="light"] .prod-upcoming-meta > div h3 {
	color: #fff;
}
[data-theme="light"] .prod-upcoming-meta > div p {
	color: rgba(255, 255, 255, 0.5);
}
[data-theme="light"] .prod-uf-item {
	color: rgba(255, 255, 255, 0.55);
	background: rgba(255, 255, 255, 0.03);
	border-color: rgba(255, 255, 255, 0.06);
}
[data-theme="light"] .prod-uf-item i {
	color: rgba(255, 255, 255, 0.35);
}
[data-theme="light"] .prod-upcoming .btn-outline-light {
	border-color: rgba(255, 255, 255, 0.3);
	color: rgba(255, 255, 255, 0.75);
}
[data-theme="light"] .prod-upcoming .btn-outline-light:hover {
	background: rgba(255, 255, 255, 0.08);
	border-color: rgba(255, 255, 255, 0.5);
	color: #fff;
}

/* --- Featured Product (idx-fp) --- */
[data-theme="light"] .idx-fp-feat {
	color: rgba(0, 0, 0, 0.65);
}
[data-theme="light"] .idx-fp-feat::before {
	background: rgba(0, 0, 0, 0.35);
}

/* --- Blog --- */
[data-theme="light"] .blg-filter-btn {
	border-color: rgba(0, 0, 0, 0.18);
	color: rgba(0, 0, 0, 0.5);
}
[data-theme="light"] .blg-filter-btn:hover {
	border-color: rgba(0, 0, 0, 0.5);
	color: rgba(0, 0, 0, 0.8);
}
[data-theme="light"] .blg-filter-btn.active {
	border-color: #000;
	color: #000;
}
[data-theme="light"] .blg-cat-tag {
	border-color: rgba(0, 0, 0, 0.18);
	color: rgba(0, 0, 0, 0.5);
}
[data-theme="light"] .blg-read-link {
	color: #000;
}
[data-theme="light"] .blg-read-link:hover {
	color: rgba(0, 0, 0, 0.65);
}
[data-theme="light"] .blg-post-card {
	background: rgba(0, 0, 0, 0.03);
	border-color: rgba(0, 0, 0, 0.08);
}
[data-theme="light"] .blg-post-card:hover {
	background: rgba(0, 0, 0, 0.05);
	border-color: rgba(0, 0, 0, 0.15);
}
[data-theme="light"] .blg-post-link {
	color: rgba(0, 0, 0, 0.45);
}
[data-theme="light"] .blg-post-link:hover {
	color: #000;
}
[data-theme="light"] .blg-nl-input-row {
	border-color: rgba(0, 0, 0, 0.15);
}
[data-theme="light"] .blg-nl-input {
	background: rgba(0, 0, 0, 0.03);
	color: #000;
}
[data-theme="light"] .blg-nl-input::placeholder {
	color: rgba(0, 0, 0, 0.3);
}
[data-theme="light"] .blg-nl-btn {
	background: #000;
	color: #fff;
}
[data-theme="light"] .blg-nl-btn:hover {
	background: #333;
}

/* --- Glass cards (serve-card, why-card, testimonial-card, blog-card, abt-value-card, abt-team-card) --- */
[data-theme="light"] .serve-card,
[data-theme="light"] .why-card,
[data-theme="light"] .testimonial-card,
[data-theme="light"] .blog-card,
[data-theme="light"] .abt-value-card,
[data-theme="light"] .abt-team-card {
	background: rgba(0, 0, 0, 0.03);
	border-color: rgba(0, 0, 0, 0.09);
	color: #111;
}
[data-theme="light"] .serve-card:hover,
[data-theme="light"] .why-card:hover,
[data-theme="light"] .blog-card:hover {
	border-color: rgba(0, 0, 0, 0.2);
	box-shadow:
		0 20px 50px rgba(0, 0, 0, 0.1),
		0 0 30px rgba(0, 0, 0, 0.06);
}
[data-theme="light"] .abt-value-card:hover,
[data-theme="light"] .abt-team-card:hover {
	border-color: rgba(0, 0, 0, 0.2);
}
[data-theme="light"] .serve-card h3,
[data-theme="light"] .why-card h3 {
	color: #111;
}
[data-theme="light"] .serve-card p,
[data-theme="light"] .why-card p {
	color: rgba(0, 0, 0, 0.58);
}
[data-theme="light"] .serve-icon,
[data-theme="light"] .why-icon {
	background: rgba(0, 0, 0, 0.07);
	border-color: rgba(0, 0, 0, 0.18);
}
[data-theme="light"] .serve-icon i,
[data-theme="light"] .why-icon i {
	color: #333;
	filter: none;
}
[data-theme="light"] .serve-card:hover .serve-icon,
[data-theme="light"] .why-card:hover .why-icon {
	background: rgba(0, 0, 0, 0.12);
	box-shadow: 0 0 20px rgba(0, 0, 0, 0.12);
	transform: scale(1.1) rotate(5deg);
}
[data-theme="light"] .testimonial-text {
	color: rgba(0, 0, 0, 0.7);
}
[data-theme="light"] .testimonial-author strong {
	color: #111;
}
[data-theme="light"] .testimonial-author span {
	color: rgba(0, 0, 0, 0.5);
}
[data-theme="light"] .quote-icon i {
	color: rgba(0, 0, 0, 0.2);
}
[data-theme="light"] .abt-value-icon {
	color: rgba(0, 0, 0, 0.55);
}
[data-theme="light"] .abt-avatar {
	border-color: rgba(0, 0, 0, 0.1);
	color: rgba(0, 0, 0, 0.45);
	background: rgba(0, 0, 0, 0.06);
}
[data-theme="light"] .abt-team-links a {
	color: rgba(0, 0, 0, 0.4);
	border-color: rgba(0, 0, 0, 0.12);
}
[data-theme="light"] .abt-team-links a:hover {
	color: #000;
	border-color: rgba(0, 0, 0, 0.3);
}

/* Vision list */
[data-theme="light"] .about-vision {
	background: #000;
	border-top-color: rgba(255, 255, 255, 0.07);
}
[data-theme="light"] .about-vision-sub {
	color: rgba(255, 255, 255, 0.5);
}
[data-theme="light"] .abt-vision-item {
	border-top-color: rgba(255, 255, 255, 0.07);
	border-bottom-color: rgba(255, 255, 255, 0.07);
}
[data-theme="light"] .abt-vision-item:first-child {
	border-top: none;
}
[data-theme="light"] .abt-vision-num {
	color: rgba(255, 255, 255, 0.25);
}
[data-theme="light"] .abt-vision-body h4 {
	color: #fff;
}
[data-theme="light"] .abt-vision-body p {
	color: rgba(255, 255, 255, 0.5);
}

/* Blog detail header + sidebar newsletter should read dark in light mode */
[data-theme="light"] .blog-post-header {
	color: #0d0d0d;
}
[data-theme="light"] .post-meta {
	color: rgba(0, 0, 0, 0.68);
}
[data-theme="light"] .author-avatar {
	color: rgba(0, 0, 0, 0.45);
}
[data-theme="light"] .author-details span {
	color: rgba(0, 0, 0, 0.55);
}
[data-theme="light"] .sidebar-newsletter {
	background: #d4d4d4;
	color: #0d0d0d;
}
[data-theme="light"] .sidebar-newsletter h4 {
	color: #0d0d0d;
}
[data-theme="light"] .sidebar-newsletter p {
	color: rgba(0, 0, 0, 0.7);
}

/* --- How It Works (old, glassmorphic) --- */
[data-theme="light"] .timeline-number {
	border-color: rgba(0, 0, 0, 0.5);
	color: rgba(0, 0, 0, 0.7);
	box-shadow: 0 0 12px rgba(0, 0, 0, 0.1);
}
[data-theme="light"] .timeline-item:not(:last-child)::after {
	color: rgba(0, 0, 0, 0.4);
	filter: none;
}
[data-theme="light"] .timeline-content h3 {
	color: #111;
}
[data-theme="light"] .timeline-content p {
	color: rgba(0, 0, 0, 0.55);
}

/* --- Demo form --- */
[data-theme="light"] .dmo-form-wrap {
	background: rgba(0, 0, 0, 0.025);
	border-color: rgba(0, 0, 0, 0.1);
}
[data-theme="light"] .dmo-form-wrap .form-label {
	color: rgba(0, 0, 0, 0.65);
}
[data-theme="light"] .dmo-form-wrap .form-control,
[data-theme="light"] .dmo-form-wrap .form-select {
	background: rgba(0, 0, 0, 0.04);
	border-color: rgba(0, 0, 0, 0.12);
	color: #111;
}
[data-theme="light"] .dmo-form-wrap .form-control:focus,
[data-theme="light"] .dmo-form-wrap .form-select:focus {
	background: rgba(0, 0, 0, 0.06);
	border-color: rgba(0, 0, 0, 0.3);
	color: #111;
}
[data-theme="light"] .dmo-form-wrap .form-control::placeholder {
	color: rgba(0, 0, 0, 0.28);
}
[data-theme="light"] .dmo-form-wrap .form-select option {
	background: #f0f0f0;
	color: #111;
}
[data-theme="light"] .dmo-form-wrap .form-check-label {
	color: rgba(0, 0, 0, 0.55);
}
[data-theme="light"] .dmo-form-wrap .form-check-input {
	background-color: rgba(0, 0, 0, 0.06);
	border-color: rgba(0, 0, 0, 0.2);
}
[data-theme="light"] .dmo-form-wrap .form-check-input:checked {
	background-color: #000;
	border-color: #000;
}
[data-theme="light"] .dmo-form-wrap .form-section {
	border-top-color: rgba(0, 0, 0, 0.08);
}
[data-theme="light"] .dmo-form-wrap .form-section .section-title {
	color: rgba(0, 0, 0, 0.35);
	background: none;
	-webkit-text-fill-color: unset;
}
[data-theme="light"] .dmo-form-wrap .text-muted small {
	color: rgba(0, 0, 0, 0.3) !important;
}
[data-theme="light"] .dmo-form-wrap a {
	color: rgba(0, 0, 0, 0.55);
}
[data-theme="light"] .dmo-form-wrap a:hover {
	color: #000;
}

/* --- Contact section form — keep dark in light mode --- */
[data-theme="light"] .contact-section {
	background: #000;
	color: #fff;
}
[data-theme="light"] .contact-form-container,
[data-theme="light"] .contact-info {
	background: rgba(255, 255, 255, 0.03);
	border-color: rgba(255, 255, 255, 0.09);
}
[data-theme="light"] .contact-section h2 {
	color: #fff;
}
[data-theme="light"] .contact-form-container h2,
[data-theme="light"] .contact-info h2 {
	color: #fff;
}
[data-theme="light"] .contact-status-bar {
	color: rgba(255, 255, 255, 0.8);
}
[data-theme="light"] .contact-status-bar .status-pulse {
	background: #10b981;
}
[data-theme="light"] .info-tile {
	color: rgba(255, 255, 255, 0.8);
}
[data-theme="light"] .info-tile-body h6 {
	color: #fff;
}
[data-theme="light"] .info-tile-body p {
	color: rgba(255, 255, 255, 0.7);
}
[data-theme="light"] .info-tile-body p a {
	color: var(--neon-blue);
}
[data-theme="light"] .info-tile-body p a:hover {
	color: rgba(255, 255, 255, 0.9);
}
[data-theme="light"] .info-tile-body p em {
	color: rgba(255, 255, 255, 0.5);
}
[data-theme="light"] .info-tile-sm {
	color: rgba(255, 255, 255, 0.8);
}
[data-theme="light"] .info-tile-sm h6 {
	color: #fff;
}
[data-theme="light"] .info-tile-sm a {
	color: rgba(255, 255, 255, 0.8);
}
[data-theme="light"] .info-tile-sm a:hover {
	color: var(--neon-blue);
}
[data-theme="light"] .oh-title {
	color: rgba(255, 255, 255, 0.8);
}
[data-theme="light"] .oh-day .day-abbr {
	color: rgba(255, 255, 255, 0.6);
}
[data-theme="light"] .oh-legend {
	color: rgba(255, 255, 255, 0.6);
}
[data-theme="light"] .legend-dot {
	border-color: rgba(255, 255, 255, 0.3);
}
[data-theme="light"] .social-links-large a {
	background: rgba(255, 255, 255, 0.08);
	border-color: rgba(255, 255, 255, 0.15);
	color: rgba(255, 255, 255, 0.8);
}
[data-theme="light"] .social-links-large a:hover {
	border-color: rgba(255, 255, 255, 0.4);
	color: #fff;
}
[data-theme="light"] .contact-section .form-control,
[data-theme="light"] .contact-section .form-select {
	background: rgba(255, 255, 255, 0.06);
	border-color: rgba(255, 255, 255, 0.12);
	color: #fff;
}
[data-theme="light"] .contact-section .form-control:focus,
[data-theme="light"] .contact-section .form-select:focus {
	background: rgba(255, 255, 255, 0.08);
	border-color: rgba(255, 255, 255, 0.3);
	color: #fff;
}
[data-theme="light"] .contact-section .form-control::placeholder {
	color: rgba(255, 255, 255, 0.3);
}
[data-theme="light"] .contact-section .form-select option {
	background: var(--dark-secondary);
	color: #fff;
}
[data-theme="light"] .contact-section .form-label {
	color: rgba(255, 255, 255, 0.8);
	font-size: 0.9rem;
}
[data-theme="light"] .contact-section .form-check-label {
	color: rgba(255, 255, 255, 0.65);
}
[data-theme="light"] .contact-section .form-check-label a {
	color: var(--neon-blue);
}
[data-theme="light"] .contact-section .form-check-input {
	background-color: rgba(255, 255, 255, 0.06);
	border-color: rgba(255, 255, 255, 0.2);
}
[data-theme="light"] .contact-section .form-check-input:checked {
	background-color: var(--neon-blue);
	border-color: var(--neon-blue);
}

/* --- Demo contact strip --- */
[data-theme="light"] .dmo-cs-link,
[data-theme="light"] .dmo-cs-cta {
	color: rgba(0, 0, 0, 0.6);
}
[data-theme="light"] .dmo-cs-link:hover,
[data-theme="light"] .dmo-cs-cta:hover {
	color: #000;
}

/* --- Buttons --- */
[data-theme="light"] .btn-primary {
	background: var(--glass-bg);
	color: var(--primary-light);
	border-color: var(--border-color);
}
[data-theme="light"] .btn-primary:hover {
	background: var(--glass-bg-hover);
	color: var(--primary-light);
	box-shadow: 0 6px 20px rgba(0, 0, 0, 0.2);
}
[data-theme="light"] .btn-outline-light {
	border-color: var(--glass-border);
	color: var(--primary-light);
}
[data-theme="light"] .btn-outline-light:hover {
	background: var(--glass-bg-hover);
	border-color: var(--glass-border);
	color: var(--primary-light);
}
[data-theme="light"] .btn-outline-primary {
	border-color: var(--glass-border);
	color: var(--primary-light);
}
[data-theme="light"] .btn-outline-primary:hover {
	background: var(--glass-bg-hover);
	border-color: var(--glass-border);
	color: var(--primary-light);
}

/* --- Footer --- */
[data-theme="light"] .footer {
	color: rgba(0, 0, 0, 0.65);
}
[data-theme="light"] .footer::after {
	background: linear-gradient(
		90deg,
		transparent,
		rgba(0, 0, 0, 0.2),
		rgba(0, 0, 0, 0.15),
		transparent
	);
}
[data-theme="light"] .footer-brand {
	background: linear-gradient(135deg, #000 0%, rgba(0, 0, 0, 0.5) 100%);
	-webkit-background-clip: text;
	-webkit-text-fill-color: transparent;
	background-clip: text;
}
[data-theme="light"] .footer-title {
	color: #0d0d0d;
}
[data-theme="light"] .footer-links a {
	color: rgba(0, 0, 0, 0.5);
}
[data-theme="light"] .footer-links a:hover {
	color: #000;
	text-shadow: none;
}
[data-theme="light"] .footer-bottom {
	border-top-color: rgba(0, 0, 0, 0.1);
	color: rgba(0, 0, 0, 0.45);
}
[data-theme="light"] .social-links a {
	background: rgba(0, 0, 0, 0.06);
	border-color: rgba(0, 0, 0, 0.1);
	color: rgba(0, 0, 0, 0.6);
}
[data-theme="light"] .social-links a:hover {
	background: rgba(0, 0, 0, 0.12);
	border-color: rgba(0, 0, 0, 0.3);
	color: #000;
	box-shadow: none;
}

/* --- Bottom nav --- */
[data-theme="light"] .bottom-nav {
	background: rgba(255, 255, 255, 0.84);
	border-color: rgba(0, 0, 0, 0.12);
	box-shadow: 0 14px 30px rgba(0, 0, 0, 0.16), inset 0 1px 0 rgba(255, 255, 255, 0.6);
}
[data-theme="light"] .bottom-nav-item {
	color: rgba(0, 0, 0, 0.55);
}
[data-theme="light"] .bottom-nav-item:hover {
	color: #000;
	background: rgba(0, 0, 0, 0.05);
}
[data-theme="light"] .bottom-nav-item.active {
	color: #000;
	background: linear-gradient(180deg, rgba(0, 0, 0, 0.09) 0%, rgba(0, 0, 0, 0.05) 100%);
}
[data-theme="light"] .bottom-nav-item.active::after {
	background: rgba(0, 0, 0, 0.6);
}

/* --- Page header (remaining pages using old page-header class) --- */
[data-theme="light"] .page-header {
	background: #f7f7f7;
}
[data-theme="light"] .page-title {
	color: #000;
}
[data-theme="light"] .page-subtitle {
	color: rgba(0, 0, 0, 0.5);
}

/* =========================================================
   Theme Toggle Button
   ========================================================= */

.theme-toggle {
	background: none;
	border: 1px solid rgba(255, 255, 255, 0.2);
	color: rgba(255, 255, 255, 0.7);
	width: 34px;
	height: 34px;
	border-radius: 50%;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	cursor: pointer;
	margin-left: 0.75rem;
	flex-shrink: 0;
	transition:
		border-color 0.25s,
		color 0.25s,
		background 0.25s;
	font-size: 0.95rem;
}
.theme-toggle:hover {
	border-color: rgba(255, 255, 255, 0.5);
	color: #fff;
	background: rgba(255, 255, 255, 0.08);
}
[data-theme="light"] .theme-toggle {
	border-color: rgba(0, 0, 0, 0.18);
	color: rgba(0, 0, 0, 0.6);
}
[data-theme="light"] .theme-toggle:hover {
	border-color: rgba(0, 0, 0, 0.4);
	color: #000;
	background: rgba(0, 0, 0, 0.07);
}

/* Global Styles */
* {
	margin: 0;
	padding: 0;
	box-sizing: border-box;
}

body {
	font-family: var(--font-body);
	color: var(--text-dark);
	line-height: 1.6;
	overflow-x: hidden;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
	font-feature-settings:
		"kern" 1,
		"liga" 1;
}

h1,
h2,
h3,
h4,
h5,
h6 {
	font-weight: 700;
	line-height: 1.15;
	font-family: var(--font-body);
	letter-spacing: -0.01em;
}

/* Display headings use Syne */
.hero-title,
.page-title,
.cta-title,
.product-title,
.navbar-brand,
.section-title,
.display-4 {
	font-family: var(--font-display);
}

a {
	text-decoration: none;
	transition: all 0.3s ease;
}

img {
	max-width: 100%;
	height: auto;
}

/* Navigation — Island Glassmorphism */
.navbar {
	background: transparent !important;
	padding: 1.25rem 0;
	box-shadow: none !important;
	border: none !important;
	transition: all 0.4s ease;
}

.navbar > .container,
.navbar > .container-fluid {
	display: flex;
	justify-content: center;
}

.navbar-island {
	display: inline-flex;
	align-items: center;
	width: auto;
	background: rgba(255, 255, 255, 0.05);
	backdrop-filter: blur(24px) saturate(160%);
	-webkit-backdrop-filter: blur(24px) saturate(160%);
	border: 1px solid rgba(255, 255, 255, 0.09);
	border-radius: 50px;
	padding: 0.5rem 1.5rem;
}

.navbar.scrolled .navbar-island {
	background: rgba(123, 128, 143, 0.06);
	border-color: rgba(255, 255, 255, 0.022);
}

/* Mobile: rounded rectangle when expanded */
.navbar-island:has(.navbar-collapse.show) {
	border-radius: 20px;
}

.navbar-brand {
	font-size: 1.5rem;
	font-weight: 700;
	flex-shrink: 0;
	white-space: nowrap;
}

/* Two-group centered layout helpers */
.navbar-nav-left {
	flex: 0 0 auto;
}
.navbar-nav-right {
	flex: 0 0 auto;
}

.brand-text {
	color: var(--primary-light);
}

.brand-light {
	color: #fff;
	font-weight: 300;
}

.nav-link {
	color: rgba(255, 255, 255, 0.82) !important;
	font-weight: 500;
	padding: 0.45rem 0.9rem !important;
	border-radius: 20px;
	transition: all 0.3s ease;
}

.nav-link:hover,
.nav-link.active {
	color: #fff !important;
	background: rgba(255, 255, 255, 0.12);
}

.navbar-toggler {
	border-color: rgba(255, 255, 255, 0.3);
	border-radius: 12px;
	padding: 0.3rem 0.6rem;
}

.navbar-toggler:focus {
	box-shadow: 0 0 0 3px rgba(255, 255, 255, 0.2);
}

.nav-cta {
	background: #fff;
	color: #000 !important;
	border-radius: 25px;
	padding: 0.45rem 1.4rem !important;
	margin-left: 0.75rem;
	border: 1px solid rgba(255, 255, 255, 0.3);
	box-shadow: none;
	font-weight: 600;
}

.nav-cta:hover {
	background: #e5e5e5;
	color: #000 !important;
	transform: translateY(-2px);
	box-shadow: none;
}

/* Hero Section */
.hero-section {
	background: var(--dark-bg);
	color: #fff;
	position: relative;
	overflow: hidden;
	padding-top: 80px;
}

/* Water Canvas */
.water-canvas {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	z-index: 0;
	display: block;
	cursor: crosshair;
}

.hero-bg {
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	background: linear-gradient(
		135deg,
		rgba(0, 0, 0, 0.07) 0%,
		rgba(30, 64, 175, 0.14) 100%
	);
	z-index: 1;
	pointer-events: none;
}

.hero-content {
	position: relative;
	z-index: 2;
	animation: fadeInUp 1s ease;
}

.hero-title {
	font-size: 3.8rem;
	font-weight: 800;
	margin-bottom: 1.5rem;
	line-height: 1.05;
	letter-spacing: -0.03em;
	background: linear-gradient(
		160deg,
		#ffffff 0%,
		rgba(255, 255, 255, 0.6) 100%
	);
	-webkit-background-clip: text;
	-webkit-text-fill-color: transparent;
	background-clip: text;
	position: relative;
	animation: kinetic-blur-in 0.9s cubic-bezier(0.16, 1, 0.3, 1) both;
	animation-delay: 0.1s;
}

.hero-text {
	font-size: 1.25rem;
	color: rgba(255, 255, 255, 0.9);
	margin-bottom: 2rem;
}

.hero-ctas {
	display: flex;
	gap: 1rem;
	flex-wrap: wrap;
}

.hero-visual {
	position: relative;
	height: 500px;
	z-index: 2;
}

.floating-card {
	position: absolute;
	background: rgba(255, 255, 255, 0.04);
	backdrop-filter: blur(16px) saturate(160%);
	border: 1px solid rgba(255, 255, 255, 0.1);
	border-radius: 16px;
	padding: 1.25rem 1.5rem;
	display: flex;
	align-items: center;
	gap: 1rem;
	animation: float 3s ease-in-out infinite;
	transition: all 0.3s ease;
	color: #fff;
	box-shadow: 0 8px 32px rgba(0, 0, 0, 0.5);
}
.floating-card:hover {
	border-color: rgba(255, 255, 255, 0.2);
	box-shadow: 0 12px 40px rgba(0, 0, 0, 0.6);
	transform: translateY(-4px) !important;
}

.floating-card i {
	font-size: 2rem;
	color: var(--neon-blue);
	filter: drop-shadow(0 0 6px rgba(255, 255, 255, 0.5));
}

.card-1 {
	top: 10%;
	left: 10%;
	animation-delay: 0s;
}

.card-2 {
	top: 40%;
	right: 10%;
	animation-delay: 0.5s;
}

.card-3 {
	bottom: 30%;
	left: 5%;
	animation-delay: 1s;
}

.card-4 {
	bottom: 10%;
	right: 15%;
	animation-delay: 1.5s;
}

@keyframes float {
	0%,
	100% {
		transform: translateY(0px);
	}
	50% {
		transform: translateY(-20px);
	}
}

@keyframes fadeInUp {
	from {
		opacity: 0;
		transform: translateY(30px);
	}
	to {
		opacity: 1;
		transform: translateY(0);
	}
}

/* Page Header — retro futuristic */
.page-header {
	background: var(--dark-bg);
	color: #fff;
	padding: 150px 0 80px;
	text-align: center;
	position: relative;
	overflow: hidden;
}
.page-header::before {
	content: "";
	position: absolute;
	inset: 0;
	pointer-events: none;
	opacity: 0.9;
}
.page-header::after {
	content: "";
	position: absolute;
	inset: 0;
	background: radial-gradient(
		ellipse at 50% -20%,
		rgba(255, 255, 255, 0.22) 0%,
		transparent 65%
	);
	pointer-events: none;
}

.page-title {
	font-size: 3.2rem;
	font-weight: 800;
	margin-bottom: 1rem;
	letter-spacing: -0.03em;
	background: linear-gradient(
		160deg,
		#ffffff 0%,
		rgba(255, 255, 255, 0.6) 100%
	);
	-webkit-background-clip: text;
	-webkit-text-fill-color: transparent;
	background-clip: text;
	position: relative;
	z-index: 1;
}

.page-subtitle {
	font-size: 1.25rem;
	color: rgba(255, 255, 255, 0.7);
	position: relative;
	z-index: 1;
}

/* Section Styles */
.section-title {
	font-size: 2.5rem;
	font-weight: 800;
	margin-bottom: 1rem;
	letter-spacing: -0.025em;
	color: var(--text-dark);
	position: relative;
}

/* Gradient headings inside dark sections */
.serve-section .section-title,
.why-choose .section-title,
.how-it-works .section-title,
.testimonials .section-title {
	background: linear-gradient(
		160deg,
		#ffffff 0%,
		rgba(255, 255, 255, 0.65) 100%
	);
	-webkit-background-clip: text;
	-webkit-text-fill-color: transparent;
	background-clip: text;
}

.section-subtitle {
	font-size: 1.1rem;
	color: var(--text-light);
	margin-bottom: 2rem;
}

/* Subtitle in dark sections */
.serve-section .section-subtitle,
.why-choose .section-subtitle,
.how-it-works .section-subtitle,
.testimonials .section-subtitle {
	color: rgba(255, 255, 255, 0.55);
}

/* Who We Serve — dark retro grid */
.serve-section {
	background: var(--dark-bg);
	position: relative;
	overflow: hidden;
}
.serve-section::before {
	content: "";
	position: absolute;
	inset: 0;
	opacity: 1;
	pointer-events: none;
}
.serve-section::after {
	content: "";
	position: absolute;
	inset: 0;
	background: radial-gradient(
		ellipse at 50% 100%,
		rgba(255, 255, 255, 0.1) 0%,
		transparent 70%
	);
	pointer-events: none;
}

.serve-card {
	background: var(--glass-bg);
	backdrop-filter: blur(12px) saturate(160%);
	-webkit-backdrop-filter: blur(12px) saturate(160%);
	border: 1px solid var(--glass-border);
	padding: 2rem;
	border-radius: 20px;
	text-align: center;
	transition: all 0.4s cubic-bezier(0.175, 0.885, 0.32, 1.275);
	height: 100%;
	color: #fff;
	position: relative;
	overflow: hidden;
	z-index: 1;
	transform-style: preserve-3d;
}
.serve-card::before {
	content: "";
	position: absolute;
	inset: 0;
	background: linear-gradient(
		135deg,
		rgba(255, 255, 255, 0.06) 0%,
		transparent 100%
	);
	opacity: 0;
	transition: opacity 0.3s ease;
	border-radius: 20px;
}
.serve-card:hover {
	border-color: rgba(255, 255, 255, 0.45);
	box-shadow:
		0 20px 50px rgba(0, 0, 0, 0.5),
		0 0 35px rgba(255, 255, 255, 0.18);
	transform: translateY(-10px);
}
.serve-card:hover::before {
	opacity: 1;
}

.serve-icon {
	width: 80px;
	height: 80px;
	margin: 0 auto 1.5rem;
	background: rgba(255, 255, 255, 0.08);
	border: 1px solid rgba(255, 255, 255, 0.3);
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	transition: all 0.4s ease;
}
.serve-icon i {
	font-size: 2.5rem;
	color: var(--neon-blue);
	filter: drop-shadow(0 0 8px rgba(255, 255, 255, 0.5));
	transition: all 0.4s ease;
}
.serve-card:hover .serve-icon {
	background: rgba(255, 255, 255, 0.18);
	box-shadow: 0 0 25px rgba(255, 255, 255, 0.45);
	transform: scale(1.1) rotate(5deg);
}
.serve-card h3 {
	font-size: 1.5rem;
	margin-bottom: 1rem;
	color: #fff;
}
.serve-card p {
	color: rgba(255, 255, 255, 0.62);
}

/* Featured Product — deep space */
.featured-product {
	background: var(--dark-secondary);
	position: relative;
	overflow: hidden;
}
.featured-product::before {
	content: "";
	position: absolute;
	inset: 0;
	pointer-events: none;
	opacity: 0.7;
}
.featured-product .product-title {
	color: #fff;
}
.featured-product .product-intro {
	color: rgba(255, 255, 255, 0.65);
}
.featured-product .benefit-item span {
	color: rgba(255, 255, 255, 0.85);
}

.product-mockup {
	width: 100%;
	height: 400px;
	background: linear-gradient(
		135deg,
		rgba(255, 255, 255, 0.18) 0%,
		rgba(255, 255, 255, 0.22) 100%
	);
	border: 1px solid rgba(255, 255, 255, 0.35);
	border-radius: 20px;
	display: flex;
	align-items: center;
	justify-content: center;
	box-shadow:
		0 0 60px rgba(255, 255, 255, 0.2),
		var(--shadow-lg);
	position: relative;
	overflow: hidden;
	animation: holographic-pulse 5s ease-in-out infinite;
}
.product-mockup::before {
	content: "";
	position: absolute;
	inset: 0;
	background: linear-gradient(
		105deg,
		transparent 35%,
		rgba(255, 255, 255, 0.06) 45%,
		rgba(255, 255, 255, 0.1) 50%,
		rgba(255, 255, 255, 0.06) 55%,
		transparent 65%
	);
	background-size: 200% 100%;
	animation: holo-slide 3.5s linear infinite;
	border-radius: 20px;
}
@keyframes holographic-pulse {
	0%,
	100% {
		box-shadow:
			0 0 40px rgba(255, 255, 255, 0.2),
			0 0 80px rgba(255, 255, 255, 0.1);
	}
	50% {
		box-shadow:
			0 0 70px rgba(255, 255, 255, 0.4),
			0 0 140px rgba(255, 255, 255, 0.2);
	}
}
@keyframes holo-slide {
	from {
		background-position: -100% 0;
	}
	to {
		background-position: 200% 0;
	}
}

.product-mockup i {
	font-size: 8rem;
	color: rgba(255, 255, 255, 0.45);
	filter: drop-shadow(0 0 20px rgba(255, 255, 255, 0.6));
	position: relative;
	z-index: 1;
}

.product-title {
	font-size: 2.5rem;
	font-weight: 700;
	margin-bottom: 1rem;
}

.product-intro {
	font-size: 1.2rem;
	color: var(--text-light);
	margin-bottom: 2rem;
}

.product-benefits {
	margin: 2rem 0;
}

.benefit-item {
	display: flex;
	align-items: center;
	gap: 1rem;
	margin-bottom: 1rem;
}

.benefit-item i {
	color: var(--success);
	font-size: 1.5rem;
}

/* Why Choose — dark with 3D glass cards */
.why-choose {
	background: var(--dark-bg);
	position: relative;
	overflow: hidden;
}
.why-choose::before {
	content: "";
	position: absolute;
	inset: 0;
	opacity: 0.8;
	pointer-events: none;
}
.why-choose::after {
	content: "";
	position: absolute;
	inset: 0;
	background: radial-gradient(
		ellipse at 50% 100%,
		rgba(255, 255, 255, 0.08) 0%,
		transparent 70%
	);
	pointer-events: none;
}

.why-card {
	background: var(--glass-bg);
	backdrop-filter: blur(12px) saturate(160%);
	-webkit-backdrop-filter: blur(12px) saturate(160%);
	border: 1px solid var(--glass-border);
	padding: 2rem;
	border-radius: 20px;
	text-align: center;
	transition: all 0.4s ease;
	height: 100%;
	color: #fff;
	position: relative;
	overflow: hidden;
	z-index: 1;
	transform-style: preserve-3d;
}
.why-card:hover {
	border-color: rgba(255, 255, 255, 0.45);
	box-shadow:
		0 20px 50px rgba(0, 0, 0, 0.5),
		0 0 35px rgba(255, 255, 255, 0.2);
}
.why-card h3 {
	color: #fff;
	font-size: 1.3rem;
	margin-bottom: 0.75rem;
}
.why-card p {
	color: rgba(255, 255, 255, 0.62);
}

.why-icon {
	width: 70px;
	height: 70px;
	margin: 0 auto 1.5rem;
	background: rgba(255, 255, 255, 0.1);
	border: 1px solid rgba(255, 255, 255, 0.3);
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	transition: all 0.4s ease;
}
.why-icon i {
	font-size: 2rem;
	color: var(--neon-purple);
	filter: drop-shadow(0 0 6px rgba(255, 255, 255, 0.55));
}
.why-card:hover .why-icon {
	background: rgba(255, 255, 255, 0.2);
	box-shadow: 0 0 25px rgba(255, 255, 255, 0.45);
	transform: scale(1.1) rotate(-5deg);
}

/* How It Works - dark */
.how-it-works {
	background: linear-gradient(
		180deg,
		var(--dark-secondary) 0%,
		var(--dark-bg) 100%
	);
	position: relative;
	overflow: hidden;
}
.how-it-works::before {
	content: "";
	position: absolute;
	inset: 0;
	opacity: 0.6;
	pointer-events: none;
}

/* Timeline */
.timeline {
	display: flex;
	justify-content: space-between;
	gap: 2rem;
	padding: 2rem 0;
	position: relative;
	z-index: 1;
}

.timeline-item {
	flex: 1;
	text-align: center;
	position: relative;
}

.timeline-item:not(:last-child)::after {
	content: "→";
	position: absolute;
	right: -2rem;
	top: 20%;
	font-size: 1.4rem;
	color: var(--neon-blue);
	filter: drop-shadow(0 0 6px rgba(255, 255, 255, 0.6));
	animation: arrow-pulse 2s ease-in-out infinite;
}
@keyframes arrow-pulse {
	0%,
	100% {
		opacity: 0.6;
		transform: translateX(0);
	}
	50% {
		opacity: 1;
		transform: translateX(4px);
	}
}

.timeline-number {
	width: 60px;
	height: 60px;
	background: transparent;
	border: 2px solid var(--neon-blue);
	color: var(--neon-blue);
	box-shadow:
		0 0 20px rgba(255, 255, 255, 0.4),
		inset 0 0 20px rgba(255, 255, 255, 0.05);
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	margin: 0 auto 1rem;
	font-size: 1.3rem;
	font-weight: 700;
	font-family: var(--font-display);
	transition: all 0.3s ease;
}
.timeline-item:hover .timeline-number {
	box-shadow:
		0 0 30px rgba(255, 255, 255, 0.7),
		inset 0 0 30px rgba(255, 255, 255, 0.1);
	transform: scale(1.1);
}

.timeline-content h3 {
	font-size: 1.3rem;
	margin-bottom: 0.5rem;
	color: #fff;
}
.timeline-content p {
	color: rgba(255, 255, 255, 0.6);
	font-size: 0.95rem;
}

/* =========================================================
   Home Page — idx-* Sections
   ========================================================= */

/* Shared section title for idx-* sections */
.idx-section-title {
	font-family: var(--font-display);
	font-size: clamp(2rem, 4.5vw, 3.8rem);
	font-weight: 800;
	line-height: 1.08;
	letter-spacing: -0.035em;
	color: #fff;
	margin: 0;
}

/* ---- Who We Serve ---- */
.idx-serve {
	background: #000;
	border-top: 1px solid rgba(255, 255, 255, 0.07);
	padding: 6rem 0;
	position: relative;
	overflow: hidden;
}
.idx-serve::before {
	content: "";
	position: absolute;
	inset: 0;
	opacity: 0.45;
	pointer-events: none;
}
.idx-serve-inner {
	display: grid;
	grid-template-columns: 280px 1fr;
	gap: 5rem;
	align-items: start;
	position: relative;
	z-index: 1;
}
.idx-serve-head {
	padding-top: 0.25rem;
	min-width: 0;
}
.idx-serve-grid {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 0;
	width: 70%;
	margin-inline: auto;
}
.idx-serve-item {
	padding: 2.25rem 2rem;
	border-top: 1px solid rgba(255, 255, 255, 0.08);
	border-right: 1px solid rgba(255, 255, 255, 0.08);
	transition: background 0.25s;
}
.idx-serve-item:nth-child(2n) {
	border-right: none;
}
.idx-serve-item:nth-child(1),
.idx-serve-item:nth-child(2) {
	border-top: none;
}
.idx-serve-item:hover {
	background: rgba(255, 255, 255, 0.03);
}
.idx-serve-num {
	font-family: var(--font-display);
	font-size: 0.72rem;
	font-weight: 700;
	letter-spacing: 0.1em;
	color: rgba(255, 255, 255, 0.2);
	display: block;
	margin-bottom: 0.9rem;
}
.idx-serve-name {
	font-family: var(--font-display);
	font-size: 1.25rem;
	font-weight: 700;
	color: #fff;
	margin-bottom: 0.6rem;
}
.idx-serve-desc {
	font-size: 0.9rem;
	color: rgba(255, 255, 255, 0.45);
	line-height: 1.7;
	margin: 0;
}

/* ---- Featured Product ---- */
.idx-fp {
	background: var(--dark-secondary);
	border-top: 1px solid rgba(255, 255, 255, 0.07);
	padding: 6rem 0;
	position: relative;
	overflow: hidden;
}
.idx-fp::before {
	content: "";
	position: absolute;
	inset: 0;
	opacity: 0.35;
	pointer-events: none;
}
.idx-fp-inner {
	display: grid;
	grid-template-columns: 220px 1fr;
	gap: 5rem;
	align-items: start;
	position: relative;
	z-index: 1;
}
.idx-fp-label {
	padding-top: 0.25rem;
	min-width: 0;
}
.idx-fp-name {
	font-family: var(--font-display);
	font-size: clamp(3rem, 6vw, 5.5rem);
	font-weight: 800;
	letter-spacing: -0.045em;
	line-height: 1;
	color: #fff;
	margin: 0 0 1.25rem;
}
.idx-fp-intro {
	font-size: 1.05rem;
	color: rgba(255, 255, 255, 0.5);
	line-height: 1.75;
	max-width: 540px;
	margin-bottom: 2rem;
}
.idx-fp-features {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 0.75rem 2rem;
	margin-bottom: 2.5rem;
}
.idx-fp-feat {
	font-size: 0.9rem;
	font-weight: 600;
	color: rgba(255, 255, 255, 0.7);
	padding-left: 1rem;
	position: relative;
}
.idx-fp-feat::before {
	content: "";
	position: absolute;
	left: 0;
	top: 50%;
	width: 4px;
	height: 4px;
	border-radius: 50%;
	background: rgba(255, 255, 255, 0.4);
	transform: translateY(-50%);
}

/* ---- Why Choose ---- */
.idx-why {
	background: #000;
	border-top: 1px solid rgba(255, 255, 255, 0.07);
	padding: 6rem 0;
	position: relative;
	overflow: hidden;
}
.idx-why::before {
	content: "";
	position: absolute;
	inset: 0;
	opacity: 0.45;
	pointer-events: none;
}
.idx-why-head {
	position: relative;
	z-index: 1;
	margin-bottom: 4rem;
	max-width: 480px;
}
.idx-why-grid {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	border-top: 1px solid rgba(255, 255, 255, 0.08);
	position: relative;
	z-index: 1;
}
.idx-why-item {
	padding: 2.5rem 2rem 2.5rem 0;
	border-right: 1px solid rgba(255, 255, 255, 0.08);
	transition: background 0.25s;
}
.idx-why-item:last-child {
	border-right: none;
	padding-right: 0;
}
.idx-why-item:first-child {
	padding-left: 0;
}
.idx-why-item:hover {
	background: rgba(255, 255, 255, 0.02);
}
.idx-why-num {
	font-family: var(--font-display);
	font-size: 0.72rem;
	font-weight: 700;
	letter-spacing: 0.1em;
	color: rgba(255, 255, 255, 0.2);
	display: block;
	margin-bottom: 1.25rem;
}
.idx-why-title {
	font-family: var(--font-display);
	font-size: 1.1rem;
	font-weight: 700;
	color: #fff;
	margin-bottom: 0.6rem;
}
.idx-why-desc {
	font-size: 0.875rem;
	color: rgba(255, 255, 255, 0.45);
	line-height: 1.7;
	margin: 0;
}

/* ---- How It Works ---- */
.idx-how {
	background: var(--dark-secondary);
	border-top: 1px solid rgba(255, 255, 255, 0.07);
	padding: 6rem 0;
	position: relative;
	overflow: hidden;
}
.idx-how::before {
	content: "";
	position: absolute;
	inset: 0;
	opacity: 0.35;
	pointer-events: none;
}
.idx-how-inner {
	position: relative;
	z-index: 1;
}
.idx-how-head {
	margin-bottom: 4rem;
	max-width: 380px;
}
.idx-how-steps {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 0;
	border-top: 1px solid rgba(255, 255, 255, 0.08);
}
.idx-how-step {
	padding: 2.5rem 2rem 2.5rem 0;
	border-right: 1px solid rgba(255, 255, 255, 0.08);
	position: relative;
}
.idx-how-step:last-child {
	border-right: none;
}
.idx-how-step:first-child {
	padding-left: 0;
}
.idx-how-num {
	font-family: var(--font-display);
	font-size: 3rem;
	font-weight: 800;
	letter-spacing: -0.04em;
	color: rgba(255, 255, 255, 0.07);
	line-height: 1;
	display: block;
	margin-bottom: 1rem;
}
.idx-how-title {
	font-family: var(--font-display);
	font-size: 1.25rem;
	font-weight: 700;
	color: #fff;
	margin-bottom: 0.6rem;
}
.idx-how-desc {
	font-size: 0.875rem;
	color: rgba(255, 255, 255, 0.45);
	line-height: 1.7;
	margin: 0;
}

/* Home Page Responsive */
@media (max-width: 992px) {
	.idx-serve-inner {
		grid-template-columns: 1fr;
		gap: 2.5rem;
	}
	.idx-fp-inner {
		grid-template-columns: 1fr;
		gap: 2.5rem;
	}
	.idx-why-grid {
		grid-template-columns: repeat(2, 1fr);
	}
	.idx-why-item:nth-child(2) {
		border-right: none;
	}
	.idx-why-item:nth-child(3) {
		padding-left: 0;
		border-right: 1px solid rgba(255, 255, 255, 0.08);
	}
	.idx-how-steps {
		grid-template-columns: repeat(2, 1fr);
	}
	.idx-how-step:nth-child(2) {
		border-right: none;
	}
	.idx-how-step:nth-child(3) {
		padding-left: 0;
		border-right: 1px solid rgba(255, 255, 255, 0.08);
	}
}
@media (max-width: 576px) {
	.idx-serve-grid {
		grid-template-columns: 1fr;
	}
	.idx-serve-item {
		border-right: none;
	}
	.idx-serve-item:nth-child(1) {
		border-top: none;
	}
	.idx-serve-item:nth-child(2) {
		border-top: 1px solid rgba(255, 255, 255, 0.08);
	}
	.idx-fp-features {
		grid-template-columns: 1fr;
	}
	.idx-why-grid {
		grid-template-columns: 1fr;
	}
	.idx-why-item {
		border-right: none;
		padding-left: 0;
		padding-right: 0;
	}
	.idx-how-steps {
		grid-template-columns: 1fr;
	}
	.idx-how-step {
		border-right: none;
		padding-left: 0;
		padding-right: 0;
	}
}

/* Testimonials — dark glass */
.testimonials {
	background: var(--dark-bg);
	position: relative;
	overflow: hidden;
}
.testimonials::before {
	content: "";
	position: absolute;
	inset: 0;
	background: radial-gradient(
		ellipse at 50% 50%,
		rgba(255, 255, 255, 0.07) 0%,
		transparent 70%
	);
	pointer-events: none;
}

.testimonial-card {
	background: var(--glass-bg);
	backdrop-filter: blur(12px);
	-webkit-backdrop-filter: blur(12px);
	border: 1px solid var(--glass-border);
	padding: 2rem;
	border-radius: 20px;
	height: 100%;
	position: relative;
	box-shadow: 0 2px 16px rgba(0, 0, 0, 0.116);
	transition: all 0.35s ease;
	z-index: 1;
}
.testimonial-card:hover {
	border-color: rgba(255, 255, 255, 0.3);
	box-shadow:
		0 4px 16px rgba(0, 0, 0, 0.2),
		0 0 15px rgba(255, 255, 255, 0.05);
	transform: translateY(-3px);
}

.quote-icon {
	font-size: 3rem;
	color: var(--neon-blue);
	opacity: 0.35;
	margin-bottom: 1rem;
}

.testimonial-text {
	font-size: 1.05rem;
	margin-bottom: 1.5rem;
	font-style: italic;
	color: rgba(255, 255, 255, 0.82);
}

.testimonial-author strong {
	display: block;
	color: #fff;
	font-weight: 600;
}

.testimonial-author span {
	color: rgba(255, 255, 255, 0.5);
	font-size: 0.9rem;
}

/* CTA Section — deep space + animated border */
.final-cta,
.cta-section {
	background: var(--dark-bg);
	color: #fff;
	position: relative;
	overflow: hidden;
}
.final-cta::before,
.cta-section::before {
	content: "";
	position: absolute;
	inset: 0;
	background: radial-gradient(
		ellipse at 50% 50%,
		rgba(255, 255, 255, 0.12) 0%,
		transparent 65%
	);
	pointer-events: none;
}

.cta-box {
	text-align: center;
	padding: 4rem 2.5rem;
	position: relative;
	background: var(--glass-bg);
	border: 1px solid rgba(255, 255, 255, 0.3);
	border-radius: 28px;
	backdrop-filter: blur(12px);
	overflow: hidden;
	z-index: 1;
}
.cta-box::before {
	content: "";
	position: absolute;
	inset: -2px;
	border-radius: 30px;
	background: linear-gradient(
		135deg,
		rgba(255, 255, 255, 0.6),
		rgba(255, 255, 255, 0.6),
		rgba(255, 255, 255, 0.6),
		rgba(255, 255, 255, 0.6)
	);
	background-size: 300% 300%;
	z-index: -1;
	animation: cta-border-rotate 5s linear infinite;
}
@keyframes cta-border-rotate {
	0% {
		background-position: 0% 50%;
	}
	50% {
		background-position: 100% 50%;
	}
	100% {
		background-position: 0% 50%;
	}
}
.cta-title {
	font-size: 2.5rem;
	font-weight: 700;
	margin-bottom: 1rem;
	background: linear-gradient(135deg, #fff 0%, var(--neon-blue) 100%);
	-webkit-background-clip: text;
	-webkit-text-fill-color: transparent;
	background-clip: text;
}

.cta-text {
	font-size: 1.2rem;
	margin-bottom: 2rem;
	color: rgba(255, 255, 255, 0.75);
}

.cta-buttons {
	display: flex;
	gap: 1rem;
	justify-content: center;
	flex-wrap: wrap;
}

/* Buttons */
.btn-primary {
	background: #fff;
	color: #000;
	border: 1px solid rgba(255, 255, 255, 0.15);
	padding: 0.75rem 2rem;
	font-weight: 600;
	transition: all 0.3s ease;
	border-radius: 8px;
	position: relative;
	overflow: hidden;
}
.btn-primary::after {
	content: "";
	position: absolute;
	inset: 0;
	background: linear-gradient(
		105deg,
		transparent 30%,
		rgba(255, 255, 255, 0.18) 50%,
		transparent 70%
	);
	transform: translateX(-120%);
	transition: transform 0.6s ease;
}
.btn-primary:hover::after {
	transform: translateX(120%);
}

.btn-primary:hover {
	background: #e5e5e5;
	color: #000;
	border-color: rgba(255, 255, 255, 0.25);
	transform: translateY(-2px);
	box-shadow: 0 6px 20px rgba(0, 0, 0, 0.5);
}

.btn-outline-light {
	border: 1px solid rgba(255, 255, 255, 0.35);
	color: rgba(255, 255, 255, 0.85);
	padding: 0.75rem 2rem;
	font-weight: 600;
}

.btn-outline-light:hover {
	background: rgba(255, 255, 255, 0.08);
	border-color: rgba(255, 255, 255, 0.6);
	color: #fff;
}

.btn-outline-primary {
	border: 1px solid rgba(255, 255, 255, 0.25);
	color: rgba(255, 255, 255, 0.75);
	padding: 0.75rem 2rem;
	font-weight: 600;
}

.btn-outline-primary:hover {
	background: rgba(255, 255, 255, 0.07);
	border-color: rgba(255, 255, 255, 0.4);
	color: #fff;
}

/* Footer — deep space futuristic */
.footer {
	background: var(--dark-bg);
	color: rgba(255, 255, 255, 0.75);
	padding: 5rem 0 2rem;
	position: relative;
	overflow: hidden;
}
.footer::before {
	content: "";
	position: absolute;
	inset: 0;
	opacity: 0.7;
	pointer-events: none;
}
.footer::after {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	height: 1px;
	background: linear-gradient(
		90deg,
		transparent,
		var(--neon-blue),
		var(--neon-purple),
		transparent
	);
}

.footer-brand {
	color: #fff;
	font-size: 1.5rem;
	font-weight: 700;
	margin-bottom: 1rem;
	font-family: var(--font-display);
	background: linear-gradient(135deg, #fff 0%, var(--neon-blue) 100%);
	-webkit-background-clip: text;
	-webkit-text-fill-color: transparent;
	background-clip: text;
}

.footer-about {
	margin-bottom: 1.5rem;
	line-height: 1.8;
}

.social-links {
	display: flex;
	gap: 1rem;
}

.social-links a {
	width: 40px;
	height: 40px;
	background: rgba(255, 255, 255, 0.06);
	border: 1px solid rgba(255, 255, 255, 0.12);
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	color: rgba(255, 255, 255, 0.7);
	transition: all 0.3s ease;
}

.social-links a:hover {
	background: rgba(255, 255, 255, 0.15);
	border-color: var(--neon-blue);
	color: var(--neon-blue);
	box-shadow: 0 0 15px rgba(255, 255, 255, 0.35);
	transform: translateY(-3px);
}

.footer-title {
	color: #fff;
	font-size: 1.1rem;
	font-weight: 600;
	margin-bottom: 1rem;
}

.footer-links {
	list-style: none;
	padding: 0;
}

.footer-links li {
	margin-bottom: 0.5rem;
}

.footer-links a {
	color: rgba(255, 255, 255, 0.55);
	transition: all 0.3s ease;
}

.footer-links a:hover {
	color: var(--neon-blue);
	padding-left: 5px;
	text-shadow: 0 0 8px rgba(255, 255, 255, 0.4);
}

.footer-bottom {
	border-top: 1px solid rgba(255, 255, 255, 0.1);
	margin-top: 3rem;
	padding-top: 2rem;
	text-align: center;
	color: rgba(255, 255, 255, 0.6);
}

/* About Page Styles */

/* Dark section backgrounds */
.company-overview,
.core-values,
.team-section {
	background: var(--dark-bg);
	color: #fff;
	position: relative;
	overflow: hidden;
}
.company-overview::before,
.core-values::before,
.team-section::before {
	content: "";
	position: absolute;
	inset: 0;
	opacity: 0.7;
	pointer-events: none;
}
.company-overview h2,
.core-values h2,
.team-section h2 {
	background: linear-gradient(135deg, #fff 0%, var(--neon-blue) 100%);
	-webkit-background-clip: text;
	-webkit-text-fill-color: transparent;
	background-clip: text;
}
.company-overview .lead,
.company-overview p {
	color: rgba(255, 255, 255, 0.72);
}

.our-story,
.future-direction {
	background: var(--dark-secondary);
	color: #fff;
	position: relative;
	overflow: hidden;
}
.our-story::before,
.future-direction::before {
	content: "";
	position: absolute;
	inset: 0;
	background: radial-gradient(
		ellipse at 50% 0%,
		rgba(255, 255, 255, 0.08) 0%,
		transparent 70%
	);
	pointer-events: none;
}
.our-story h2 {
	background: linear-gradient(135deg, #fff 0%, var(--neon-cyan) 100%);
	-webkit-background-clip: text;
	-webkit-text-fill-color: transparent;
	background-clip: text;
}
.future-direction h2 {
	background: linear-gradient(135deg, #fff 0%, var(--neon-blue) 100%);
	-webkit-background-clip: text;
	-webkit-text-fill-color: transparent;
	background-clip: text;
}
.future-direction .lead {
	color: rgba(255, 255, 255, 0.75);
}

.story-content p {
	color: rgba(255, 255, 255, 0.72);
}

.stat-label {
	color: rgba(255, 255, 255, 0.55);
	font-weight: 500;
}

.overview-stats {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 2rem;
}

.stat-item {
	text-align: center;
	padding: 1.5rem;
	background: var(--glass-bg);
	border: 1px solid var(--glass-border);
	border-radius: 15px;
	backdrop-filter: blur(8px);
	transition: all 0.3s ease;
}
.stat-item:hover {
	border-color: rgba(255, 255, 255, 0.35);
	box-shadow: 0 0 20px rgba(255, 255, 255, 0.1);
}

.stat-number {
	font-size: 2.5rem;
	font-weight: 700;
	color: var(--neon-blue);
	margin-bottom: 0.5rem;
	font-family: var(--font-display);
	filter: drop-shadow(0 0 8px rgba(255, 255, 255, 0.4));
}

.stat-label {
	color: var(--text-light);
	font-weight: 500;
}

.story-content {
	font-size: 1.1rem;
	line-height: 1.9;
}

.story-content p {
	margin-bottom: 1.5rem;
}

.value-card {
	background: var(--glass-bg);
	backdrop-filter: blur(12px);
	-webkit-backdrop-filter: blur(12px);
	border: 1px solid var(--glass-border);
	padding: 2rem;
	border-radius: 20px;
	text-align: center;
	height: 100%;
	transition: all 0.4s ease;
	color: #fff;
	position: relative;
	overflow: hidden;
}

.value-card:hover {
	border-color: rgba(255, 255, 255, 0.4);
	box-shadow:
		0 16px 40px rgba(0, 0, 0, 0.4),
		0 0 25px rgba(255, 255, 255, 0.15);
	transform: translateY(-8px);
}
.value-card h3 {
	color: #fff;
	margin-bottom: 0.75rem;
}
.value-card p {
	color: rgba(255, 255, 255, 0.65);
}

.value-icon {
	width: 80px;
	height: 80px;
	margin: 0 auto 1.5rem;
	background: rgba(255, 255, 255, 0.1);
	border: 1px solid rgba(255, 255, 255, 0.3);
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	transition: all 0.4s ease;
}
.value-card:hover .value-icon {
	background: rgba(255, 255, 255, 0.2);
	box-shadow: 0 0 25px rgba(255, 255, 255, 0.45);
}

.value-icon i {
	font-size: 2.5rem;
	color: var(--neon-blue);
	filter: drop-shadow(0 0 6px rgba(255, 255, 255, 0.5));
}

.team-card {
	background: var(--glass-bg);
	backdrop-filter: blur(12px);
	-webkit-backdrop-filter: blur(12px);
	border: 1px solid var(--glass-border);
	padding: 2rem;
	border-radius: 20px;
	text-align: center;
	transition: all 0.4s ease;
	color: #fff;
}

.team-card:hover {
	transform: translateY(-8px);
	border-color: rgba(255, 255, 255, 0.4);
	box-shadow:
		0 16px 40px rgba(0, 0, 0, 0.4),
		0 0 25px rgba(255, 255, 255, 0.15);
}

.team-avatar {
	font-size: 5rem;
	color: var(--neon-blue);
	margin-bottom: 1rem;
	filter: drop-shadow(0 0 12px rgba(255, 255, 255, 0.4));
}

.team-name {
	font-size: 1.3rem;
	margin-bottom: 0.5rem;
	color: #fff;
}

.team-role {
	color: var(--neon-cyan);
	font-weight: 600;
	margin-bottom: 1rem;
	font-size: 0.9rem;
	text-transform: uppercase;
	letter-spacing: 0.05em;
}

.team-bio {
	color: rgba(255, 255, 255, 0.6);
	margin-bottom: 1rem;
	font-size: 0.9rem;
}

.team-social {
	display: flex;
	gap: 0.5rem;
	justify-content: center;
}

.team-social a {
	width: 35px;
	height: 35px;
	background: rgba(255, 255, 255, 0.06);
	border: 1px solid rgba(255, 255, 255, 0.12);
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	color: rgba(255, 255, 255, 0.6);
	transition: all 0.3s ease;
}

.team-social a:hover {
	background: rgba(255, 255, 255, 0.15);
	border-color: var(--neon-blue);
	color: var(--neon-blue);
	box-shadow: 0 0 12px rgba(255, 255, 255, 0.3);
}

.future-visual {
	font-size: 10rem;
	color: var(--neon-blue);
	text-align: center;
	opacity: 0.45;
	filter: drop-shadow(0 0 30px rgba(255, 255, 255, 0.5));
	animation: orb-pulse 5s ease-in-out infinite;
}

.future-item {
	display: flex;
	gap: 1rem;
	margin-bottom: 1.5rem;
	align-items: flex-start;
}

.future-item i {
	color: var(--neon-cyan);
	font-size: 1.3rem;
	flex-shrink: 0;
	filter: drop-shadow(0 0 4px rgba(255, 255, 255, 0.5));
	margin-top: 0.15rem;
}
.future-item strong {
	color: #fff;
}
.future-item p {
	color: rgba(255, 255, 255, 0.65);
	margin: 0.2rem 0 0;
}

/* =============================================
   ABOUT PAGE — REDESIGN
   ============================================= */

/* Shared typography utilities */
.about-label {
	font-size: 0.72rem;
	font-weight: 700;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	color: rgba(255, 255, 255, 0.4);
	margin-bottom: 0.75rem;
}
.about-section-title {
	font-family: var(--font-display);
	font-size: 2.4rem;
	font-weight: 800;
	color: #fff;
	letter-spacing: -0.03em;
	line-height: 1.1;
	margin-bottom: 0;
}
.about-tag {
	display: inline-block;
	font-size: 0.75rem;
	font-weight: 600;
	letter-spacing: 0.06em;
	text-transform: uppercase;
	padding: 0.35rem 0.9rem;
	border: 1px solid rgba(255, 255, 255, 0.18);
	border-radius: 100px;
	color: rgba(255, 255, 255, 0.6);
	background: rgba(255, 255, 255, 0.04);
}

/* About Hero */
.about-hero {
	background: #000;
	padding: 14rem 0 6rem;
	position: relative;
	overflow: hidden;
}
.about-hero::before {
	content: "";
	position: absolute;
	inset: 0;
	opacity: 0.5;
	pointer-events: none;
}
.about-hero-inner {
	max-width: 820px;
	position: relative;
	z-index: 1;
}
.about-eyebrow {
	font-size: 0.72rem;
	font-weight: 700;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	color: rgba(255, 255, 255, 0.4);
	margin-bottom: 1.5rem;
}
.about-hero-title {
	font-family: var(--font-display);
	font-size: clamp(2.8rem, 6vw, 5.5rem);
	font-weight: 800;
	line-height: 1.05;
	letter-spacing: -0.04em;
	color: #fff;
	margin-bottom: 1.5rem;
}
.about-hero-sub {
	font-size: 1.15rem;
	color: rgba(255, 255, 255, 0.5);
	max-width: 540px;
	line-height: 1.7;
	margin: 0;
}

/* Stats Strip */
.abt-stats-strip {
	background: #000;
	border-top: 1px solid rgba(255, 255, 255, 0.08);
	border-bottom: 1px solid rgba(255, 255, 255, 0.08);
	padding: 2.5rem 0;
}
.abt-strip-inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	flex-wrap: wrap;
	gap: 1.5rem;
}
.abt-strip-stat {
	display: flex;
	flex-direction: column;
	gap: 0.2rem;
	flex: 1;
	min-width: 100px;
	text-align: center;
}
.abt-strip-num {
	font-family: var(--font-display);
	font-size: 2rem;
	font-weight: 800;
	color: #fff;
	letter-spacing: -0.03em;
	line-height: 1;
}
.abt-strip-lbl {
	font-size: 0.72rem;
	font-weight: 600;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: rgba(255, 255, 255, 0.4);
}
.abt-strip-divider {
	width: 1px;
	height: 40px;
	background: rgba(255, 255, 255, 0.1);
	flex-shrink: 0;
}

/* Mission */
.about-mission {
	background: #000;
	padding: 7rem 0;
	border-bottom: 1px solid rgba(255, 255, 255, 0.07);
}
.about-mission-text {
	font-size: 1.25rem;
	color: rgba(255, 255, 255, 0.72);
	line-height: 1.85;
	margin-bottom: 0;
}

/* Our Story / Timeline */
.about-story {
	background: var(--dark-secondary);
	padding: 7rem 0;
	position: relative;
	overflow: hidden;
}
.about-story::before {
	content: "";
	position: absolute;
	inset: 0;
	opacity: 0.5;
	pointer-events: none;
}
.about-timeline {
	position: relative;
	padding-left: 2rem;
	border-left: 1px solid rgba(255, 255, 255, 0.12);
}
.abt-tl-item {
	display: grid;
	grid-template-columns: 100px 1fr;
	gap: 2rem;
	padding: 0 0 3.5rem 1.5rem;
	position: relative;
}
.abt-tl-item::before {
	content: "";
	position: absolute;
	left: -0.45rem;
	top: 0.45rem;
	width: 8px;
	height: 8px;
	background: #fff;
	border-radius: 50%;
	box-shadow: 0 0 0 3px rgba(255, 255, 255, 0.1);
}
.abt-tl-item:last-child {
	padding-bottom: 0;
}
.abt-tl-year {
	font-family: var(--font-display);
	font-size: 1rem;
	font-weight: 700;
	color: rgba(255, 255, 255, 0.35);
	letter-spacing: 0.04em;
	padding-top: 0.25rem;
	flex-shrink: 0;
}
.abt-tl-content h4 {
	font-family: var(--font-display);
	font-size: 1.15rem;
	font-weight: 700;
	color: #fff;
	margin-bottom: 0.6rem;
	letter-spacing: -0.01em;
}
.abt-tl-content p {
	color: rgba(255, 255, 255, 0.6);
	line-height: 1.75;
	margin: 0;
	font-size: 0.95rem;
}

/* Core Values */
.about-values {
	background: #000;
	padding: 7rem 0;
	border-bottom: 1px solid rgba(255, 255, 255, 0.07);
}
.abt-value-card {
	background: var(--glass-bg);
	border: 1px solid var(--glass-border);
	border-radius: 16px;
	padding: 2rem 1.75rem;
	height: 100%;
	position: relative;
	overflow: hidden;
	transition:
		border-color 0.3s ease,
		transform 0.3s ease;
}
.abt-value-card:hover {
	border-color: rgba(255, 255, 255, 0.25);
	transform: translateY(-4px);
}
.abt-value-num {
	display: block;
	font-family: var(--font-display);
	font-size: 0.72rem;
	font-weight: 700;
	letter-spacing: 0.1em;
	color: rgba(255, 255, 255, 0.2);
	margin-bottom: 1.25rem;
}
.abt-value-icon {
	font-size: 1.6rem;
	color: rgba(255, 255, 255, 0.65);
	margin-bottom: 1.25rem;
	line-height: 1;
}
.abt-value-card h4 {
	font-family: var(--font-display);
	font-size: 1.05rem;
	font-weight: 700;
	color: #fff;
	margin-bottom: 0.65rem;
	letter-spacing: -0.01em;
}
.abt-value-card p {
	color: rgba(255, 255, 255, 0.55);
	font-size: 0.9rem;
	line-height: 1.7;
	margin: 0;
}

/* Team */
.about-team {
	background: var(--dark-secondary);
	padding: 7rem 0;
	position: relative;
	overflow: hidden;
}
.about-team::before {
	content: "";
	position: absolute;
	inset: 0;
	opacity: 0.5;
	pointer-events: none;
}
.about-team-sub {
	color: rgba(255, 255, 255, 0.5);
	font-size: 0.95rem;
	line-height: 1.7;
	margin: 0;
}
.abt-team-card {
	background: rgba(255, 255, 255, 0.03);
	border: 1px solid rgba(255, 255, 255, 0.08);
	border-radius: 16px;
	padding: 2rem;
	height: 100%;
	display: flex;
	flex-direction: column;
	gap: 1rem;
	transition:
		border-color 0.3s ease,
		background 0.3s ease;
	position: relative;
	z-index: 1;
}
.abt-team-card:hover {
	border-color: rgba(255, 255, 255, 0.2);
	background: rgba(255, 255, 255, 0.05);
}
.abt-avatar {
	width: 52px;
	height: 52px;
	border-radius: 14px;
	background: rgba(255, 255, 255, 0.08);
	border: 1px solid rgba(255, 255, 255, 0.14);
	display: flex;
	align-items: center;
	justify-content: center;
	font-family: var(--font-display);
	font-size: 0.9rem;
	font-weight: 800;
	color: rgba(255, 255, 255, 0.75);
	letter-spacing: 0.04em;
	flex-shrink: 0;
}
.abt-team-info {
	flex: 1;
}
.abt-team-name {
	font-family: var(--font-display);
	font-size: 1rem;
	font-weight: 700;
	color: #fff;
	margin-bottom: 0.2rem;
	letter-spacing: -0.01em;
}
.abt-team-role {
	font-size: 0.72rem;
	font-weight: 700;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	color: rgba(255, 255, 255, 0.35);
	margin-bottom: 0.75rem;
}
.abt-team-bio {
	color: rgba(255, 255, 255, 0.55);
	font-size: 0.88rem;
	line-height: 1.65;
	margin: 0;
}
.abt-team-links {
	display: flex;
	gap: 0.5rem;
	margin-top: auto;
}
.abt-team-links a {
	width: 32px;
	height: 32px;
	border-radius: 8px;
	background: rgba(255, 255, 255, 0.05);
	border: 1px solid rgba(255, 255, 255, 0.1);
	display: flex;
	align-items: center;
	justify-content: center;
	color: rgba(255, 255, 255, 0.45);
	font-size: 0.85rem;
	text-decoration: none;
	transition: all 0.25s ease;
}
.abt-team-links a:hover {
	background: rgba(255, 255, 255, 0.12);
	border-color: rgba(255, 255, 255, 0.3);
	color: #fff;
}

/* Vision */
.about-vision {
	background: #000;
	padding: 7rem 0;
	border-top: 1px solid rgba(255, 255, 255, 0.07);
}
.about-vision-sub {
	color: rgba(255, 255, 255, 0.5);
	font-size: 0.95rem;
	line-height: 1.7;
	margin-top: 1.5rem;
	margin-bottom: 0;
}
.abt-vision-list {
	display: flex;
	flex-direction: column;
}
.abt-vision-item {
	display: grid;
	grid-template-columns: 48px 1fr;
	gap: 1.5rem;
	padding: 2rem 0;
	border-bottom: 1px solid rgba(255, 255, 255, 0.07);
	align-items: start;
}
.abt-vision-item:first-child {
	border-top: 1px solid rgba(255, 255, 255, 0.07);
}
.abt-vision-num {
	font-family: var(--font-display);
	font-size: 0.72rem;
	font-weight: 700;
	letter-spacing: 0.1em;
	color: rgba(255, 255, 255, 0.25);
	padding-top: 0.3rem;
}
.abt-vision-body h4 {
	font-family: var(--font-display);
	font-size: 1rem;
	font-weight: 700;
	color: #fff;
	margin-bottom: 0.4rem;
	letter-spacing: -0.01em;
}
.abt-vision-body p {
	color: rgba(255, 255, 255, 0.5);
	font-size: 0.9rem;
	line-height: 1.7;
	margin: 0;
}

/* About page responsive */
@media (max-width: 767px) {
	.about-hero {
		padding: 10rem 0 4rem;
	}
	.about-hero-title {
		font-size: 2.5rem;
	}
	.about-section-title {
		font-size: 1.9rem;
	}
	.abt-strip-divider {
		display: none;
	}
	.abt-strip-inner {
		justify-content: flex-start;
		gap: 2rem;
	}
	.abt-strip-stat {
		text-align: left;
		min-width: 120px;
	}
	.about-mission,
	.about-story,
	.about-values,
	.about-team,
	.about-vision {
		padding: 4rem 0;
	}
	.about-timeline {
		padding-left: 1rem;
	}
	.abt-tl-item {
		grid-template-columns: 1fr;
		gap: 0.5rem;
		padding-left: 1rem;
	}
	.abt-tl-year {
		font-size: 0.75rem;
	}
}

/* Products Page */
.products-grid {
	background: var(--dark-bg);
	position: relative;
	overflow: hidden;
}
.products-grid::before {
	content: "";
	position: absolute;
	inset: 0;
	opacity: 0.7;
	pointer-events: none;
}

.product-preview-card {
	background: var(--glass-bg);
	backdrop-filter: blur(14px);
	-webkit-backdrop-filter: blur(14px);
	border: 1px solid var(--glass-border);
	padding: 2.5rem;
	border-radius: 20px;
	text-align: center;
	height: 100%;
	transition: all 0.4s ease;
	color: #fff;
	position: relative;
	overflow: hidden;
	z-index: 1;
}

.product-preview-card:hover,
.product-preview-card.active {
	border-color: rgba(255, 255, 255, 0.5);
	box-shadow:
		0 20px 50px rgba(0, 0, 0, 0.5),
		0 0 35px rgba(255, 255, 255, 0.2);
	transform: translateY(-8px);
}
.product-preview-card.active {
	border-color: rgba(255, 255, 255, 0.5);
}
.product-preview-card h3 {
	color: #fff;
}
.product-preview-card p {
	color: rgba(255, 255, 255, 0.65);
}

.product-icon {
	font-size: 4rem;
	color: var(--neon-blue);
	margin-bottom: 1.5rem;
	filter: drop-shadow(0 0 12px rgba(255, 255, 255, 0.4));
	display: block;
}
.product-preview-card.active .product-icon {
	color: var(--neon-green);
	filter: drop-shadow(0 0 12px rgba(255, 255, 255, 0.5));
}

.product-mockup-large {
	width: 100%;
	height: 400px;
	background: linear-gradient(
		135deg,
		rgba(255, 255, 255, 0.12) 0%,
		rgba(255, 255, 255, 0.15) 100%
	);
	border: 1px solid rgba(255, 255, 255, 0.25);
	border-radius: 20px;
	display: flex;
	align-items: center;
	justify-content: center;
	box-shadow: 0 0 50px rgba(255, 255, 255, 0.15);
	animation: holographic-pulse 5s ease-in-out infinite;
	position: relative;
	overflow: hidden;
}
.product-mockup-large::after {
	content: "";
	position: absolute;
	inset: 0;
	background: linear-gradient(
		105deg,
		transparent 35%,
		rgba(255, 255, 255, 0.05) 50%,
		transparent 65%
	);
	background-size: 200% 100%;
	animation: holo-slide 4s linear infinite;
	border-radius: 20px;
}

.product-mockup-large i {
	font-size: 9rem;
	color: var(--neon-blue);
	opacity: 0.35;
	filter: drop-shadow(0 0 20px rgba(255, 255, 255, 0.5));
	position: relative;
	z-index: 1;
}

.product-detail {
	background: var(--dark-secondary);
	position: relative;
	overflow: hidden;
}
.product-detail::before {
	content: "";
	position: absolute;
	inset: 0;
	opacity: 0.5;
	pointer-events: none;
}
.product-detail h2,
.product-detail h3 {
	color: #fff;
}
.product-detail .lead {
	color: rgba(255, 255, 255, 0.75);
}
.product-detail p {
	color: rgba(255, 255, 255, 0.65);
}

.features-section h3,
.target-users h3,
.screenshots-section h3,
.pricing-section h3 {
	background: linear-gradient(135deg, #fff 0%, var(--neon-blue) 100%);
	-webkit-background-clip: text;
	-webkit-text-fill-color: transparent;
	background-clip: text;
}

.feature-box {
	background: var(--glass-bg);
	backdrop-filter: blur(10px);
	border: 1px solid var(--glass-border);
	border-radius: 16px;
	padding: 1.5rem;
	text-align: center;
	height: 100%;
	transition: all 0.3s ease;
	color: #fff;
	position: relative;
	z-index: 1;
}
.feature-box:hover {
	border-color: rgba(255, 255, 255, 0.3);
	box-shadow:
		0 8px 25px rgba(0, 0, 0, 0.3),
		0 0 15px rgba(255, 255, 255, 0.1);
}
.feature-box i {
	font-size: 2.5rem;
	color: var(--neon-blue);
	filter: drop-shadow(0 0 8px rgba(255, 255, 255, 0.4));
	margin-bottom: 1rem;
	display: block;
}
.feature-box h4 {
	color: #fff;
	font-size: 1.1rem;
	margin-bottom: 0.5rem;
}
.feature-box p {
	color: rgba(255, 255, 255, 0.6);
	font-size: 0.9rem;
	margin: 0;
}

.user-type {
	background: var(--glass-bg);
	border: 1px solid var(--glass-border);
	border-radius: 16px;
	padding: 1.5rem;
	text-align: center;
	transition: 0.3s ease;
	color: #fff;
	position: relative;
	z-index: 1;
}
.user-type:hover {
	border-color: rgba(255, 255, 255, 0.35);
	box-shadow: 0 0 20px rgba(255, 255, 255, 0.1);
}
.user-type i {
	font-size: 2.5rem;
	display: block;
	margin-bottom: 0.75rem;
	color: var(--neon-purple);
	filter: drop-shadow(0 0 8px rgba(255, 255, 255, 0.4));
}
.user-type h4 {
	color: #fff;
	margin-bottom: 0.25rem;
}
.user-type p {
	color: rgba(255, 255, 255, 0.6);
	font-size: 0.9rem;
	margin: 0;
}

.screenshot-placeholder {
	background: rgba(255, 255, 255, 0.08);
	border: 1px solid rgba(255, 255, 255, 0.2);
	border-radius: 12px;
	height: 180px;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	color: rgba(255, 255, 255, 0.5);
	transition: 0.3s ease;
}
.screenshot-placeholder:hover {
	border-color: rgba(255, 255, 255, 0.35);
	background: rgba(255, 255, 255, 0.06);
}
.screenshot-placeholder i {
	font-size: 2.5rem;
	margin-bottom: 0.5rem;
	color: rgba(255, 255, 255, 0.45);
}

.pricing-card {
	background: var(--glass-bg);
	backdrop-filter: blur(16px);
	border: 1px solid var(--glass-border-blue);
	border-radius: 24px;
	padding: 2.5rem;
	color: #fff;
	position: relative;
	z-index: 1;
}
.plan-option {
	background: rgba(255, 255, 255, 0.04);
	border: 1px solid rgba(255, 255, 255, 0.1);
	border-radius: 16px;
	padding: 1.5rem;
	text-align: center;
	transition: 0.3s ease;
}
.plan-option:hover,
.plan-option.featured {
	border-color: rgba(255, 255, 255, 0.45);
	box-shadow: 0 0 25px rgba(255, 255, 255, 0.15);
}
.plan-option h4 {
	color: #fff;
	margin-bottom: 0.5rem;
}
.plan-option.featured {
	border-color: rgba(255, 255, 255, 0.55);
}
.plan-option .price {
	font-size: 1.4rem;
	font-weight: 700;
	color: var(--neon-blue);
	font-family: var(--font-display);
	margin: 0.5rem 0 1rem;
}
.plan-option.featured .price {
	color: var(--neon-purple);
}
.plan-option ul {
	list-style: none;
	padding: 0;
	color: rgba(255, 255, 255, 0.7);
	font-size: 0.9rem;
}
.plan-option ul li {
	padding: 0.25rem 0;
	border-bottom: 1px solid rgba(255, 255, 255, 0.05);
}

.status-badge .badge {
	font-size: 0.9rem;
	padding: 0.5rem 1rem;
}

/* Target users & problem-solution in upcoming products */
.problem-solution h4,
.planned-features h4 {
	color: var(--neon-blue);
	font-size: 1rem;
	text-transform: uppercase;
	letter-spacing: 0.05em;
	margin-bottom: 0.75rem;
}

/* blog-grid section background */
.blog-grid {
	background: var(--dark-bg);
}

.upcoming-product {
	background: var(--dark-bg);
	color: #fff;
	position: relative;
	overflow: hidden;
}
.upcoming-product::before {
	content: "";
	position: absolute;
	inset: 0;
	opacity: 0.7;
	pointer-events: none;
}
.upcoming-product h2,
.upcoming-product h4 {
	color: #fff;
}
.upcoming-product p {
	color: rgba(255, 255, 255, 0.7);
}
.upcoming-product:nth-child(even) {
	background: var(--dark-secondary);
}

.coming-soon-visual {
	width: 100%;
	height: 420px;
	background: rgba(255, 255, 255, 0.06);
	border: 1px solid rgba(255, 255, 255, 0.2);
	border-radius: 24px;
	display: flex;
	align-items: center;
	justify-content: center;
	animation: holographic-pulse 5s ease-in-out infinite;
	position: relative;
	z-index: 1;
}

.coming-soon-visual i {
	font-size: 10rem;
	color: var(--neon-blue);
	opacity: 0.5;
	filter: drop-shadow(0 0 30px rgba(255, 255, 255, 0.5));
	animation: orb-pulse 4s ease-in-out infinite;
}

.feature-list {
	list-style: none;
	padding: 0;
}

.feature-list li {
	margin-bottom: 0.75rem;
	display: flex;
	align-items: center;
	gap: 0.75rem;
	color: rgba(255, 255, 255, 0.82);
}

.feature-list i {
	color: var(--neon-cyan);
	font-size: 1.1rem;
	filter: drop-shadow(0 0 4px rgba(255, 255, 255, 0.6));
	flex-shrink: 0;
}

/* =============================================
   PRODUCTS PAGE — REDESIGN
   ============================================= */

/* Products Hero */
.prod-hero {
	background: #000;
	padding: 14rem 0 5rem;
	position: relative;
	overflow: hidden;
}
.prod-hero::before {
	content: "";
	position: absolute;
	inset: 0;
	opacity: 0.5;
	pointer-events: none;
}
.prod-hero-inner {
	max-width: 780px;
	position: relative;
	z-index: 1;
}
.prod-eyebrow {
	font-size: 0.72rem;
	font-weight: 700;
	letter-spacing: 0.14em;
	text-transform: uppercase;
	color: rgba(255, 255, 255, 0.4);
	margin-bottom: 1.5rem;
}
.prod-hero-title {
	font-family: var(--font-display);
	font-size: clamp(2.8rem, 6vw, 5.5rem);
	font-weight: 800;
	line-height: 1.05;
	letter-spacing: -0.04em;
	color: #fff;
	margin-bottom: 1.5rem;
}
.prod-hero-sub {
	font-size: 1.1rem;
	color: rgba(255, 255, 255, 0.5);
	max-width: 540px;
	line-height: 1.75;
	margin: 0;
}

/* Product Suite Index Strip */
.prod-index {
	background: #000;
	border-top: 1px solid rgba(255, 255, 255, 0.08);
	border-bottom: 1px solid rgba(255, 255, 255, 0.08);
	padding: 0;
}
.prod-index-grid {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
}
.prod-index-card {
	display: flex;
	align-items: center;
	gap: 1rem;
	padding: 1.5rem 2rem;
	border-right: 1px solid rgba(255, 255, 255, 0.07);
	text-decoration: none;
	color: #fff;
	transition: background 0.25s ease;
	position: relative;
}
.prod-index-card:last-child {
	border-right: none;
}
.prod-index-card:hover {
	background: rgba(255, 255, 255, 0.04);
	color: #fff;
}
.prod-index-live:hover {
	background: rgba(255, 255, 255, 0.05);
}
.prod-index-status {
	position: absolute;
	top: 0.75rem;
	right: 1rem;
	font-size: 0.6rem;
	font-weight: 700;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	padding: 0.2rem 0.55rem;
	border-radius: 100px;
	border: 1px solid rgba(255, 255, 255, 0.5);
	color: rgba(255, 255, 255, 0.85);
	background: rgba(255, 255, 255, 0.06);
}
.prod-index-status.prod-index-wip {
	border-color: rgba(255, 255, 255, 0.2);
	color: rgba(255, 255, 255, 0.4);
	background: none;
}
.prod-index-icon {
	font-size: 1.4rem;
	color: rgba(255, 255, 255, 0.55);
	flex-shrink: 0;
}
.prod-index-info h3 {
	font-family: var(--font-display);
	font-size: 0.95rem;
	font-weight: 700;
	color: #fff;
	margin: 0 0 0.1rem;
	letter-spacing: -0.01em;
}
.prod-index-info p {
	font-size: 0.75rem;
	color: rgba(255, 255, 255, 0.4);
	margin: 0;
}
.prod-index-arrow {
	margin-left: auto;
	font-size: 0.8rem;
	color: rgba(255, 255, 255, 0.2);
	flex-shrink: 0;
	transition:
		color 0.2s ease,
		transform 0.2s ease;
}
.prod-index-card:hover .prod-index-arrow {
	color: rgba(255, 255, 255, 0.6);
	transform: translateX(3px);
}

/* HosCare Detail */
.prod-detail {
	background: var(--dark-secondary);
	padding: 7rem 0;
	position: relative;
	overflow: hidden;
}
.prod-detail::before {
	content: "";
	position: absolute;
	inset: 0;
	opacity: 0.5;
	pointer-events: none;
}
.prod-detail .container {
	position: relative;
	z-index: 1;
}
.prod-detail-header {
	max-width: 820px;
	margin-bottom: 4rem;
}
.prod-detail-meta {
	display: flex;
	align-items: center;
	gap: 1rem;
	margin-bottom: 1.25rem;
}
.prod-live-badge {
	font-size: 0.65rem;
	font-weight: 700;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	padding: 0.25rem 0.7rem;
	border-radius: 100px;
	border: 1px solid rgba(255, 255, 255, 0.55);
	color: rgba(255, 255, 255, 0.9);
	background: rgba(255, 255, 255, 0.08);
}
.prod-wip-badge {
	font-size: 0.65rem;
	font-weight: 700;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	padding: 0.25rem 0.7rem;
	border-radius: 100px;
	border: 1px solid rgba(255, 255, 255, 0.2);
	color: rgba(255, 255, 255, 0.45);
}
.prod-detail-cat {
	font-size: 0.72rem;
	font-weight: 700;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	color: rgba(255, 255, 255, 0.35);
}
.prod-detail-title {
	font-family: var(--font-display);
	font-size: clamp(2.5rem, 5vw, 4.5rem);
	font-weight: 800;
	color: #fff;
	letter-spacing: -0.04em;
	line-height: 1;
	margin-bottom: 1.25rem;
}
.prod-detail-lead {
	font-size: 1.1rem;
	color: rgba(255, 255, 255, 0.6);
	line-height: 1.8;
	margin: 0;
	max-width: 640px;
}

/* Feature Modules Grid */
.prod-modules-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 0;
	border: 1px solid rgba(255, 255, 255, 0.07);
	border-radius: 16px;
	overflow: hidden;
	margin-bottom: 5rem;
}
.prod-module {
	display: flex;
	gap: 1rem;
	padding: 1.5rem 1.75rem;
	border-bottom: 1px solid rgba(255, 255, 255, 0.07);
	border-right: 1px solid rgba(255, 255, 255, 0.07);
	transition: background 0.25s ease;
}
.prod-module:nth-child(3n) {
	border-right: none;
}
.prod-module:nth-last-child(-n + 3) {
	border-bottom: none;
}
.prod-module:hover {
	background: rgba(255, 255, 255, 0.03);
}
.prod-module-icon {
	font-size: 1.1rem;
	color: rgba(255, 255, 255, 0.45);
	flex-shrink: 0;
	margin-top: 0.15rem;
	line-height: 1;
}
.prod-module-body h4 {
	font-family: var(--font-display);
	font-size: 0.88rem;
	font-weight: 700;
	color: #fff;
	margin-bottom: 0.3rem;
	letter-spacing: -0.01em;
}
.prod-module-body p {
	font-size: 0.82rem;
	color: rgba(255, 255, 255, 0.5);
	line-height: 1.6;
	margin: 0;
}

/* Fits List */
.prod-fits-list {
	display: flex;
	flex-direction: column;
	gap: 0.75rem;
	margin-top: 1rem;
}
.prod-fit-item {
	display: flex;
	align-items: flex-start;
	gap: 0.85rem;
	padding: 0.85rem 1rem;
	background: rgba(255, 255, 255, 0.03);
	border: 1px solid rgba(255, 255, 255, 0.07);
	border-radius: 10px;
}
.prod-fit-item i {
	font-size: 1rem;
	color: rgba(255, 255, 255, 0.45);
	flex-shrink: 0;
	margin-top: 0.1rem;
}
.prod-fit-item div {
	display: flex;
	flex-direction: column;
}
.prod-fit-item strong {
	font-size: 0.88rem;
	font-weight: 700;
	color: #fff;
	line-height: 1.3;
}
.prod-fit-item span {
	font-size: 0.78rem;
	color: rgba(255, 255, 255, 0.4);
}

/* Pricing Table */
.prod-pricing-table {
	border: 1px solid rgba(255, 255, 255, 0.1);
	border-radius: 14px;
	overflow: hidden;
	margin-top: 1rem;
}
.prod-plan-row {
	display: grid;
	grid-template-columns: 1fr 1.5fr auto;
	gap: 1.5rem;
	padding: 1.25rem 1.5rem;
	border-bottom: 1px solid rgba(255, 255, 255, 0.07);
	align-items: center;
	background: rgba(255, 255, 255, 0.02);
	transition: background 0.2s ease;
}
.prod-plan-row:last-child {
	border-bottom: none;
}
.prod-plan-row:hover {
	background: rgba(255, 255, 255, 0.04);
}
.prod-plan-featured {
	background: rgba(255, 255, 255, 0.05);
	border-left: 2px solid rgba(255, 255, 255, 0.35);
}
.prod-plan-featured:hover {
	background: rgba(255, 255, 255, 0.07);
}
.prod-plan-name span {
	display: block;
	font-family: var(--font-display);
	font-size: 0.95rem;
	font-weight: 700;
	color: #fff;
	letter-spacing: -0.01em;
}
.prod-plan-name small {
	display: block;
	font-size: 0.75rem;
	color: rgba(255, 255, 255, 0.4);
	margin-top: 0.15rem;
}
.prod-popular-tag {
	display: inline-block;
	font-size: 0.6rem;
	font-weight: 700;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: rgba(255, 255, 255, 0.6);
	border: 1px solid rgba(255, 255, 255, 0.25);
	border-radius: 100px;
	padding: 0.15rem 0.5rem;
	margin-top: 0.35rem;
	font-style: normal;
}
.prod-plan-features {
	list-style: none;
	padding: 0;
	margin: 0;
	display: flex;
	flex-wrap: wrap;
	gap: 0.35rem 1.25rem;
}
.prod-plan-features li {
	font-size: 0.82rem;
	color: rgba(255, 255, 255, 0.55);
	position: relative;
	padding-left: 0.85rem;
}
.prod-plan-features li::before {
	content: "—";
	position: absolute;
	left: 0;
	color: rgba(255, 255, 255, 0.2);
	font-size: 0.7rem;
}
.prod-plan-price {
	text-align: right;
	white-space: nowrap;
}
.prod-price-num {
	display: block;
	font-family: var(--font-display);
	font-size: 1.4rem;
	font-weight: 800;
	color: #fff;
	letter-spacing: -0.03em;
	line-height: 1;
}
.prod-price-period {
	display: block;
	font-size: 0.72rem;
	color: rgba(255, 255, 255, 0.4);
	margin-top: 0.2rem;
}

/* Upcoming Products Section */
.prod-upcoming {
	background: #000;
	padding: 7rem 0;
	border-top: 1px solid rgba(255, 255, 255, 0.07);
}
.prod-upcoming-sub {
	color: rgba(255, 255, 255, 0.5);
	font-size: 0.95rem;
	line-height: 1.7;
	margin: 0;
}
.prod-upcoming-item {
	border-top: 1px solid rgba(255, 255, 255, 0.08);
	padding: 3rem 0;
}
.prod-upcoming-item:last-child {
	border-bottom: 1px solid rgba(255, 255, 255, 0.08);
}
.prod-upcoming-header {
	display: flex;
	align-items: flex-start;
	justify-content: space-between;
	gap: 1.5rem;
	margin-bottom: 2rem;
}
.prod-upcoming-meta {
	display: flex;
	align-items: flex-start;
	gap: 1.25rem;
}
.prod-upcoming-icon {
	font-size: 1.75rem;
	color: rgba(255, 255, 255, 0.5);
	flex-shrink: 0;
	margin-top: 0.1rem;
}
.prod-upcoming-meta > div h3 {
	font-family: var(--font-display);
	font-size: 1.5rem;
	font-weight: 800;
	color: #fff;
	letter-spacing: -0.03em;
	margin-bottom: 0.2rem;
}
.prod-upcoming-meta > div p {
	color: rgba(255, 255, 255, 0.5);
	font-size: 0.92rem;
	margin: 0;
}
.prod-upcoming-features {
	display: grid;
	grid-template-columns: repeat(5, 1fr);
	gap: 0.5rem;
}
.prod-uf-item {
	display: flex;
	align-items: center;
	gap: 0.5rem;
	font-size: 0.82rem;
	color: rgba(255, 255, 255, 0.55);
	padding: 0.6rem 0.75rem;
	background: rgba(255, 255, 255, 0.03);
	border: 1px solid rgba(255, 255, 255, 0.06);
	border-radius: 8px;
}
.prod-uf-item i {
	font-size: 0.8rem;
	color: rgba(255, 255, 255, 0.35);
	flex-shrink: 0;
}

/* Products responsive */
@media (max-width: 991px) {
	.prod-index-grid {
		grid-template-columns: repeat(2, 1fr);
	}
	.prod-index-card:nth-child(2) {
		border-right: none;
	}
	.prod-index-card:nth-child(3) {
		border-right: 1px solid rgba(255, 255, 255, 0.07);
	}
	.prod-index-card:nth-child(1),
	.prod-index-card:nth-child(2) {
		border-bottom: 1px solid rgba(255, 255, 255, 0.07);
	}
	.prod-modules-grid {
		grid-template-columns: repeat(2, 1fr);
	}
	.prod-module:nth-child(3n) {
		border-right: 1px solid rgba(255, 255, 255, 0.07);
	}
	.prod-module:nth-child(2n) {
		border-right: none;
	}
	.prod-module:nth-last-child(-n + 3) {
		border-bottom: 1px solid rgba(255, 255, 255, 0.07);
	}
	.prod-module:nth-last-child(-n + 2) {
		border-bottom: none;
	}
	.prod-upcoming-features {
		grid-template-columns: repeat(3, 1fr);
	}
	.prod-plan-row {
		grid-template-columns: 1fr;
		gap: 0.5rem;
	}
	.prod-plan-price {
		text-align: left;
	}
}
@media (max-width: 767px) {
	.prod-hero {
		padding: 10rem 0 4rem;
	}
	.prod-hero-title {
		font-size: 2.5rem;
	}
	.prod-detail,
	.prod-upcoming {
		padding: 4rem 0;
	}
	.prod-index-grid {
		grid-template-columns: 1fr;
	}
	.prod-index-card {
		border-right: none;
		border-bottom: 1px solid rgba(255, 255, 255, 0.07);
	}
	.prod-index-card:last-child {
		border-bottom: none;
	}
	.prod-modules-grid {
		grid-template-columns: 1fr;
		border: none;
		gap: 0;
	}
	.prod-module {
		border-right: none;
		border-bottom: 1px solid rgba(255, 255, 255, 0.07);
		border-radius: 0;
	}
	.prod-module:last-child {
		border-bottom: none;
	}
	.prod-upcoming-features {
		grid-template-columns: repeat(2, 1fr);
	}
	.prod-upcoming-header {
		flex-direction: column;
	}
	.prod-upcoming-meta {
		flex-wrap: wrap;
	}
}

/* Portfolio Page */
.portfolio-filters,
.blog-categories {
	background: var(--dark-bg);
	border-bottom: 1px solid rgba(255, 255, 255, 0.06);
}

.filter-btn {
	background: rgba(255, 255, 255, 0.05);
	border: 1px solid rgba(255, 255, 255, 0.12);
	color: rgba(255, 255, 255, 0.7);
	padding: 0.5rem 1.5rem;
	border-radius: 25px;
	font-weight: 500;
	transition: all 0.3s ease;
	backdrop-filter: blur(8px);
}

.filter-btn:hover,
.filter-btn.active {
	background: rgba(255, 255, 255, 0.15);
	border-color: var(--neon-blue);
	color: var(--neon-blue);
	box-shadow: 0 0 15px rgba(255, 255, 255, 0.2);
}

.portfolio-card {
	background: var(--glass-bg);
	backdrop-filter: blur(12px);
	border: 1px solid var(--glass-border);
	border-radius: 20px;
	overflow: hidden;
	height: 100%;
	transition: all 0.4s ease;
	color: #fff;
}

.portfolio-card:hover {
	transform: translateY(-10px);
	border-color: rgba(255, 255, 255, 0.4);
	box-shadow:
		0 20px 50px rgba(0, 0, 0, 0.5),
		0 0 30px rgba(255, 255, 255, 0.15);
}

.portfolio-image {
	background: var(--gradient-1);
	height: 200px;
	display: flex;
	align-items: center;
	justify-content: center;
	position: relative;
}

.portfolio-image i {
	font-size: 4rem;
	color: rgba(255, 255, 255, 0.3);
}

.category-badge {
	position: absolute;
	top: 1rem;
	right: 1rem;
}

.portfolio-content {
	padding: 1.5rem;
}

.industry-tag {
	color: var(--neon-cyan);
	font-weight: 600;
	font-size: 0.9rem;
}

.portfolio-desc {
	color: rgba(255, 255, 255, 0.65);
	margin: 1rem 0;
}

.tech-stack {
	display: flex;
	flex-wrap: wrap;
	gap: 0.5rem;
	margin-top: 1rem;
}

.tech-tag {
	background: rgba(255, 255, 255, 0.12);
	border: 1px solid rgba(255, 255, 255, 0.25);
	padding: 0.2rem 0.7rem;
	border-radius: 15px;
	font-size: 0.82rem;
	color: rgba(255, 255, 255, 0.8);
}

.project-stats small {
	display: block;
	color: var(--text-light);
	margin-top: 0.25rem;
}

.case-study-card {
	background: var(--light-bg);
	border-radius: 20px;
	padding: 3rem;
}

.case-image {
	background: var(--gradient-2);
	height: 300px;
	border-radius: 15px;
	display: flex;
	align-items: center;
	justify-content: center;
}

.case-image i {
	font-size: 8rem;
	color: rgba(255, 255, 255, 0.3);
}

.case-details h5 {
	color: var(--primary-color);
	font-weight: 700;
	margin-top: 1.5rem;
	margin-bottom: 0.5rem;
}

.tech-item {
	text-align: center;
	padding: 1.5rem;
	background: var(--light-bg);
	border-radius: 15px;
	transition: all 0.3s ease;
}

.tech-item:hover {
	transform: translateY(-5px);
	box-shadow: var(--shadow-md);
}

.tech-item i {
	font-size: 3rem;
	color: var(--primary-color);
	margin-bottom: 0.5rem;
}

/* Blog Page */
.featured-post {
	background: var(--dark-secondary);
	position: relative;
	overflow: hidden;
}
.featured-post::before {
	content: "";
	position: absolute;
	inset: 0;
	opacity: 0.6;
	pointer-events: none;
}

.featured-card {
	background: var(--glass-bg);
	backdrop-filter: blur(16px);
	border: 1px solid var(--glass-border);
	border-radius: 24px;
	padding: 2rem;
	color: #fff;
	position: relative;
	z-index: 1;
}

.featured-image {
	background: linear-gradient(
		135deg,
		rgba(255, 255, 255, 0.2) 0%,
		rgba(255, 255, 255, 0.2) 100%
	);
	border: 1px solid rgba(255, 255, 255, 0.25);
	height: 300px;
	border-radius: 16px;
	display: flex;
	align-items: center;
	justify-content: center;
}

.featured-image i {
	font-size: 8rem;
	color: var(--neon-purple);
	opacity: 0.55;
	filter: drop-shadow(0 0 25px rgba(255, 255, 255, 0.5));
}

.featured-card h2 {
	color: #fff;
}

.blog-meta {
	color: rgba(255, 255, 255, 0.5);
	font-size: 0.9rem;
	margin: 1rem 0;
}

.blog-meta i {
	margin-right: 0.25rem;
}

.blog-excerpt {
	color: rgba(255, 255, 255, 0.72);
	line-height: 1.8;
	margin-bottom: 1.5rem;
}

.blog-card {
	background: var(--glass-bg);
	backdrop-filter: blur(12px);
	border: 1px solid var(--glass-border);
	border-radius: 20px;
	overflow: hidden;
	height: 100%;
	transition: all 0.35s ease;
	color: #fff;
}

.blog-card:hover {
	transform: translateY(-8px);
	border-color: rgba(255, 255, 255, 0.35);
	box-shadow:
		0 20px 50px rgba(0, 0, 0, 0.5),
		0 0 30px rgba(255, 255, 255, 0.12);
}

.blog-image {
	background: linear-gradient(
		135deg,
		rgba(255, 255, 255, 0.18) 0%,
		rgba(255, 255, 255, 0.18) 100%
	);
	height: 200px;
	display: flex;
	align-items: center;
	justify-content: center;
	position: relative;
}

.blog-image i {
	font-size: 4rem;
	color: var(--neon-blue);
	opacity: 0.6;
	filter: drop-shadow(0 0 12px rgba(255, 255, 255, 0.4));
}

.blog-content {
	padding: 1.5rem;
}

.blog-content h3 {
	font-size: 1.15rem;
	margin-bottom: 0.75rem;
}

.blog-content h3 a {
	color: rgba(255, 255, 255, 0.9);
	transition: color 0.3s ease;
}

.blog-content h3 a:hover {
	color: var(--neon-blue);
}

.read-more {
	color: var(--neon-blue);
	font-weight: 600;
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
	text-shadow: 0 0 8px rgba(255, 255, 255, 0.3);
}

.read-more:hover {
	gap: 0.75rem;
}

.newsletter-section {
	background: var(--dark-bg);
	position: relative;
	overflow: hidden;
}
.newsletter-section::before {
	content: "";
	position: absolute;
	inset: 0;
	opacity: 0.5;
	pointer-events: none;
}

.newsletter-box {
	background: var(--glass-bg);
	backdrop-filter: blur(16px);
	border: 1px solid var(--glass-border-blue);
	padding: 3rem;
	border-radius: 24px;
	position: relative;
	z-index: 1;
	color: #fff;
}
.newsletter-box h3 {
	color: #fff;
}
.newsletter-box p {
	color: rgba(255, 255, 255, 0.65);
}

.newsletter-form .input-group {
	margin-bottom: 0.5rem;
}

/* =========================================================
   Blog Page
   ========================================================= */

/* Blog Hero */
.blg-hero {
	background: #000;
	padding: 14rem 0 5rem;
	position: relative;
	overflow: hidden;
}
.blg-hero::before {
	content: "";
	position: absolute;
	inset: 0;
	opacity: 0.5;
	pointer-events: none;
}
.blg-hero-inner {
	max-width: 780px;
	position: relative;
	z-index: 1;
}
.blg-hero-title {
	font-family: var(--font-display);
	font-size: clamp(2.8rem, 6vw, 5.5rem);
	font-weight: 800;
	line-height: 1.05;
	letter-spacing: -0.04em;
	color: #fff;
	margin-bottom: 1.5rem;
}
.blg-hero-sub {
	font-size: 1.1rem;
	color: rgba(255, 255, 255, 0.5);
	max-width: 540px;
	line-height: 1.75;
	margin: 0;
}

/* Category Filter Strip */
.blg-filter {
	background: #000;
	border-top: 1px solid rgba(255, 255, 255, 0.08);
	border-bottom: 1px solid rgba(255, 255, 255, 0.08);
	padding: 0;
}
.blg-filter-row {
	display: flex;
	flex-wrap: wrap;
	gap: 0.5rem;
	padding: 1rem 0;
}
.blg-filter-btn {
	background: none;
	border: 1px solid rgba(255, 255, 255, 0.18);
	color: rgba(255, 255, 255, 0.45);
	font-family: var(--font-body);
	font-size: 0.8rem;
	font-weight: 600;
	letter-spacing: 0.05em;
	text-transform: uppercase;
	padding: 0.45rem 1.1rem;
	border-radius: 100px;
	cursor: pointer;
	transition:
		border-color 0.25s,
		color 0.25s;
}
.blg-filter-btn:hover {
	border-color: rgba(255, 255, 255, 0.5);
	color: rgba(255, 255, 255, 0.8);
}
.blg-filter-btn.active {
	border-color: #fff;
	color: #fff;
}

/* Featured Post */
.blg-featured {
	background: var(--dark-secondary);
	padding: 5rem 0;
	position: relative;
	overflow: hidden;
}
.blg-featured::before {
	content: "";
	position: absolute;
	inset: 0;
	opacity: 0.35;
	pointer-events: none;
}
.blg-featured-inner {
	display: grid;
	grid-template-columns: 220px 1fr;
	gap: 4rem;
	position: relative;
	z-index: 1;
	align-items: start;
}
.blg-featured-label {
	padding-top: 0.25rem;
}
.blg-featured-title {
	font-family: var(--font-display);
	font-size: clamp(1.7rem, 3.5vw, 2.8rem);
	font-weight: 800;
	line-height: 1.1;
	letter-spacing: -0.03em;
	color: #fff;
	margin-bottom: 1.25rem;
}
.blg-featured-excerpt {
	font-size: 1.05rem;
	color: rgba(255, 255, 255, 0.55);
	line-height: 1.75;
	margin-bottom: 2rem;
}
.blg-featured-foot {
	display: flex;
	align-items: center;
	gap: 2rem;
	flex-wrap: wrap;
}
.blg-cat-tag {
	display: inline-block;
	font-size: 0.72rem;
	font-weight: 700;
	letter-spacing: 0.1em;
	text-transform: uppercase;
	color: rgba(255, 255, 255, 0.5);
	border: 1px solid rgba(255, 255, 255, 0.2);
	padding: 0.2rem 0.7rem;
	border-radius: 100px;
	margin-top: 0.75rem;
}
.blg-meta {
	font-size: 0.85rem;
	color: rgba(255, 255, 255, 0.4);
}
.blg-read-link {
	font-size: 0.88rem;
	font-weight: 600;
	color: #fff;
	display: inline-flex;
	align-items: center;
	gap: 0.4rem;
	text-decoration: none;
	transition:
		gap 0.25s,
		color 0.25s;
}
.blg-read-link:hover {
	gap: 0.7rem;
	color: rgba(255, 255, 255, 0.75);
}

/* Blog Grid */
.blg-grid {
	background: #000;
	padding: 5rem 0 6rem;
}
.blg-post-card {
	background: rgba(255, 255, 255, 0.03);
	border: 1px solid rgba(255, 255, 255, 0.08);
	border-radius: 16px;
	overflow: hidden;
	height: 100%;
	display: flex;
	flex-direction: column;
	transition:
		border-color 0.3s,
		background 0.3s;
}
.blg-post-card:hover {
	border-color: rgba(255, 255, 255, 0.2);
	background: rgba(255, 255, 255, 0.05);
}
.blg-post-top {
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding: 1.25rem 1.5rem 0;
}
.blg-post-num {
	font-family: var(--font-display);
	font-size: 0.75rem;
	font-weight: 700;
	color: rgba(255, 255, 255, 0.18);
	letter-spacing: 0.08em;
}
.blg-post-body {
	padding: 1rem 1.5rem 1.5rem;
	flex: 1;
	display: flex;
	flex-direction: column;
}
.blg-post-title {
	font-family: var(--font-display);
	font-size: 1.05rem;
	font-weight: 700;
	line-height: 1.35;
	margin: 0.6rem 0 0.5rem;
}
.blg-post-title a {
	color: rgba(255, 255, 255, 0.9);
	text-decoration: none;
	transition: color 0.25s;
}
.blg-post-title a:hover {
	color: #fff;
}
.blg-post-meta {
	font-size: 0.8rem;
	color: rgba(255, 255, 255, 0.35);
	margin-bottom: 0.75rem;
}
.blg-post-excerpt {
	font-size: 0.9rem;
	color: rgba(255, 255, 255, 0.5);
	line-height: 1.7;
	flex: 1;
	margin-bottom: 1.25rem;
}
.blg-post-link {
	font-size: 0.82rem;
	font-weight: 600;
	color: rgba(255, 255, 255, 0.5);
	text-decoration: none;
	display: inline-flex;
	align-items: center;
	gap: 0.35rem;
	transition:
		color 0.25s,
		gap 0.25s;
	margin-top: auto;
}
.blg-post-link:hover {
	color: #fff;
	gap: 0.6rem;
}

/* Newsletter */
.blg-newsletter {
	background: var(--dark-secondary);
	border-top: 1px solid rgba(255, 255, 255, 0.07);
	padding: 5rem 0;
	position: relative;
	overflow: hidden;
}
.blg-newsletter::before {
	content: "";
	position: absolute;
	inset: 0;
	opacity: 0.3;
	pointer-events: none;
}
.blg-nl-inner {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: 4rem;
	align-items: center;
	position: relative;
	z-index: 1;
}
.blg-nl-title {
	font-family: var(--font-display);
	font-size: 2rem;
	font-weight: 800;
	color: #fff;
	margin: 0.5rem 0 0.75rem;
}
.blg-nl-sub {
	font-size: 0.95rem;
	color: rgba(255, 255, 255, 0.45);
	line-height: 1.7;
	margin: 0;
}
.blg-nl-input-row {
	display: flex;
	gap: 0;
	border: 1px solid rgba(255, 255, 255, 0.15);
	border-radius: 8px;
	overflow: hidden;
	margin-bottom: 0.75rem;
}
.blg-nl-input {
	flex: 1;
	background: rgba(255, 255, 255, 0.04);
	border: none;
	color: #fff;
	font-family: var(--font-body);
	font-size: 0.9rem;
	padding: 0.8rem 1rem;
	outline: none;
}
.blg-nl-input::placeholder {
	color: rgba(255, 255, 255, 0.28);
}
.blg-nl-btn {
	background: #fff;
	border: none;
	color: #000;
	font-family: var(--font-body);
	font-size: 0.88rem;
	font-weight: 700;
	padding: 0.8rem 1.5rem;
	cursor: pointer;
	transition: background 0.25s;
	white-space: nowrap;
}
.blg-nl-btn:hover {
	background: rgba(255, 255, 255, 0.88);
}
.blg-nl-note {
	font-size: 0.78rem;
	color: rgba(255, 255, 255, 0.25);
	margin: 0;
}

/* Blog Page Responsive */
@media (max-width: 768px) {
	.blg-hero {
		padding: 10rem 0 4rem;
	}
	.blg-hero-title {
		font-size: 2.4rem;
	}
	.blg-featured-inner {
		grid-template-columns: 1fr;
		gap: 2rem;
	}
	.blg-nl-inner {
		grid-template-columns: 1fr;
		gap: 2.5rem;
	}
}

/* Contact Page */
.contact-section {
	background: var(--dark-bg);
	position: relative;
	overflow: hidden;
}
.contact-section::before {
	content: "";
	position: absolute;
	inset: 0;
	opacity: 0.6;
	pointer-events: none;
}
.contact-section h2 {
	color: #fff;
}

.contact-form-container {
	background: var(--glass-bg);
	backdrop-filter: blur(16px) saturate(160%);
	-webkit-backdrop-filter: blur(16px) saturate(160%);
	border: 1px solid var(--glass-border);
	padding: 2.5rem;
	border-radius: 24px;
	position: relative;
	z-index: 1;
}

.contact-form-container h2 {
	background: linear-gradient(135deg, #fff 0%, var(--neon-blue) 100%);
	-webkit-background-clip: text;
	-webkit-text-fill-color: transparent;
	background-clip: text;
}

.contact-info {
	background: var(--glass-bg);
	backdrop-filter: blur(16px);
	-webkit-backdrop-filter: blur(16px);
	border: 1px solid var(--glass-border);
	padding: 2.5rem;
	border-radius: 24px;
	position: relative;
	z-index: 1;
	color: #fff;
}

.contact-info h2 {
	background: linear-gradient(135deg, #fff 0%, var(--neon-cyan) 100%);
	-webkit-background-clip: text;
	-webkit-text-fill-color: transparent;
	background-clip: text;
}

/* Status bar */
.contact-status-bar {
	display: flex;
	align-items: center;
	gap: 0.6rem;
	background: rgba(255, 255, 255, 0.08);
	border: 1px solid rgba(255, 255, 255, 0.25);
	border-radius: 50px;
	padding: 0.45rem 1rem;
	font-size: 0.82rem;
	color: rgba(255, 255, 255, 0.75);
}

.status-pulse {
	width: 8px;
	height: 8px;
	border-radius: 50%;
	background: #a3a3a3;
	flex-shrink: 0;
	box-shadow: 0 0 0 0 rgba(255, 255, 255, 0.5);
	animation: pulse-ring 1.8s ease-out infinite;
}

@keyframes pulse-ring {
	0% {
		box-shadow: 0 0 0 0 rgba(255, 255, 255, 0.55);
	}
	70% {
		box-shadow: 0 0 0 8px rgba(255, 255, 255, 0);
	}
	100% {
		box-shadow: 0 0 0 0 rgba(255, 255, 255, 0);
	}
}

/* Info tiles — full-width row style */
.info-tile {
	display: flex;
	gap: 1rem;
	align-items: flex-start;
	background: rgba(255, 255, 255, 0.04);
	border: 1px solid rgba(255, 255, 255, 0.08);
	border-left: 3px solid var(--tc, var(--neon-blue));
	border-radius: 14px;
	padding: 1rem 1.1rem;
	transition:
		background 0.25s ease,
		box-shadow 0.25s ease;
}

.info-tile:hover {
	background: rgba(255, 255, 255, 0.07);
	box-shadow: 0 4px 24px rgba(0, 0, 0, 0.25);
}

.info-tile-icon {
	width: 42px;
	height: 42px;
	border-radius: 12px;
	background: rgba(255, 255, 255, 0.06);
	border: 1px solid rgba(255, 255, 255, 0.1);
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
}

.info-tile-icon i {
	font-size: 1.1rem;
	color: var(--tc, var(--neon-blue));
	filter: drop-shadow(0 0 5px var(--tc, var(--neon-blue)));
}

.info-tile-body h6 {
	font-size: 0.75rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.07em;
	color: rgba(255, 255, 255, 0.45);
	margin-bottom: 0.35rem;
}

.info-tile-body p {
	margin: 0 0 0.4rem;
	color: rgba(255, 255, 255, 0.82);
	font-size: 0.9rem;
	line-height: 1.5;
}

.info-tile-body p:last-child {
	margin-bottom: 0;
}

.info-tile-body p a {
	color: var(--tc, var(--neon-blue));
	text-decoration: none;
	display: block;
	font-weight: 500;
}

.info-tile-body p a:hover {
	text-shadow: 0 0 8px var(--tc, var(--neon-blue));
}

.info-tile-body p em {
	display: block;
	font-style: normal;
	font-size: 0.75rem;
	color: rgba(255, 255, 255, 0.35);
}

/* Small square info tiles (phone) */
.info-tile-sm {
	background: rgba(255, 255, 255, 0.04);
	border: 1px solid rgba(255, 255, 255, 0.08);
	border-radius: 14px;
	padding: 1rem;
	text-align: center;
	transition: background 0.25s ease;
}

.info-tile-sm:hover {
	background: rgba(255, 255, 255, 0.07);
}

.info-tile-sm .info-tile-icon {
	width: 38px;
	height: 38px;
	border-radius: 10px;
	margin: 0 auto 0.5rem;
}

.info-tile-sm h6 {
	font-size: 0.72rem;
	text-transform: uppercase;
	letter-spacing: 0.07em;
	color: rgba(255, 255, 255, 0.4);
	margin-bottom: 0.25rem;
}

.info-tile-sm a {
	font-size: 0.82rem;
	font-weight: 600;
	color: rgba(255, 255, 255, 0.8);
	text-decoration: none;
	display: block;
}

.info-tile-sm a:hover {
	color: var(--neon-blue);
}

/* Office hours */
.office-hours {
	background: rgba(255, 255, 255, 0.03);
	border: 1px solid rgba(255, 255, 255, 0.07);
	border-radius: 14px;
	padding: 1rem 1.2rem;
}

.oh-title {
	font-size: 0.72rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.08em;
	color: rgba(255, 255, 255, 0.4);
	margin-bottom: 0.8rem;
}

.oh-grid {
	display: flex;
	gap: 0.3rem;
	margin-bottom: 0.75rem;
}

.oh-day {
	flex: 1;
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 0.35rem;
}

.day-abbr {
	font-size: 0.65rem;
	font-weight: 600;
	text-transform: uppercase;
	letter-spacing: 0.04em;
	color: rgba(255, 255, 255, 0.45);
}

.day-bar {
	width: 100%;
	height: 28px;
	border-radius: 6px;
}

.oh-day.open .day-bar {
	background: rgba(255, 255, 255, 0.3);
	border: 1px solid rgba(255, 255, 255, 0.45);
}
.oh-day.half .day-bar {
	background: rgba(255, 255, 255, 0.2);
	border: 1px solid rgba(255, 255, 255, 0.4);
}
.oh-day.closed .day-bar {
	background: rgba(255, 255, 255, 0.05);
	border: 1px solid rgba(255, 255, 255, 0.08);
}

.oh-day.open .day-abbr {
	color: rgba(255, 255, 255, 0.75);
}
.oh-day.half .day-abbr {
	color: rgba(255, 255, 255, 0.75);
}

.oh-legend {
	display: flex;
	gap: 1rem;
	flex-wrap: wrap;
}

.oh-legend span {
	display: flex;
	align-items: center;
	gap: 0.35rem;
	font-size: 0.72rem;
	color: rgba(255, 255, 255, 0.45);
}

.legend-dot {
	width: 8px;
	height: 8px;
	border-radius: 3px;
	flex-shrink: 0;
}

.legend-dot.open {
	background: rgba(255, 255, 255, 0.7);
}
.legend-dot.half {
	background: rgba(255, 255, 255, 0.7);
}
.legend-dot.closed {
	background: rgba(255, 255, 255, 0.2);
}

/* Dark form controls */
.contact-section .form-control,
.contact-section .form-select {
	background: rgba(255, 255, 255, 0.06);
	border: 1px solid rgba(255, 255, 255, 0.12);
	color: #fff;
	border-radius: 10px;
}
.contact-section .form-control:focus,
.contact-section .form-select:focus {
	background: rgba(255, 255, 255, 0.1);
	border-color: var(--neon-blue);
	color: #fff;
	box-shadow: 0 0 0 3px rgba(255, 255, 255, 0.15);
}
.contact-section .form-control::placeholder {
	color: rgba(255, 255, 255, 0.3);
}
.contact-section .form-select option {
	background: var(--dark-secondary);
	color: #fff;
}
.contact-section .form-label {
	color: rgba(255, 255, 255, 0.8);
	font-size: 0.9rem;
}
.contact-section .form-check-label {
	color: rgba(255, 255, 255, 0.65);
}
.contact-section .form-check-label a {
	color: var(--neon-blue);
}
.contact-section .form-check-input {
	background-color: rgba(255, 255, 255, 0.06);
	border-color: rgba(255, 255, 255, 0.2);
}
.contact-section .form-check-input:checked {
	background-color: var(--neon-blue);
	border-color: var(--neon-blue);
}

.info-item {
	display: flex;
	gap: 1.5rem;
	margin-bottom: 2rem;
}

.info-icon {
	width: 50px;
	height: 50px;
	background: rgba(255, 255, 255, 0.12);
	border: 1px solid rgba(255, 255, 255, 0.3);
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
	transition: all 0.3s ease;
}
.info-icon:hover {
	background: rgba(255, 255, 255, 0.22);
	box-shadow: 0 0 16px rgba(255, 255, 255, 0.35);
}

.info-icon i {
	font-size: 1.3rem;
	color: var(--neon-blue);
	filter: drop-shadow(0 0 4px rgba(255, 255, 255, 0.5));
}

.info-content h5 {
	font-weight: 700;
	margin-bottom: 0.25rem;
	color: #fff;
}
.info-content p {
	color: rgba(255, 255, 255, 0.65);
	margin: 0;
}

.info-content a {
	color: var(--neon-blue);
}

.info-content a:hover {
	text-shadow: 0 0 8px rgba(255, 255, 255, 0.4);
}

.social-links-large {
	display: flex;
	gap: 1rem;
}

.social-link {
	width: 48px;
	height: 48px;
	background: rgba(255, 255, 255, 0.06);
	border: 1px solid rgba(255, 255, 255, 0.12);
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	color: rgba(255, 255, 255, 0.7);
	transition: all 0.3s ease;
}

.social-link:hover {
	background: rgba(from var(--sb) r g b / 0.18);
	border-color: var(--sb, var(--neon-blue));
	color: var(--sb, var(--neon-blue));
	box-shadow: 0 0 16px rgba(from var(--sb) r g b / 0.35);
	transform: translateY(-3px);
}

.map-placeholder {
	height: 400px;
	background: var(--dark-secondary);
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	color: rgba(255, 255, 255, 0.5);
	position: relative;
	overflow: hidden;
}
.map-placeholder::before {
	content: "";
	position: absolute;
	inset: 0;
	opacity: 0.5;
}

.map-placeholder i {
	font-size: 5rem;
	margin-bottom: 1rem;
	color: var(--neon-blue);
	filter: drop-shadow(0 0 20px rgba(255, 255, 255, 0.4));
	position: relative;
	z-index: 1;
}
.map-placeholder p,
.map-placeholder small {
	position: relative;
	z-index: 1;
}

.social-connect h5 {
	color: rgba(255, 255, 255, 0.85);
	font-family: var(--font-display);
	font-size: 0.85rem;
	letter-spacing: 0.06em;
	text-transform: uppercase;
}

.social-links-large {
	display: flex;
	gap: 0.75rem;
	flex-wrap: wrap;
}

.cta-option-card {
	background: #fff;
	padding: 2rem;
	border-radius: 15px;
	text-align: center;
	height: 100%;
	transition: all 0.3s ease;
}

.cta-option-card:hover {
	transform: translateY(-5px);
	box-shadow: var(--shadow-lg);
}

.cta-icon {
	font-size: 3rem;
	color: var(--primary-color);
	margin-bottom: 1rem;
}

/* Demo Page */
.demo-intro {
	background: var(--light-bg);
	padding: 3rem 2rem;
	border-radius: 20px;
}

.demo-icon {
	font-size: 5rem;
	color: var(--primary-color);
	margin-bottom: 1rem;
}

.steps-container {
	display: flex;
	justify-content: center;
	align-items: center;
	gap: 1rem;
	flex-wrap: wrap;
}

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

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

.step-divider {
	font-size: 2rem;
	color: var(--primary-light);
	font-weight: 700;
}

.demo-form-container {
	background: #fff;
	padding: 3rem;
	border-radius: 20px;
	box-shadow: var(--shadow-md);
}

.form-section .section-title {
	font-size: 1.5rem;
	color: var(--primary-color);
	margin-bottom: 1.5rem;
	padding-bottom: 0.5rem;
	border-bottom: 2px solid var(--border-color);
}

.expect-card {
	background: var(--light-bg);
	padding: 2rem;
	border-radius: 15px;
	text-align: center;
	height: 100%;
}

.expect-icon {
	font-size: 3rem;
	color: var(--primary-color);
	margin-bottom: 1rem;
}

.contact-box {
	background: var(--light-bg);
	padding: 2.5rem;
	border-radius: 20px;
}

.contact-options {
	display: flex;
	gap: 2rem;
	margin-top: 1.5rem;
	flex-wrap: wrap;
}

.contact-option {
	display: flex;
	align-items: center;
	gap: 1rem;
	color: var(--primary-color);
	font-weight: 600;
	font-size: 1.1rem;
}

.contact-option i {
	font-size: 1.5rem;
}

/* =========================================================
   Demo Page
   ========================================================= */

/* Demo Hero */
.dmo-hero {
	background: #000;
	padding: 14rem 0 5rem;
	position: relative;
	overflow: hidden;
}
.dmo-hero::before {
	content: "";
	position: absolute;
	inset: 0;
	opacity: 0.5;
	pointer-events: none;
}
.dmo-hero-inner {
	max-width: 760px;
	position: relative;
	z-index: 1;
}
.dmo-hero-title {
	font-family: var(--font-display);
	font-size: clamp(2.8rem, 6vw, 5.5rem);
	font-weight: 800;
	line-height: 1.05;
	letter-spacing: -0.04em;
	color: #fff;
	margin-bottom: 1.5rem;
}
.dmo-hero-sub {
	font-size: 1.1rem;
	color: rgba(255, 255, 255, 0.5);
	max-width: 500px;
	line-height: 1.75;
	margin: 0;
}

/* Demo Form Section */
.dmo-form-section {
	background: #000;
	border-top: 1px solid rgba(255, 255, 255, 0.07);
	padding: 5rem 0 6rem;
	position: relative;
	overflow: hidden;
}
.dmo-form-section::before {
	content: "";
	position: absolute;
	inset: 0;
	opacity: 0.35;
	pointer-events: none;
}
.dmo-form-steps {
	display: flex;
	align-items: center;
	gap: 1.5rem;
	margin-bottom: 3.5rem;
	flex-wrap: wrap;
	position: relative;
	z-index: 1;
}
.dmo-step {
	display: flex;
	align-items: center;
	gap: 0.75rem;
}
.dmo-step-num {
	font-family: var(--font-display);
	font-size: 0.72rem;
	font-weight: 700;
	letter-spacing: 0.1em;
	color: rgba(255, 255, 255, 0.25);
}
.dmo-step-label {
	font-size: 0.88rem;
	font-weight: 600;
	color: rgba(255, 255, 255, 0.55);
}
.dmo-step-arrow {
	color: rgba(255, 255, 255, 0.18);
	font-size: 0.9rem;
}
.dmo-form-wrap {
	background: rgba(255, 255, 255, 0.03);
	border: 1px solid rgba(255, 255, 255, 0.1);
	border-radius: 20px;
	padding: 3rem;
	position: relative;
	z-index: 1;
}
.dmo-form-wrap .form-label {
	color: rgba(255, 255, 255, 0.65);
	font-size: 0.85rem;
	font-weight: 600;
	margin-bottom: 0.4rem;
}
.dmo-form-wrap .form-control,
.dmo-form-wrap .form-select {
	background: rgba(255, 255, 255, 0.05);
	border: 1px solid rgba(255, 255, 255, 0.12);
	color: #fff;
	border-radius: 8px;
}
.dmo-form-wrap .form-control:focus,
.dmo-form-wrap .form-select:focus {
	background: rgba(255, 255, 255, 0.07);
	border-color: rgba(255, 255, 255, 0.35);
	box-shadow: none;
	color: #fff;
}
.dmo-form-wrap .form-control::placeholder {
	color: rgba(255, 255, 255, 0.25);
}
.dmo-form-wrap .form-select option {
	background: #1a1a1a;
	color: #fff;
}
.dmo-form-wrap .form-check-label {
	color: rgba(255, 255, 255, 0.55);
	font-size: 0.88rem;
}
.dmo-form-wrap .form-check-input {
	background-color: rgba(255, 255, 255, 0.06);
	border-color: rgba(255, 255, 255, 0.2);
}
.dmo-form-wrap .form-check-input:checked {
	background-color: #fff;
	border-color: #fff;
}
.dmo-form-wrap .form-section {
	border-top: 1px solid rgba(255, 255, 255, 0.08);
	padding-top: 2rem;
	margin-top: 2rem;
}
.dmo-form-wrap .form-section:first-child {
	border-top: none;
	padding-top: 0;
	margin-top: 0;
}
.dmo-form-wrap .form-section .section-title {
	font-family: var(--font-display);
	font-size: 0.72rem;
	font-weight: 700;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	color: rgba(255, 255, 255, 0.35);
	border-bottom: none;
	margin-bottom: 1.25rem;
	padding-bottom: 0;
}
.dmo-form-wrap .text-muted small {
	color: rgba(255, 255, 255, 0.3) !important;
}
.dmo-form-wrap a {
	color: rgba(255, 255, 255, 0.55);
}
.dmo-form-wrap a:hover {
	color: #fff;
}

/* What to Expect */
.dmo-expect {
	background: var(--dark-secondary);
	border-top: 1px solid rgba(255, 255, 255, 0.07);
	padding: 6rem 0;
	position: relative;
	overflow: hidden;
}
.dmo-expect::before {
	content: "";
	position: absolute;
	inset: 0;
	opacity: 0.3;
	pointer-events: none;
}
.dmo-expect-inner {
	display: grid;
	grid-template-columns: 260px 1fr;
	gap: 5rem;
	align-items: start;
	position: relative;
	z-index: 1;
}
.dmo-expect-head {
	padding-top: 0.25rem;
	min-width: 0;
}
.dmo-expect-title {
	font-family: var(--font-display);
	font-size: clamp(1.8rem, 3.5vw, 3rem);
	font-weight: 800;
	line-height: 1.1;
	letter-spacing: -0.03em;
	color: #fff;
	margin: 0;
}
.dmo-expect-grid {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 0;
}
.dmo-expect-item {
	padding: 2rem;
	border-top: 1px solid rgba(255, 255, 255, 0.08);
	border-right: 1px solid rgba(255, 255, 255, 0.08);
	transition: background 0.25s;
}
.dmo-expect-item:nth-child(2n) {
	border-right: none;
}
.dmo-expect-item:nth-child(1),
.dmo-expect-item:nth-child(2) {
	border-top: none;
}
.dmo-expect-item:hover {
	background: rgba(255, 255, 255, 0.03);
}
.dmo-expect-num {
	font-family: var(--font-display);
	font-size: 0.72rem;
	font-weight: 700;
	letter-spacing: 0.1em;
	color: rgba(255, 255, 255, 0.2);
	display: block;
	margin-bottom: 0.8rem;
}
.dmo-expect-name {
	font-family: var(--font-display);
	font-size: 1.05rem;
	font-weight: 700;
	color: #fff;
	margin-bottom: 0.5rem;
}
.dmo-expect-desc {
	font-size: 0.875rem;
	color: rgba(255, 255, 255, 0.45);
	line-height: 1.7;
	margin: 0;
}

/* Demo Testimonials */
.dmo-testimonials {
	background: #000;
	border-top: 1px solid rgba(255, 255, 255, 0.07);
	padding: 6rem 0;
	position: relative;
	overflow: hidden;
}
.dmo-testimonials::before {
	content: "";
	position: absolute;
	inset: 0;
	opacity: 0.3;
	pointer-events: none;
}
.dmo-testimonials-head {
	margin-bottom: 3.5rem;
	position: relative;
	z-index: 1;
}
.dmo-testimonials-title {
	font-family: var(--font-display);
	font-size: clamp(1.8rem, 3.5vw, 3rem);
	font-weight: 800;
	letter-spacing: -0.03em;
	color: #fff;
	margin: 0.5rem 0 0;
}
.dmo-testimonials .row {
	position: relative;
	z-index: 1;
}

/* Demo Contact Strip */
.dmo-contact-strip {
	background: var(--dark-secondary);
	border-top: 1px solid rgba(255, 255, 255, 0.07);
	padding: 5rem 0;
	position: relative;
	overflow: hidden;
}
.dmo-contact-strip::before {
	content: "";
	position: absolute;
	inset: 0;
	opacity: 0.25;
	pointer-events: none;
}
.dmo-cs-inner {
	display: flex;
	align-items: center;
	justify-content: space-between;
	gap: 3rem;
	flex-wrap: wrap;
	position: relative;
	z-index: 1;
}
.dmo-cs-title {
	font-family: var(--font-display);
	font-size: 1.6rem;
	font-weight: 800;
	color: #fff;
	margin: 0.5rem 0 0.5rem;
}
.dmo-cs-sub {
	font-size: 0.9rem;
	color: rgba(255, 255, 255, 0.4);
	margin-bottom: 1.5rem;
}
.dmo-cs-links {
	display: flex;
	gap: 2.5rem;
	flex-wrap: wrap;
}
.dmo-cs-link {
	display: inline-flex;
	align-items: center;
	gap: 0.5rem;
	font-size: 0.95rem;
	font-weight: 600;
	color: rgba(255, 255, 255, 0.6);
	text-decoration: none;
	transition: color 0.25s;
}
.dmo-cs-link:hover {
	color: #fff;
}
.dmo-cs-cta {
	font-size: 0.9rem;
	white-space: nowrap;
}

/* Demo Page Responsive */
@media (max-width: 992px) {
	.dmo-expect-inner {
		grid-template-columns: 1fr;
		gap: 2.5rem;
	}
}
@media (max-width: 576px) {
	.dmo-hero {
		padding: 10rem 0 4rem;
	}
	.dmo-hero-title {
		font-size: 2.4rem;
	}
	.dmo-form-wrap {
		padding: 2rem 1.5rem;
	}
	.dmo-expect-grid {
		grid-template-columns: 1fr;
	}
	.dmo-expect-item {
		border-right: none;
	}
	.dmo-expect-item:nth-child(2) {
		border-top: 1px solid rgba(255, 255, 255, 0.08);
	}
	.dmo-cs-inner {
		flex-direction: column;
		align-items: flex-start;
	}
}

/* =========================================================
   Contact Page — CTA & FAQ
   ========================================================= */

/* Contact CTA */
.cnt-cta {
	background: var(--dark-secondary);
	border-top: 1px solid rgba(255, 255, 255, 0.07);
	padding: 6rem 0;
	position: relative;
	overflow: hidden;
}
.cnt-cta::before {
	content: "";
	position: absolute;
	inset: 0;
	opacity: 0.3;
	pointer-events: none;
}
.cnt-cta-head {
	position: relative;
	z-index: 1;
	margin-bottom: 4rem;
	max-width: 500px;
}
.cnt-cta-title {
	font-family: var(--font-display);
	font-size: clamp(2rem, 4vw, 3.5rem);
	font-weight: 800;
	line-height: 1.08;
	letter-spacing: -0.035em;
	color: #fff;
	margin: 0.5rem 0 0;
}
.cnt-cta-grid {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	border-top: 1px solid rgba(255, 255, 255, 0.08);
	position: relative;
	z-index: 1;
}
.cnt-cta-item {
	padding: 2.5rem 2rem 2.5rem 0;
	border-right: 1px solid rgba(255, 255, 255, 0.08);
	display: flex;
	flex-direction: column;
	gap: 0;
	transition: background 0.25s;
}
.cnt-cta-item:last-child {
	border-right: none;
}
.cnt-cta-item:first-child {
	padding-left: 0;
}
.cnt-cta-item:hover {
	background: rgba(255, 255, 255, 0.02);
}
.cnt-cta-num {
	font-family: var(--font-display);
	font-size: 0.72rem;
	font-weight: 700;
	letter-spacing: 0.1em;
	color: rgba(255, 255, 255, 0.2);
	display: block;
	margin-bottom: 1.1rem;
}
.cnt-cta-name {
	font-family: var(--font-display);
	font-size: 1.1rem;
	font-weight: 700;
	color: #fff;
	margin-bottom: 0.6rem;
}
.cnt-cta-desc {
	font-size: 0.875rem;
	color: rgba(255, 255, 255, 0.45);
	line-height: 1.7;
	flex: 1;
	margin-bottom: 1.5rem;
}

/* Contact FAQ */
.cnt-faq {
	background: #000;
	border-top: 1px solid rgba(255, 255, 255, 0.07);
	padding: 6rem 0;
	position: relative;
	overflow: hidden;
}
.cnt-faq::before {
	content: "";
	position: absolute;
	inset: 0;
	opacity: 0.35;
	pointer-events: none;
}
.cnt-faq-inner {
	display: grid;
	grid-template-columns: 300px 1fr;
	gap: 6rem;
	align-items: start;
	position: relative;
	z-index: 1;
}
.cnt-faq-head {
	padding-top: 0.5rem;
	min-width: 0;
}
.cnt-faq-title {
	font-family: var(--font-display);
	font-size: clamp(1.8rem, 3vw, 2.8rem);
	font-weight: 800;
	line-height: 1.1;
	letter-spacing: -0.03em;
	color: #fff;
	margin: 0.5rem 0 0;
}
.cnt-faq-list {
	display: flex;
	flex-direction: column;
}
.cnt-faq-item {
	border-top: 1px solid rgba(255, 255, 255, 0.08);
	padding: 0;
}
.cnt-faq-item:last-child {
	border-bottom: 1px solid rgba(255, 255, 255, 0.08);
}
.cnt-faq-q {
	list-style: none;
	font-family: var(--font-display);
	font-size: 1rem;
	font-weight: 700;
	color: rgba(255, 255, 255, 0.85);
	padding: 1.5rem 2rem 1.5rem 0;
	cursor: pointer;
	display: flex;
	align-items: center;
	justify-content: space-between;
	position: relative;
	user-select: none;
	transition: color 0.25s;
}
.cnt-faq-q::after {
	content: "+";
	font-size: 1.25rem;
	font-weight: 300;
	color: rgba(255, 255, 255, 0.3);
	flex-shrink: 0;
	margin-left: 1rem;
	transition:
		transform 0.25s,
		color 0.25s;
}
.cnt-faq-item[open] .cnt-faq-q {
	color: #fff;
}
.cnt-faq-item[open] .cnt-faq-q::after {
	content: "\2212";
	color: rgba(255, 255, 255, 0.5);
}
.cnt-faq-q::-webkit-details-marker {
	display: none;
}
.cnt-faq-a {
	font-size: 0.93rem;
	color: rgba(255, 255, 255, 0.5);
	line-height: 1.75;
	padding: 0 2rem 1.75rem 0;
	margin: 0;
}

/* Contact responsive */
@media (max-width: 992px) {
	.cnt-cta-grid {
		grid-template-columns: repeat(2, 1fr);
	}
	.cnt-cta-item:nth-child(2) {
		border-right: none;
	}
	.cnt-cta-item:nth-child(3) {
		padding-left: 0;
		border-right: 1px solid rgba(255, 255, 255, 0.08);
	}
	.cnt-faq-inner {
		grid-template-columns: 1fr;
		gap: 3rem;
	}
}
@media (max-width: 576px) {
	.cnt-cta-grid {
		grid-template-columns: 1fr;
	}
	.cnt-cta-item {
		border-right: none;
		padding-left: 0;
		padding-right: 0;
	}
}

/* Product Detail Page Styles */
.product-detail-header {
	background: var(--dark-bg);
	color: #fff;
	padding: 150px 0 80px;
}

.breadcrumb {
	background: transparent;
	padding: 0;
	margin: 0;
}

.breadcrumb-item a {
	color: rgba(255, 255, 255, 0.7);
}

.breadcrumb-item.active {
	color: rgba(255, 255, 255, 0.5);
}

.product-tagline {
	font-size: 1.2rem;
	color: rgba(255, 255, 255, 0.9);
}

.product-meta {
	display: flex;
	flex-wrap: wrap;
	gap: 2rem;
	color: rgba(255, 255, 255, 0.8);
}

.meta-item {
	display: flex;
	align-items: center;
	gap: 0.5rem;
}

.product-ctas {
	display: flex;
	gap: 1rem;
	flex-wrap: wrap;
}

.product-hero-image {
	position: relative;
}

.product-screenshot {
	background: var(--gradient-1);
	border-radius: 20px;
	padding: 3rem;
	display: flex;
	align-items: center;
	justify-content: center;
	min-height: 400px;
	position: relative;
}

.product-screenshot i {
	font-size: 8rem;
	color: rgba(255, 255, 255, 0.3);
}

.screenshot-badge {
	position: absolute;
	background: rgba(255, 255, 255, 0.95);
	padding: 1rem 1.5rem;
	border-radius: 15px;
	box-shadow: var(--shadow-lg);
	display: flex;
	align-items: center;
	gap: 0.75rem;
	font-weight: 600;
	color: var(--text-dark);
}

.screenshot-badge i {
	font-size: 1.5rem;
	color: var(--primary-color);
}

.badge-1 {
	top: 10%;
	left: -10%;
}

.badge-2 {
	top: 40%;
	right: -10%;
}

.badge-3 {
	bottom: 10%;
	left: 10%;
}

.quick-stats {
	background: var(--light-bg);
}

.stat-box {
	background: #fff;
	padding: 2rem;
	border-radius: 15px;
	transition: all 0.3s ease;
}

.stat-box:hover {
	transform: translateY(-5px);
	box-shadow: var(--shadow-lg);
}

.stat-box i {
	font-size: 3rem;
	color: var(--primary-color);
	margin-bottom: 1rem;
}

.stat-box h3 {
	font-size: 2.5rem;
	font-weight: 700;
	color: var(--primary-color);
	margin-bottom: 0.5rem;
}

.overview-card {
	background: #fff;
	padding: 2rem;
	border-radius: 15px;
	height: 100%;
	border: 2px solid var(--border-color);
	transition: all 0.3s ease;
}

.overview-card:hover {
	border-color: var(--primary-color);
	box-shadow: var(--shadow-md);
}

.overview-icon {
	width: 70px;
	height: 70px;
	background: rgba(0, 0, 0, 0.1);
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	margin-bottom: 1.5rem;
}

.overview-icon i {
	font-size: 2rem;
	color: var(--primary-color);
}

.feature-list-compact {
	list-style: none;
	padding: 0;
	margin-top: 1rem;
}

.feature-list-compact li {
	padding-left: 1.5rem;
	margin-bottom: 0.5rem;
	position: relative;
}

.feature-list-compact li::before {
	content: "✓";
	position: absolute;
	left: 0;
	color: var(--success);
	font-weight: 700;
}

.feature-module {
	background: var(--light-bg);
	padding: 2rem;
	border-radius: 15px;
	height: 100%;
}

.feature-module h4 {
	color: var(--primary-color);
	margin-bottom: 1.5rem;
	padding-bottom: 1rem;
	border-bottom: 2px solid var(--border-color);
}

.feature-module ul {
	list-style: none;
	padding: 0;
}

.feature-module li {
	padding-left: 1.5rem;
	margin-bottom: 0.75rem;
	position: relative;
}

.feature-module li::before {
	content: "•";
	position: absolute;
	left: 0;
	color: var(--primary-color);
	font-weight: 700;
}

.screenshot-card {
	background: #fff;
	border-radius: 15px;
	overflow: hidden;
	box-shadow: var(--shadow-md);
	transition: all 0.3s ease;
}

.screenshot-card:hover {
	transform: translateY(-5px);
	box-shadow: var(--shadow-lg);
}

.screenshot-img {
	background: var(--gradient-1);
	height: 200px;
	display: flex;
	align-items: center;
	justify-content: center;
}

.screenshot-img i {
	font-size: 4rem;
	color: rgba(255, 255, 255, 0.3);
}

.screenshot-card h4 {
	padding: 1rem 1.5rem 0.5rem;
	margin-bottom: 0;
}

.screenshot-card p {
	padding: 0 1.5rem 1.5rem;
	color: var(--text-light);
	margin: 0;
}

.pricing-plan {
	background: #fff;
	border: 2px solid var(--border-color);
	border-radius: 20px;
	padding: 2.5rem;
	text-align: center;
	height: 100%;
	transition: all 0.3s ease;
	position: relative;
}

.pricing-plan:hover {
	transform: translateY(-10px);
	box-shadow: var(--shadow-lg);
}

.pricing-plan.featured {
	border-color: var(--primary-color);
	box-shadow: 0 10px 40px rgba(0, 0, 0, 0.2);
}

.plan-badge {
	position: absolute;
	top: -15px;
	left: 50%;
	transform: translateX(-50%);
	background: var(--primary-color);
	color: #fff;
	padding: 0.5rem 1.5rem;
	border-radius: 20px;
	font-weight: 600;
	font-size: 0.9rem;
}

.plan-header h3 {
	font-size: 1.8rem;
	margin-bottom: 0.5rem;
}

.plan-price {
	margin: 2rem 0;
}

.plan-price .currency {
	font-size: 1.5rem;
	vertical-align: top;
}

.plan-price .amount {
	font-size: 3.5rem;
	font-weight: 700;
	color: var(--primary-color);
}

.plan-price .period {
	font-size: 1.2rem;
	color: var(--text-light);
}

.plan-features {
	list-style: none;
	padding: 0;
	margin: 2rem 0;
	text-align: left;
}

.plan-features li {
	padding: 0.75rem 0;
	border-bottom: 1px solid var(--border-color);
	display: flex;
	align-items: center;
	gap: 0.75rem;
}

.plan-features i {
	color: var(--success);
	font-size: 1.2rem;
	flex-shrink: 0;
}

.pricing-note {
	color: var(--text-light);
	font-size: 0.95rem;
}

.testimonial-detailed {
	background: #fff;
	padding: 2rem;
	border-radius: 15px;
	box-shadow: var(--shadow-md);
}

.testimonial-header {
	display: flex;
	gap: 1rem;
	margin-bottom: 1rem;
}

.author-avatar {
	font-size: 3rem;
	color: var(--primary-light);
}

.author-info strong {
	display: block;
	font-size: 1.1rem;
}

.author-info p {
	margin: 0;
	color: var(--text-light);
	font-size: 0.9rem;
}

.property-name {
	color: var(--primary-color);
	font-weight: 600;
}

.rating i {
	color: var(--warning);
}

/* Portfolio Detail Page */
.portfolio-detail-header {
	background: var(--dark-bg);
	color: #fff;
	padding: 150px 0 80px;
}

.project-info-box {
	background: rgba(255, 255, 255, 0.1);
	backdrop-filter: blur(10px);
	border-radius: 15px;
	padding: 1.5rem;
}

.info-item {
	display: flex;
	justify-content: space-between;
	padding: 0.75rem 0;
	border-bottom: 1px solid rgba(255, 255, 255, 0.1);
}

.info-item:last-child {
	border-bottom: none;
}

.info-item .label {
	color: rgba(255, 255, 255, 0.7);
}

.info-item .value {
	font-weight: 600;
}

.project-hero-image {
	background: var(--gradient-1);
	border-radius: 20px;
	height: 400px;
	display: flex;
	align-items: center;
	justify-content: center;
	box-shadow: var(--shadow-lg);
}

.project-hero-image i {
	font-size: 10rem;
	color: rgba(255, 255, 255, 0.3);
}

.project-content {
	font-size: 1.1rem;
	line-height: 1.8;
}

.project-section {
	margin-top: 3rem;
}

.challenge-item,
.solution-phase,
.takeaway-item {
	margin-bottom: 1.5rem;
}

.challenge-item {
	display: flex;
	gap: 1.5rem;
}

.challenge-icon {
	width: 50px;
	height: 50px;
	background: rgba(239, 68, 68, 0.1);
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
}

.challenge-icon i {
	color: #737373;
	font-size: 1.5rem;
}

.solution-phase {
	background: var(--light-bg);
	padding: 1.5rem;
	border-radius: 15px;
	margin-bottom: 1rem;
}

.solution-phase h4 {
	color: var(--primary-color);
	margin-bottom: 1rem;
}

.result-card {
	background: #fff;
	padding: 2rem;
	border-radius: 15px;
	text-align: center;
	border: 2px solid var(--border-color);
}

.result-card.success {
	border-color: var(--success);
}

.result-number {
	font-size: 3rem;
	font-weight: 700;
	color: var(--success);
	margin-bottom: 1rem;
}

.impact-quote {
	background: var(--light-bg);
	padding: 3rem;
	border-radius: 20px;
	border-left: 4px solid var(--primary-color);
}

.impact-quote .quote-icon {
	font-size: 3rem;
	color: var(--primary-light);
	opacity: 0.3;
}

.impact-quote p {
	font-size: 1.3rem;
	font-style: italic;
	margin-bottom: 1.5rem;
}

.impact-quote footer {
	text-align: right;
}

.takeaway-item {
	display: flex;
	gap: 1rem;
	padding: 1rem;
	background: var(--light-bg);
	border-radius: 10px;
}

.takeaway-item i {
	color: var(--primary-color);
	font-size: 1.5rem;
	flex-shrink: 0;
}

.project-sidebar {
	background: var(--light-bg);
	border-radius: 20px;
	padding: 2rem;
	top: 100px;
}

.sidebar-section {
	margin-bottom: 2rem;
	padding-bottom: 2rem;
	border-bottom: 1px solid var(--border-color);
}

.sidebar-section:last-child {
	border-bottom: none;
}

.detail-list {
	list-style: none;
	padding: 0;
}

.detail-list li {
	display: flex;
	justify-content: space-between;
	padding: 0.75rem 0;
	border-bottom: 1px solid var(--border-color);
}

.detail-list li:last-child {
	border-bottom: none;
}

.detail-label {
	color: var(--text-light);
}

.detail-value {
	font-weight: 600;
}

.tech-stack-sidebar {
	display: flex;
	flex-wrap: wrap;
	gap: 0.5rem;
}

.module-list,
.service-list {
	list-style: none;
	padding: 0;
}

.module-list li,
.service-list li {
	padding: 0.5rem 0;
}

.sidebar-cta {
	background: var(--primary-color);
	color: #fff;
	padding: 2rem;
	border-radius: 15px;
	text-align: center;
}

.sidebar-cta h4 {
	color: #fff;
}

/* Blog Post Detail Page */
.blog-post-header {
	background: var(--dark-bg);
	color: #fff;
	padding: 150px 0 80px;
}

.post-categories {
	margin-bottom: 1rem;
}

.post-title {
	font-size: 2.5rem;
	font-weight: 700;
	line-height: 1.3;
	margin-bottom: 1.5rem;
}

.post-meta {
	display: flex;
	flex-wrap: wrap;
	gap: 2rem;
	align-items: center;
	color: rgba(255, 255, 255, 0.8);
}

.author-info {
	display: flex;
	align-items: center;
	gap: 1rem;
}

.author-avatar {
	font-size: 3rem;
	color: var(--primary-light);
}

.author-details strong {
	display: block;
	font-size: 1.1rem;
}

.author-details span {
	color: rgba(255, 255, 255, 0.7);
	font-size: 0.9rem;
}

.post-details {
	display: flex;
	flex-wrap: wrap;
	gap: 1.5rem;
}

.post-featured-image {
	background: var(--gradient-1);
	border-radius: 20px;
	height: 400px;
	display: flex;
	align-items: center;
	justify-content: center;
	margin-bottom: 3rem;
}

.post-featured-image i {
	font-size: 10rem;
	color: rgba(255, 255, 255, 0.3);
}

.post-body {
	font-size: 1.1rem;
	line-height: 1.8;
	color: var(--text-dark);
}

.post-body h2 {
	margin-top: 3rem;
	margin-bottom: 1.5rem;
	color: var(--primary-color);
}

.post-body h3 {
	margin-top: 2rem;
	margin-bottom: 1rem;
	color: var(--text-dark);
}

.post-body ul,
.post-body ol {
	margin-bottom: 1.5rem;
}

.post-body li {
	margin-bottom: 0.75rem;
}

.post-quote {
	background: var(--light-bg);
	padding: 2.5rem;
	border-left: 4px solid var(--primary-color);
	border-radius: 10px;
	margin: 2rem 0;
	position: relative;
}

.post-quote .bi-quote {
	font-size: 4rem;
	color: var(--primary-light);
	opacity: 0.2;
	position: absolute;
	top: 1rem;
	left: 1rem;
}

.post-quote p {
	font-size: 1.3rem;
	font-style: italic;
	margin: 0;
	position: relative;
	z-index: 1;
}

.objection-response {
	background: var(--light-bg);
	padding: 1.5rem;
	border-radius: 10px;
	margin-bottom: 1.5rem;
}

.post-cta {
	background: var(--gradient-2);
	color: #fff;
	padding: 3rem;
	border-radius: 20px;
	text-align: center;
	margin: 3rem 0;
}

.post-cta h3 {
	color: #fff;
	margin-bottom: 1rem;
}

.author-bio {
	background: var(--light-bg);
	padding: 2rem;
	border-radius: 15px;
	display: flex;
	gap: 2rem;
	margin: 3rem 0;
}

.author-avatar-large {
	font-size: 5rem;
	color: var(--primary-light);
	flex-shrink: 0;
}

.author-title {
	color: var(--primary-color);
	font-weight: 600;
	margin-bottom: 0.5rem;
}

.author-social {
	display: flex;
	gap: 1rem;
	margin-top: 1rem;
}

.author-social a {
	width: 35px;
	height: 35px;
	background: var(--primary-color);
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	color: #fff;
}

.post-share {
	background: var(--light-bg);
	padding: 2rem;
	border-radius: 15px;
	margin: 3rem 0;
}

.share-buttons {
	display: flex;
	gap: 1rem;
	flex-wrap: wrap;
}

.share-btn {
	padding: 0.75rem 1.5rem;
	border-radius: 8px;
	color: #fff;
	font-weight: 600;
	transition: all 0.3s ease;
}

.share-btn:hover {
	transform: translateY(-2px);
	color: #fff;
}

.share-btn {
	background: #404040;
}

.share-btn.email {
	background: var(--text-dark);
}

.blog-sidebar {
	top: 100px;
}

.sidebar-widget {
	background: var(--light-bg);
	padding: 2rem;
	border-radius: 15px;
	margin-bottom: 2rem;
}

.sidebar-widget h4 {
	font-size: 1.3rem;
	margin-bottom: 1.5rem;
	color: var(--primary-color);
}

.toc-list {
	list-style: none;
	padding: 0;
}

.toc-list li {
	margin-bottom: 0.5rem;
}

.toc-list a {
	color: var(--text-dark);
	transition: color 0.3s ease;
}

.toc-list a:hover {
	color: var(--primary-color);
}

.toc-list ul {
	list-style: none;
	padding-left: 1.5rem;
	margin-top: 0.5rem;
}

.related-post {
	padding: 1rem 0;
	border-bottom: 1px solid var(--border-color);
}

.related-post:last-child {
	border-bottom: none;
}

.related-post h5 {
	font-size: 1rem;
	margin-bottom: 0.5rem;
}

.related-post h5 a {
	color: var(--text-dark);
}

.related-post h5 a:hover {
	color: var(--primary-color);
}

.related-post .meta {
	color: var(--text-light);
	font-size: 0.85rem;
}

.sidebar-newsletter {
	background: var(--primary-color);
	color: #fff;
}

.sidebar-newsletter h4 {
	color: #fff;
}

.sidebar-newsletter p {
	color: rgba(255, 255, 255, 0.9);
}

.tag-cloud {
	display: flex;
	flex-wrap: wrap;
	gap: 0.5rem;
}

.tag {
	background: #fff;
	padding: 0.5rem 1rem;
	border-radius: 20px;
	color: var(--text-dark);
	font-size: 0.9rem;
	transition: all 0.3s ease;
}

.tag:hover {
	background: var(--primary-color);
	color: #fff;
}

/* =====================================================
   BOTTOM MOBILE NAVIGATION
   ===================================================== */
.bottom-nav {
	position: fixed;
	bottom: calc(10px + env(safe-area-inset-bottom));
	left: 12px;
	right: 12px;
	z-index: 1050;
	max-width: 620px;
	margin: 0 auto;
	background: rgba(8, 12, 20, 0.78);
	backdrop-filter: blur(24px) saturate(180%);
	-webkit-backdrop-filter: blur(24px) saturate(180%);
	border: 1px solid rgba(255, 255, 255, 0.11);
	box-shadow: 0 14px 34px rgba(0, 0, 0, 0.42), inset 0 1px 0 rgba(255, 255, 255, 0.04);
	border-radius: 18px;
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding: 0.35rem;
}

@media (min-width: 992px) {
	.bottom-nav {
		display: none !important;
	}
}

.bottom-nav-item {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 3px;
	text-decoration: none;
	color: rgba(255, 255, 255, 0.52);
	padding: 0.45rem 0.55rem;
	border-radius: 14px;
	transition:
		color 0.25s ease,
		filter 0.25s ease,
		background 0.25s ease,
		transform 0.25s ease;
	flex: 1;
	max-width: 95px;
	position: relative;
}

.bottom-nav-item .material-icons {
	font-size: 1.5rem;
	line-height: 1;
}

.bottom-nav-label {
	font-size: 0.64rem;
	font-family: var(--font-body);
	font-weight: 700;
	letter-spacing: 0.045em;
	text-transform: uppercase;
	line-height: 1;
}

.bottom-nav-item:hover {
	color: rgba(255, 255, 255, 0.86);
	background: rgba(255, 255, 255, 0.06);
}

.bottom-nav-item.active {
	color: #fff;
	background: linear-gradient(180deg, rgba(255, 255, 255, 0.18) 0%, rgba(255, 255, 255, 0.08) 100%);
	transform: translateY(-1px);
}

.bottom-nav-item.active .material-icons {
	filter: drop-shadow(0 0 8px rgba(255, 255, 255, 0.65));
}

.bottom-nav-item.active::after {
	content: "";
	position: absolute;
	bottom: 4px;
	width: 18px;
	height: 2px;
	border-radius: 999px;
	background: rgba(255, 255, 255, 0.85);
}

/* Responsive */
@media (max-width: 991px) {
	/* Hide top navbar; bottom nav takes over on mobile */
	.navbar {
		display: none !important;
	}

	body {
		padding-bottom: 76px;
	}

	.hero-section {
		padding-top: 20px;
	}

	.page-header {
		padding: 80px 0 50px;
	}

	.hero-title {
		font-size: 2.5rem;
	}

	.page-title {
		font-size: 2.5rem;
	}

	.section-title {
		font-size: 2rem;
	}

	.timeline {
		flex-direction: column;
	}

	.timeline-item:not(:last-child)::after {
		content: "↓";
		right: auto;
		top: auto;
		bottom: -2rem;
		left: 50%;
		transform: translateX(-50%);
	}

	.overview-stats {
		grid-template-columns: 1fr;
	}

	.steps-container {
		flex-direction: column;
	}

	.step-divider {
		transform: rotate(90deg);
	}
}

@media (max-width: 767px) {
	.hero-title {
		font-size: 2rem;
	}

	.hero-visual {
		height: 300px;
	}

	.floating-card {
		padding: 1rem;
	}

	.floating-card i {
		font-size: 1.5rem;
	}

	.floating-card span {
		font-size: 0.9rem;
	}
}

/* Single Product Page Styles */
.product-hero {
	background: var(--dark-bg);
	color: #fff;
	padding: 150px 0 80px;
}

.breadcrumb {
	background: transparent;
	padding: 0;
	margin-bottom: 1rem;
}

.breadcrumb-item a {
	color: rgba(255, 255, 255, 0.7);
}

.breadcrumb-item.active {
	color: rgba(255, 255, 255, 0.9);
}

.product-hero-title {
	font-size: 3.5rem;
	font-weight: 700;
	margin-bottom: 1rem;
}

.product-hero-subtitle {
	font-size: 1.5rem;
	margin-bottom: 1rem;
	color: rgba(255, 255, 255, 0.9);
}

.product-hero-description {
	font-size: 1.1rem;
	color: rgba(255, 255, 255, 0.8);
	margin-bottom: 2rem;
}

.product-hero-actions {
	display: flex;
	gap: 1rem;
	margin-bottom: 2rem;
}

.product-stats {
	display: flex;
	gap: 3rem;
}

.product-stats .stat h3 {
	font-size: 2.5rem;
	color: var(--primary-light);
	margin-bottom: 0.25rem;
}

.product-stats .stat p {
	color: rgba(255, 255, 255, 0.7);
	margin: 0;
}

.product-hero-image {
	height: 100%;
	min-height: 400px;
}

.dashboard-preview {
	background: rgba(255, 255, 255, 0.1);
	backdrop-filter: blur(10px);
	border: 1px solid rgba(255, 255, 255, 0.2);
	border-radius: 20px;
	overflow: hidden;
	height: 100%;
}

.preview-header {
	background: rgba(255, 255, 255, 0.05);
	padding: 1rem;
	display: flex;
	gap: 0.5rem;
}

.preview-header .dot {
	width: 12px;
	height: 12px;
	border-radius: 50%;
	background: rgba(255, 255, 255, 0.3);
}

.preview-content {
	padding: 3rem;
	text-align: center;
}

.preview-content i {
	font-size: 6rem;
	color: rgba(255, 255, 255, 0.3);
}

.feature-detail-card {
	background: #fff;
	padding: 2rem;
	border-radius: 15px;
	height: 100%;
	box-shadow: var(--shadow-md);
	transition: all 0.3s ease;
}

.feature-detail-card:hover {
	transform: translateY(-5px);
	box-shadow: var(--shadow-lg);
}

.feature-icon-large {
	width: 80px;
	height: 80px;
	background: var(--gradient-2);
	border-radius: 15px;
	display: flex;
	align-items: center;
	justify-content: center;
	margin-bottom: 1.5rem;
}

.feature-icon-large i {
	font-size: 2.5rem;
	color: #fff;
}

.feature-list-detail {
	list-style: none;
	padding: 0;
	margin-top: 1rem;
}

.feature-list-detail li {
	margin-bottom: 0.5rem;
	display: flex;
	align-items: flex-start;
	gap: 0.5rem;
}

.feature-list-detail i {
	color: var(--success);
	margin-top: 0.25rem;
}

.workflow-step {
	text-align: center;
	padding: 2rem;
	background: var(--light-bg);
	border-radius: 15px;
	height: 100%;
}

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

.workflow-icon {
	font-size: 3rem;
	color: var(--primary-light);
	margin-bottom: 1rem;
}

.screenshot-card {
	background: #fff;
	border-radius: 15px;
	overflow: hidden;
	box-shadow: var(--shadow-md);
	height: 100%;
}

.screenshot-image {
	background: var(--gradient-1);
	height: 250px;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	color: rgba(255, 255, 255, 0.4);
}

.screenshot-image.small {
	height: 180px;
}

.screenshot-image i {
	font-size: 4rem;
	margin-bottom: 0.5rem;
}

.screenshot-info {
	padding: 1.5rem;
}

.pricing-plan {
	background: #fff;
	border-radius: 20px;
	padding: 2.5rem;
	text-align: center;
	height: 100%;
	border: 2px solid var(--border-color);
	transition: all 0.3s ease;
	position: relative;
}

.pricing-plan:hover,
.pricing-plan.featured {
	border-color: var(--primary-color);
	box-shadow: var(--shadow-lg);
	transform: translateY(-10px);
}

.plan-badge {
	position: absolute;
	top: -15px;
	left: 50%;
	transform: translateX(-50%);
	background: var(--primary-color);
	color: #fff;
	padding: 0.5rem 1.5rem;
	border-radius: 25px;
	font-weight: 600;
	font-size: 0.9rem;
}

.plan-header {
	margin-bottom: 2rem;
}

.plan-header h3 {
	font-size: 1.8rem;
	margin-bottom: 0.5rem;
}

.plan-price {
	margin-bottom: 2rem;
}

.plan-price .currency {
	font-size: 1.5rem;
	vertical-align: super;
}

.plan-price .amount {
	font-size: 3.5rem;
	font-weight: 700;
	color: var(--primary-color);
}

.plan-price .period {
	font-size: 1.2rem;
	color: var(--text-light);
}

.plan-price .custom {
	font-size: 2.5rem;
	font-weight: 700;
	color: var(--primary-color);
}

.plan-features {
	list-style: none;
	padding: 0;
	text-align: left;
	margin-bottom: 2rem;
}

.plan-features li {
	margin-bottom: 1rem;
	display: flex;
	align-items: flex-start;
	gap: 0.75rem;
}

.plan-features i {
	color: var(--success);
	font-size: 1.25rem;
	flex-shrink: 0;
}

.testimonial-detail {
	background: #fff;
	padding: 2rem;
	border-radius: 15px;
	height: 100%;
	box-shadow: var(--shadow-md);
}

.stars {
	color: #fbbf24;
}

.author-avatar {
	width: 50px;
	height: 50px;
	border-radius: 50%;
	margin-right: 1rem;
}

.testimonial-author {
	display: flex;
	align-items: center;
	margin-top: 1.5rem;
}

.related-product-card {
	background: var(--light-bg);
	padding: 2rem;
	border-radius: 15px;
	text-align: center;
	height: 100%;
}

.related-icon {
	font-size: 3rem;
	color: var(--primary-color);
	margin-bottom: 1rem;
}

/* Single Portfolio Page Styles */
.case-study-hero {
	background: var(--dark-bg);
	color: #fff;
	padding: 150px 0 80px;
}

.case-study-title {
	font-size: 3rem;
	font-weight: 700;
	margin-bottom: 1rem;
}

.case-study-subtitle {
	font-size: 1.2rem;
	color: rgba(255, 255, 255, 0.9);
	margin-bottom: 2rem;
}

.case-meta {
	display: flex;
	gap: 2rem;
	flex-wrap: wrap;
}

.meta-item {
	display: flex;
	align-items: center;
	gap: 0.5rem;
	color: rgba(255, 255, 255, 0.8);
}

.case-hero-image {
	height: 400px;
	background: rgba(255, 255, 255, 0.1);
	backdrop-filter: blur(10px);
	border: 1px solid rgba(255, 255, 255, 0.2);
	border-radius: 20px;
	display: flex;
	align-items: center;
	justify-content: center;
}

.case-hero-image i {
	font-size: 10rem;
	color: rgba(255, 255, 255, 0.2);
}

.overview-stat-card {
	background: #fff;
	padding: 2rem;
	border-radius: 15px;
	text-align: center;
	box-shadow: var(--shadow-md);
}

.stat-icon {
	width: 60px;
	height: 60px;
	background: var(--gradient-2);
	border-radius: 50%;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	margin-bottom: 1rem;
}

.stat-icon i {
	font-size: 1.5rem;
	color: #fff;
}

.overview-stat-card h3 {
	font-size: 2.5rem;
	color: var(--primary-color);
	margin-bottom: 0.5rem;
}

.client-quick-facts {
	background: var(--light-bg);
	padding: 2rem;
	border-radius: 15px;
}

.fact-list {
	list-style: none;
	padding: 0;
}

.fact-list li {
	margin-bottom: 0.75rem;
	padding-bottom: 0.75rem;
	border-bottom: 1px solid var(--border-color);
}

.fact-list li:last-child {
	border-bottom: none;
}

.challenge-item {
	display: flex;
	gap: 1.5rem;
	margin-bottom: 2rem;
}

.challenge-icon {
	width: 50px;
	height: 50px;
	background: rgba(239, 68, 68, 0.1);
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	flex-shrink: 0;
}

.challenge-icon i {
	font-size: 1.5rem;
	color: #737373;
}

.pain-point-card {
	background: rgba(239, 68, 68, 0.05);
	padding: 2rem;
	border-radius: 15px;
	border: 1px solid rgba(239, 68, 68, 0.2);
}

.impact-list {
	list-style: none;
	padding: 0;
}

.impact-list li {
	margin-bottom: 0.75rem;
	display: flex;
	align-items: flex-start;
	gap: 0.75rem;
}

.quote-box {
	background: var(--light-bg);
	padding: 2rem;
	border-radius: 15px;
	border-left: 4px solid var(--primary-color);
}

.quote-box i {
	font-size: 2rem;
	color: var(--primary-light);
	opacity: 0.3;
}

.quote-box cite {
	display: block;
	margin-top: 1rem;
	font-style: normal;
	color: var(--text-light);
}

.solution-phase {
	background: #fff;
	padding: 2rem;
	border-radius: 15px;
	box-shadow: var(--shadow-md);
	height: 100%;
}

.phase-number {
	display: inline-block;
	background: var(--primary-color);
	color: #fff;
	padding: 0.5rem 1rem;
	border-radius: 25px;
	font-weight: 700;
	margin-bottom: 1rem;
}

.phase-activities {
	list-style: none;
	padding: 0;
}

.phase-activities li {
	margin-bottom: 0.5rem;
	padding-left: 1.5rem;
	position: relative;
}

.phase-activities li::before {
	content: "→";
	position: absolute;
	left: 0;
	color: var(--primary-color);
}

.implementation-highlight {
	background: var(--light-bg);
	padding: 2.5rem;
	border-radius: 20px;
}

.feature-implemented {
	display: flex;
	align-items: center;
	gap: 0.75rem;
	padding: 0.75rem;
	background: #fff;
	border-radius: 10px;
}

.feature-implemented i {
	color: var(--success);
	font-size: 1.25rem;
}

.result-card {
	background: #fff;
	padding: 2rem;
	border-radius: 15px;
	text-align: center;
	box-shadow: var(--shadow-md);
	height: 100%;
}

.result-icon {
	width: 70px;
	height: 70px;
	border-radius: 50%;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	margin-bottom: 1rem;
}

.result-icon.success {
	background: rgba(255, 255, 255, 0.1);
	color: var(--success);
}

.result-icon i {
	font-size: 2rem;
}

.result-card h3 {
	font-size: 2.5rem;
	color: var(--primary-color);
	margin-bottom: 0.5rem;
}

.result-card h5 {
	margin-bottom: 1rem;
}

.additional-results {
	background: var(--light-bg);
	padding: 2rem;
	border-radius: 15px;
}

.results-list {
	list-style: none;
	padding: 0;
}

.results-list li {
	margin-bottom: 1rem;
	display: flex;
	align-items: flex-start;
	gap: 0.75rem;
}

.results-list i {
	color: var(--success);
	font-size: 1.25rem;
	flex-shrink: 0;
}

.testimonial-result {
	background: #fff;
	padding: 2rem;
	border-radius: 15px;
	box-shadow: var(--shadow-md);
}

.tech-stack-item {
	background: var(--light-bg);
	padding: 2rem;
	border-radius: 15px;
	text-align: center;
}

.tech-stack-item i {
	font-size: 3rem;
	color: var(--primary-color);
	margin-bottom: 1rem;
}

.lesson-card {
	background: #fff;
	padding: 2rem;
	border-radius: 15px;
	box-shadow: var(--shadow-md);
	height: 100%;
}

.lesson-icon {
	width: 60px;
	height: 60px;
	background: var(--gradient-2);
	border-radius: 50%;
	display: inline-flex;
	align-items: center;
	justify-content: center;
	margin-bottom: 1rem;
}

.lesson-icon i {
	font-size: 1.5rem;
	color: #fff;
}

.project-preview-card {
	background: #fff;
	border-radius: 15px;
	overflow: hidden;
	box-shadow: var(--shadow-md);
	height: 100%;
}

.project-preview-image {
	background: var(--gradient-1);
	height: 200px;
	display: flex;
	align-items: center;
	justify-content: center;
}

.project-preview-image i {
	font-size: 4rem;
	color: rgba(255, 255, 255, 0.3);
}

.project-preview-content {
	padding: 1.5rem;
}

/* Single Blog Post Styles */
.blog-post-hero {
	background: var(--dark-bg);
	color: #fff;
	padding: 150px 0 80px;
}

.blog-post-title {
	font-size: 3rem;
	font-weight: 700;
	margin-bottom: 2rem;
	line-height: 1.3;
}

.blog-post-meta {
	display: flex;
	align-items: center;
	gap: 1.5rem;
	justify-content: center;
}

.author-avatar-large {
	width: 60px;
	height: 60px;
	border-radius: 50%;
}

.meta-info strong {
	display: block;
	font-size: 1.1rem;
	margin-bottom: 0.25rem;
}

.meta-details {
	display: flex;
	gap: 1.5rem;
	color: rgba(255, 255, 255, 0.7);
	font-size: 0.9rem;
}

.blog-featured-image {
	border-radius: 20px;
	overflow: hidden;
}

.featured-placeholder {
	background: var(--gradient-1);
	height: 400px;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	color: rgba(255, 255, 255, 0.4);
}

.featured-placeholder i {
	font-size: 6rem;
	margin-bottom: 1rem;
}

.article-body {
	font-size: 1.1rem;
	line-height: 1.9;
}

.article-body h2 {
	margin-top: 3rem;
	margin-bottom: 1.5rem;
	font-size: 2rem;
}

.article-body h3 {
	margin-top: 2rem;
	margin-bottom: 1rem;
	font-size: 1.5rem;
}

.article-body p {
	margin-bottom: 1.5rem;
}

.article-body ul {
	margin-bottom: 1.5rem;
}

.callout-box {
	background: var(--light-bg);
	padding: 2rem;
	border-radius: 15px;
	margin: 2rem 0;
	border-left: 4px solid var(--primary-color);
}

.callout-box.info {
	background: rgba(0, 0, 0, 0.05);
	border-color: var(--primary-color);
}

.callout-box h4 {
	margin-bottom: 1rem;
	color: var(--primary-color);
}

.blog-quote {
	background: var(--light-bg);
	padding: 2rem;
	border-left: 4px solid var(--primary-color);
	margin: 2rem 0;
	font-size: 1.2rem;
	font-style: italic;
}

.blog-quote cite {
	display: block;
	margin-top: 1rem;
	font-style: normal;
	color: var(--text-light);
	font-size: 0.9rem;
}

.stats-highlight {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 2rem;
	margin: 3rem 0;
}

.stat-item-blog {
	background: var(--light-bg);
	padding: 2rem;
	border-radius: 15px;
	text-align: center;
}

.stat-item-blog h3 {
	font-size: 2.5rem;
	color: var(--primary-color);
	margin-bottom: 0.5rem;
}

.step-guide {
	margin: 2rem 0;
}

.step-guide-item {
	display: flex;
	gap: 1.5rem;
	margin-bottom: 2rem;
}

.step-guide-number {
	width: 50px;
	height: 50px;
	background: var(--primary-color);
	color: #fff;
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 1.5rem;
	font-weight: 700;
	flex-shrink: 0;
}

.step-guide-content h4 {
	margin-bottom: 0.5rem;
}

.post-tags {
	padding-top: 2rem;
	border-top: 1px solid var(--border-color);
}

.tag-link {
	display: inline-block;
	background: var(--light-bg);
	padding: 0.5rem 1rem;
	border-radius: 25px;
	margin-right: 0.5rem;
	margin-bottom: 0.5rem;
	color: var(--text-dark);
	font-size: 0.9rem;
	transition: all 0.3s ease;
}

.tag-link:hover {
	background: var(--primary-color);
	color: #fff;
}

.post-share {
	padding-top: 1.5rem;
}

.share-buttons {
	display: flex;
	gap: 0.5rem;
}

.share-btn {
	width: 40px;
	height: 40px;
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	color: #fff;
	transition: all 0.3s ease;
}

.share-btn {
	background: #404040;
}

.share-btn:hover {
	transform: translateY(-3px);
}

.author-bio {
	background: var(--light-bg);
	padding: 2rem;
	border-radius: 15px;
	display: flex;
	gap: 1.5rem;
}

.author-bio-avatar {
	width: 100px;
	height: 100px;
	border-radius: 50%;
	flex-shrink: 0;
}

.author-bio-content h4 {
	color: var(--text-light);
	font-size: 0.9rem;
	text-transform: uppercase;
	margin-bottom: 0.5rem;
}

.author-bio-content h5 {
	margin-bottom: 0.25rem;
}

.author-role {
	color: var(--primary-color);
	font-size: 0.9rem;
	margin-bottom: 1rem;
}

.author-social {
	display: flex;
	gap: 0.5rem;
	margin-top: 1rem;
}

.author-social a {
	width: 35px;
	height: 35px;
	background: #fff;
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	color: var(--primary-color);
}

.related-post-card {
	background: var(--light-bg);
	padding: 1rem;
	border-radius: 10px;
	transition: all 0.3s ease;
}

.related-post-card:hover {
	background: #fff;
	box-shadow: var(--shadow-md);
}

.related-post-image {
	background: var(--gradient-2);
	height: 150px;
	border-radius: 10px;
	display: flex;
	align-items: center;
	justify-content: center;
	margin-bottom: 1rem;
}

.related-post-image i {
	font-size: 3rem;
	color: rgba(255, 255, 255, 0.3);
}

.comment {
	display: flex;
	gap: 1rem;
	margin-bottom: 2rem;
	padding-bottom: 2rem;
	border-bottom: 1px solid var(--border-color);
}

.comment-avatar {
	width: 50px;
	height: 50px;
	border-radius: 50%;
	flex-shrink: 0;
}

.comment-header {
	display: flex;
	justify-content: space-between;
	margin-bottom: 0.5rem;
}

.comment-date {
	color: var(--text-light);
	font-size: 0.9rem;
}

.comment-reply {
	color: var(--primary-color);
	font-size: 0.9rem;
	margin-top: 0.5rem;
	display: inline-block;
}

.blog-sidebar {
	position: sticky;
	top: 100px;
}

.sidebar-widget {
	background: #fff;
	padding: 2rem;
	border-radius: 15px;
	margin-bottom: 2rem;
	box-shadow: var(--shadow-sm);
}

.sidebar-widget h4 {
	margin-bottom: 1rem;
}

.popular-post {
	padding: 1rem 0;
	border-bottom: 1px solid var(--border-color);
}

.popular-post:last-child {
	border-bottom: none;
}

.popular-post h6 {
	margin-bottom: 0.25rem;
}

.category-list {
	list-style: none;
	padding: 0;
}

.category-list li {
	margin-bottom: 0.5rem;
}

.category-list a {
	color: var(--text-dark);
	display: block;
	padding: 0.5rem 0;
	transition: all 0.3s ease;
}

.category-list a:hover {
	color: var(--primary-color);
	padding-left: 5px;
}

.cta-widget {
	background: var(--gradient-2);
	color: #fff;
}

.cta-widget h4,
.cta-widget p {
	color: #fff;
}

.portfolio-cta {
	background: var(--gradient-2);
	color: #fff;
}

.product-cta {
	background: var(--gradient-2);
	color: #fff;
}

/* ============================================================
   FUTURISTIC UTILITIES — Appended
   ============================================================ */

/* ----------  Scroll Reveal  ---------- */
.reveal {
	opacity: 0;
	transform: translateY(40px);
	transition:
		opacity 0.65s cubic-bezier(0.16, 1, 0.3, 1),
		transform 0.65s cubic-bezier(0.16, 1, 0.3, 1);
	will-change: opacity, transform;
}
.reveal-left {
	opacity: 0;
	transform: translateX(-50px);
	transition:
		opacity 0.65s cubic-bezier(0.16, 1, 0.3, 1),
		transform 0.65s cubic-bezier(0.16, 1, 0.3, 1);
}
.reveal-right {
	opacity: 0;
	transform: translateX(50px);
	transition:
		opacity 0.65s cubic-bezier(0.16, 1, 0.3, 1),
		transform 0.65s cubic-bezier(0.16, 1, 0.3, 1);
}
.reveal.active,
.reveal-left.active,
.reveal-right.active {
	opacity: 1;
	transform: translate(0);
}
.delay-1 {
	transition-delay: 0.1s !important;
}
.delay-2 {
	transition-delay: 0.2s !important;
}
.delay-3 {
	transition-delay: 0.3s !important;
}
.delay-4 {
	transition-delay: 0.4s !important;
}

/* ----------  Gradient Text Utility  ---------- */
.gradient-text {
	background: linear-gradient(
		135deg,
		var(--neon-blue) 0%,
		var(--neon-purple) 100%
	);
	-webkit-background-clip: text;
	-webkit-text-fill-color: transparent;
	background-clip: text;
}
.text-neon-blue {
	color: var(--neon-blue) !important;
}
.text-neon-purple {
	color: var(--neon-purple) !important;
}
.text-neon-cyan {
	color: var(--neon-cyan) !important;
}
.text-neon-pink {
	color: var(--neon-pink) !important;
}

/* ----------  Kinetic blur-in animation  ---------- */
@keyframes kinetic-blur-in {
	0% {
		opacity: 0;
		filter: blur(20px);
		transform: scale(0.85);
	}
	60% {
		opacity: 0.9;
		filter: blur(4px);
	}
	100% {
		opacity: 1;
		filter: blur(0);
		transform: scale(1);
	}
}
.kinetic-in {
	animation: kinetic-blur-in 0.85s cubic-bezier(0.16, 1, 0.3, 1) both;
}

/* ----------  Glitch effect  ---------- */
@keyframes glitch-1 {
	0%,
	100% {
		clip-path: inset(0 0 98% 0);
		transform: translate(-2px, 0);
	}
	20% {
		clip-path: inset(60% 0 20% 0);
		transform: translate(2px, 0);
	}
	40% {
		clip-path: inset(30% 0 60% 0);
		transform: translate(-1px, 0);
	}
	60% {
		clip-path: inset(80% 0 5% 0);
		transform: translate(1px, 0);
	}
}
@keyframes glitch-2 {
	0%,
	100% {
		clip-path: inset(98% 0 0% 0);
		transform: translate(2px, 0);
	}
	25% {
		clip-path: inset(10% 0 70% 0);
		transform: translate(-2px, 0);
	}
	50% {
		clip-path: inset(50% 0 40% 0);
		transform: translate(1px, 0);
	}
	75% {
		clip-path: inset(20% 0 50% 0);
		transform: translate(-1px, 0);
	}
}
.glitch {
	position: relative;
}
.glitch::before,
.glitch::after {
	content: attr(data-text);
	position: absolute;
	inset: 0;
	pointer-events: none;
}
.glitch::before {
	color: var(--neon-cyan);
	animation: glitch-1 3.5s infinite;
	opacity: 0.7;
}
.glitch::after {
	color: var(--neon-pink);
	animation: glitch-2 3.5s infinite;
	opacity: 0.6;
}

/* ----------  Neon-line separator  ---------- */
.neon-line {
	height: 1px;
	background: linear-gradient(
		90deg,
		transparent,
		var(--neon-blue),
		var(--neon-purple),
		transparent
	);
	border: none;
	margin: 3rem auto;
	max-width: 60%;
	opacity: 0.6;
}

/* ----------  Retro Orb (ambient glow sphere)  ---------- */
.retro-orb {
	position: absolute;
	border-radius: 50%;
	pointer-events: none;
	filter: blur(80px);
	animation: orb-pulse 8s ease-in-out infinite;
	z-index: 0;
}
.retro-orb.orb-blue {
	background: rgba(255, 255, 255, 0.25);
}
.retro-orb.orb-purple {
	background: rgba(255, 255, 255, 0.2);
}
.retro-orb.orb-cyan {
	background: rgba(255, 255, 255, 0.15);
}
@keyframes orb-pulse {
	0%,
	100% {
		transform: scale(1);
		opacity: 0.7;
	}
	50% {
		transform: scale(1.25);
		opacity: 1;
	}
}

/* ----------  Particles  ---------- */
.particle {
	position: absolute;
	border-radius: 50%;
	background: rgba(255, 255, 255, 0.55);
	pointer-events: none;
	z-index: 0;
	animation: particle-float var(--duration, 6s) ease-in-out infinite;
}
@keyframes particle-float {
	0% {
		transform: translateY(0) scale(1);
		opacity: 0;
	}
	15% {
		opacity: 0.8;
	}
	85% {
		opacity: 0.4;
	}
	100% {
		transform: translateY(-120px) scale(0.5);
		opacity: 0;
	}
}

/* ----------  Holo shimmer card modifier  ---------- */
.holo-shimmer {
	position: relative;
	overflow: hidden;
}
.holo-shimmer::after {
	content: "";
	position: absolute;
	inset: 0;
	background: linear-gradient(
		105deg,
		transparent 30%,
		rgba(255, 255, 255, 0.06) 45%,
		rgba(255, 255, 255, 0.12) 52%,
		rgba(255, 255, 255, 0.06) 58%,
		transparent 70%
	);
	background-size: 250% 100%;
	animation: holo-slide 4s linear infinite;
	pointer-events: none;
	border-radius: inherit;
}

/* ----------  3D tilt card  ---------- */
.tilt-card {
	transform-style: preserve-3d;
	transition: transform 0.15s ease;
}
.tilt-card-inner {
	transform: translateZ(28px);
}

/* ----------  Magnetic button utility  ---------- */
.magnetic {
	display: inline-block;
	transition: transform 0.25s cubic-bezier(0.23, 1, 0.32, 1);
}

/* ----------  Custom scrollbar  ---------- */
::-webkit-scrollbar {
	width: 6px;
}
::-webkit-scrollbar-track {
	background: var(--dark-bg);
}
::-webkit-scrollbar-thumb {
	background: rgba(255, 255, 255, 0.4);
	border-radius: 4px;
}
::-webkit-scrollbar-thumb:hover {
	background: rgba(255, 255, 255, 0.6);
}

/* =====================================================
   PRICING PAGE — prc-* components
   ===================================================== */
.prc-plans {
	background: var(--dark-bg);
	padding-bottom: 4rem;
}
.prc-intro-text {
	font-size: 0.95rem;
	color: rgba(255, 255, 255, 0.45);
	max-width: 500px;
	margin: 0.75rem auto 0;
	line-height: 1.6;
}

/* --- Card --- */
.prc-card {
	background: var(--glass-bg);
	border: 1px solid var(--glass-border);
	border-radius: 20px;
	padding: 2rem 1.75rem;
	display: flex;
	flex-direction: column;
	position: relative;
	transition: border-color 0.3s ease, box-shadow 0.3s ease, transform 0.3s ease;
}
.prc-card:hover {
	border-color: rgba(255, 255, 255, 0.2);
	box-shadow: 0 12px 40px rgba(0, 0, 0, 0.35);
	transform: translateY(-4px);
}
.prc-card--featured {
	background: rgba(255, 255, 255, 0.06);
	border-color: rgba(255, 255, 255, 0.22);
	box-shadow:
		0 8px 32px rgba(0, 0, 0, 0.3),
		inset 0 1px 0 rgba(255, 255, 255, 0.08);
}
.prc-card--featured:hover {
	border-color: rgba(255, 255, 255, 0.38);
}

/* --- Popular badge --- */
.prc-badge {
	position: absolute;
	top: -13px;
	left: 50%;
	transform: translateX(-50%);
	background: #fff;
	color: #000;
	font-size: 0.65rem;
	font-weight: 700;
	letter-spacing: 0.12em;
	text-transform: uppercase;
	padding: 0.22rem 0.9rem;
	border-radius: 999px;
	white-space: nowrap;
}

/* --- Price display --- */
.prc-price-wrap {
	display: flex;
	align-items: baseline;
	gap: 0;
	margin: 0.75rem 0 1rem;
}
.prc-currency {
	font-family: var(--font-display);
	font-size: 1.15rem;
	font-weight: 600;
	color: rgba(255, 255, 255, 0.5);
	align-self: flex-start;
	margin-top: 0.55rem;
}
.prc-amount {
	font-family: var(--font-display);
	font-size: 3rem;
	font-weight: 800;
	color: #fff;
	line-height: 1;
	letter-spacing: -0.03em;
}
.prc-period {
	font-size: 0.88rem;
	color: rgba(255, 255, 255, 0.4);
	margin-left: 0.35rem;
}
.prc-desc {
	font-size: 0.9rem;
	color: rgba(255, 255, 255, 0.5);
	margin-bottom: 1.5rem;
	line-height: 1.55;
}

/* --- Feature list --- */
.prc-features {
	list-style: none;
	padding: 0;
	margin: 0 0 2rem;
	flex: 1;
	display: flex;
	flex-direction: column;
	gap: 0.65rem;
}
.prc-features li {
	font-size: 0.9rem;
	color: rgba(255, 255, 255, 0.7);
	display: flex;
	align-items: center;
	gap: 0.55rem;
}
.prc-features li i {
	font-size: 0.95rem;
	color: rgba(255, 255, 255, 0.4);
	flex-shrink: 0;
}
.prc-card--featured .prc-features li {
	color: rgba(255, 255, 255, 0.85);
}
.prc-card--featured .prc-features li i {
	color: rgba(255, 255, 255, 0.75);
}

/* --- Comparison table --- */
.prc-table-wrap {
	background: var(--glass-bg);
	border: 1px solid var(--glass-border);
	border-radius: 20px;
	padding: 2rem 2rem 1.5rem;
}
.prc-table {
	color: rgba(255, 255, 255, 0.88);
	margin: 0;
}
.prc-table thead th {
	font-family: var(--font-display);
	font-size: 0.78rem;
	font-weight: 700;
	letter-spacing: 0.08em;
	text-transform: uppercase;
	color: rgba(255, 255, 255, 0.55);
	border-bottom: 1px solid rgba(255, 255, 255, 0.1);
	padding-bottom: 1rem;
	background: transparent;
}
.prc-table tbody tr {
	border-bottom: 1px solid rgba(255, 255, 255, 0.06);
}
.prc-table tbody tr:last-child {
	border-bottom: none;
}
.prc-table tbody td {
	padding: 0.85rem 0.75rem;
	font-size: 0.9rem;
	background: transparent;
	border: none;
}
.prc-table-featured {
	color: #fff !important;
	font-weight: 600;
}

/* --- Light mode overrides --- */
[data-theme="light"] .prc-intro-text {
	color: rgba(0, 0, 0, 0.5);
}
[data-theme="light"] .prc-card:hover {
	border-color: rgba(0, 0, 0, 0.18);
	box-shadow: 0 12px 40px rgba(0, 0, 0, 0.1);
}
[data-theme="light"] .prc-card--featured {
	background: rgba(0, 0, 0, 0.04);
	border-color: rgba(0, 0, 0, 0.18);
	box-shadow:
		0 8px 32px rgba(0, 0, 0, 0.08),
		inset 0 1px 0 rgba(255, 255, 255, 0.7);
}
[data-theme="light"] .prc-card--featured:hover {
	border-color: rgba(0, 0, 0, 0.28);
}
[data-theme="light"] .prc-badge {
	background: #1a1a1a;
	color: #fff;
}
[data-theme="light"] .prc-currency {
	color: rgba(0, 0, 0, 0.45);
}
[data-theme="light"] .prc-amount {
	color: var(--text-dark);
}
[data-theme="light"] .prc-period {
	color: rgba(0, 0, 0, 0.4);
}
[data-theme="light"] .prc-desc {
	color: rgba(0, 0, 0, 0.5);
}
[data-theme="light"] .prc-features li {
	color: rgba(0, 0, 0, 0.65);
}
[data-theme="light"] .prc-features li i {
	color: rgba(0, 0, 0, 0.4);
}
[data-theme="light"] .prc-card--featured .prc-features li {
	color: rgba(0, 0, 0, 0.8);
}
[data-theme="light"] .prc-card--featured .prc-features li i {
	color: rgba(0, 0, 0, 0.6);
}
[data-theme="light"] .prc-table {
	color: rgba(0, 0, 0, 0.65);
}
[data-theme="light"] .prc-table thead th {
	color: rgba(0, 0, 0, 0.38);
	border-bottom-color: rgba(0, 0, 0, 0.1);
}
[data-theme="light"] .prc-table tbody tr {
	border-bottom-color: rgba(0, 0, 0, 0.07);
}
[data-theme="light"] .prc-table-featured {
	color: var(--text-dark) !important;
}
