/*********  VARIABLES  **********/

:root {
	/* Couleurs principales - Palette Crimson */
	--color-primary: #BE123C;
	--color-primary-light: #FFF1F2;
	--color-primary-dark: #9F1239;
	--color-accent: #FDA4AF;

	/* Texte */
	--color-text: #0A0406;
	--color-text-secondary: #6B7280;
	--color-text-light: #9CA3AF;

	/* Fond et bordures */
	--color-background: #FAFAFA;
	--color-background-alt: #F3F4F6;
	--color-border: #E5E7EB;
	--color-white: #FFFFFF;

	/* États */
	--color-success: #10B981;
	--color-error: #EF4444;
	--color-warning: #F59E0B;

	/* Ombres */
	--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, 0.05);
	--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, 0.1);
	--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, 0.1);

	/* Rayons */
	--radius-sm: 4px;
	--radius-md: 8px;
	--radius-lg: 12px;
	--radius-xl: 20px;
}

/*********  RESET & BASE  **********/

* {
	box-sizing: border-box;
}

body {
	font-family: 'Jost', sans-serif;
	color: var(--color-text);
	font-weight: 300;
	line-height: 1.6;
	scroll-behavior: smooth;
	background-color: var(--color-white);
}

/*********  TYPOGRAPHY  **********/

h1, h2, h3, h4, h5, h6 {
	font-weight: 600;
	line-height: 1.2;
	color: var(--color-text);
}

h1 {
	font-size: 3.5rem;
}

h2 {
	font-size: 2.5rem;
	margin-bottom: 1rem;
}

h3 {
	font-size: 1.75rem;
	color: var(--color-text-secondary);
}

p {
	line-height: 1.7;
	margin-bottom: 1rem;
}

/*********  LINKS  **********/

a {
	color: var(--color-primary);
	text-decoration: none;
	transition: opacity 0.3s ease;
}

a:hover {
	opacity: 0.8;
	text-decoration: none;
	color: var(--color-primary);
}

/*********  BUTTONS  **********/

.btn-primary {
	background-color: var(--color-primary);
	border-color: var(--color-primary);
	color: var(--color-white);
	font-weight: 600;
	padding: 12px 28px;
	border-radius: var(--radius-md);
	transition: all 0.3s ease;
}

.btn-primary:hover {
	background-color: var(--color-primary-dark);
	border-color: var(--color-primary-dark);
	color: var(--color-white);
	transform: translateY(-2px);
	box-shadow: var(--shadow-md);
}

.btn-outline-primary {
	background-color: transparent;
	border: 2px solid var(--color-primary);
	color: var(--color-primary);
	font-weight: 600;
	padding: 10px 26px;
	border-radius: var(--radius-md);
	transition: all 0.3s ease;
}

.btn-outline-primary:hover {
	background-color: var(--color-primary);
	color: var(--color-white);
}

.btn-lg {
	padding: 16px 36px;
	font-size: 1.125rem;
}

/*********  NAVBAR  **********/

.navbar {
	background-color: var(--color-white) !important;
	box-shadow: var(--shadow-sm);
	padding: 0.5rem 0;
}

.navbar-brand img {
	height: 50px;
	width: auto;
}

.nav-link {
	color: var(--color-text) !important;
	font-weight: 400;
	padding: 0.5rem 1rem !important;
	transition: color 0.3s ease;
}

.nav-link:hover {
	color: var(--color-primary) !important;
}

.nav-link.active {
	color: var(--color-primary) !important;
	font-weight: 600;
}

/*********  HERO  **********/

.hero {
	background: linear-gradient(135deg, var(--color-primary) 0%, var(--color-primary-dark) 100%);
	color: var(--color-white);
	padding: 100px 0;
	text-align: center;
	position: relative;
	overflow: hidden;
}

.hero::before {
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	background: url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='none' fill-rule='evenodd'%3E%3Cg fill='%23ffffff' fill-opacity='0.05'%3E%3Ccircle cx='30' cy='30' r='2'/%3E%3C/g%3E%3C/g%3E%3C/svg%3E");
	pointer-events: none;
}

.hero h1 {
	color: var(--color-white);
	font-size: 3rem;
	margin-bottom: 1.5rem;
	position: relative;
}

.hero .lead {
	font-size: 1.25rem;
	opacity: 0.95;
	max-width: 700px;
	margin: 0 auto 2rem;
	position: relative;
}

.hero .btn-primary {
	background-color: var(--color-white);
	color: var(--color-primary);
	border-color: var(--color-white);
}

