:root {
	--mai-bg-color: #121212;
	--mai-primary-color: #1a237e;
	--mai-secondary-color: #e91e63;
	--mai-text-color: #e0e0e0;
	--mai-dark-gray: #1a1a1a;
	--mai-mid-gray: #2d2d2d;
	--mai-light-gray: #505050;
	--mai-border-radius: 4px;
	--mai-transition-speed: 0.3s;
	--mai-shadow: 0 4px 10px rgba(0, 0, 0, 0.3);
	--mai-font-family: 'Roboto', 'Segoe UI', Arial, sans-serif;
	--mai-header-height: 80px;
}

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

html {
	scroll-behavior: smooth;
	font-size: 16px;
}

body {
	font-family: var(--mai-font-family);
	background-color: var(--mai-bg-color);
	color: var(--mai-text-color);
	line-height: 1.6;
	overflow-x: hidden;
	position: relative;
}

h1,
h2,
h3,
h4,
h5,
h6 {
	font-weight: 700;
	line-height: 1.2;
	margin-bottom: 1rem;
}

h1 {
	font-size: 3.5rem;
	margin-bottom: 2rem;
}

h2 {
	font-size: 2.5rem;
	margin-bottom: 2rem;
	position: relative;
}

h2:after {
	content: '';
	position: absolute;
	left: 0;
	bottom: -10px;
	width: 60px;
	height: 4px;
	background-color: var(--mai-secondary-color);
}

h3 {
	font-size: 1.8rem;
	margin-bottom: 1.5rem;
}

h4 {
	font-size: 1.4rem;
	margin-bottom: 1.2rem;
}

p {
	margin-bottom: 1.5rem;
	font-size: 1.1rem;
}

a {
	color: var(--mai-secondary-color);
	text-decoration: none;
	transition: all var(--mai-transition-speed) ease;
	word-wrap: break-word;
}

a:hover {
	color: var(--mai-primary-color);
}

ul,
ol {
	margin-left: 1.5rem;
	margin-bottom: 1.5rem;
}

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

button,
.mai-btn {
	cursor: pointer;
	padding: 12px 24px;
	font-size: 1rem;
	font-weight: 600;
	border-radius: var(--mai-border-radius);
	transition: all var(--mai-transition-speed) ease;
	display: inline-block;
	text-align: center;
	border: none;
	font-family: var(--mai-font-family);
}

.mai-btn-primary {
	background-color: var(--mai-primary-color);
	color: var(--mai-text-color);
}

.mai-btn-primary:hover {
	background-color: #262f9b;
	transform: translateY(-2px);
	box-shadow: 0 6px 12px rgba(26, 35, 126, 0.3);
}

.mai-btn-secondary {
	background-color: var(--mai-secondary-color);
	color: var(--mai-text-color);
}

.mai-btn-secondary:hover {
	background-color: #d81b60;
	transform: translateY(-2px);
	box-shadow: 0 6px 12px rgba(233, 30, 99, 0.3);
}

.mai-btn-outline {
	background-color: transparent;
	color: var(--mai-secondary-color);
	border: 2px solid var(--mai-secondary-color);
}

.mai-btn-outline:hover {
	background-color: var(--mai-secondary-color);
	color: var(--mai-text-color);
	transform: translateY(-2px);
	box-shadow: 0 6px 12px rgba(233, 30, 99, 0.2);
}

.mai-container {
	width: 100%;
	max-width: 1200px;
	margin: 0 auto;
	padding: 0 20px;
}

.mai-text-center {
	text-align: center;
}

.mai-text-right {
	text-align: right;
}

.mai-mb-1 {
	margin-bottom: 1rem;
}

.mai-mb-2 {
	margin-bottom: 2rem;
}

.mai-mb-3 {
	margin-bottom: 3rem;
}

.mai-mt-1 {
	margin-top: 1rem;
}

.mai-mt-2 {
	margin-top: 2rem;
}

.mai-mt-3 {
	margin-top: 3rem;
}

.mai-mx-auto {
	margin-left: auto;
	margin-right: auto;
}

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

.mai-text-secondary {
	color: var(--mai-secondary-color);
}

/* ===== HEADER STYLES ===== */
.mai-header {
	position: fixed;
	top: 0;
	left: 0;
	right: 0;
	height: var(--mai-header-height);
	background-color: rgba(18, 18, 18, 0.95);
	z-index: 1000;
	backdrop-filter: blur(10px);
	box-shadow: 0 2px 10px rgba(0, 0, 0, 0.3);
	transition: all var(--mai-transition-speed) ease;
}

.mai-header.mai-scrolled {
	height: 60px;
	background-color: rgba(18, 18, 18, 0.98);
}

.mai-header-container {
	display: flex;
	justify-content: space-between;
	align-items: center;
	height: 100%;
}

.mai-logo {
	display: flex;
	align-items: center;
}

.mai-logo-text {
	font-size: 1.8rem;
	font-weight: 700;
	color: var(--mai-text-color);
	transition: all var(--mai-transition-speed) ease;
}

.mai-logo-text span {
	color: var(--mai-secondary-color);
}

.mai-nav {
	display: flex;
	align-items: center;
}

.mai-nav-links {
	display: flex;
	list-style: none;
	margin: 0;
}

.mai-nav-link {
	color: var(--mai-text-color);
	margin-left: 2rem;
	font-size: 1.1rem;
	font-weight: 500;
	position: relative;
	transition: all var(--mai-transition-speed) ease;
}

.mai-nav-link:hover {
	color: var(--mai-secondary-color);
}

.mai-nav-link:after {
	content: '';
	position: absolute;
	bottom: -5px;
	left: 0;
	width: 0;
	height: 2px;
	background-color: var(--mai-secondary-color);
	transition: all var(--mai-transition-speed) ease;
}

.mai-nav-link:hover:after {
	width: 100%;
}

.mai-hamburger {
	display: none;
	flex-direction: column;
	justify-content: space-between;
	width: 30px;
	height: 21px;
	cursor: pointer;
	z-index: 1001;
}

.mai-hamburger span {
	display: block;
	width: 100%;
	height: 3px;
	background-color: var(--mai-text-color);
	transition: all 0.3s ease-in-out;
}

.mai-hamburger.mai-active span:nth-child(1) {
	transform: translateY(9px) rotate(45deg);
}

.mai-hamburger.mai-active span:nth-child(2) {
	opacity: 0;
}

.mai-hamburger.mai-active span:nth-child(3) {
	transform: translateY(-9px) rotate(-45deg);
}

/* ===== HERO SECTION STYLES ===== */
.mai-hero {
	height: 100vh;
	min-height: 700px;
	padding-top: var(--mai-header-height);
	position: relative;
	display: flex;
	align-items: center;
	overflow: hidden;
	background: linear-gradient(135deg, rgb(57 67 58) 0%, rgb(8 229 174 / 47%) 100%), url(assets/mai-hero.jpg) center / cover;
}

.mai-hero:before {
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background: radial-gradient(
			circle at 20% 30%,
			rgba(26, 35, 126, 0.15),
			transparent 25%
		),
		radial-gradient(circle at 80% 70%, rgba(233, 30, 99, 0.15), transparent 25%);
	z-index: -1;
}

.mai-hero-grid {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background-image: url("data:image/svg+xml,%3Csvg width='100' height='100' viewBox='0 0 100 100' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M0 0h100v100H0z' fill='none'/%3E%3Cpath d='M0 0v100M100 0v100M0 0h100M0 100h100' stroke='rgba(224, 224, 224, 0.05)' stroke-width='0.5'/%3E%3C/svg%3E");
	opacity: 0.3;
	z-index: -1;
}

.mai-hero-content {
	display: flex;
	justify-content: space-between;
	align-items: center;
	width: 100%;
}

.mai-hero-text {
	flex: 1;
	padding-right: 3rem;
}

.mai-hero-title {
	font-size: 3.5rem;
	line-height: 1.1;
	margin-bottom: 1.5rem;
	color: var(--mai-text-color);
}

.mai-hero-title .mai-highlight {
	color: var(--mai-secondary-color);
}

.mai-hero-subtitle {
	font-size: 1.4rem;
	margin-bottom: 2rem;
	color: var(--mai-text-color);
	opacity: 0.9;
}

.mai-hero-buttons {
	display: flex;
	gap: 1rem;
}

.mai-hero-visual {
	flex: 1;
	display: flex;
	justify-content: center;
	align-items: center;
	position: relative;
	min-height: 450px;
}

.mai-brain-illustration {
	position: relative;
	width: 350px;
	height: 350px;
}

.mai-brain-circle {
	position: absolute;
	width: 350px;
	height: 350px;
	border-radius: 50%;
	background: radial-gradient(
		circle,
		rgba(26, 35, 126, 0.05) 0%,
		rgba(233, 30, 99, 0.1) 100%
	);
	border: 1px solid rgba(233, 30, 99, 0.2);
	display: flex;
	justify-content: center;
	align-items: center;
}

