/* Crypton landing page styles — extracted from Blade templates.
   Loaded via layouts/landing.blade.php */

/* === Landing index: nav + proof strip (dark-mode safe) === */
.dark-mode #siteHeaderNavbar.site-header-navbar .nav-link,
.dark-mode #siteHeaderNavbar.site-header-navbar .navbar-brand,
#siteHeaderNavbar.site-header-navbar .nav-link,
#siteHeaderNavbar.site-header-navbar .navbar-brand {
    color: #222 !important;
}
.dark-mode #siteHeaderNavbar.site-header-navbar .nav-link:hover,
.dark-mode #siteHeaderNavbar.site-header-navbar .nav-link.active,
#siteHeaderNavbar.site-header-navbar .nav-link:hover,
#siteHeaderNavbar.site-header-navbar .nav-link.active {
    color: #000 !important;
}

#landing-social-proof {
    background: #0f0f0f !important;
    color: #aaa !important;
}
#landing-social-proof .landing-proof-label {
    color: #aaa !important;
}
#landing-social-proof .landing-proof-value {
    color: #ffcd00 !important;
}
.dark-mode #landing-social-proof,
.dark-mode #landing-social-proof .landing-proof-label {
    color: #aaa !important;
}
.dark-mode #landing-social-proof .landing-proof-value {
    color: #ffcd00 !important;
}

.landing-proof-strip {
    display: flex;
    justify-content: center;
    align-items: center;
    flex-wrap: wrap;
    gap: 28px 40px;
}
.landing-proof-item {
    text-align: center;
}
.landing-proof-value {
    color: #ffcd00;
    font-size: 32px;
    font-weight: 800;
    margin-bottom: 5px;
    line-height: 1.1;
}
.landing-proof-label {
    color: #aaa;
    font-size: 14px;
}
.landing-proof-link {
    text-decoration: none;
    color: inherit;
}
.landing-proof-link:hover .landing-proof-value {
    color: #ffcd00;
}
.landing-proof-link:hover .landing-proof-label {
    color: #ccc;
}
.landing-proof-divider {
    width: 1px;
    height: 40px;
    background: rgba(255, 255, 255, 0.1);
}
@media (max-width: 576px) {
    .landing-proof-divider--hide-sm,
    .landing-proof-item--hide-sm {
        display: none;
    }
    .landing-proof-value {
        font-size: 26px;
    }
}

@media (max-width: 768px) {
    #main-banner {
        padding-bottom: 16px;
    }
    /* Terminal sizing — see demo-terminal.css */
    #main-banner .banner-main h4 {
        margin-bottom: 16px;
    }
}

/* === home.blade.php — hero — block 1 === */
#canvas {
		  width: 100%;
		  height: 100%;
		  position: absolute;
		}
		/* Hero typography — editorial 2026 treatment. Overrides
		   theme.css .banner-main h3/h4 (which forces UPPERCASE
		   and gold-on-gold gradient text). Mixed case + ultra-
		   tight tracking + dark ink on the gold hero so the words
		   actually read at first glance. */
		.banner-main {
			padding: 30px 30px 30px 0;
		}
		.banner-main h3 {
			font-size: clamp(2.4rem, 5.2vw, 4.2rem);
			font-weight: 900;
			line-height: 1.02;
			letter-spacing: -0.035em;
			margin: 0 0 22px;
			background: none;
			-webkit-background-clip: initial;
			-webkit-text-fill-color: initial;
			background-clip: initial;
			color: #0a0a0a;
			text-transform: none;
			text-wrap: balance;
			font-feature-settings: 'ss01' on, 'cv11' on;
		}
		.banner-main h4 {
			font-size: clamp(1.05rem, 1.55vw, 1.32rem);
			font-weight: 400;
			line-height: 1.5;
			letter-spacing: -0.005em;
			margin: 0 0 30px;
			color: rgba(0, 0, 0, 0.78);
			max-width: 58ch;
			text-wrap: pretty;
		}
		/* Pick out the privacy promise so it carries the message
		   without needing markup changes. The em-dash separates a
		   prose phrase ("…and SMS") from a stacked-noun promise
		   ("no name, no email, no KYC") — different visual weight
		   helps the eye parse it. */
		.banner-main h4 strong {
			color: #0a0a0a;
			font-weight: 700;
			letter-spacing: -0.008em;
		}
		@media (max-width: 768px) {
			.banner-main {
				padding: 20px 0;
			}
			.banner-main h3 {
				font-size: clamp(2rem, 7.5vw, 2.6rem);
				letter-spacing: -0.03em;
				margin-bottom: 16px;
			}
			.banner-main h4 {
				font-size: 1.02rem;
				line-height: 1.45;
				margin-bottom: 22px;
			}
		}

/* === home.blade.php — hero — block 2 === */
/* Unified Spotlight launcher — the only hero CTA.
									   The bar is the canonical entry point to every
									   product, account action, info page, and Travel
									   eSIM destination via the shared modal. */
									.hero-search-row {
										margin-top: 22px;
										width: 100%;
										max-width: 580px;
									}
									.hero-search-row-only {
										margin-top: 28px;
									}
									.hero-cta-actions {
										display: flex;
										flex-wrap: wrap;
										gap: 10px;
										margin-top: 14px;
									}
									.hero-cta-btn {
										display: inline-flex;
										align-items: center;
										padding: 11px 20px;
										font-size: 14px;
										font-weight: 700;
										border-radius: 999px;
										text-decoration: none;
										transition: transform 0.15s ease, box-shadow 0.2s ease, background 0.2s ease;
									}
									.hero-cta-btn--primary {
										background: #0a0a0a;
										color: #ffcd00;
										border: 2px solid #0a0a0a;
										box-shadow: 0 4px 14px rgba(0, 0, 0, 0.2);
									}
									.hero-cta-btn--secondary {
										background: transparent;
										color: #0a0a0a;
										border: 2px solid rgba(0, 0, 0, 0.45);
									}
									.hero-cta-btn:hover {
										transform: translateY(-1px);
										color: #ffcd00;
									}
									.hero-cta-btn--secondary:hover {
										background: rgba(0, 0, 0, 0.08);
										color: #0a0a0a;
									}
									/* Spotlight hero + navbar trigger styles: see
									   /assets/shared/css/spotlight-triggers.css */