.hero .btn-primary:hover {
	background-color: var(--color-primary-light);
	color: var(--color-primary-dark);
	border-color: var(--color-primary-light);
}

.hero .btn-outline-primary {
	border-color: var(--color-white);
	color: var(--color-white);
}

.hero .btn-outline-primary:hover {
	background-color: var(--color-white);
	color: var(--color-primary);
}

/*********  SECTIONS  **********/

section {
	padding: 80px 0;
}

.section-light {
	background-color: var(--color-background);
}

.section-title {
	text-align: center;
	margin-bottom: 3rem;
}

.section-title h2 {
	color: var(--color-text);
	margin-bottom: 0.5rem;
}

.section-title h3 {
	color: var(--color-text-secondary);
	font-weight: 400;
	font-size: 1.25rem;
}

/*********  STATS / CHIFFRES CLÉS  **********/

.stats {
	background-color: var(--color-primary-light);
	padding: 60px 0;
}

.stat-item {
	text-align: center;
	padding: 20px;
}

.stat-number {
	font-size: 3rem;
	font-weight: 600;
	color: var(--color-primary);
	line-height: 1;
	margin-bottom: 0.5rem;
}

.stat-label {
	color: var(--color-text-secondary);
	font-size: 1rem;
}

/*********  FEATURE BOXES  **********/

.feature-box {
	background-color: var(--color-white);
	border: 1px solid var(--color-border);
	border-radius: var(--radius-lg);
	padding: 2rem;
	height: 100%;
	transition: all 0.3s ease;
	display: flex;
	flex-direction: column;
}

.feature-box:hover {
	box-shadow: var(--shadow-lg);
	transform: translateY(-5px);
	border-color: var(--color-accent);
}

.feature-box .icon {
	width: 56px;
	height: 56px;
	background-color: var(--color-primary-light);
	border-radius: var(--radius-md);
	display: flex;
	align-items: center;
	justify-content: center;
	margin-bottom: 1.5rem;
}

.feature-box .icon svg {
	width: 28px;
	height: 28px;
	fill: var(--color-primary);
}

.feature-box h5 {
	font-size: 1.25rem;
	margin-bottom: 1rem;
	color: var(--color-text);
}

.feature-box p {
	color: var(--color-text-secondary);
	flex-grow: 1;
	margin-bottom: 0;
}

/*********  TARGET CARDS (Pour qui)  **********/

.target-card {
	background-color: var(--color-white);
	border-radius: var(--radius-lg);
	padding: 2.5rem;
	text-align: center;
	height: 100%;
	border: 2px solid transparent;
	transition: all 0.3s ease;
}

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

.target-card .icon {
	width: 80px;
	height: 80px;
	background: linear-gradient(135deg, var(--color-primary) 0%, var(--color-primary-dark) 100%);
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	margin: 0 auto 1.5rem;
}

.target-card .icon svg {
	width: 40px;
	height: 40px;
	fill: var(--color-white);
}

.target-card h4 {
	color: var(--color-text);
	margin-bottom: 1rem;
}

.target-card p {
	color: var(--color-text-secondary);
	margin-bottom: 0;
}

/*********  PRICING  **********/

.pricing-card {
	background-color: var(--color-white);
	border: 2px solid var(--color-border);
	border-radius: var(--radius-lg);
	padding: 2rem;
	text-align: center;
	height: 100%;
	transition: all 0.3s ease;
}

.pricing-card.featured {
	border-color: var(--color-primary);
	box-shadow: var(--shadow-lg);
	transform: scale(1.05);
}

.pricing-card .badge {
	background-color: var(--color-primary);
	color: var(--color-white);
	padding: 0.5rem 1rem;
	border-radius: var(--radius-sm);
	font-size: 0.875rem;
	font-weight: 600;
	margin-bottom: 1rem;
	display: inline-block;
}

.pricing-card h4 {
	margin-bottom: 0.5rem;
}

.pricing-card .price {
	font-size: 2.5rem;
	font-weight: 600;
	color: var(--color-primary);
	margin-bottom: 0.5rem;
}

.pricing-card .price span {
	font-size: 1rem;
	font-weight: 400;
	color: var(--color-text-secondary);
}

.pricing-card .description {
	color: var(--color-text-secondary);
	margin-bottom: 1.5rem;
}

.pricing-card ul {
	list-style: none;
	padding: 0;
	margin-bottom: 2rem;
	text-align: left;
}

.pricing-card ul li {
	padding: 0.5rem 0;
	border-bottom: 1px solid var(--color-border);
	display: flex;
	align-items: center;
}