.mai-brain-animation {
	width: 250px;
	height: 250px;
	position: relative;
}

.mai-neuron {
	position: absolute;
	background-color: rgba(26, 35, 126, 0.2);
	border: 1px solid rgba(26, 35, 126, 0.4);
	border-radius: 50%;
}

.mai-synapse {
	position: absolute;
	height: 2px;
	background: linear-gradient(
		90deg,
		rgba(26, 35, 126, 0.4),
		rgba(233, 30, 99, 0.4)
	);
	transform-origin: left center;
}

/* ===== VISION & VALUES SECTION STYLES ===== */
.mai-vision {
	padding: 100px 0;
	background-color: var(--mai-bg-color);
	position: relative;
}

.mai-vision:before {
	content: '';
	position: absolute;
	top: -50px;
	left: 0;
	width: 100%;
	height: 50px;
	background: linear-gradient(to top, var(--mai-bg-color), transparent);
}

.mai-vision-title {
	text-align: center;
	margin-bottom: 4rem;
}

.mai-vision-title h2:after {
	left: 50%;
	transform: translateX(-50%);
}

.mai-timeline {
	position: relative;
	padding: 0 20px;
}

.mai-timeline:before {
	content: '';
	position: absolute;
	top: 0;
	bottom: 0;
	left: 50%;
	width: 4px;
	background: linear-gradient(
		to bottom,
		var(--mai-primary-color),
		var(--mai-secondary-color)
	);
	transform: translateX(-50%);
}

.mai-timeline-item {
	position: relative;
	margin-bottom: 60px;
	width: 50%;
}

.mai-timeline-item:nth-child(odd) {
	left: 0;
	padding-right: 40px;
	text-align: right;
}

.mai-timeline-item:nth-child(even) {
	left: 50%;
	padding-left: 40px;
}

.mai-timeline-dot {
	position: absolute;
	width: 24px;
	height: 24px;
	border-radius: 50%;
	top: 15px;
	background-color: var(--mai-secondary-color);
	border: 4px solid var(--mai-bg-color);
	box-shadow: var(--mai-shadow);
}

.mai-timeline-item:nth-child(odd) .mai-timeline-dot {
	right: -12px;
}

.mai-timeline-item:nth-child(even) .mai-timeline-dot {
	left: -12px;
}

.mai-timeline-content {
	padding: 20px;
	background: var(--mai-dark-gray);
	border-radius: var(--mai-border-radius);
	box-shadow: var(--mai-shadow);
	position: relative;
	transition: all var(--mai-transition-speed) ease;
}

.mai-timeline-content:hover {
	transform: translateY(-5px);
	box-shadow: 0 10px 20px rgba(0, 0, 0, 0.4);
	background: linear-gradient(
		135deg,
		var(--mai-dark-gray),
		rgba(26, 35, 126, 0.2)
	);
}

.mai-timeline-icon {
	font-size: 2rem;
	color: var(--mai-secondary-color);
	margin-bottom: 1rem;
	display: inline-block;
}

.mai-timeline-title {
	font-size: 1.5rem;
	margin-bottom: 1rem;
	color: var(--mai-text-color);
}

.mai-timeline-text {
	font-size: 1rem;
	color: var(--mai-text-color);
	opacity: 0.9;
}

/* ===== METHODS SECTION STYLES ===== */
.mai-methods {
	padding: 100px 0;
	background-color: var(--mai-dark-gray);
	position: relative;
}

.mai-methods:before {
	content: '';
	position: absolute;
	top: -50px;
	left: 0;
	width: 100%;
	height: 50px;
	background: linear-gradient(
		to top,
		var(--mai-dark-gray),
		var(--mai-bg-color)
	);
}

.mai-methods-title {
	text-align: center;
	margin-bottom: 4rem;
}

.mai-methods-title h2:after {
	left: 50%;
	transform: translateX(-50%);
}

.mai-methods-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 30px;
}

.mai-method-card {
	background-color: var(--mai-bg-color);
	border-radius: var(--mai-border-radius);
	overflow: hidden;
	box-shadow: var(--mai-shadow);
	transition: all var(--mai-transition-speed) ease;
	height: 100%;
	display: flex;
	flex-direction: column;
}

.mai-method-card:hover {
	transform: translateY(-10px);
	box-shadow: 0 15px 30px rgba(0, 0, 0, 0.3);
}

.mai-method-image {
	height: 200px;
	background-color: var(--mai-mid-gray);
	position: relative;
	overflow: hidden;
}

.mai-method-image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: all var(--mai-transition-speed) ease;
}

.mai-method-card:hover .mai-method-image img {
	transform: scale(1.05);
}

.mai-method-overlay {
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	background: linear-gradient(to bottom, transparent, rgba(18, 18, 18, 0.8));
	display: flex;
	align-items: flex-end;
	padding: 20px;
}

.mai-method-icon {
	position: absolute;
	top: 20px;
	right: 20px;
	width: 50px;
	height: 50px;
	background-color: var(--mai-primary-color);
	border-radius: 50%;
	display: flex;
	justify-content: center;
	align-items: center;
	color: var(--mai-text-color);
	font-size: 1.5rem;
	box-shadow: var(--mai-shadow);
}

.mai-method-content {
	padding: 20px;
	flex-grow: 1;
	display: flex;
	flex-direction: column;
}

.mai-method-title {
	font-size: 1.5rem;
	margin-bottom: 1rem;
}

.mai-method-text {
	margin-bottom: 1.5rem;
	flex-grow: 1;
}

.mai-method-features {
	margin-bottom: 1.5rem;
}

.mai-method-feature {
	display: flex;
	align-items: center;
	margin-bottom: 0.5rem;
}

.mai-method-feature i {
	color: var(--mai-secondary-color);
	margin-right: 0.5rem;
}

/* ===== PRICING SECTION STYLES ===== */
.mai-pricing {
	padding: 100px 0;
	background: linear-gradient(
		135deg,
		rgba(26, 35, 126, 0.1) 0%,
		rgba(233, 30, 99, 0.1) 100%
	);
	position: relative;
}

.mai-pricing:before {
	content: '';
	position: absolute;
	top: -50px;
	left: 0;
	width: 100%;
	height: 50px;
	background: linear-gradient(
		to top,
		rgba(26, 35, 126, 0.1),
		var(--mai-dark-gray)
	);
}

.mai-pricing-title {
	text-align: center;
	margin-bottom: 4rem;
}

.mai-pricing-title h2:after {
	left: 50%;
	transform: translateX(-50%);
}

.mai-pricing-toggle {
	display: flex;
	justify-content: center;
	align-items: center;
	margin-bottom: 3rem;
}

.mai-pricing-toggle-option {
	padding: 10px 20px;
	cursor: pointer;
	transition: all var(--mai-transition-speed) ease;
	opacity: 0.7;
}

.mai-pricing-toggle-option.mai-active {
	opacity: 1;
	font-weight: 600;
}

.mai-pricing-toggle-switch {
	width: 60px;
	height: 30px;
	background-color: var(--mai-primary-color);
	border-radius: 15px;
	margin: 0 10px;
	position: relative;
	cursor: pointer;
}

.mai-pricing-toggle-switch:before {
	content: '';
	position: absolute;
	width: 24px;
	height: 24px;
	border-radius: 50%;
	background-color: var(--mai-text-color);
	top: 3px;
	left: 3px;
	transition: all var(--mai-transition-speed) ease;
}

.mai-pricing-toggle-switch.mai-yearly:before {
	left: 33px;
}

.mai-pricing-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 30px;
}

.mai-pricing-card {
	background-color: var(--mai-dark-gray);
	border-radius: var(--mai-border-radius);
	padding: 40px 30px;
	transition: all var(--mai-transition-speed) ease;
	position: relative;
	overflow: hidden;
	border: 1px solid var(--mai-mid-gray);
	height: 100%;
	display: flex;
	flex-direction: column;
}

.mai-pricing-card.mai-popular {
	border-color: var(--mai-secondary-color);
	transform: scale(1.05);
}

.mai-pricing-card.mai-popular:before {
	content: 'Populaire';
	position: absolute;
	top: 20px;
	right: -35px;
	background-color: var(--mai-secondary-color);
	color: var(--mai-text-color);
	font-size: 0.9rem;
	padding: 5px 40px;
	transform: rotate(45deg);
}

.mai-pricing-card:hover {
	transform: translateY(-10px);
	box-shadow: 0 15px 30px rgba(0, 0, 0, 0.3);
}

.mai-pricing-card.mai-popular:hover {
	transform: scale(1.05) translateY(-10px);
}

.mai-pricing-header {
	text-align: center;
	padding-bottom: 20px;
	margin-bottom: 20px;
	border-bottom: 1px solid var(--mai-mid-gray);
}