/* === home.blade.php — hero — block 3 === */
/* Tier eyebrows: short uppercase labels mirroring the no-JS
				   "Or jump to" eyebrow we use in the hero. Scoped to both
				   #section-services and #section-pricing so the "Other Crypton
				   plans" eyebrow under the pricing strip matches the Tier 1/2/3
				   eyebrows in Services without copy-pasting the styles. */
				#section-services .services-tier-row,
				#section-pricing .services-tier-row { margin-top: 0; }
				#section-services .services-tier-builders-eyebrow,
				#section-services .services-tier-also-eyebrow { margin-top: 20px; }
				#section-services .services-tier-eyebrow,
				#section-pricing .services-tier-eyebrow {
					color: rgba(255, 205, 0, 0.85);
					font-size: 12px;
					font-weight: 800;
					letter-spacing: 1.6px;
					text-transform: uppercase;
					margin: 0 0 24px 4px;
					display: inline-flex;
					align-items: center;
					gap: 10px;
				}
				#section-services .services-tier-eyebrow::before,
				#section-pricing .services-tier-eyebrow::before {
					content: '';
					display: inline-block;
					width: 18px;
					height: 1px;
					background: rgba(255, 205, 0, 0.55);
				}

				/* Tier 3 tile hover lift — keeps the tile passive at rest so
				   it doesn't compete with Tier 1/2 buttons. */
				#section-services .service-tile:hover {
					transform: translateY(-2px);
					background: rgba(255, 255, 255, 0.06);
					border-color: rgba(255, 255, 255, 0.16);
				}

				/* Responsive: horizontal builder cards collapse to vertical
				   under 991px, just like before. */
				@media (max-width: 991px) {
					.email-service-horizontal,
					.verification-service-horizontal {
						flex-direction: column !important;
						text-align: center !important;
						gap: 30px !important;
					}
					#api,
					#sms-verification {
						padding: 35px 30px !important;
					}
					#api h3,
					#sms-verification h3 {
						text-align: center !important;
					}
					#api .email-service-horizontal > div:last-child,
					#sms-verification .verification-service-horizontal > div:last-child {
						width: 100%;
					}
					#sms-verification .verification-service-horizontal > div:last-child {
						align-items: center;
					}
					#api .email-service-horizontal > div:last-child .btn {
						width: 100%;
					}
				}

				@media (max-width: 768px) {
					#api {
						padding: 30px 20px !important;
					}
					.email-service-horizontal {
						gap: 25px !important;
					}
					#section-services .services-tier-eyebrow,
					#section-pricing .services-tier-eyebrow {
						margin-left: 0;
					}
				}

/* === home.blade.php — hero — block 4 === */
/* Unique Pricing Section Design - Not a clone */
		#section-pricing::before {
			content: '';
			position: absolute;
			top: 0;
			left: 0;
			right: 0;
			bottom: 0;
			background: radial-gradient(circle at 30% 50%, rgba(255,205,0,0.05) 0%, transparent 50%),
			            radial-gradient(circle at 70% 50%, rgba(255,205,0,0.03) 0%, transparent 50%);
			pointer-events: none;
		}
		.pricing-container-modern {
			position: relative;
			z-index: 1;
		}
		.pricing-card-modern {
			background: rgba(255,255,255,0.04);
			border: 1px solid rgba(255,255,255,0.1);
			border-radius: 24px;
			padding: 0;
			overflow: hidden;
			transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1);
			position: relative;
			height: 100%;
			display: flex;
			flex-direction: column;
		}
		.pricing-card-modern:hover {
			transform: translateY(-8px);
			border-color: rgba(255,205,0,0.4);
			box-shadow: 0 20px 60px rgba(255,205,0,0.15);
		}
		.pricing-header-modern {
			background: linear-gradient(135deg, rgba(255,205,0,0.15) 0%, rgba(255,205,0,0.05) 100%);
			padding: 35px 30px;
			border-bottom: 1px solid rgba(255,255,255,0.1);
			position: relative;
		}
		
		.pricing-card-featured .pricing-header-modern {
			padding-top: 50px;
			padding-right: 20px;
			padding-left: 20px;
		}
		.pricing-body-modern {
			padding: 35px 30px;
			flex: 1;
		}
		.pricing-footer-modern {
			padding: 0 30px 35px;
		}
		.price-display-modern {
			display: flex;
			align-items: baseline;
			justify-content: center;
			gap: 8px;
			margin: 25px 0;
		}
		.price-amount-modern {
			font-size: 56px;
			font-weight: 800;
			color: #ffcd00;
			line-height: 1;
		}
		.price-period-modern {
			font-size: 18px;
			color: #999;
			font-weight: 500;
		}
		.pricing-features-modern {
			list-style: none;
			padding: 0;
			margin: 30px 0;
		}
		.pricing-features-modern li {
			padding: 12px 0;
			color: #ccc;
			display: flex;
			align-items: center;
			border-bottom: 1px solid rgba(255,255,255,0.05);
		}
		.pricing-features-modern li:last-child {
			border-bottom: none;
		}
		.pricing-features-modern li i {
			color: #ffcd00;
			margin-right: 12px;
			font-size: 16px;
		}
		.pricing-cta-modern {
			width: 100%;
			padding: 16px;
			font-size: 16px;
			font-weight: 700;
			border-radius: 12px;
			border: 2px solid #ffcd00;
			background: rgba(255,205,0,0.1);
			color: #ffcd00;
			transition: all 0.3s ease;
			text-decoration: none;
			display: block;
			text-align: center;
		}
		.pricing-cta-modern:hover {
			background: #ffcd00 !important;
			color: #000 !important;
			transform: scale(1.02);
			border-color: #ffcd00 !important;
		}
		/* Ensure eSIM buttons with yellow background maintain black text on hover */
		.pricing-cta-modern[style*="background: #ffcd00"]:hover,
		.pricing-cta-modern[style*="background:#ffcd00"]:hover {
			background: #ffb800 !important;
			color: #000 !important;
			border-color: #ffb800 !important;
		}
		/* Ensure message pricing CTA maintains readability */
		.pricing-cta-modern[style*="background: linear-gradient"]:hover {
			background: linear-gradient(135deg, #ffb800 0%, #ffa500 100%) !important;
			color: #000 !important;
		}
		.pricing-card-featured {
			border: 2px solid #ffcd00;
			background: linear-gradient(135deg, rgba(255,205,0,0.1) 0%, rgba(255,205,0,0.03) 100%);
		}
		.pricing-card-featured .pricing-header-modern {
			background: linear-gradient(135deg, rgba(255,205,0,0.25) 0%, rgba(255,205,0,0.1) 100%);
		}

/* === home.blade.php — hero — block 5 === */
#section-pricing .pricing-tile:hover {
						transform: translateY(-2px);
						background: rgba(255, 255, 255, 0.06);
						border-color: rgba(255, 255, 255, 0.16);
					}

/* === home.blade.php — hero — block 6 === */
/* Modern Payment Cards Styling */
			.payment-card-modern:hover {
				transform: translateY(-8px);
				border-color: rgba(255,205,0,0.3) !important;
				box-shadow: 0 20px 60px rgba(255,205,0,0.15);
			}
			
			.payment-icon-container:hover {
				transform: scale(1.1) rotate(5deg);
				border-color: rgba(255,205,0,0.5) !important;
				background: linear-gradient(135deg, rgba(255,205,0,0.25) 0%, rgba(255,205,0,0.15) 100%) !important;
			}
			
			.crypto-badge:hover {
				transform: translateY(-2px);
				border-color: rgba(255,205,0,0.4) !important;
				background: rgba(255,205,0,0.12) !important;
				box-shadow: 0 4px 12px rgba(255,205,0,0.2);
			}
			
			@media (max-width: 768px) {
				.payment-card-modern {
					padding: 35px 25px !important;
				}
				
				.crypto-badge {
					font-size: 13px !important;
					padding: 8px 12px !important;
				}
			}