.pricing-card ul li:last-child {
	border-bottom: none;
}

.pricing-card ul li svg {
	width: 20px;
	height: 20px;
	fill: var(--color-success);
	margin-right: 0.75rem;
	flex-shrink: 0;
}

/*********  CALCULATOR  **********/

.calculator {
	background-color: var(--color-white);
	border: 2px solid var(--color-border);
	border-radius: var(--radius-lg);
	padding: 2rem;
}

.calculator h4 {
	color: var(--color-primary);
	margin-bottom: 1.5rem;
}

.calculator .form-label {
	font-weight: 500;
	color: var(--color-text);
}

.calculator .form-control {
	border-radius: var(--radius-md);
	border-color: var(--color-border);
	padding: 0.75rem 1rem;
}

.calculator .form-control:focus {
	border-color: var(--color-primary);
	box-shadow: 0 0 0 3px var(--color-primary-light);
}

.calculator .result {
	background-color: var(--color-primary-light);
	border-radius: var(--radius-md);
	padding: 1.5rem;
	margin-top: 1.5rem;
}

.calculator .result .savings {
	font-size: 1.5rem;
	font-weight: 600;
	color: var(--color-success);
}

/*********  TESTIMONIALS  **********/

.testimonial {
	background-color: var(--color-white);
	border-radius: var(--radius-lg);
	padding: 2rem;
	box-shadow: var(--shadow-md);
	height: 100%;
}

.testimonial .quote {
	font-size: 1.125rem;
	font-style: italic;
	color: var(--color-text);
	margin-bottom: 1.5rem;
	position: relative;
	padding-left: 1.5rem;
}

.testimonial .quote::before {
	content: '"';
	position: absolute;
	left: 0;
	top: -10px;
	font-size: 3rem;
	color: var(--color-accent);
	line-height: 1;
}

.testimonial .author {
	display: flex;
	align-items: center;
}

.testimonial .author img {
	width: 50px;
	height: 50px;
	border-radius: 50%;
	margin-right: 1rem;
	object-fit: cover;
}

.testimonial .author-info h6 {
	margin-bottom: 0;
	color: var(--color-text);
}

.testimonial .author-info span {
	font-size: 0.875rem;
	color: var(--color-text-secondary);
}

/*********  STEPS  **********/

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

.step .number {
	width: 60px;
	height: 60px;
	background: linear-gradient(135deg, var(--color-primary) 0%, var(--color-primary-dark) 100%);
	color: var(--color-white);
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	font-size: 1.5rem;
	font-weight: 600;
	margin: 0 auto 1.5rem;
}

.step h5 {
	margin-bottom: 0.75rem;
}

.step p {
	color: var(--color-text-secondary);
	margin-bottom: 0;
}

/*********  CTA SECTION  **********/

.cta-section {
	background: linear-gradient(135deg, var(--color-primary) 0%, var(--color-primary-dark) 100%);
	color: var(--color-white);
	padding: 80px 0;
	text-align: center;
}

.cta-section h2 {
	color: var(--color-white);
	margin-bottom: 1rem;
}

.cta-section p {
	opacity: 0.95;
	max-width: 600px;
	margin: 0 auto 2rem;
}

.cta-section .btn-primary {
	background-color: var(--color-white);
	color: var(--color-primary);
	border-color: var(--color-white);
}

.cta-section .btn-primary:hover {
	background-color: var(--color-primary-light);
	color: var(--color-primary-dark);
}

.cta-section .btn-outline-primary {
	border-color: var(--color-white);
	color: var(--color-white);
}

.cta-section .btn-outline-primary:hover {
	background-color: var(--color-white);
	color: var(--color-primary);
}

/*********  CONTACT  **********/

.contact-info {
	margin-bottom: 2rem;
}

.contact-info a {
	color: var(--color-text);
	text-decoration: none;
}

.contact-info a:hover {
	color: var(--color-primary);
}

.contact-btn {
	display: inline-flex;
	align-items: center;
	padding: 1rem 1.5rem;
	border-radius: var(--radius-md);
	font-weight: 600;
	transition: all 0.3s ease;
	margin: 0.5rem;
}

.contact-btn svg {
	width: 20px;
	height: 20px;
	margin-right: 0.75rem;
}

.contact-btn.phone {
	background-color: var(--color-accent);
	color: var(--color-primary-dark);
}

.contact-btn.email {
	background-color: var(--color-primary);
	color: var(--color-white);
}

.contact-btn:hover {
	transform: translateY(-2px);
	box-shadow: var(--shadow-md);
}