.mai-pricing-name {
	font-size: 1.5rem;
	margin-bottom: 1rem;
	color: var(--mai-text-color);
}

.mai-pricing-price {
	font-size: 2.5rem;
	font-weight: 700;
	color: var(--mai-secondary-color);
	margin-bottom: 0.5rem;
}

.mai-pricing-price .mai-currency {
	font-size: 1.5rem;
	vertical-align: super;
	margin-right: 5px;
}

.mai-pricing-period {
	font-size: 1rem;
	opacity: 0.7;
}

.mai-pricing-features {
	margin-bottom: 2rem;
	flex-grow: 1;
}

.mai-pricing-feature {
	display: flex;
	align-items: center;
	margin-bottom: 1rem;
	font-size: 1rem;
}

.mai-pricing-feature i {
	color: var(--mai-secondary-color);
	margin-right: 10px;
	font-size: 1.2rem;
}

.mai-pricing-feature.mai-inactive {
	opacity: 0.5;
}

.mai-pricing-button {
	display: block;
	width: 100%;
}

/* ===== CONTACT SECTION STYLES ===== */
.mai-contact {
	padding: 100px 0;
	background-color: var(--mai-bg-color);
	position: relative;
}

.mai-contact:before {
	content: '';
	position: absolute;
	top: -50px;
	left: 0;
	width: 100%;
	height: 50px;
	background: linear-gradient(
		to top,
		var(--mai-bg-color),
		rgba(26, 35, 126, 0.1)
	);
}

.mai-contact-title {
	text-align: center;
	margin-bottom: 4rem;
}

.mai-contact-title h2:after {
	left: 50%;
	transform: translateX(-50%);
}

.mai-contact-grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: 30px;
}

.mai-contact-form {
	background-color: var(--mai-dark-gray);
	padding: 30px;
	border-radius: var(--mai-border-radius);
	box-shadow: var(--mai-shadow);
}

.mai-form-group {
	margin-bottom: 20px;
}

.mai-form-group label {
	display: block;
	margin-bottom: 5px;
	font-weight: 500;
}

.mai-form-control {
	width: 100%;
	padding: 12px;
	background-color: var(--mai-mid-gray);
	border: 1px solid var(--mai-light-gray);
	border-radius: var(--mai-border-radius);
	color: var(--mai-text-color);
	font-family: var(--mai-font-family);
	font-size: 1rem;
	transition: all var(--mai-transition-speed) ease;
}

.mai-form-control:focus {
	outline: none;
	border-color: var(--mai-secondary-color);
	box-shadow: 0 0 0 2px rgba(233, 30, 99, 0.2);
}

textarea.mai-form-control {
	min-height: 150px;
	resize: vertical;
}

.mai-form-control.mai-is-invalid {
	border-color: #ff4136;
}

.mai-invalid-feedback {
	display: none;
	color: #ff4136;
	font-size: 0.9rem;
	margin-top: 5px;
}

.mai-form-control.mai-is-invalid + .mai-invalid-feedback {
	display: block;
}

.mai-map {
	height: 100%;
	min-height: 450px;
	border-radius: var(--mai-border-radius);
	overflow: hidden;

	position: relative;
}

.iti {
	width: 100% !important;
}
.iti input[type='tel'] {
	width: 100% !important;
}

.mai-error-message {
	display: block;
	color: #ff4444;
	font-size: 0.85rem;
	margin-top: 0.5rem;
}

.mai-contact-info {
	padding: 20px;
	background-color: var(--mai-dark-gray);
	border-radius: var(--mai-border-radius);
	box-shadow: var(--mai-shadow);
}

.mai-contact-item {
	display: flex;
	align-items: flex-start;
	margin-bottom: 15px;
}

.mai-contact-item i {
	font-size: 1.2rem;
	color: var(--mai-secondary-color);
	margin-right: 15px;
	margin-top: 5px;
}

.mai-contact-item-content h4 {
	margin: 0 0 5px;
	font-size: 1.1rem;
}

.mai-contact-item-content p {
	margin: 0;
	opacity: 0.8;
}

/* ===== FOOTER STYLES ===== */
.mai-footer {
	background-color: var(--mai-dark-gray);
	padding: 60px 0 0;
}

.mai-footer-grid {
	display: grid;
	grid-template-columns: 2fr 1fr 1fr 1fr;
	gap: 30px;
}

.mai-footer-info {
	padding-right: 20px;
}

.mai-footer-logo {
	font-size: 2rem;
	font-weight: 700;
	margin-bottom: 20px;
	color: var(--mai-text-color);
}

.mai-footer-logo span {
	color: var(--mai-secondary-color);
}

.mai-footer-text {
	margin-bottom: 20px;
	opacity: 0.8;
}

.mai-footer-social {
	display: flex;
	gap: 10px;
}

.mai-footer-social-link {
	width: 40px;
	height: 40px;
	border-radius: 50%;
	background-color: var(--mai-mid-gray);
	display: flex;
	justify-content: center;
	align-items: center;
	transition: all var(--mai-transition-speed) ease;
}

.mai-footer-social-link:hover {
	background-color: var(--mai-secondary-color);
}

.mai-footer-social-link i {
	color: var(--mai-text-color);
	font-size: 1.2rem;
}

.mai-footer-links h3 {
	margin-bottom: 20px;
	position: relative;
	display: inline-block;
}

.mai-footer-links h3:after {
	content: '';
	position: absolute;
	bottom: -10px;
	left: 0;
	width: 30px;
	height: 3px;
	background-color: var(--mai-secondary-color);
}

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

.mai-footer-links li {
	margin-bottom: 10px;
}

.mai-footer-links a {
	color: var(--mai-text-color);
	opacity: 0.8;
	transition: all var(--mai-transition-speed) ease;
}

.mai-footer-links a:hover {
	color: var(--mai-secondary-color);
	opacity: 1;
	padding-left: 5px;
}

.mai-footer-contact-item {
	display: flex;
	margin-bottom: 15px;
}

.mai-footer-contact-icon {
	flex: 0 0 24px;
	color: var(--mai-secondary-color);
	margin-right: 10px;
}

.mai-footer-contact-text {
	color: var(--mai-text-color);
	opacity: 0.8;
}

.mai-footer-bottom {
	margin-top: 30px;
	padding: 20px 0;
	border-top: 1px solid var(--mai-mid-gray);
	text-align: center;
}

.mai-footer-bottom p {
	margin: 0;
	opacity: 0.8;
	font-size: 0.9rem;
}

/* ===== COOKIE POPUP STYLES ===== */
.mai-cookie-popup {
	position: fixed;
	bottom: 0;
	left: 0;
	width: 100%;
	background-color: var(--mai-dark-gray);
	padding: 20px 0;
	box-shadow: 0 -2px 10px rgba(0, 0, 0, 0.3);
	z-index: 1000;
	transform: translateY(100%);
	transition: transform 0.5s ease;
}

.mai-cookie-popup.mai-active {
	transform: translateY(0);
}

.mai-cookie-container {
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: 20px;
}

.mai-cookie-content {
	flex: 1;
}

.mai-cookie-title {
	font-size: 1.3rem;
	margin-bottom: 5px;
}

.mai-cookie-text {
	margin: 0;
	opacity: 0.9;
}

.mai-cookie-buttons {
	display: flex;
	gap: 10px;
}

/* ===== POLICY PAGES STYLES ===== */
.mai-policy-page {
	padding: 120px 0 60px;
}

.mai-policy-header {
	text-align: center;
	margin-bottom: 40px;
}

.mai-policy-content {
	background-color: var(--mai-dark-gray);
	padding: 30px;
	border-radius: var(--mai-border-radius);
	box-shadow: var(--mai-shadow);
}

.mai-policy-section {
	margin-bottom: 30px;
}

.mai-policy-section:last-child {
	margin-bottom: 0;
}

.mai-policy-section h2 {
	border-bottom: 1px solid var(--mai-mid-gray);
	padding-bottom: 10px;
	margin-bottom: 20px;
}

.mai-policy-section h3 {
	margin: 20px 0 10px;
}

.mai-policy-list {
	margin-left: 20px;
	margin-bottom: 20px;
}

.mai-policy-list li {
	margin-bottom: 5px;
}