/* === home.blade.php — hero — block 7 === */
/* FAQ Section Styles */
	.faq-category-btn:hover {
		background: rgba(255,205,0,0.1) !important;
		border-color: rgba(255,205,0,0.3) !important;
		color: #ffcd00 !important;
		transform: translateY(-2px);
	}
	
	.faq-category-btn.active {
		background: rgba(255,205,0,0.15) !important;
		border-color: #ffcd00 !important;
		color: #ffcd00 !important;
	}
	
	#faq-search:focus {
		outline: none;
		border-color: #ffcd00;
		background: rgba(255,255,255,0.08);
	}
	
	/* No-JS fallback: Show all answers by default */
	.faq-answer {
		max-height: 1000px !important;
		padding-top: 0 !important;
		overflow: visible !important;
	}
	
	/* Hide answers when JS is enabled (will be shown via JS toggle) */
	.js-enabled .faq-answer {
		max-height: 0 !important;
		overflow: hidden !important;
	}
	
	.faq-item.active .faq-answer {
		max-height: 1000px !important;
		padding-top: 0 !important;
	}
	
	.faq-item.active .faq-icon {
		transform: rotate(180deg);
	}
	
	.faq-item:hover {
		border-color: rgba(255,205,0,0.2);
		box-shadow: 0 4px 12px rgba(255,205,0,0.1);
	}
	
	.faq-question:hover {
		background: rgba(255,205,0,0.05) !important;
	}
	
	.faq-item.hidden {
		display: none;
	}
	
	.faq-item-hidden-initially {
		display: none !important;
	}
	
	.faq-item-hidden-initially.show {
		display: block !important;
		animation: fadeInUp 0.4s ease;
	}
	
	@keyframes fadeInUp {
		from {
			opacity: 0;
			transform: translateY(10px);
		}
		to {
			opacity: 1;
			transform: translateY(0);
		}
	}
	
	#faq-show-more-btn:hover {
		background: rgba(255,205,0,0.25) !important;
		border-color: #ffcd00 !important;
		transform: translateY(-2px);
		box-shadow: 0 4px 12px rgba(255,205,0,0.2);
	}
	
	#faq-show-more-btn.expanded #faq-show-more-icon {
		transform: rotate(180deg);
	}
	
	@media (max-width: 768px) {
		.faq-category-btn {
			font-size: 12px !important;
			padding: 10px 16px !important;
		}
		
		.faq-question span {
			font-size: 16px !important;
		}
	}

/* === home.blade.php — hero — block 8 === */
/* Ensure FAQ answers are visible without JavaScript */
			.faq-answer {
				max-height: none !important;
				overflow: visible !important;
				padding-top: 0 !important;
			}
			/* Show all FAQ items without JavaScript */
			.faq-item-hidden-initially {
				display: block !important;
			}
			#faq-show-more-container {
				display: none !important;
			}