/*********  FOOTER  **********/

footer {
	background-color: var(--color-text);
	color: var(--color-text-light);
	padding: 60px 0 30px;
}

footer h5 {
	color: var(--color-white);
	font-size: 1rem;
	margin-bottom: 1.5rem;
}

footer a {
	color: var(--color-text-light);
	transition: color 0.3s ease;
}

footer a:hover {
	color: var(--color-white);
}

footer ul {
	list-style: none;
	padding: 0;
}

footer ul li {
	margin-bottom: 0.75rem;
}

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

footer .social-links a {
	display: inline-flex;
	align-items: center;
	justify-content: center;
	width: 40px;
	height: 40px;
	background-color: rgba(255, 255, 255, 0.1);
	border-radius: 50%;
	margin-right: 0.75rem;
	transition: all 0.3s ease;
}

footer .social-links a:hover {
	background-color: var(--color-primary);
}

footer .social-links svg {
	width: 20px;
	height: 20px;
	fill: var(--color-white);
}

/*********  UTILITIES  **********/

.text-primary {
	color: var(--color-primary) !important;
}

.bg-primary-light {
	background-color: var(--color-primary-light) !important;
}

.check-icon {
	color: var(--color-success);
}

/*********  RESPONSIVE  **********/

@media (max-width: 992px) {
	h1 {
		font-size: 2.5rem;
	}

	h2 {
		font-size: 2rem;
	}

	.hero {
		padding: 80px 0;
	}

	.hero h1 {
		font-size: 2.25rem;
	}

	section {
		padding: 60px 0;
	}

	.pricing-card.featured {
		transform: none;
	}
}

@media (max-width: 768px) {
	h1 {
		font-size: 2rem;
	}

	h2 {
		font-size: 1.75rem;
	}

	.hero {
		padding: 60px 0;
	}

	.hero h1 {
		font-size: 1.75rem;
	}

	.hero .lead {
		font-size: 1rem;
	}

	section {
		padding: 40px 0;
	}

	.stat-number {
		font-size: 2.5rem;
	}

	.contact-btn {
		width: 100%;
		justify-content: center;
	}
}

/*********  HERO SMALL  **********/

.hero-small {
	padding: 60px 0;
}

.hero-small h1 {
	font-size: 2.5rem;
	margin-bottom: 1rem;
}

@media (max-width: 768px) {
	.hero-small {
		padding: 40px 0;
	}

	.hero-small h1 {
		font-size: 1.75rem;
	}
}

/*********  MODULE CARDS  **********/

.module-card {
	background-color: var(--color-white);
	border: 2px solid var(--color-border);
	border-radius: var(--radius-lg);
	padding: 2.5rem;
	height: 100%;
	transition: all 0.3s ease;
}

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

.module-icon {
	width: 64px;
	height: 64px;
	background: linear-gradient(135deg, var(--color-primary) 0%, var(--color-primary-dark) 100%);
	border-radius: var(--radius-md);
	display: flex;
	align-items: center;
	justify-content: center;
	margin-bottom: 1.5rem;
}

.module-icon svg {
	width: 32px;
	height: 32px;
	fill: var(--color-white);
}

.module-card h4 {
	margin-bottom: 1rem;
}

.module-card p {
	color: var(--color-text-secondary);
	margin-bottom: 1.5rem;
}

.module-features {
	list-style: none;
	padding: 0;
	margin: 0;
}

.module-features li {
	padding: 0.5rem 0;
	padding-left: 1.75rem;
	position: relative;
	color: var(--color-text);
}

.module-features li::before {
	content: '';
	position: absolute;
	left: 0;
	top: 50%;
	transform: translateY(-50%);
	width: 18px;
	height: 18px;
	background-color: var(--color-success);
	border-radius: 50%;
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='white'%3E%3Cpath d='M9 16.17L4.83 12l-1.42 1.41L9 19 21 7l-1.41-1.41L9 16.17z'/%3E%3C/svg%3E");
	background-size: 12px;
	background-position: center;
	background-repeat: no-repeat;
}

/*********  PRICING FEATURES LIST  **********/

.pricing-card .pricing-features {
	list-style: none;
	padding: 0;
	margin-bottom: 1.5rem;
	text-align: left;
}

.pricing-card .pricing-features li {
	padding: 0.5rem 0;
	padding-left: 1.75rem;
	position: relative;
	color: var(--color-text);
	border-bottom: 1px solid var(--color-border);
	display: block;
}

.pricing-card .pricing-features li:last-child {
	border-bottom: none;
}