/* ===== RESPONSIVE STYLES ===== */
@media (max-width: 1200px) {
	.mai-container {
		max-width: 100%;
		padding: 0 30px;
	}

	.mai-hero-title {
		font-size: 3rem;
	}

	.mai-timeline:before {
		display: none;
	}

	.mai-timeline-dot {
		display: none;
	}

	.mai-timeline-item:nth-child(odd),
	.mai-timeline-item:nth-child(even) {
		padding-left: 0 !important;
	}

	.mai-timeline-item {
		width: 100%;
		left: 0;
		padding-left: 80px;
		padding-right: 0;
		text-align: left;
	}

	.mai-timeline-item:nth-child(odd) {
		padding-right: 0;
		text-align: left;
	}

	.mai-timeline-item:nth-child(even) {
		left: 0;
		padding-left: 80px;
	}

	.mai-timeline-dot {
		left: 27px;
		right: auto;
	}

	.mai-methods-grid {
		grid-template-columns: repeat(2, 1fr);
	}

	.mai-pricing-grid {
		grid-template-columns: repeat(2, 1fr);
	}

	.mai-pricing-card.mai-popular {
		grid-row: 1;
	}

	.mai-footer-grid {
		grid-template-columns: repeat(2, 1fr);
	}
}

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

	h2 {
		font-size: 2.2rem;
	}

	.mai-hero-content {
		flex-direction: column;
	}

	.mai-hero-text {
		padding-right: 0;
		text-align: center;
		margin-bottom: 30px;
	}

	.mai-hero-buttons {
		justify-content: center;
	}

	.mai-contact-grid {
		grid-template-columns: 1fr;
	}

	.mai-map {
		height: 400px;
	}
}

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

	h2 {
		font-size: 2rem;
	}

	.mai-nav {
		position: static;
	}

	.mai-nav-links {
		position: fixed;
		top: 0;
		right: -100%;
		width: 270px;
		height: 100vh;
		background-color: var(--mai-dark-gray);
		flex-direction: column;
		justify-content: center;
		align-items: center;
		transition: right 0.4s ease;
		z-index: 1000;
		box-shadow: -5px 0 15px rgba(0, 0, 0, 0.3);
		margin: 0;
	}

	.mai-nav-links.mai-active {
		right: 0;
	}

	.mai-nav-link {
		margin: 15px 0;
		font-size: 1.2rem;
	}

	.mai-hamburger {
		display: flex;
		margin-left: auto;
	}

	.mai-methods-grid,
	.mai-pricing-grid {
		grid-template-columns: 1fr;
	}

	.mai-footer-grid {
		grid-template-columns: 1fr;
	}

	.mai-cookie-container {
		flex-direction: column;
		text-align: center;
	}

	.mai-cookie-buttons {
		justify-content: center;
	}
}

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

	h2 {
		font-size: 1.8rem;
	}

	.mai-hero-title {
		font-size: 2rem;
	}

	.mai-hero-subtitle {
		font-size: 1.1rem;
	}

	.mai-hero-buttons {
		flex-direction: column;
		width: 100%;
	}

	.mai-btn {
		width: 100%;
		margin-bottom: 10px;
	}

	.mai-brain-illustration {
		width: 250px;
		height: 250px;
	}

	.mai-brain-circle {
		width: 250px;
		height: 250px;
	}

	.mai-brain-animation {
		width: 180px;
		height: 180px;
	}

	.mai-brain-pulse {
		width: 150px;
		height: 150px;
	}

	.mai-policy-content {
		padding: 20px 15px;
	}
}

/* ===== OVERLAY ===== */
.mai-overlay {
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background-color: rgba(0, 0, 0, 0.8);
	z-index: 999;
	display: none;
}

.mai-overlay.mai-active {
	display: block;
}

.mai-no-scroll {
	overflow: hidden;
}

/* ===== UTILITY CLASSES ===== */
.mai-gradient-text {
	background: linear-gradient(
		90deg,
		var(--mai-primary-color),
		var(--mai-secondary-color)
	);
	-webkit-background-clip: text;
	-webkit-text-fill-color: transparent;
	display: inline-block;
}

.mai-glass-panel {
	background-color: rgba(26, 26, 26, 0.7);
	backdrop-filter: blur(10px);
	border-radius: var(--mai-border-radius);
	box-shadow: var(--mai-shadow);
	border: 1px solid rgba(255, 255, 255, 0.1);
}

.mai-bg-dark {
	background-color: var(--mai-dark-gray);
}

.mai-bg-primary {
	background-color: var(--mai-primary-color);
}

.mai-bg-secondary {
	background-color: var(--mai-secondary-color);
}

.mai-text-dark {
	color: var(--mai-dark-gray);
}

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

.mai-shadow {
	box-shadow: var(--mai-shadow);
}

/* ===== CUSTOM SCROLLBAR ===== */
::-webkit-scrollbar {
	width: 10px;
}

::-webkit-scrollbar-track {
	background: var(--mai-dark-gray);
}

::-webkit-scrollbar-thumb {
	background: var(--mai-mid-gray);
	border-radius: 5px;
}

::-webkit-scrollbar-thumb:hover {
	background: var(--mai-primary-color);
}

/* Hover Effects */
.mai-hover-lift {
	transition: transform 0.3s ease;
}

.mai-hover-lift:hover {
	transform: translateY(-5px);
}

.mai-hover-glow {
	transition: box-shadow 0.3s ease, transform 0.3s ease;
}

.mai-hover-glow:hover {
	box-shadow: 0 0 15px rgba(233, 30, 99, 0.5);
	transform: translateY(-2px);
}

/* CSS Grid Helpers */
.mai-grid-2 {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 20px;
}

.mai-grid-3 {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 20px;
}

.mai-grid-4 {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 20px;
}

/* Additional Utility Classes */
.mai-divider {
	height: 1px;
	width: 100%;
	background: linear-gradient(
		to right,
		transparent,
		var(--mai-secondary-color),
		transparent
	);
	margin: 40px 0;
}

.mai-btn-icon {
	display: inline-flex;
	align-items: center;
	gap: 8px;
}

.mai-btn-icon i {
	font-size: 1.1rem;
}

.mai-blur-bg {
	position: relative;
	overflow: hidden;
}

.mai-blur-bg:before {
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background: radial-gradient(
		circle at 50% 50%,
		rgba(26, 35, 126, 0.3),
		transparent 70%
	);
	z-index: -1;
	filter: blur(40px);
}

/* Special Elements */
.mai-tag {
	display: inline-block;
	padding: 4px 10px;
	background-color: var(--mai-primary-color);
	border-radius: 20px;
	font-size: 0.8rem;
	font-weight: 500;
	text-transform: uppercase;
	letter-spacing: 0.5px;
}

.mai-badge {
	display: inline-flex;
	align-items: center;
	gap: 5px;
	padding: 3px 8px;
	background-color: rgba(233, 30, 99, 0.2);
	border: 1px solid var(--mai-secondary-color);
	border-radius: 4px;
	font-size: 0.8rem;
}