/* === home.blade.php — hero — block 9 === */
/* ============================================
	   2025 Modern Landing Page - Complete Redesign
	   Based on UX/UI Review Feedback
	   ============================================ */
	
	/* === Typography Improvements === */
	/* Using local fonts: Poppins for headings, Roboto for body text */
	
	.section-heading h2 {
		font-family: 'Poppins', 'Roboto', sans-serif !important;
		font-weight: 700 !important;
		letter-spacing: -0.02em !important;
	}
	
	.section-heading p {
		font-family: 'Roboto', sans-serif !important;
		font-weight: 400 !important;
		line-height: 1.6 !important;
	}
	
	.banner-main h3 {
		font-family: 'Poppins', 'Roboto', sans-serif !important;
	}
	
	/* === Navigation Hover Animations === */
	.site-header-navbar .nav-link {
		position: relative;
		transition: color 0.3s ease, background-color 0.3s ease;
	}
	
	.site-header-navbar .nav-link:not(.dropdown-toggle)::after {
		content: '';
		position: absolute;
		bottom: 0;
		left: 50%;
		transform: translateX(-50%) scaleX(0);
		width: 0;
		height: 2px;
		background: #222;
		transition: transform 0.3s ease, width 0.3s ease;
	}
	
	.site-header-navbar .nav-link:not(.dropdown-toggle):hover::after,
	.site-header-navbar .nav-link:not(.dropdown-toggle).active::after {
		transform: translateX(-50%) scaleX(1);
		width: 80%;
	}
	
	.site-header-navbar .nav-link:hover {
		background-color: rgba(34, 34, 34, 0.1);
	}
	
	/* Dropdown menu styles */
	.site-header-navbar .dropdown-menu {
		margin-top: 8px;
	}
	
	.site-header-navbar .dropdown-menu .dropdown-item {
		transition: all 0.2s ease;
	}
	
	.site-header-navbar .dropdown-menu .dropdown-item:hover {
		background-color: rgba(255, 205, 0, 0.15) !important;
		color: #ffcd00 !important;
		padding-left: 28px !important;
		transform: translateX(4px);
	}
	
	.site-header-navbar .dropdown-toggle::after {
		margin-left: 6px;
		vertical-align: 0.2em;
		border-top: 0.35em solid;
		border-right: 0.35em solid transparent;
		border-bottom: 0;
		border-left: 0.35em solid transparent;
		transition: transform 0.2s ease;
	}
	
	.site-header-navbar .dropdown-toggle[aria-expanded="true"]::after {
		transform: rotate(180deg);
	}
	
	/* Mobile dropdown improvements */
	@media (max-width: 991px) {
		.site-header-navbar .dropdown-menu {
			position: static !important;
			float: none;
			width: 100%;
			margin-top: 0;
			background-color: rgba(20, 20, 20, 0.95) !important;
			border: none;
			border-top: 1px solid rgba(255, 205, 0, 0.2);
			border-radius: 0;
		}
	}
	
	/* === Scroll Animations === */
	/* No-JS fallback: Elements are visible by default */
	.fade-in-section {
		opacity: 1;
		transform: translateY(0);
		transition: opacity 0.6s ease-out, transform 0.6s ease-out;
	}
	
	/* Only hide elements if JavaScript is enabled */
	.js-enabled .fade-in-section {
		opacity: 0;
		transform: translateY(30px);
	}
	
	.js-enabled .fade-in-section.is-visible {
		opacity: 1;
		transform: translateY(0);
	}
	
	/* Stagger animations for cards - only when JS is enabled */
	.js-enabled .fade-in-section.delay-1 {
		transition-delay: 0.1s;
	}
	
	.js-enabled .fade-in-section.delay-2 {
		transition-delay: 0.2s;
	}
	
	.js-enabled .fade-in-section.delay-3 {
		transition-delay: 0.3s;
	}
	
	/* === Modern Section Separators (2025 UI/UX) === */
	.section-separator {
		position: relative;
		width: 100%;
		height: 2px;
		margin: 0;
		background: linear-gradient(90deg, 
			transparent 0%, 
			rgba(255, 205, 0, 0.15) 20%, 
			rgba(255, 205, 0, 0.3) 50%, 
			rgba(255, 205, 0, 0.15) 80%, 
			transparent 100%);
		box-shadow: 0 0 10px rgba(255, 205, 0, 0.2);
		animation: separator-fade-gentle 8s ease-in-out infinite;
	}
	
	.section-separator::before {
		content: "";
		position: absolute;
		top: 0;
		left: 0;
		width: 100%;
		height: 100%;
		background: linear-gradient(90deg, 
			transparent 0%, 
			rgba(255, 205, 0, 0.2) 20%, 
			rgba(255, 205, 0, 0.4) 50%, 
			rgba(255, 205, 0, 0.2) 80%, 
			transparent 100%);
		opacity: 0.3;
		animation: separator-fade-overlay 8s ease-in-out infinite;
	}
	
	@keyframes separator-fade-gentle {
		0%, 100% {
			box-shadow: 0 0 10px rgba(255, 205, 0, 0.2);
			opacity: 0.7;
		}
		50% {
			box-shadow: 0 0 15px rgba(255, 205, 0, 0.25);
			opacity: 0.85;
		}
	}
	
	@keyframes separator-fade-overlay {
		0%, 100% {
			opacity: 0.3;
		}
		50% {
			opacity: 0.5;
		}
	}
	
	/* Alternative separator style - gradient line with gentle glow */
	.section-separator-gradient {
		position: relative;
		width: 100%;
		height: 2px;
		margin: 0;
		background: linear-gradient(90deg, 
			transparent 0%, 
			rgba(255, 205, 0, 0.2) 20%, 
			rgba(255, 205, 0, 0.35) 50%, 
			rgba(255, 205, 0, 0.2) 80%, 
			transparent 100%);
		box-shadow: 0 0 12px rgba(255, 205, 0, 0.25);
		animation: separator-fade-gradient-gentle 8s ease-in-out infinite;
	}
	
	.section-separator-gradient::before {
		content: "";
		position: absolute;
		top: 0;
		left: 0;
		width: 100%;
		height: 100%;
		background: linear-gradient(90deg, 
			transparent 0%, 
			rgba(255, 205, 0, 0.25) 20%, 
			rgba(255, 205, 0, 0.45) 50%, 
			rgba(255, 205, 0, 0.25) 80%, 
			transparent 100%);
		opacity: 0.35;
		animation: separator-fade-gradient-overlay 8s ease-in-out infinite;
	}
	
	@keyframes separator-fade-gradient-gentle {
		0%, 100% {
			box-shadow: 0 0 12px rgba(255, 205, 0, 0.25);
			opacity: 0.75;
		}
		50% {
			box-shadow: 0 0 18px rgba(255, 205, 0, 0.3);
			opacity: 0.9;
		}
	}
	
	@keyframes separator-fade-gradient-overlay {
		0%, 100% {
			opacity: 0.35;
		}
		50% {
			opacity: 0.55;
		}
	}
	
	/* Reduced motion support for separators */
	@media (prefers-reduced-motion: reduce) {
		.section-separator,
		.section-separator-gradient {
			animation: none;
			box-shadow: 0 0 15px rgba(255, 205, 0, 0.3);
		}
		.section-separator::before,
		.section-separator-gradient::before {
			animation: none;
			opacity: 0.5;
		}
	}
	
	/* === Enhanced Card Styles === */
	.service-card {
		transition: transform 0.4s cubic-bezier(0.4, 0, 0.2, 1), box-shadow 0.4s ease, border-color 0.4s ease;
		position: relative;
		overflow: hidden;
	}

	/* === Row alignment across Tier 1 cards ===
	   Each card is a flex column; without explicit slot heights, variable
	   title / description copy makes the inner rows drift vertically
	   (title row at different Y, features starting at different lines,
	   primary button at different baseline). Reserve min-heights for the
	   variable slots so all four cards align horizontally.

	   Sizes are calibrated to the WORST-CASE actual rendered line count
	   at the col-lg-3 column width (~205px content area inside 45px
	   padding) rather than the line count we'd *expect* from character
	   count, because narrow columns wrap aggressively. Longest copies
	   observed across the 16 shipped locales:
	     - title:       29 chars ("E-Mail-Weiterleitung & Aliase" / DE)
	                    -> ~3 lines @ 28px/1.25 = 105px
	     - description: 168 chars ("Numéros de téléphone..." / FR)
	                    -> ~8 lines @ 16px/1.7 = 217px

	     [icon] -> already fixed height
	     [title]            min-height 110px (3 lines + small buffer)
	     [price]            min-height 34px  (1 line @ 22px/1.4, slot
	                         always rendered so cards w/o price still align)
	     [description]      min-height 220px (8 lines + buffer; covers
	                         the long French/German/Polish strings)
	     [separator + features] uniform (all cards ship 4 features)
	     [cta]              min-height 84px  (~24px chip + 10px gap + 50px
	                         primary button; absent chip => empty gap above
	                         the button, justify-content: flex-end keeps the
	                         primary pinned to the bottom edge so every
	                         card's button sits at the SAME baseline)

	   Scoped to ≥992px because that's where col-lg-3 (4-up) kicks in and
	   columns become narrow enough for the wrapping to drift. Between
	   768–991px the cards render at col-md-6 (2-up, much wider columns),
	   so the same min-heights would just bake in wasted whitespace there.
	   Below 768px cards stack vertically and alignment is irrelevant. */
	@media (min-width: 992px) {
		.service-card-title {
			min-height: 110px;
			display: flex;
			align-items: center;
			justify-content: center;
		}
		.service-card-price {
			min-height: 34px;
		}
		.service-card-description {
			min-height: 220px;
		}
		.service-card-cta {
			min-height: 84px;
			display: flex;
			flex-direction: column;
			justify-content: flex-end;
			align-items: stretch;
		}
		/* Center the chip within the CTA slot (otherwise align-items:
		   stretch above would make it span the full width). */
		.service-card-cta .service-card-chip {
			align-self: center;
		}
	}
	
	.service-card::before {
		content: '';
		position: absolute;
		top: 0;
		left: -100%;
		width: 100%;
		height: 100%;
		background: linear-gradient(90deg, transparent, rgba(255, 205, 0, 0.15), transparent);
		transition: left 0.6s ease;
		z-index: 0;
	}
	
	.service-card::after {
		content: '';
		position: absolute;
		top: -50%;
		right: -50%;
		width: 200%;
		height: 200%;
		background: radial-gradient(circle, rgba(255, 205, 0, 0.05) 0%, transparent 70%);
		opacity: 0;
		transition: opacity 0.4s ease;
		pointer-events: none;
	}
	
	@media (min-width: 768px) {
		.service-card:hover {
			transform: translateY(-12px) scale(1.02);
			box-shadow: 0 20px 60px rgba(255, 205, 0, 0.3);
			border-color: rgba(255, 205, 0, 0.4) !important;
		}
		
		.service-card:hover::before {
			left: 100%;
		}
		
		.service-card:hover::after {
			opacity: 1;
		}
		
		.intro-box-modern:hover {
			transform: translateY(-8px);
			border-color: rgba(255,205,0,0.4);
			box-shadow: 0 15px 40px rgba(255,205,0,0.15);
		}
		
		.country-card:hover {
			transform: translateY(-8px);
			border-color: rgba(255,205,0,0.4);
			box-shadow: 0 15px 40px rgba(255,205,0,0.15);
		}
		
		/* Virtual Numbers Country Links Hover */
		.pricing-card-modern a[href*="phone-numbers"]:hover:not(.pricing-cta-modern),
		.pricing-card-modern a[href*="register"]:hover:not(.pricing-cta-modern) {
			transform: translateY(-2px);
			border-color: rgba(255,205,0,0.3) !important;
			background: rgba(255,255,255,0.05) !important;
			box-shadow: 0 4px 12px rgba(255,205,0,0.15);
		}
		
		/* Country item hover effects */
		.country-item:hover {
			transform: translateY(-2px);
			border-color: rgba(255,205,0,0.3) !important;
			background: rgba(255,255,255,0.05) !important;
		}
		
		.country-grid-compact .country-item {
			margin-bottom: 35px;
		}
		
		.country-grid-compact .country-item:hover .country-name {
			opacity: 1 !important;
		}
		
		@media (max-width: 768px) {
			.pricing-card-modern .pricing-body-modern > div[style*="grid-template-columns"] {
				grid-template-columns: 1fr !important;
			}
			.pricing-card-modern .pricing-body-modern > div[style*="grid-template-columns: 1fr 1fr"] {
				grid-template-columns: 1fr !important;
				gap: 20px !important;
			}
			.pricing-card-modern .pricing-body-modern > div[style*="grid-template-columns: 1fr 1fr 1fr"] {
				grid-template-columns: 1fr !important;
				gap: 30px !important;
			}
			.pricing-card-modern .pricing-body-modern[style*="padding: 50px 60px"],
			.pricing-card-modern .pricing-body-modern[style*="padding: 60px 80px"] {
				padding: 40px 30px !important;
			}
			.pricing-card-modern .pricing-footer-modern[style*="padding: 0 60px 50px"],
			.pricing-card-modern .pricing-footer-modern[style*="padding: 0 80px 60px"] {
				padding: 0 30px 40px !important;
			}
			.pricing-card-modern .pricing-body-modern > div[style*="grid-template-columns: 1.2fr 1fr"] {
				grid-template-columns: 1fr !important;
				gap: 30px !important;
			}
		}
		
		.use-case-card:hover {
			transform: translateY(-8px);
			border-color: rgba(255,205,0,0.3);
			box-shadow: 0 15px 40px rgba(255,205,0,0.15);
		}
		
		.review-card:hover {
			transform: translateY(-8px);
			border-color: rgba(255,205,0,0.3);
			box-shadow: 0 15px 40px rgba(255,205,0,0.15);
		}
		
		.pricing-card-modern:hover {
			transform: translateY(-10px) scale(1.02);
		}
	}
	
	/* === Enhanced Color Scheme === */
	:root {
		--primary-yellow: #ffcd00;
		--primary-yellow-light: #ffef00;
		--primary-yellow-dark: #f0b800;
		--accent-green: #22c55e;
		--accent-blue: #3b82f6;
		--accent-purple: #8b5cf6;
		--bg-dark: #0a0a0a;
		--bg-darker: #050505;
		--bg-light: rgba(255, 255, 255, 0.05);
		--text-primary: #ffffff;
		--text-secondary: #aaaaaa;
		--text-muted: #666666;
	}
	
	/* Gradient accents for key elements */
	.gradient-accent {
		background: linear-gradient(135deg, var(--primary-yellow) 0%, var(--primary-yellow-light) 100%);
		-webkit-background-clip: text;
		-webkit-text-fill-color: transparent;
		background-clip: text;
	}
	
	/* === Visual Enhancements === */
	/* Animated lock icon for encryption */
	@keyframes lock-pulse {
		0%, 100% { transform: scale(1); opacity: 1; }
		50% { transform: scale(1.1); opacity: 0.8; }
	}
	
	.encryption-icon {
		animation: lock-pulse 2s ease-in-out infinite;
	}
	
	/* Subtle glow effects */
	.glow-effect {
		position: relative;
	}
	
	.glow-effect::before {
		content: '';
		position: absolute;
		top: 50%;
		left: 50%;
		transform: translate(-50%, -50%);
		width: 120%;
		height: 120%;
		background: radial-gradient(circle, rgba(255, 205, 0, 0.2) 0%, transparent 70%);
		opacity: 0;
		transition: opacity 0.4s ease;
		pointer-events: none;
		z-index: -1;
	}
	
	.glow-effect:hover::before {
		opacity: 1;
	}
	
	/* === Tooltip Styles === */
	.tooltip-trigger {
		position: relative;
		cursor: help;
		border-bottom: 1px dotted rgba(255, 205, 0, 0.5);
		text-decoration: none;
	}
	
	.tooltip-content {
		position: absolute;
		bottom: 100%;
		left: 50%;
		transform: translateX(-50%) translateY(-8px);
		background: rgba(20, 20, 20, 0.98);
		color: #fff;
		padding: 12px 16px;
		border-radius: 8px;
		font-size: 13px;
		line-height: 1.5;
		white-space: nowrap;
		opacity: 0;
		pointer-events: none;
		transition: opacity 0.3s ease, transform 0.3s ease;
		border: 1px solid rgba(255, 205, 0, 0.3);
		box-shadow: 0 4px 20px rgba(0, 0, 0, 0.5);
		z-index: 1000;
		max-width: 250px;
		white-space: normal;
	}
	
	.tooltip-trigger:hover .tooltip-content {
		opacity: 1;
		transform: translateX(-50%) translateY(-12px);
		pointer-events: auto;
	}
	
	.tooltip-content::after {
		content: '';
		position: absolute;
		top: 100%;
		left: 50%;
		transform: translateX(-50%);
		border: 6px solid transparent;
		border-top-color: rgba(20, 20, 20, 0.98);
	}
	
	/* === Enhanced Button Styles === */
	.btn-feature {
		transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
		position: relative;
		overflow: hidden;
		font-weight: 600;
		letter-spacing: 0.5px;
	}
	
	.btn-feature::before {
		content: '';
		position: absolute;
		top: 0;
		left: -100%;
		width: 100%;
		height: 100%;
		background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.2), transparent);
		transition: left 0.5s ease;
	}
	
	.btn-feature:hover::before {
		left: 100%;
	}
	
	.btn-feature:hover {
		transform: translateY(-2px) scale(1.02);
		box-shadow: 0 8px 25px rgba(255, 205, 0, 0.4);
	}
	
	.btn-feature:active {
		transform: translateY(0) scale(0.98);
	}
	
	/* === Accessibility Improvements === */
	/* Focus styles for keyboard navigation */
	*:focus-visible {
		outline: 2px solid var(--primary-yellow);
		outline-offset: 2px;
		border-radius: 4px;
	}
	
	/* High contrast mode support */
	@media (prefers-contrast: high) {
		.service-card,
		.intro-box-modern,
		.pricing-card-modern {
			border-width: 2px;
			border-color: rgba(255, 255, 255, 0.3);
		}
	}
	
	/* Reduced motion support */
	@media (prefers-reduced-motion: reduce) {
		*,
		*::before,
		*::after {
			animation-duration: 0.01ms !important;
			animation-iteration-count: 1 !important;
			transition-duration: 0.01ms !important;
		}
		
		.js-enabled .fade-in-section {
			opacity: 1 !important;
			transform: none !important;
		}
	}
	
	/* === Section Background Variations === */
	#section-services {
		background: linear-gradient(135deg, #0a0a0a 0%, #1a1a1a 100%) !important;
		position: relative;
	}
	
	#section-services::before {
		content: '';
		position: absolute;
		top: 0;
		left: 0;
		right: 0;
		bottom: 0;
		background: radial-gradient(circle at 20% 50%, rgba(255, 205, 0, 0.03) 0%, transparent 50%),
		            radial-gradient(circle at 80% 50%, rgba(255, 205, 0, 0.02) 0%, transparent 50%);
		pointer-events: none;
	}
	
	/* === Responsive Improvements === */
	@media (max-width: 768px) {
		.service-card, .intro-box-modern, .pricing-card-modern {
			margin-bottom: 30px;
		}
		
		#section-services .section-heading h2,
		#section-pricing .section-heading h2 {
			font-size: 32px !important;
		}
		
		.price-amount-modern {
			font-size: 42px !important;
		}
		
		.sticky-nav {
			padding: 0.5rem 0;
		}
		
		.banner-main h3 {
			font-size: 2rem !important;
		}
		
		/* Comparison Section (Why Choose Crypton.sh) - Mobile Responsive */
		#section-comparison .section-heading h2 {
			font-size: 32px !important;
		}
		
		#section-comparison .section-heading p {
			font-size: 16px !important;
		}
		
		#section-comparison table {
			display: none;
		}
		
		#section-comparison .comparison-mobile {
			display: block;
		}
		
		#section-comparison .comparison-mobile .comparison-item {
			background: rgba(255,255,255,0.03);
			border: 1px solid rgba(255,255,255,0.08);
			border-radius: 16px;
			padding: 20px;
			margin-bottom: 15px;
		}
		
		#section-comparison .comparison-mobile .comparison-item .feature-title {
			color: #fff;
			font-weight: 700;
			font-size: 16px;
			margin-bottom: 15px;
			padding-bottom: 12px;
			border-bottom: 1px solid rgba(255,255,255,0.1);
		}
		
		#section-comparison .comparison-mobile .comparison-row {
			display: flex;
			justify-content: space-between;
			align-items: center;
			padding: 10px 0;
		}
		
		#section-comparison .comparison-mobile .comparison-row:not(:last-child) {
			border-bottom: 1px solid rgba(255,255,255,0.05);
		}
		
		#section-comparison .comparison-mobile .comparison-label {
			color: #aaa;
			font-size: 14px;
			font-weight: 600;
		}
		
		#section-comparison .comparison-mobile .comparison-value {
			font-size: 18px;
			font-weight: 700;
		}
		
		#section-comparison .comparison-mobile .comparison-value.crypton {
			color: #ffcd00;
		}
		
		#section-comparison .comparison-mobile .comparison-value.others {
			color: #999;
		}
		
		/* Message Pricing Section - Mobile Responsive */
		.message-pricing-container {
			grid-template-columns: 1fr !important;
			gap: 25px !important;
		}
		
		/* Reorder elements on mobile: Country selector first, then pricing cards, then features */
		.message-pricing-left {
			order: 1 !important;
			display: flex !important;
			flex-direction: column !important;
		}
		
		.message-pricing-country-selector {
			order: 1 !important;
			margin-bottom: 20px !important;
		}
		
		.message-pricing-cards {
			order: 2 !important;
		}
		
		.message-pricing-features {
			order: 3 !important;
		}
		
		#section-pricing .pricing-card-modern .pricing-body-modern[style*="padding: 40px 60px 60px"] {
			padding: 25px 20px 35px !important;
		}
		
		#section-pricing .pricing-card-modern .pricing-header-modern[style*="padding: 40px 40px 20px"] {
			padding: 25px 20px 15px !important;
		}
		
		#section-pricing .pricing-card-modern .pricing-header-modern h4 {
			font-size: 24px !important;
			line-height: 1.3 !important;
		}
		
		#section-pricing .pricing-card-modern .pricing-header-modern p {
			font-size: 14px !important;
			margin-top: 8px !important;
		}
		
		#section-pricing .pricing-card-modern .pricing-footer-modern[style*="padding: 0 60px 50px"] {
			padding: 0 20px 35px !important;
		}
		
		#section-pricing .pricing-card-modern .pricing-footer-modern .pricing-cta-modern {
			max-width: 100% !important;
			width: 100% !important;
			padding: 16px 30px !important;
			font-size: 16px !important;
		}
		
		/* Country Selector Mobile */
		.message-pricing-country-selector {
			padding: 20px !important;
		}
		
		.message-pricing-country-selector label {
			font-size: 14px !important;
			margin-bottom: 12px !important;
		}
		
		#section-pricing #country-price-form {
			font-size: 15px !important;
			padding: 12px 20px 12px 65px !important;
		}
		
		#section-pricing #country-flag-select {
			font-size: 28px !important;
			left: 15px !important;
		}
		
		/* Pricing Cards Mobile */
		.message-pricing-cards {
			grid-template-columns: 1fr !important;
			gap: 15px !important;
		}
		
		.message-pricing-cards > div {
			padding: 20px !important;
		}
		
		.message-pricing-cards > div > div:first-child {
			font-size: 12px !important;
			margin-bottom: 10px !important;
		}
		
		.message-pricing-cards > div > div:nth-child(2) {
			font-size: 28px !important;
			margin-bottom: 6px !important;
		}
		
		.message-pricing-cards > div > div:last-child {
			font-size: 12px !important;
		}
		
		/* Features List Mobile */
		.message-pricing-features > div {
			padding: 25px !important;
		}
		
		.message-pricing-features h5 {
			font-size: 18px !important;
			margin-bottom: 18px !important;
		}
		
		.message-pricing-features h5 i {
			font-size: 20px !important;
		}
		
		.message-pricing-features ul li {
			padding: 12px 0 !important;
			font-size: 14px !important;
		}
		
		.message-pricing-features ul li i {
			font-size: 14px !important;
			margin-top: 2px !important;
		}
	}
	
	/* === Smooth Scroll Behavior === */
	html {
		scroll-behavior: smooth;
		scroll-padding-top: 80px;
	}
	
	/* === Form Select Styling === */
	#country-price-form {
		color: #fff !important;
	}
	
	#country-price-form option {
		background: #1a1a1a;
		color: #fff;
	}
	
	/* === FAQ Subtitle Centering Fix === */
	.feature-inner {
		text-align: center !important;
		width: 100% !important;
		float: none !important;
	}
	
	.feature-inner p {
		float: none !important;
		text-align: center !important;
		margin: 0 auto !important;
		display: block !important;
	}
	
	
	/* === Trust Badge Animation === */
	@keyframes float {
		0%, 100% { transform: translateY(0px); }
		50% { transform: translateY(-10px); }
	}
	
	.trust-badge {
		animation: float 3s ease-in-out infinite;
	}
	
	/* === Icon Enhancements === */
	.service-card i,
	.intro-box-modern i {
		transition: transform 0.3s ease, color 0.3s ease;
	}
	
	.service-card:hover i,
	.intro-box-modern:hover i {
		transform: scale(1.1) rotate(5deg);
		color: var(--primary-yellow-light) !important;
	}
	
	/* === CTA Button Improvements === */
	.cta-primary {
		background: linear-gradient(135deg, var(--primary-yellow) 0%, var(--primary-yellow-light) 100%);
		color: #000;
		font-weight: 700;
		padding: 16px 40px;
		border-radius: 12px;
		border: none;
		box-shadow: 0 4px 15px rgba(255, 205, 0, 0.3);
		transition: all 0.3s ease;
	}
	
	.cta-primary:hover {
		transform: translateY(-3px);
		box-shadow: 0 8px 25px rgba(255, 205, 0, 0.5);
	}
	
	.cta-secondary {
		background: rgba(255, 205, 0, 0.1);
		color: var(--primary-yellow);
		border: 2px solid var(--primary-yellow);
		font-weight: 600;
		padding: 14px 38px;
		border-radius: 12px;
		transition: all 0.3s ease;
	}
	
	.cta-secondary:hover {
		background: rgba(255, 205, 0, 0.2);
		transform: translateY(-2px);
		box-shadow: 0 6px 20px rgba(255, 205, 0, 0.2);
	}