.pricing-card .pricing-features li::before {
	content: '';
	position: absolute;
	left: 0;
	top: 50%;
	transform: translateY(-50%);
	width: 16px;
	height: 16px;
	background-color: var(--color-success);
	border-radius: 50%;
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='white'%3E%3Cpath d='M9 16.17L4.83 12l-1.42 1.41L9 19 21 7l-1.41-1.41L9 16.17z'/%3E%3C/svg%3E");
	background-size: 10px;
	background-position: center;
	background-repeat: no-repeat;
}

/*********  CALCULATOR  **********/

.calculator-card {
	background-color: var(--color-white);
	border: 2px solid var(--color-border);
	border-radius: var(--radius-lg);
	padding: 2.5rem;
}

.calculator-card h4 {
	color: var(--color-text);
	margin-bottom: 0.5rem;
}

.calculator-card > p {
	color: var(--color-text-secondary);
	margin-bottom: 2rem;
}

.calculator-inputs .form-label {
	font-weight: 500;
	color: var(--color-text);
	margin-bottom: 0.5rem;
}

.calculator-inputs .form-control {
	border-radius: var(--radius-md);
	border: 2px solid var(--color-border);
	padding: 0.875rem 1rem;
	font-size: 1.125rem;
	font-weight: 500;
}

.calculator-inputs .form-control:focus {
	border-color: var(--color-primary);
	box-shadow: 0 0 0 3px var(--color-primary-light);
}

.result-card {
	background-color: var(--color-background);
	border-radius: var(--radius-md);
	padding: 1.5rem;
}

.result-card h5 {
	font-size: 1rem;
	margin-bottom: 1rem;
	color: var(--color-text);
}

.result-alivea {
	border: 2px solid var(--color-primary);
	background-color: var(--color-primary-light);
}

.result-alivea h5 {
	color: var(--color-primary);
}

.result-competitor {
	border: 2px solid var(--color-border);
}

.result-breakdown {
	margin-bottom: 1rem;
}

.result-line {
	display: flex;
	justify-content: space-between;
	padding: 0.375rem 0;
	font-size: 0.875rem;
	color: var(--color-text-secondary);
}

.result-total {
	display: flex;
	justify-content: space-between;
	padding-top: 0.75rem;
	border-top: 2px solid var(--color-border);
	font-size: 1.125rem;
	font-weight: 600;
	color: var(--color-text);
}