.mai-badge i {
	font-size: 0.9rem;
	color: var(--mai-secondary-color);
}
:root {
	--mai-bg-color: #0b0f14;
	--mai-surface-color: #0f1420;
	--mai-primary-color: #39ff14; /* неоново-зелёный */
	--mai-secondary-color: #00e0c7;
	--mai-accent-color: #ffd166;
	--mai-text-color: #e6eef9;
	--mai-dark-gray: #0f1420;
	--mai-mid-gray: #182235;
	--mai-light-gray: #2a3b5e;
	--mai-border-radius: 14px;
	--mai-border-radius-sm: 10px;
	--mai-border-radius-lg: 22px;
	--mai-transition-speed: 0.3s;
	--mai-shadow: 0 10px 25px rgba(6, 12, 20, 0.45), 0 2px 8px rgba(6, 12, 20, 0.35);
	--mai-shadow-soft: 0 20px 40px rgba(10, 20, 35, 0.35);
	--mai-shadow-glow: 0 0 0 6px rgba(57, 255, 20, 0.15), 0 0 35px rgba(57, 255, 20, 0.25); /* зелёное свечение */
	--mai-ring: 0 0 0 2px rgba(57, 255, 20, 0.5); /* обводка при фокусе */
	--mai-font-family: 'Manrope', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Arial, sans-serif;
	--mai-font-display: 'Playfair Display', Georgia, 'Times New Roman', serif;
	--mai-header-height: 80px;
	--mai-gradient-primary: linear-gradient(135deg, #39ff14 0%, #00e0c7 100%); /* основной градиент зелёный */
	--mai-gradient-surface: linear-gradient(180deg, rgba(255,255,255,0.02) 0%, rgba(255,255,255,0.00) 100%);
	--mai-gradient-hero: radial-gradient(1200px 600px at 10% 10%, rgba(57,255,20,0.18) 0%, transparent 70%), radial-gradient(900px 500px at 90% 30%, rgba(0,224,199,0.18) 0%, transparent 70%), linear-gradient(180deg, #0b0f14 0%, #0e1623 100%);
}


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

html {
	scroll-behavior: smooth;
	font-size: 16px;
}

body {
	font-family: var(--mai-font-family);
	background: radial-gradient(1200px 800px at 50% -20%, rgba(106,124,255,0.12), transparent 60%) , var(--mai-bg-color);
	color: var(--mai-text-color);
	line-height: 1.65;
	overflow-x: hidden;
	position: relative;
}

h1,
h2,
h3,
h4,
h5,
h6 {
	font-weight: 700;
	line-height: 1.2;
	margin-bottom: 1rem;
	font-family: var(--mai-font-display);
	letter-spacing: 0.2px;
}

h1 {
	font-size: 3.6rem;
	margin-bottom: 2rem;
}

h2 {
	font-size: 2.6rem;
	margin-bottom: 2rem;
	position: relative;
}

h2:after {
	content: '';
	position: absolute;
	left: 0;
	bottom: -12px;
	width: 74px;
	height: 4px;
	background: var(--mai-gradient-primary);
	border-radius: 999px;
	box-shadow: var(--mai-shadow-glow);
}

h3 {
	font-size: 1.9rem;
	margin-bottom: 1.5rem;
}

h4 {
	font-size: 1.45rem;
	margin-bottom: 1.2rem;
}

p {
	margin-bottom: 1.2rem;
	font-size: 1.06rem;
	color: rgba(230, 238, 249, 0.9);
}

a {
	color: var(--mai-secondary-color);
	text-decoration: none;
	transition: all var(--mai-transition-speed) ease;
	word-wrap: break-word;
}

a:hover {
	color: #8ea0ff;
	text-shadow: 0 0 10px rgba(0, 224, 199, 0.25);
}

ul,
ol {
	margin-left: 1.5rem;
	margin-bottom: 1.5rem;
}

img {
	max-width: 100%;
	height: auto;
	display: block;
	border-radius: var(--mai-border-radius-sm);
}

button,
.mai-btn {
	cursor: pointer;
	padding: 14px 24px;
	font-size: 1rem;
	font-weight: 700;
	border-radius: var(--mai-border-radius);
	transition: all var(--mai-transition-speed) ease;
	display: inline-block;
	text-align: center;
	border: none;
	font-family: var(--mai-font-family);
	letter-spacing: 0.2px;
}

.mai-btn-primary {
	background: var(--mai-gradient-primary);
	color: #0a0f18;
	box-shadow: var(--mai-shadow-soft);
}

.mai-btn-primary:hover {
	transform: translateY(-2px);
	box-shadow: 0 20px 40px rgba(106, 124, 255, 0.25), 0 8px 18px rgba(0, 224, 199, 0.25);
	filter: saturate(1.05);
}

.mai-btn-secondary {
	background: #111b2b;
	color: var(--mai-text-color);
	border: 2px solid transparent;
	background-clip: padding-box, border-box;
	background-origin: border-box;
	background-image: linear-gradient(#111b2b, #111b2b), var(--mai-gradient-primary);
	box-shadow: var(--mai-shadow);
}

.mai-btn-secondary:hover {
	transform: translateY(-2px);
	box-shadow: var(--mai-shadow-glow);
}

.mai-btn-outline {
	background-color: transparent;
	color: var(--mai-text-color);
	border: 2px solid rgba(106,124,255,0.6);
	backdrop-filter: blur(6px);
}

.mai-btn-outline:hover {
	background: rgba(106,124,255,0.1);
	transform: translateY(-2px);
	box-shadow: var(--mai-shadow-glow);
}

.mai-container {
	width: 100%;
	max-width: 1220px;
	margin: 0 auto;
	padding: 0 24px;
}

.mai-text-center { text-align: center; }
.mai-text-right { text-align: right; }

.mai-mb-1 { margin-bottom: 1rem; }
.mai-mb-2 { margin-bottom: 2rem; }
.mai-mb-3 { margin-bottom: 3rem; }

.mai-mt-1 { margin-top: 1rem; }
.mai-mt-2 { margin-top: 2rem; }
.mai-mt-3 { margin-top: 3rem; }

.mai-mx-auto { margin-left: auto; margin-right: auto; }

.mai-text-primary { color: var(--mai-primary-color); }
.mai-text-secondary { color: var(--mai-secondary-color); }

.mai-header {
	position: fixed;
	top: 0;
	left: 0;
	right: 0;
	height: var(--mai-header-height);
	background: linear-gradient(180deg, rgba(11,15,20,0.85), rgba(11,15,20,0.75)), var(--mai-gradient-surface);
	z-index: 1000;
	backdrop-filter: blur(10px);
	box-shadow: 0 10px 30px rgba(5, 10, 18, 0.45);
	transition: all var(--mai-transition-speed) ease;
}

.mai-header.mai-scrolled {
	height: 64px;
	background: linear-gradient(180deg, rgba(11,15,20,0.95), rgba(11,15,20,0.9));
	box-shadow: var(--mai-shadow);
}

.mai-header-container {
	display: flex;
	justify-content: space-between;
	align-items: center;
	height: 100%;
}

.mai-logo {
	display: flex;
	align-items: center;
}

.mai-logo-text {
	font-size: 1.9rem;
	font-weight: 800;
	color: var(--mai-text-color);
	transition: all var(--mai-transition-speed) ease;
	letter-spacing: 0.4px;
	font-family: var(--mai-font-display);
}

.mai-logo-text span {
	background: var(--mai-gradient-primary);
	-webkit-background-clip: text;
	-webkit-text-fill-color: transparent;
}

.mai-nav {
	display: flex;
	align-items: center;
}

.mai-nav-links {
	display: flex;
	list-style: none;
	margin: 0;
}

.mai-nav-link {
	color: var(--mai-text-color);
	margin-left: 2rem;
	font-size: 1.05rem;
	font-weight: 600;
	position: relative;
	transition: all var(--mai-transition-speed) ease;
	opacity: 0.9;
}

.mai-nav-link:hover {
	color: #ffffff;
	opacity: 1;
	text-shadow: 0 0 16px rgba(106,124,255,0.45);
}

.mai-nav-link:after {
	content: '';
	position: absolute;
	bottom: -6px;
	left: 0;
	width: 0;
	height: 2px;
	background: var(--mai-gradient-primary);
	transition: all var(--mai-transition-speed) ease;
	border-radius: 999px;
}

.mai-nav-link:hover:after { width: 100%; }

.mai-hamburger {
	display: none;
	flex-direction: column;
	justify-content: space-between;
	width: 30px;
	height: 21px;
	cursor: pointer;
	z-index: 1001;
}

.mai-hamburger span {
	display: block;
	width: 100%;
	height: 3px;
	background: linear-gradient(90deg, #6a7cff, #00e0c7);
	border-radius: 3px;
	transition: all 0.3s ease-in-out;
	box-shadow: 0 2px 8px rgba(0, 224, 199, 0.25);
}

.mai-hamburger.mai-active span:nth-child(1) { transform: translateY(9px) rotate(45deg); }
.mai-hamburger.mai-active span:nth-child(2) { opacity: 0; }
.mai-hamburger.mai-active span:nth-child(3) { transform: translateY(-9px) rotate(-45deg); }

.mai-hero {
	height: 100vh;
	min-height: 700px;
	padding-top: var(--mai-header-height);
	position: relative;
	display: flex;
	align-items: center;
	overflow: hidden;
}

.mai-hero:before {
	content: '';
	position: absolute;
	inset: 0;
	background: radial-gradient(900px 500px at 15% 80%, rgba(255, 209, 102, 0.12) 0%, transparent 70%);
}

.mai-hero-grid {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background-image: url("data:image/svg+xml,%3Csvg width='120' height='120' viewBox='0 0 120 120' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M0 0h120v120H0z' fill='none'/%3E%3Cpath d='M0 0v120M120 0v120M0 0h120M0 120h120' stroke='rgba(142,160,255,0.08)' stroke-width='0.5'/%3E%3C/svg%3E");
	opacity: 0.35;
	z-index: 0;
}

.mai-hero-content {
	display: flex;
	justify-content: space-between;
	align-items: center;
	width: 100%;
	position: relative;
	z-index: 1;
}

.mai-hero-text {
	flex: 1;
	padding-right: 3rem;
}

.mai-hero-title {
	font-size: 3.6rem;
	line-height: 1.1;
	margin-bottom: 1.5rem;
	color: #ffffff;
	text-shadow: 0 8px 40px rgba(106,124,255,0.25);
}

.mai-hero-title .mai-highlight {
	background: var(--mai-gradient-primary);
	-webkit-background-clip: text;
	-webkit-text-fill-color: transparent;
}

.mai-hero-subtitle {
	font-size: 1.35rem;
	margin-bottom: 2rem;
	color: rgba(230, 238, 249, 0.92);
	opacity: 0.95;
}

.mai-hero-buttons {
	display: flex;
	gap: 1rem;
}

.mai-hero-visual {
	flex: 1;
	display: flex;
	justify-content: center;
	align-items: center;
	position: relative;
	min-height: 450px;
}

.mai-brain-illustration { position: relative; width: 360px; height: 360px; }
.mai-brain-circle {
	position: absolute;
	inset: 0;
	border-radius: 50%;
	background: radial-gradient(circle at 50% 50%, rgba(106,124,255,0.08) 0%, rgba(0,224,199,0.12) 55%, rgba(11,15,20,0.1) 100%);
	border: 1px solid rgba(142,160,255,0.25);
	display: flex;
	justify-content: center;
	align-items: center;
	box-shadow: var(--mai-shadow-glow);
}

.mai-brain-animation { width: 260px; height: 260px; position: relative; }
.mai-neuron {
	position: absolute;
	background: rgba(106,124,255,0.18);
	border: 1px solid rgba(106,124,255,0.35);
	border-radius: 50%;
	backdrop-filter: blur(2px);
}
.mai-synapse {
	position: absolute;
	height: 2px;
	background: linear-gradient(90deg, rgba(106,124,255,0.5), rgba(0,224,199,0.5));
	transform-origin: left center;
}

.mai-vision {
	padding: 110px 0;
	background: var(--mai-bg-color);
	position: relative;
}

.mai-vision:before {
	content: '';
	position: absolute;
	top: -50px;
	left: 0;
	width: 100%;
	height: 50px;
	background: linear-gradient(to top, var(--mai-bg-color), transparent);
}

.mai-vision-title { text-align: center; margin-bottom: 4rem; }
.mai-vision-title h2:after { left: 50%; transform: translateX(-50%); }

.mai-timeline { position: relative; padding: 0 20px; }

.mai-timeline:before {
	content: '';
	position: absolute;
	top: 0;
	bottom: 0;
	left: 50%;
	width: 4px;
	background: var(--mai-gradient-primary);
	transform: translateX(-50%);
	border-radius: 999px;
	box-shadow: var(--mai-shadow-glow);
}

.mai-timeline-item { position: relative; margin-bottom: 60px; width: 50%; }

.mai-timeline-item:nth-child(odd) { left: 0; padding-right: 40px; text-align: right; }
.mai-timeline-item:nth-child(even) { left: 50%; padding-left: 40px; }

.mai-timeline-dot {
	position: absolute;
	width: 26px;
	height: 26px;
	border-radius: 50%;
	top: 15px;
	background: var(--mai-gradient-primary);
	border: 4px solid var(--mai-bg-color);
	box-shadow: var(--mai-shadow);
}

.mai-timeline-item:nth-child(odd) .mai-timeline-dot { right: -13px; }
.mai-timeline-item:nth-child(even) .mai-timeline-dot { left: -13px; }

.mai-timeline-content {
	padding: 22px;
	background: linear-gradient(180deg, rgba(19, 26, 40, 0.9) 0%, rgba(16, 22, 34, 0.9) 100%);
	border-radius: var(--mai-border-radius);
	box-shadow: var(--mai-shadow);
	position: relative;
	transition: all var(--mai-transition-speed) ease;
	border: 1px solid rgba(142,160,255,0.12);
}

.mai-timeline-content:hover {
	transform: translateY(-5px);
	box-shadow: var(--mai-shadow-glow);
}

.mai-timeline-icon {
	font-size: 2rem;
	background: var(--mai-gradient-primary);
	-webkit-background-clip: text;
	-webkit-text-fill-color: transparent;
	margin-bottom: 1rem;
	display: inline-block;
}

.mai-timeline-title { font-size: 1.55rem; margin-bottom: 1rem; color: #ffffff; }

.mai-timeline-text { font-size: 1rem; color: rgba(230, 238, 249, 0.9); }

.mai-methods {
	padding: 110px 0;
	background: linear-gradient(180deg, #0f1420 0%, #0b0f14 100%);
	position: relative;
}

.mai-methods:before {
	content: '';
	position: absolute;
	top: -50px;
	left: 0;
	width: 100%;
	height: 50px;
	background: linear-gradient(to top, #0f1420, var(--mai-bg-color));
}

.mai-methods-title { text-align: center; margin-bottom: 4rem; }
.mai-methods-title h2:after { left: 50%; transform: translateX(-50%); }

.mai-methods-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 30px;
}

.mai-method-card {
	background: linear-gradient(180deg, rgba(22,30,46,0.9), rgba(14,20,32,0.9));
	border-radius: var(--mai-border-radius-lg);
	overflow: hidden;
	box-shadow: var(--mai-shadow);
	transition: all var(--mai-transition-speed) ease;
	height: 100%;
	display: flex;
	flex-direction: column;
	border: 1px solid rgba(142,160,255,0.12);
}

.mai-method-card:hover {
	transform: translateY(-10px);
	box-shadow: var(--mai-shadow-glow);
}

.mai-method-image {
	height: 220px;
	background: radial-gradient(600px 200px at 50% 0%, rgba(106,124,255,0.18), transparent), #0e1525;
	position: relative;
	overflow: hidden;
}

.mai-method-image img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: all var(--mai-transition-speed) ease;
	filter: contrast(1.05) saturate(1.02);
}

.mai-method-card:hover .mai-method-image img { transform: scale(1.05); }

.mai-method-overlay {
	position: absolute;
	inset: 0;
	display: flex;
	align-items: flex-end;
	padding: 20px;
	background: linear-gradient(to bottom, transparent, rgba(11,15,20,0.85));
}

.mai-method-icon {
	position: absolute;
	top: 20px;
	right: 20px;
	width: 56px;
	height: 56px;
	background: var(--mai-gradient-primary);
	border-radius: 16px;
	display: flex;
	justify-content: center;
	align-items: center;
	color: #0a0f18;
	font-size: 1.5rem;
	box-shadow: var(--mai-shadow-glow);
}

.mai-method-content {
	padding: 22px;
	flex-grow: 1;
	display: flex;
	flex-direction: column;
}

.mai-method-title { font-size: 1.55rem; margin-bottom: 1rem; }
.mai-method-text { margin-bottom: 1.4rem; flex-grow: 1; }

.mai-method-features { margin-bottom: 1.2rem; }
.mai-method-feature { display: flex; align-items: center; margin-bottom: 0.5rem; }
.mai-method-feature i {
	background: var(--mai-gradient-primary);
	-webkit-background-clip: text;
	-webkit-text-fill-color: transparent;
	margin-right: 0.5rem;
}

.mai-pricing {
	padding: 110px 0;
	background: radial-gradient(900px 400px at 10% 10%, rgba(106,124,255,0.12), transparent 60%), radial-gradient(900px 400px at 90% 20%, rgba(0,224,199,0.12), transparent 60%), linear-gradient(180deg, #0b0f14 0%, #0f1420 100%);
	position: relative;
}

.mai-pricing:before {
	content: '';
	position: absolute;
	top: -50px;
	left: 0;
	width: 100%;
	height: 50px;
	background: linear-gradient(to top, rgba(106,124,255,0.08), var(--mai-dark-gray));
}

.mai-pricing-title { text-align: center; margin-bottom: 4rem; }
.mai-pricing-title h2:after { left: 50%; transform: translateX(-50%); }

.mai-pricing-toggle {
	display: flex;
	justify-content: center;
	align-items: center;
	margin-bottom: 3rem;
	background: rgba(16, 24, 38, 0.6);
	backdrop-filter: blur(8px);
	border-radius: 999px;
	padding: 10px 14px;
	border: 1px solid rgba(142,160,255,0.15);
	box-shadow: var(--mai-shadow);
}

.mai-pricing-toggle-option {
	padding: 10px 18px;
	cursor: pointer;
	transition: all var(--mai-transition-speed) ease;
	opacity: 0.75;
	border-radius: 999px;
}

.mai-pricing-toggle-option.mai-active {
	opacity: 1;
	font-weight: 700;
	background: var(--mai-gradient-primary);
	color: #0a0f18;
	box-shadow: var(--mai-shadow-glow);
}

.mai-pricing-toggle-switch {
	display: none;
}

.mai-pricing-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 30px;
}

.mai-pricing-card {
	background: linear-gradient(180deg, rgba(22,30,46,0.92), rgba(12,18,30,0.92));
	border-radius: var(--mai-border-radius-lg);
	padding: 40px 30px;
	transition: all var(--mai-transition-speed) ease;
	position: relative;
	overflow: hidden;
	border: 1px solid rgba(142,160,255,0.12);
	height: 100%;
	display: flex;
	flex-direction: column;
	box-shadow: var(--mai-shadow);
}

.mai-pricing-card.mai-popular {
	border-color: rgba(0,224,199,0.7);
	box-shadow: var(--mai-shadow-glow);
}

.mai-pricing-card.mai-popular:before {
	content: 'Populaire';
	position: absolute;
	top: 18px;
	right: -34px;
	background: var(--mai-gradient-primary);
	color: #0a0f18;
	font-size: 0.88rem;
	padding: 6px 42px;
	transform: rotate(45deg);
	border-radius: 0;
	font-weight: 800;
}

.mai-pricing-card:hover {
	transform: translateY(-10px);
	box-shadow: var(--mai-shadow-glow);
}

.mai-pricing-card.mai-popular:hover {
	transform: translateY(-10px) scale(1.01);
}

.mai-pricing-header {
	text-align: center;
	padding-bottom: 20px;
	margin-bottom: 20px;
	border-bottom: 1px solid rgba(142,160,255,0.15);
}

.mai-pricing-name {
	font-size: 1.55rem;
	margin-bottom: 1rem;
	color: #ffffff;
}

.mai-pricing-price {
	font-size: 2.6rem;
	font-weight: 800;
	background: var(--mai-gradient-primary);
	-webkit-background-clip: text;
	-webkit-text-fill-color: transparent;
	margin-bottom: 0.5rem;
}

.mai-pricing-price .mai-currency {
	font-size: 1.5rem;
	vertical-align: super;
	margin-right: 5px;
}

.mai-pricing-period { font-size: 1rem; opacity: 0.85; }

.mai-pricing-features { margin-bottom: 2rem; flex-grow: 1; }
.mai-pricing-feature {
	display: flex;
	align-items: center;
	margin-bottom: 1rem;
	font-size: 1rem;
}
.mai-pricing-feature i {
	background: var(--mai-gradient-primary);
	-webkit-background-clip: text;
	-webkit-text-fill-color: transparent;
	margin-right: 10px;
	font-size: 1.2rem;
}
.mai-pricing-feature.mai-inactive { opacity: 0.55; }

.mai-pricing-button { display: block; width: 100%; }

.mai-contact {
	padding: 110px 0;
	background: radial-gradient(1000px 500px at 15% 20%, rgba(106,124,255,0.12), transparent 60%), var(--mai-bg-color);
	position: relative;
}

.mai-contact:before {
	content: '';
	position: absolute;
	top: -50px;
	left: 0;
	width: 100%;
	height: 50px;
	background: linear-gradient(to top, var(--mai-bg-color), rgba(106,124,255,0.1));
}

.mai-contact-title { text-align: center; margin-bottom: 4rem; }
.mai-contact-title h2:after { left: 50%; transform: translateX(-50%); }

.mai-contact-grid { display: grid; grid-template-columns: 1fr; gap: 30px; }

.mai-contact-form {
	background: linear-gradient(180deg, rgba(22,30,46,0.92), rgba(14,20,32,0.92));
	padding: 30px;
	border-radius: var(--mai-border-radius-lg);
	box-shadow: var(--mai-shadow);
	border: 1px solid rgba(142,160,255,0.12);
}

.mai-form-group { margin-bottom: 20px; }
.mai-form-group label { display: block; margin-bottom: 8px; font-weight: 600; }

.mai-form-control {
	width: 100%;
	padding: 14px;
	background-color: #101a2b;
	border: 1px solid rgba(142,160,255,0.2);
	border-radius: var(--mai-border-radius);
	color: var(--mai-text-color);
	font-family: var(--mai-font-family);
	font-size: 1rem;
	transition: all var(--mai-transition-speed) ease;
	box-shadow: inset 0 0 0 1px rgba(255,255,255,0.02);
}

.mai-form-control:focus {
	outline: none;
	border-color: rgba(0,224,199,0.9);
	box-shadow: var(--mai-ring);
	background-color: #0f192a;
}

textarea.mai-form-control { min-height: 160px; resize: vertical; }

.mai-form-control.mai-is-invalid { border-color: #ff5c5c; }
.mai-invalid-feedback { display: none; color: #ff5c5c; font-size: 0.9rem; margin-top: 6px; }
.mai-form-control.mai-is-invalid + .mai-invalid-feedback { display: block; }

.mai-map {
	height: 100%;
	min-height: 450px;
	border-radius: var(--mai-border-radius-lg);
	overflow: hidden;
	position: relative;
	box-shadow: var(--mai-shadow);
}

.iti { width: 100% !important; }
.iti input[type='tel'] { width: 100% !important; }

.mai-error-message { display: block; color: #ff5c5c; font-size: 0.88rem; margin-top: 0.5rem; }

.mai-contact-info {
	padding: 22px;
	background: linear-gradient(180deg, rgba(22,30,46,0.92), rgba(14,20,32,0.92));
	border-radius: var(--mai-border-radius-lg);
	box-shadow: var(--mai-shadow);
	border: 1px solid rgba(142,160,255,0.12);
}

.mai-contact-item { display: flex; align-items: flex-start; margin-bottom: 15px; }
.mai-contact-item i {
	font-size: 1.2rem;
	background: var(--mai-gradient-primary);
	-webkit-background-clip: text;
	-webkit-text-fill-color: transparent;
	margin-right: 14px;
	margin-top: 5px;
}
.mai-contact-item-content h4 { margin: 0 0 5px; font-size: 1.1rem; }
.mai-contact-item-content p { margin: 0; opacity: 0.85; }

.mai-footer {
	background: linear-gradient(180deg, #0f1420 0%, #0b0f14 100%);
	padding: 70px 0 0;
}

.mai-footer-grid {
	display: grid;
	grid-template-columns: 2fr 1fr 1fr 1fr;
	gap: 30px;
}

.mai-footer-info { padding-right: 20px; }
.mai-footer-logo {
	font-size: 2rem;
	font-weight: 800;
	margin-bottom: 20px;
	color: var(--mai-text-color);
	font-family: var(--mai-font-display);
}
.mai-footer-logo span {
	background: var(--mai-gradient-primary);
	-webkit-background-clip: text;
	-webkit-text-fill-color: transparent;
}

.mai-footer-text { margin-bottom: 20px; opacity: 0.85; }

.mai-footer-social { display: flex; gap: 10px; }
.mai-footer-social-link {
	width: 42px;
	height: 42px;
	border-radius: 50%;
	background: #121c2b;
	display: flex;
	justify-content: center;
	align-items: center;
	transition: all var(--mai-transition-speed) ease;
	border: 1px solid rgba(142,160,255,0.15);
}
.mai-footer-social-link:hover {
	background: var(--mai-gradient-primary);
	box-shadow: var(--mai-shadow-glow);
}
.mai-footer-social-link i { color: #0a0f18; font-size: 1.2rem; }

.mai-footer-links h3 {
	margin-bottom: 20px;
	position: relative;
	display: inline-block;
}

.mai-footer-links h3:after {
	content: '';
	position: absolute;
	bottom: -10px;
	left: 0;
	width: 42px;
	height: 3px;
	background: var(--mai-gradient-primary);
	border-radius: 999px;
}

.mai-footer-links ul { list-style: none; margin: 0; padding: 0; }
.mai-footer-links li { margin-bottom: 10px; }
.mai-footer-links a {
	color: var(--mai-text-color);
	opacity: 0.85;
	transition: all var(--mai-transition-speed) ease;
}
.mai-footer-links a:hover {
	opacity: 1;
	padding-left: 6px;
	text-shadow: 0 0 14px rgba(106,124,255,0.4);
}

.mai-footer-contact-item { display: flex; margin-bottom: 15px; }
.mai-footer-contact-icon { flex: 0 0 24px; color: var(--mai-secondary-color); margin-right: 10px; }
.mai-footer-contact-text { color: var(--mai-text-color); opacity: 0.85; }

.mai-footer-bottom {
	margin-top: 36px;
	padding: 22px 0;
	border-top: 1px solid rgba(142,160,255,0.15);
	text-align: center;
	background: rgba(10, 16, 28, 0.35);
}
.mai-footer-bottom p { margin: 0; opacity: 0.85; font-size: 0.95rem; }

.mai-cookie-popup {
	position: fixed;
	bottom: 0;
	left: 0;
	width: 100%;
	background: linear-gradient(180deg, rgba(22,30,46,0.95), rgba(14,20,32,0.95));
	padding: 22px 0;
	box-shadow: 0 -10px 30px rgba(5, 10, 18, 0.45);
	z-index: 1000;
	transform: translateY(100%);
	transition: transform 0.5s ease;
	border-top: 1px solid rgba(142,160,255,0.15);
}

.mai-cookie-popup.mai-active { transform: translateY(0); }

.mai-cookie-container {
	display: flex;
	justify-content: space-between;
	align-items: center;
	gap: 20px;
}

.mai-cookie-content { flex: 1; }
.mai-cookie-title { font-size: 1.25rem; margin-bottom: 6px; }
.mai-cookie-text { margin: 0; opacity: 0.9; }
.mai-cookie-buttons { display: flex; gap: 10px; }

.mai-policy-page { padding: 130px 0 70px; }
.mai-policy-header { text-align: center; margin-bottom: 40px; }

.mai-policy-content {
	background: linear-gradient(180deg, rgba(22,30,46,0.92), rgba(14,20,32,0.92));
	padding: 30px;
	border-radius: var(--mai-border-radius-lg);
	box-shadow: var(--mai-shadow);
	border: 1px solid rgba(142,160,255,0.12);
}

.mai-policy-section { margin-bottom: 30px; }
.mai-policy-section:last-child { margin-bottom: 0; }

.mai-policy-section h2 {
	border-bottom: 1px solid rgba(142,160,255,0.15);
	padding-bottom: 12px;
	margin-bottom: 20px;
}

.mai-policy-section h3 { margin: 20px 0 10px; }
.mai-policy-list { margin-left: 20px; margin-bottom: 20px; }
.mai-policy-list li { margin-bottom: 7px; }

@media (max-width: 1200px) {
	.mai-container { max-width: 100%; padding: 0 28px; }
	.mai-hero-title { font-size: 3.1rem; }
	.mai-timeline:before { display: none; }
	.mai-timeline-dot { display: none; }
	.mai-timeline-item:nth-child(odd),
	.mai-timeline-item:nth-child(even) { padding-left: 0 !important; }
	.mai-timeline-item { width: 100%; left: 0; padding-left: 80px; padding-right: 0; text-align: left; }
	.mai-timeline-item:nth-child(odd) { padding-right: 0; text-align: left; }
	.mai-timeline-item:nth-child(even) { left: 0; padding-left: 80px; }
	.mai-timeline-dot { left: 27px; right: auto; }
	.mai-methods-grid { grid-template-columns: repeat(2, 1fr); }
	.mai-pricing-grid { grid-template-columns: repeat(2, 1fr); }
	.mai-pricing-card.mai-popular { grid-row: 1; }
	.mai-footer-grid { grid-template-columns: repeat(2, 1fr); }
}

@media (max-width: 992px) {
	h1 { font-size: 3rem; }
	h2 { font-size: 2.2rem; }
	.mai-hero-content { flex-direction: column; }
	.mai-hero-text { padding-right: 0; text-align: center; margin-bottom: 30px; }
	.mai-hero-buttons { justify-content: center; }
	.mai-contact-grid { grid-template-columns: 1fr; }
	.mai-map { height: 400px; }
}

@media (max-width: 768px) {
	h1 { font-size: 2.5rem; }
	h2 { font-size: 2rem; }
	.mai-nav { position: static; }
	.mai-nav-links {
		position: fixed;
		top: 0;
		right: -100%;
		width: 290px;
		height: 100vh;
		background: linear-gradient(180deg, #0f1420, #0b0f14);
		flex-direction: column;
		justify-content: center;
		align-items: center;
		transition: right 0.4s ease;
		z-index: 1000;
		box-shadow: -5px 0 20px rgba(0, 0, 0, 0.35);
		margin: 0;
		border-left: 1px solid rgba(142,160,255,0.12);
	}
	.mai-nav-links.mai-active { right: 0; }
	.mai-nav-link { margin: 16px 0; font-size: 1.2rem; }
	.mai-hamburger { display: flex; margin-left: auto; }
	.mai-methods-grid, .mai-pricing-grid { grid-template-columns: 1fr; }
	.mai-footer-grid { grid-template-columns: 1fr; }
	.mai-cookie-container { flex-direction: column; text-align: center; }
	.mai-cookie-buttons { justify-content: center; }
}

@media (max-width: 480px) {
	h1 { font-size: 2.2rem; }
	h2 { font-size: 1.8rem; }
	.mai-hero-title { font-size: 2.2rem; }
	.mai-hero-subtitle { font-size: 1.08rem; }
	.mai-hero-buttons { flex-direction: column; width: 100%; }
	.mai-btn { width: 100%; margin-bottom: 10px; }
	.mai-brain-illustration { width: 260px; height: 260px; }
	.mai-brain-animation { width: 190px; height: 190px; }
	.mai-policy-content { padding: 20px 16px; }
}

.mai-overlay {
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background: radial-gradient(800px 400px at 50% 10%, rgba(106,124,255,0.15), rgba(0,0,0,0.7));
	z-index: 999;
	display: none;
}

.mai-overlay.mai-active { display: block; }

.mai-no-scroll { overflow: hidden; }

.mai-gradient-text {
	background: var(--mai-gradient-primary);
	-webkit-background-clip: text;
	-webkit-text-fill-color: transparent;
	display: inline-block;
}

.mai-glass-panel {
	background: rgba(16, 24, 38, 0.6);
	backdrop-filter: blur(12px);
	border-radius: var(--mai-border-radius-lg);
	box-shadow: var(--mai-shadow);
	border: 1px solid rgba(142,160,255,0.15);
}

.mai-bg-dark { background-color: var(--mai-dark-gray); }
.mai-bg-primary { background: var(--mai-gradient-primary); }
.mai-bg-secondary { background: radial-gradient(400px 200px at 50% 0%, rgba(0,224,199,0.25), rgba(0,224,199,0.05)); }

.mai-text-dark { color: var(--mai-dark-gray); }
.mai-text-light { color: var(--mai-text-color); }

.mai-shadow { box-shadow: var(--mai-shadow); }

::-webkit-scrollbar { width: 10px; }
::-webkit-scrollbar-track { background: #0f1420; }
::-webkit-scrollbar-thumb { background: #182235; border-radius: 5px; }
::-webkit-scrollbar-thumb:hover { background: #26324d; }

.mai-hover-lift { transition: transform 0.3s ease, box-shadow 0.3s ease; }
.mai-hover-lift:hover { transform: translateY(-6px); box-shadow: var(--mai-shadow-glow); }

.mai-hover-glow { transition: box-shadow 0.3s ease, transform 0.3s ease; }
.mai-hover-glow:hover { box-shadow: var(--mai-shadow-glow); transform: translateY(-2px); }

.mai-grid-2 { display: grid; grid-template-columns: repeat(2, 1fr); gap: 20px; }
.mai-grid-3 { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; }
.mai-grid-4 { display: grid; grid-template-columns: repeat(4, 1fr); gap: 20px; }

.mai-divider {
	height: 1px;
	width: 100%;
	background: linear-gradient(to right, transparent, rgba(106,124,255,0.6), transparent);
	margin: 40px 0;
}

.mai-btn-icon { display: inline-flex; align-items: center; gap: 8px; }
.mai-btn-icon i { font-size: 1.1rem; }

.mai-blur-bg { position: relative; overflow: hidden; }
.mai-blur-bg:before {
	content: '';
	position: absolute;
	inset: 0;
	background: radial-gradient(600px 300px at 50% 50%, rgba(106,124,255,0.25), transparent 70%);
	z-index: -1;
	filter: blur(40px);
}

.mai-tag {
	display: inline-block;
	padding: 6px 12px;
	background: rgba(106,124,255,0.12);
	border-radius: 999px;
	font-size: 0.82rem;
	font-weight: 700;
	text-transform: uppercase;
	letter-spacing: 0.6px;
	border: 1px solid rgba(106,124,255,0.35);
	color: #cfd7ff;
}

.mai-badge {
	display: inline-flex;
	align-items: center;
	gap: 6px;
	padding: 4px 10px;
	background: rgba(0,224,199,0.12);
	border: 1px solid rgba(0,224,199,0.5);
	border-radius: 12px;
	font-size: 0.82rem;
	color: #a6fff2;
}
.mai-badge i { font-size: 0.95rem; background: var(--mai-gradient-primary); -webkit-background-clip: text; -webkit-text-fill-color: transparent; }
.mai-highlight {
    color: #FFD700; /* Ярко-жёлтый цвет */
}
.mai-vision-card {
	padding: 15px;
}
/* Responsive tweaks scoped to the Vision block only */
		#vision .mai-vision-features {
			display: grid;
			grid-template-columns: repeat(2, minmax(0, 1fr));
			gap: 28px;
		}
		#vision .mai-vision-card {
			padding: 28px;
			border-radius: var(--mai-border-radius-lg);
		}
		#vision .mai-vision-card .mai-btn {
			white-space: nowrap;
		}

		@media (max-width: 992px) {
			#vision .mai-vision-features {
				grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
				gap: 22px;
			}
			#vision .mai-vision-card { padding: 24px; }
			#vision .mai-vision-title h2 { font-size: 2.1rem; }
		}

		@media (max-width: 768px) {
			#vision .mai-vision-features {
				grid-template-columns: 1fr;
				gap: 18px;
			}
			#vision .mai-vision-card {
				padding: 20px;
			}
			#vision .mai-timeline-title { font-size: 1.25rem; }
			#vision .mai-timeline-text { font-size: 1rem; }
			#vision .mai-vision-card .mai-btn {
				display: inline-flex;
				width: 100%;
				justify-content: center;
				padding: 12px 18px;
			}
		}

		@media (max-width: 480px) {
			#vision .mai-vision-title h2 { font-size: 1.8rem; }
			#vision .mai-vision-card { padding: 18px; }
		}