/* === home.blade.php — hero — block 10 === */
/* === API Code Examples Styles === */
	.api-example-toggle:hover {
		background: rgba(255,255,255,0.08) !important;
		border-color: rgba(255,205,0,0.3) !important;
	}
	
	.api-example-item.active .api-example-code {
		max-height: 1000px !important;
		padding-top: 15px !important;
	}
	
	.api-example-item.active .api-example-icon {
		transform: rotate(180deg) !important;
	}
	
	/* Visual enhancements for encryption concepts */
	.encryption-visual {
		display: inline-flex;
		align-items: center;
		gap: 8px;
		margin: 10px 0;
	}
	
	.encryption-visual i {
		font-size: 20px;
		color: #ffcd00;
		animation: lock-pulse 2s ease-in-out infinite;
	}
	
	/* Break up text walls with visual separators */
	.text-separator {
		width: 60px;
		height: 3px;
		background: linear-gradient(90deg, transparent, #ffcd00, transparent);
		margin: 30px auto;
		border-radius: 2px;
	}

/* === Crypton Mobile teaser === */
#section-mobile.cm-teaser-section {
	position: relative;
	scroll-margin-top: 100px;
	padding: 56px 0 64px;
	overflow: hidden;
	background:
		radial-gradient(ellipse 90% 60% at 50% 0%, rgba(255, 205, 0, 0.16), transparent 55%),
		linear-gradient(180deg, #121218 0%, #0a0a0c 100%);
	border-top: 1px solid rgba(255, 205, 0, 0.25);
	border-bottom: 1px solid rgba(255, 255, 255, 0.06);
}

#section-mobile .cm-teaser-card {
	position: relative;
	border-radius: 20px;
	padding: 32px 36px;
	background: linear-gradient(155deg, rgba(18, 18, 22, 0.98) 0%, rgba(8, 8, 12, 0.99) 100%);
	border: 2px solid rgba(255, 205, 0, 0.75);
	box-shadow:
		0 24px 56px rgba(0, 0, 0, 0.45),
		0 0 80px rgba(255, 205, 0, 0.08);
}