.savings-banner {
	background: linear-gradient(135deg, var(--color-success) 0%, #059669 100%);
	border-radius: var(--radius-md);
	padding: 1.5rem;
	text-align: center;
	color: var(--color-white);
}

.savings-banner.positive {
	background: linear-gradient(135deg, var(--color-success) 0%, #059669 100%);
}

.savings-banner.negative {
	background: linear-gradient(135deg, var(--color-error) 0%, #DC2626 100%);
}

.savings-amount .label {
	display: block;
	font-size: 0.875rem;
	opacity: 0.9;
	margin-bottom: 0.25rem;
}

.savings-amount .amount {
	font-size: 2rem;
	font-weight: 600;
}

.savings-amount .percent {
	font-size: 1rem;
	opacity: 0.9;
	margin-left: 0.5rem;
}

/*********  COMPARISON TABLE  **********/

.comparison-table .table {
	background-color: var(--color-white);
	border-radius: var(--radius-lg);
	overflow: hidden;
	box-shadow: var(--shadow-sm);
}

.comparison-table .table th {
	background-color: var(--color-background);
	font-weight: 600;
	padding: 1rem;
	border-bottom: 2px solid var(--color-border);
}

.comparison-table .table td {
	padding: 1rem;
	vertical-align: middle;
	border-bottom: 1px solid var(--color-border);
}

.comparison-table .table tr:last-child td {
	border-bottom: none;
}

/*********  COMBO CARD  **********/

.combo-card {
	background: linear-gradient(135deg, var(--color-primary-light) 0%, var(--color-white) 100%);
	border: 2px solid var(--color-primary);
	border-radius: var(--radius-lg);
	padding: 2.5rem;
}

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

.combo-card p {
	color: var(--color-text-secondary);
}

.combo-benefits {
	list-style: none;
	padding: 0;
	margin: 0;
}

.combo-benefits li {
	padding: 0.375rem 0;
	padding-left: 1.5rem;
	position: relative;
}

.combo-benefits li::before {
	content: '';
	position: absolute;
	left: 0;
	top: 50%;
	transform: translateY(-50%);
	width: 16px;
	height: 16px;
	background-color: var(--color-primary);
	border-radius: 50%;
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='white'%3E%3Cpath d='M9 16.17L4.83 12l-1.42 1.41L9 19 21 7l-1.41-1.41L9 16.17z'/%3E%3C/svg%3E");
	background-size: 10px;
	background-position: center;
	background-repeat: no-repeat;
}

.combo-price {
	background-color: var(--color-white);
	border-radius: var(--radius-md);
	padding: 1.5rem;
	box-shadow: var(--shadow-md);
}

.combo-price .from {
	display: block;
	font-size: 0.875rem;
	color: var(--color-text-secondary);
}

.combo-price .amount {
	display: block;
	font-size: 2.5rem;
	font-weight: 600;
	color: var(--color-primary);
	line-height: 1.2;
}

.combo-price .period {
	display: block;
	font-size: 0.875rem;
	color: var(--color-text-secondary);
}

/*********  ACCORDION / FAQ  **********/

.accordion-item {
	border: 1px solid var(--color-border);
	margin-bottom: 0.75rem;
	border-radius: var(--radius-md) !important;
	overflow: hidden;
}

.accordion-button {
	font-weight: 500;
	color: var(--color-text);
	background-color: var(--color-white);
	padding: 1.25rem;
}

.accordion-button:not(.collapsed) {
	color: var(--color-primary);
	background-color: var(--color-primary-light);
	box-shadow: none;
}

.accordion-button:focus {
	box-shadow: none;
	border-color: var(--color-primary);
}

.accordion-button::after {
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='%23BE123C'%3E%3Cpath d='M7.41 8.59L12 13.17l4.59-4.58L18 10l-6 6-6-6 1.41-1.41z'/%3E%3C/svg%3E");
}

.accordion-body {
	padding: 1.25rem;
	color: var(--color-text-secondary);
}

/*********  STANCER INFO  **********/

.stancer-info {
	background-color: var(--color-background);
	border-radius: var(--radius-sm);
	padding: 0.75rem 1rem;
}

/*********  FEATURE TAG  **********/

.feature-tag {
	display: inline-block;
	background-color: var(--color-primary-light);
	color: var(--color-primary);
	padding: 0.375rem 1rem;
	border-radius: var(--radius-xl);
	font-size: 0.875rem;
	font-weight: 600;
	margin-bottom: 1rem;
}

/*********  FEATURE LIST  **********/

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

.feature-list li {
	padding: 1rem 0;
	border-bottom: 1px solid var(--color-border);
}

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

.feature-list li strong {
	display: block;
	color: var(--color-text);
	margin-bottom: 0.25rem;
}

.feature-list li span {
	color: var(--color-text-secondary);
	font-size: 0.9375rem;
}

/*********  FEATURE VISUALS  **********/

.feature-visual {
	display: flex;
	justify-content: center;
	align-items: center;
}

/* Browser-like card */
.visual-card {
	background-color: var(--color-white);
	border-radius: var(--radius-lg);
	box-shadow: var(--shadow-lg);
	overflow: hidden;
	width: 100%;
	max-width: 400px;
}

.visual-header {
	background-color: var(--color-background);
	padding: 0.75rem 1rem;
	display: flex;
	gap: 0.5rem;
}

.visual-header .dot {
	width: 12px;
	height: 12px;
	border-radius: 50%;
	background-color: var(--color-border);
}

.visual-header .dot:nth-child(1) {
	background-color: #EF4444;
}

.visual-header .dot:nth-child(2) {
	background-color: #F59E0B;
}

.visual-header .dot:nth-child(3) {
	background-color: #10B981;
}

.visual-content {
	padding: 1.5rem;
}

/* Mock form */
.mock-form {
	display: flex;
	flex-direction: column;
	gap: 1rem;
}

.mock-field {
	height: 40px;
	background-color: var(--color-background);
	border-radius: var(--radius-sm);
	border: 1px solid var(--color-border);
}

.mock-field.short {
	flex: 1;
}

.mock-row {
	display: flex;
	gap: 1rem;
}

.mock-btn {
	height: 44px;
	background-color: var(--color-primary);
	border-radius: var(--radius-md);
	margin-top: 0.5rem;
}

/* Payment methods */
.payment-methods {
	display: flex;
	flex-wrap: wrap;
	gap: 1rem;
	justify-content: center;
}

.payment-item {
	background-color: var(--color-white);
	border: 2px solid var(--color-border);
	border-radius: var(--radius-md);
	padding: 1.25rem 1.5rem;
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 0.75rem;
	min-width: 120px;
	transition: all 0.3s ease;
}

.payment-item:hover {
	border-color: var(--color-primary);
	transform: translateY(-3px);
	box-shadow: var(--shadow-md);
}

.payment-item.featured {
	border-color: var(--color-primary);
	background-color: var(--color-primary-light);
}

.payment-item svg {
	width: 32px;
	height: 32px;
	fill: var(--color-primary);
}

.payment-item span {
	font-size: 0.875rem;
	font-weight: 500;
	color: var(--color-text);
}

/* Attendance preview */
.attendance-preview {
	background-color: var(--color-white);
	border-radius: var(--radius-lg);
	box-shadow: var(--shadow-lg);
	overflow: hidden;
	width: 100%;
	max-width: 400px;
}

.attendance-header {
	background-color: var(--color-primary);
	color: var(--color-white);
	padding: 1rem 1.25rem;
	display: flex;
	justify-content: space-between;
	align-items: center;
}

.attendance-header .date {
	font-weight: 500;
	font-size: 0.9375rem;
}

.attendance-header .count {
	background-color: rgba(255, 255, 255, 0.2);
	padding: 0.25rem 0.75rem;
	border-radius: var(--radius-sm);
	font-size: 0.875rem;
}

.attendance-list {
	padding: 0.5rem;
}

.attendance-item {
	display: flex;
	align-items: center;
	padding: 0.75rem 1rem;
	border-radius: var(--radius-sm);
}

.attendance-item:hover {
	background-color: var(--color-background);
}

.attendance-item .status-dot {
	width: 10px;
	height: 10px;
	border-radius: 50%;
	margin-right: 0.75rem;
}

.attendance-item.present .status-dot {
	background-color: var(--color-success);
}

.attendance-item.absent .status-dot {
	background-color: var(--color-error);
}

.attendance-item.excused .status-dot {
	background-color: var(--color-warning);
}

.attendance-item .name {
	flex: 1;
	font-weight: 400;
}

.attendance-item .badge-status {
	font-size: 0.75rem;
	padding: 0.25rem 0.5rem;
	border-radius: var(--radius-sm);
}

.attendance-item.present .badge-status {
	background-color: rgba(16, 185, 129, 0.1);
	color: var(--color-success);
}

.attendance-item.absent .badge-status {
	background-color: rgba(239, 68, 68, 0.1);
	color: var(--color-error);
}

.attendance-item.excused .badge-status {
	background-color: rgba(245, 158, 11, 0.1);
	color: var(--color-warning);
}

/* Email preview */
.email-preview {
	background-color: var(--color-white);
	border-radius: var(--radius-lg);
	box-shadow: var(--shadow-lg);
	overflow: hidden;
	width: 100%;
	max-width: 400px;
}

.email-header {
	background-color: var(--color-background);
	padding: 1rem 1.25rem;
	border-bottom: 1px solid var(--color-border);
}

.email-to {
	font-size: 0.875rem;
	color: var(--color-text-secondary);
	margin-bottom: 0.25rem;
}

.email-subject {
	font-weight: 600;
	color: var(--color-text);
}

.email-body {
	padding: 1.25rem;
}

.email-body p {
	margin-bottom: 0.75rem;
	font-size: 0.9375rem;
}

.email-info {
	background-color: var(--color-primary-light);
	border-left: 3px solid var(--color-primary);
	padding: 0.75rem 1rem;
	margin: 1rem 0;
}

.email-info span {
	display: block;
	font-size: 0.9375rem;
	color: var(--color-text);
}

/* Calendar preview */
.calendar-preview {
	background-color: var(--color-white);
	border-radius: var(--radius-lg);
	box-shadow: var(--shadow-lg);
	overflow: hidden;
	width: 100%;
	max-width: 320px;
}

.calendar-header {
	background-color: var(--color-primary);
	color: var(--color-white);
	padding: 1rem;
	text-align: center;
	font-weight: 600;
}

.calendar-grid {
	display: grid;
	grid-template-columns: repeat(7, 1fr);
	padding: 0.5rem;
}

.calendar-day {
	padding: 0.5rem;
	text-align: center;
	font-weight: 600;
	font-size: 0.75rem;
	color: var(--color-text-secondary);
}

.calendar-cell {
	padding: 0.5rem;
	text-align: center;
	font-size: 0.875rem;
	border-radius: var(--radius-sm);
}

.calendar-cell.has-event {
	background-color: var(--color-primary-light);
	color: var(--color-primary);
	font-weight: 500;
}

.calendar-cell.active {
	background-color: var(--color-primary);
	color: var(--color-white);
}

/* Giftcard preview */
.giftcard-preview {
	display: flex;
	justify-content: center;
}

.giftcard {
	background: linear-gradient(135deg, var(--color-primary) 0%, var(--color-primary-dark) 100%);
	color: var(--color-white);
	border-radius: var(--radius-lg);
	padding: 2rem;
	width: 100%;
	max-width: 320px;
	box-shadow: var(--shadow-lg);
	text-align: center;
}

.giftcard-header {
	font-size: 0.875rem;
	text-transform: uppercase;
	letter-spacing: 2px;
	opacity: 0.9;
	margin-bottom: 1rem;
}

.giftcard-amount {
	font-size: 3rem;
	font-weight: 600;
	margin-bottom: 0.5rem;
}

.giftcard-message {
	font-style: italic;
	opacity: 0.9;
	margin-bottom: 1.5rem;
}

.giftcard-footer {
	font-size: 0.75rem;
	opacity: 0.8;
	padding-top: 1rem;
	border-top: 1px solid rgba(255, 255, 255, 0.2);
}

/* Ticket preview */
.ticket-preview {
	display: flex;
	justify-content: center;
}

.ticket {
	background-color: var(--color-white);
	border-radius: var(--radius-lg);
	box-shadow: var(--shadow-lg);
	display: flex;
	overflow: hidden;
	width: 100%;
	max-width: 400px;
}

.ticket-left {
	flex: 1;
	padding: 1.5rem;
	border-right: 2px dashed var(--color-border);
}

.ticket-left .event-name {
	font-weight: 600;
	font-size: 1.125rem;
	color: var(--color-text);
	margin-bottom: 0.5rem;
}

.ticket-left .event-date {
	font-size: 0.9375rem;
	color: var(--color-primary);
	margin-bottom: 0.25rem;
}

.ticket-left .event-venue {
	font-size: 0.875rem;
	color: var(--color-text-secondary);
	margin-bottom: 1rem;
}

.ticket-left .ticket-type {
	display: inline-block;
	background-color: var(--color-primary-light);
	color: var(--color-primary);
	padding: 0.25rem 0.75rem;
	border-radius: var(--radius-sm);
	font-size: 0.75rem;
	font-weight: 600;
}

.ticket-right {
	width: 100px;
	padding: 1rem;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	background-color: var(--color-background);
}

.ticket-right .qr-placeholder {
	width: 60px;
	height: 60px;
	background-color: var(--color-text);
	border-radius: var(--radius-sm);
	margin-bottom: 0.5rem;
}

.ticket-right .ticket-code {
	font-size: 0.75rem;
	font-weight: 600;
	color: var(--color-text-secondary);
}

/*********  CONTACT FORM  **********/

.contact-form {
	background-color: var(--color-white);
	border-radius: var(--radius-lg);
	padding: 2.5rem;
	box-shadow: var(--shadow-lg);
}

.contact-form h3 {
	color: var(--color-text);
	margin-bottom: 1.5rem;
	font-size: 1.5rem;
}

.contact-form .form-label {
	font-weight: 500;
	color: var(--color-text);
	margin-bottom: 0.5rem;
}

.contact-form .form-control,
.contact-form .form-select {
	border: 2px solid var(--color-border);
	border-radius: var(--radius-md);
	padding: 0.75rem 1rem;
}

.contact-form .form-control:focus,
.contact-form .form-select:focus {
	border-color: var(--color-primary);
	box-shadow: 0 0 0 3px var(--color-primary-light);
}

.contact-form textarea.form-control {
	min-height: 120px;
}

/*********  CONTACT INFO CARD  **********/

.contact-info-card {
	background-color: var(--color-primary-light);
	border-radius: var(--radius-lg);
	padding: 2rem;
	margin-bottom: 1.5rem;
}

.contact-info-card h4 {
	color: var(--color-primary);
	margin-bottom: 1rem;
}

.contact-info-card p {
	color: var(--color-text-secondary);
	margin-bottom: 0;
}

.contact-info-item {
	display: flex;
	align-items: flex-start;
	padding: 1rem 0;
	border-bottom: 1px solid var(--color-border);
}

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

.contact-info-item svg {
	width: 24px;
	height: 24px;
	fill: var(--color-primary);
	margin-right: 1rem;
	flex-shrink: 0;
}

.contact-info-item strong {
	display: block;
	color: var(--color-text);
	margin-bottom: 0.25rem;
}

.contact-info-item span,
.contact-info-item a {
	color: var(--color-text-secondary);
	font-size: 0.9375rem;
}