#section-mobile .cm-teaser-card-bg {
	position: absolute;
	inset: 0;
	border-radius: inherit;
	pointer-events: none;
	overflow: hidden;
}

#section-mobile .cm-teaser-card-bg::before {
	content: '';
	position: absolute;
	inset: 0;
	background:
		radial-gradient(ellipse 70% 55% at 0% 0%, rgba(255, 205, 0, 0.14), transparent 50%),
		radial-gradient(circle at 100% 100%, rgba(255, 205, 0, 0.08), transparent 45%);
}

#section-mobile .cm-teaser-layout {
	position: relative;
	z-index: 1;
	display: grid;
	grid-template-columns: minmax(0, 1fr) auto;
	gap: 28px 40px;
	align-items: center;
}

#section-mobile .cm-teaser-eyebrow {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	margin: 0 0 14px;
	padding: 6px 12px;
	border-radius: 999px;
	background: rgba(255, 205, 0, 0.12);
	border: 1px solid rgba(255, 205, 0, 0.35);
	color: #ffcd00 !important;
	font-size: 11px;
	font-weight: 800;
	letter-spacing: 1.2px;
	text-transform: uppercase;
}

#section-mobile .cm-teaser-title {
	margin: 0 0 14px;
	line-height: 1;
}

#section-mobile .cm-teaser-title-mark {
	display: inline-flex;
	align-items: center;
	flex-wrap: nowrap;
	gap: 0.32em;
	font-size: clamp(2rem, 3.2vw, 2.75rem);
	font-weight: 800;
	line-height: 1;
	letter-spacing: -0.03em;
}

#section-mobile .cm-teaser-logo-full {
	display: block;
	/* Match cap-height of the adjacent Mobile label (same ratio as pre-refactor teaser) */
	height: 1.15em;
	width: auto;
	max-width: min(100%, 280px);
	margin: 0;
	flex: 0 0 auto;
	align-self: center;
	object-fit: contain;
	object-position: left center;
	vertical-align: middle;
	filter: drop-shadow(0 2px 10px rgba(255, 205, 0, 0.35)) brightness(0) saturate(100%) invert(82%) sepia(58%) saturate(1100%) hue-rotate(358deg) brightness(1.07) contrast(1.06);
}

#section-mobile .cm-teaser-title-accent {
	display: inline-block;
	font-size: 1em;
	line-height: 1;
	font-weight: 800;
	letter-spacing: -0.03em;
	padding: 0;
	margin: 0;
	background: linear-gradient(135deg, #fff8c8 0%, #ffcd00 45%, #e6b000 100%);
	-webkit-background-clip: text;
	background-clip: text;
	-webkit-text-fill-color: transparent;
	color: #ffcd00;
}

.dark-mode #section-mobile .cm-teaser-desc,
.dark-mode #section-mobile .cm-teaser-feature {
	color: #f0f0f4 !important;
}

#section-mobile .cm-teaser-desc {
	margin: 0 0 20px;
	max-width: 52ch;
	color: rgba(255, 255, 255, 0.82) !important;
	font-size: 16px;
	line-height: 1.65;
}

#section-mobile .cm-teaser-features {
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
	margin: 0;
	padding: 0;
	list-style: none;
}

#section-mobile .cm-teaser-feature {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	padding: 8px 14px;
	border-radius: 999px;
	background: rgba(0, 0, 0, 0.35);
	border: 1px solid rgba(255, 205, 0, 0.3);
	color: #fff !important;
	font-size: 13px;
	font-weight: 600;
	line-height: 1.3;
	white-space: nowrap;
}

#section-mobile .cm-teaser-feature i {
	color: #ffcd00;
	flex-shrink: 0;
}

#section-mobile .cm-teaser-feature--muted {
	opacity: 0.65;
}

#section-mobile .cm-teaser-action {
	display: flex;
	justify-content: flex-end;
	align-items: center;
}

#section-mobile .cm-teaser-cta {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	gap: 6px;
	padding: 15px 28px;
	border-radius: 12px;
	background: linear-gradient(135deg, #ffef00 0%, #ffcd00 50%, #e6b000 100%);
	color: #000 !important;
	font-weight: 700;
	font-size: 14px;
	text-transform: uppercase;
	letter-spacing: 0.3px;
	border: none;
	box-shadow: 0 8px 28px rgba(255, 205, 0, 0.35);
	white-space: nowrap;
	transition: transform 0.2s ease, box-shadow 0.2s ease;
}

#section-mobile .cm-teaser-cta:hover {
	transform: translateY(-2px);
	box-shadow: 0 12px 36px rgba(255, 205, 0, 0.45);
	color: #000 !important;
}

#section-mobile .cm-teaser-cta-arrow {
	transition: transform 0.25s ease;
}

#section-mobile .cm-teaser-cta:hover .cm-teaser-cta-arrow {
	transform: translateX(4px);
}

@media (max-width: 991px) {
	#section-mobile .cm-teaser-layout {
		grid-template-columns: 1fr;
		gap: 24px;
	}

	#section-mobile .cm-teaser-action {
		justify-content: stretch;
	}

	#section-mobile .cm-teaser-cta {
		width: 100%;
	}
}

@media (max-width: 576px) {
	#section-mobile.cm-teaser-section {
		padding: 40px 0 48px;
	}

	#section-mobile .cm-teaser-card {
		padding: 48px 20px 24px;
	}

	#section-mobile .cm-teaser-features {
		flex-direction: column;
		align-items: stretch;
	}

	#section-mobile .cm-teaser-feature {
		white-space: normal;
	}
}

@media (prefers-reduced-motion: reduce) {
	#section-mobile .cm-teaser-cta,
	#section-mobile .cm-teaser-cta-arrow {
		transition: none;
	}
}


/* === Footer ambient orbs (main footer only — 2 large glows) === */
#section-footer.section-footer-modern {
	overflow: hidden;
}

.footer-ambient {
	position: absolute;
	inset: -20% 0;
	z-index: 0;
	pointer-events: none;
	overflow: hidden;
}

.footer-orb {
	position: absolute;
	border-radius: 50%;
	filter: blur(64px);
	will-change: transform, opacity;
	animation: footerOrbDrift 36s ease-in-out infinite;
}

.footer-orb--a {
	width: min(72vw, 560px);
	height: min(72vw, 560px);
	background: radial-gradient(
		circle at 42% 42%,
		rgba(255, 205, 0, 0.7) 0%,
		rgba(255, 205, 0, 0.35) 32%,
		rgba(255, 180, 0, 0.12) 58%,
		transparent 72%
	);
	top: -35%;
	left: -18%;
	opacity: 0.48;
	animation-duration: 38s;
	animation-delay: -8s;
}

.footer-orb--b {
	width: min(65vw, 480px);
	height: min(65vw, 480px);
	background: radial-gradient(
		circle at 58% 52%,
		rgba(255, 205, 0, 0.65) 0%,
		rgba(255, 190, 0, 0.3) 38%,
		rgba(255, 160, 0, 0.1) 58%,
		transparent 74%
	);
	bottom: -40%;
	right: -14%;
	opacity: 0.42;
	animation-duration: 44s;
	animation-delay: -18s;
}

@keyframes footerOrbDrift {
	0%,
	100% {
		transform: translate(0, 0) scale(1);
		opacity: 0.38;
	}
	50% {
		transform: translate(4%, -3%) scale(1.04);
		opacity: 0.52;
	}
}

@media (prefers-reduced-motion: reduce) {
	.footer-orb {
		animation: none;
		opacity: 0.42;
	}
}

/* === esim-vs-mobile — block 1 === */
.esim-vs-mobile-card:hover {
                background: rgba(23, 162, 184, 0.12) !important;
                border-color: rgba(23, 162, 184, 0.45) !important;
                transform: translateY(-1px);
            }
            @media (max-width: 640px) {
                .esim-vs-mobile-panel > div:last-child {
                    grid-template-columns: 1fr !important;
                }
                .esim-vs-mobile-panel > div:last-child > div[aria-hidden] {
                    display: none !important;
                }
            }

/* ── Crypton scrollbars (match app / auth) ── */
html {
	--crypton-scrollbar-size: 10px;
	--crypton-scrollbar-track: rgba(255, 255, 255, 0.07);
	--crypton-scrollbar-track-hover: rgba(255, 255, 255, 0.1);
	--crypton-scrollbar-thumb: rgba(255, 202, 32, 0.48);
	--crypton-scrollbar-thumb-hover: rgba(255, 202, 32, 0.68);
	--crypton-scrollbar-thumb-active: rgba(255, 214, 80, 0.85);
	scrollbar-width: thin;
	scrollbar-color: var(--crypton-scrollbar-thumb) var(--crypton-scrollbar-track);
}

html:not(.dark-mode) {
	--crypton-scrollbar-track: rgba(0, 0, 0, 0.06);
	--crypton-scrollbar-track-hover: rgba(0, 0, 0, 0.1);
}

html ::-webkit-scrollbar {
	width: var(--crypton-scrollbar-size);
	height: var(--crypton-scrollbar-size);
}

html ::-webkit-scrollbar-track {
	background: var(--crypton-scrollbar-track);
	border-radius: 999px;
}

html ::-webkit-scrollbar-track:hover {
	background: var(--crypton-scrollbar-track-hover);
}

html ::-webkit-scrollbar-thumb {
	background-color: var(--crypton-scrollbar-thumb);
	border: 2px solid transparent;
	background-clip: padding-box;
	border-radius: 999px;
	box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.08);
}

html ::-webkit-scrollbar-thumb:hover {
	background-color: var(--crypton-scrollbar-thumb-hover);
}

html ::-webkit-scrollbar-thumb:active {
	background-color: var(--crypton-scrollbar-thumb-active);
}

html ::-webkit-scrollbar-corner {
	background: transparent;
}
