﻿/* =========== © 2025 Centroarts.com - https://deepbot.cloud =========== */

:root {
	--g-card: 12px;
	--h-img-card: 52%;
	--r-card: 6px;
	--mw-card: 288px;
	--p-card: 28px;
}
@media (min-width: 576px) {
	:root {
		--p-card: 32px;
	}
}
@media (min-width: 992px) {
	:root {
		--g-card: 20px;
	}
}

.grid {
    display: grid;
	grid-template-rows: auto;
	grid-template-columns: repeat(var(--grid-cols), 1fr);
    gap: var(--g-card);
}

/* Cols */
.g-c4 { --grid-cols: 4; }
.g-c3 { --grid-cols: 3; }
.g-c2 { --grid-cols: 2; }

@media (max-width: 991px) {
	.scroll-h.g-c4 .card, .scroll-h.g-c3 .card, .scroll-h.g-c2 .card { min-width: var(--mw-card); }
	.scroll-h { scroll-snap-type: x mandatory }
	.scroll-h .card {
        scroll-snap-align: start;
        scroll-margin-left: var(--p-wrp);
		scroll-margin-right: var(--p-wrp);
    }
}

@media (min-width: 576px) {
	.grid-sm {
		display: grid;
		grid-template-rows: auto;
		grid-template-columns: repeat(var(--grid-cols), 1fr);
		gap: var(--g-card);
		--grid-cols: 2;
	}
	.g-sm-c4 { --grid-cols: 4; }
	.g-sm-c3 { --grid-cols: 3; }
	.g-sm-c2 { --grid-cols: 2; }

	.grid-sm > *:not(.card) { grid-column: auto/span var(--grid-cols); }
}

@media (min-width: 768px) {
	.grid-md {
		display: grid;
		grid-template-rows: auto;
		grid-template-columns: repeat(var(--grid-cols), 1fr);
		gap: var(--g-card);
		--grid-cols: 2;
	}
	.g-md-c4 { --grid-cols: 4; }
	.g-md-c3 { --grid-cols: 3; }
	.g-md-c2 { --grid-cols: 2; }

	.grid-md > *:not(.card) { grid-column: auto/span var(--grid-cols); }
}

@media (min-width: 992px) {
	.grid-lg {
		display: grid;
		grid-template-rows: auto;
		grid-template-columns: repeat(var(--grid-cols), 1fr);
		gap: var(--g-card);
		--grid-cols: 2;
	}
	.g-lg-c4 { --grid-cols: 4; }
	.g-lg-c3 { --grid-cols: 3; }
	.g-lg-c2 { --grid-cols: 2; }

	.grid-lg > *:not(.card) { grid-column: auto/span var(--grid-cols); }
}

@media (min-width: 1200px) {
	.grid-xl {
		display: grid;
		grid-template-rows: auto;
		grid-template-columns: repeat(var(--grid-cols), 1fr);
		gap: var(--g-card);
		--grid-cols: 2;
	}
	.g-xl-c4 { --grid-cols: 4; }
	.g-xl-c3 { --grid-cols: 3; }
	.g-xl-c2 { --grid-cols: 2; }

	.grid-xl > *:not(.card) { grid-column: auto/span var(--grid-cols); }
}

/* Title & Cont */
.title {
	--fs-title: 18px;
	--lh-title: 1.5;
	font-size: var(--fs-title); font-weight: 500;
	line-height: var(--lh-title); margin-bottom: 0;
}
@media (min-width: 1100px) {
	.title { --fs-title: 20px; }
}
.title a { color: inherit; }
.title + .desc { margin-top: 8px; }
.desc {
	--fs-desc: inherit;
	font-size: var(--fs-desc); opacity: .8;
}
.desc ul, .desc ol { padding: 0 0 0 4px; margin-bottom: var(--text-padding); }
.desc ul { list-style: outside; }
.desc ul li { margin-left: 16px; }
.desc ul li + li, .desc > ol li + li { margin-top: .125em; }
.desc p + ul, .desc p + ol { margin-top: -12px; }
.desc p:last-child, ul:last-child, ol:last-child { margin-bottom: 0; }

/* Cards */
.card:not(.review) .cover { border-radius: var(--r-card); }
.card:not(.review) .cover + .card-cont { margin-top: 16px; }

.card .cover::before { content: ""; width: 1px; margin-left: -1px; padding-top: var(--h-img-card); }
.card .cover::after { content: ""; position: absolute; inset: 0; background-color: #000; opacity: 0; transition: opacity .15s ease; }
html.dark .card .cover::after { opacity: .05; }

.card-icon { display: block; width: 32px; height: 32px; margin-bottom: 16px; }
.card-icon .ic { width: inherit; height: inherit; color: hsl(var(--c-primary2)); }

.card-cont { padding-right: 20px; }

.card .price { margin-top: var(--p-card); }
.card .btn-group { justify-content: start; margin-top: 16px; }

/* Card & Styles */
.card-border, .card-highlight { padding: var(--p-card); }

.card-border { border-radius: var(--r-card); box-shadow: inset 0 0 0 1px var(--c-border); transition: box-shadow .2s ease; }
.item.card-border:hover { box-shadow: inset 0 0 0 1px var(--c-border-h); }
.card-border .card-cont { padding-right: 0; }

.card-highlight { background-color: var(--c-body-tone); border-radius: var(--r-card); transition: background-color .2s ease; }
.item.card-highlight:hover { background-color: var(--c-body-tone-h); }
.card-highlight .card-cont { padding-right: 0; }

/* Pic Cards */
.card-pic {
	display: flex; align-items: center; justify-content: center; padding: 20px;
	background-color: var(--c-body-tone); border-radius: var(--r-card);
}
.card-pic::before { content: ""; width: 1px; margin-left: -1px; padding-top: var(--h-img-card); }
.card-pic svg { max-width: 100%; height: auto; fill: currentColor; }

.pic-color-p { fill: hsl(var(--c-primary2)); }

.card-pic + .card-cont { margin-top: 20px; padding-right: 32px; }

@media (min-width: 576px) {
	.card:not(.review) .cover + .card-cont { margin-top: 20px; }
	.card-cont { padding-right: 32px; }
	.card-icon { margin-bottom: 20px; }
}

/* Features IMG */
.features-img { --h-img-card: 75%; }

/* Features Video */
.features-video { --h-img-card: 121.6%; }

/* Features Text */
@media (max-width: 575px) {
	.features-text .card-list { margin: 0 calc(var(--p-wrp)/-1); }
	.features-text .card-border { display: flex; border-radius: 0; box-shadow: inset 0 1px 0 0 var(--c-border); }
	.features-text .card-border .card-icon { margin-right: 16px; }
	.features-text .card-border .card-icon .ic { width: 28px; height: 28px; }
}

/* Features Edu */
.features-edu .card-list .card { padding-bottom: 12px; }
@media (max-width: 575px) {
	.features-edu .sect-cont { margin: 0 calc(var(--p-wrp)/-1); }
	.features-edu .card-list { padding-left: var(--p-wrp); padding-right: var(--p-wrp); }
	.features-edu .card .title { --fs-title: inherit; }
	.features-edu .card .cover { border-radius: 0; }
}

/* features-more */
@media (max-width: 575px) {
	.features-more.wrp { padding-left: 0; padding-right: 0; }
	.features-more .highlight-box { border-radius: 0; }
}

/* Card Big Img */
.card-bigimg { --h-img-card: 380px; }
.card-bigimg + .grid { margin-top: var(--g-cont3); }
@media (min-width: 992px) {
	.card-bigimg { --h-img-card: 490px; }
}

/* highlight-box */
.highlight-box { padding: 64px 32px; background-color: hsl(var(--c-text), 0.03); border-radius: var(--r-card); }
html.dark .highlight-box { background-color: hsl(var(--c-text), 0.1); }

/* Prompt Gallery */
.sect-anim.active .p-gallery { opacity: 1; }
.p-gallery { overflow: hidden; opacity: 0; transition: opacity .5s ease-out; }
.p-gallery-row { display: flex; user-select: none; gap: var(--g-card); }
.p-gallery-row:first-child { margin-left: -64px; }
.p-gallery-row:last-child { margin-left: -32px; }
.p-gallery-row + .p-gallery-row { margin-top: var(--g-card); }
.p-gallery-group {
	display: flex; flex-shrink: 0; min-width: 100%;
	justify-content: space-around; gap: var(--g-card);
	will-change: transform;
}

.sect-anim.active .p-gallery-group { animation: gallery 180s linear infinite; }
.p-gallery-row.reverse .p-gallery-group { animation-direction: reverse; }

@keyframes gallery {
	from { transform: translate3d(0, 0, 0); }
	to { transform: translate3d(-100%, 0, 0); }
}

.p-gallery-item {
	width: 260px; position: relative;
	border-radius: var(--r-card); padding: 20px;
	box-shadow: inset 0 0 0 1px var(--c-border);
}
.p-gallery-item::before {
	content: ""; position: absolute; left: 5px; top: 5px; width: 12px; height: 12px; display: block;
	mask-image: url(../images/prompt-star.svg); -webkit-mask-image: url(../images/prompt-star.svg);
	mask-size: 100% 100%; -webkit-mask-size: 100% 100%;
	background-color: currentColor;
}

.p-gallery-item .title { font-size: 14px; }
.p-gallery-muted .title, .p-gallery-muted::before { opacity: .5; }

html.dark .p-gallery-highlight .title { color: hsl(var(--c-primary)); }
.p-gallery-highlight::before { color: hsl(var(--c-primary2)); }

@media (min-width: 992px) {
	.p-gallery-item { width: 340px; padding: 32px; }
	.p-gallery-item::before { left: 16px; top: 16px; width: 16px; height: 16px; }
	.p-gallery-item .title { font-size: 18px; }
}

/* Benefit & Illustrations */
.sect-benefits.sect-anim .card-illustrate {
	transform: translate3d(0,-4px,0); opacity: 0; transition: transform .6s ease-out, opacity .4s ease-out;
	will-change: transform;
}
.sect-benefits.active .card-illustrate { transform: translate3d(0,0,0); opacity: 1; }

@media (max-width: 767px) {
	.sect-benefits .card-list .card + .card { margin-top: var(--g-card); }
}
@media (max-width: 575px) {
	.sect-benefits .card-list { margin-left: calc(var(--p-wrp)/-1); margin-right: calc(var(--p-wrp)/-1); padding-left: var(--g-card); padding-right: var(--g-card); }
}

.card-cont + .card-illustrate { margin-top: 32px; }
.card-illustrate { display: flex; align-items: center; justify-content: center; }
.card-illustrate::before { content: ""; width: 1px; margin-left: -1px; padding-top: var(--h-img-card); }
.il-pic { position: relative; pointer-events: none; }

/* Vpn */
.il-vpn-circle-group { display: flex; }
.il-vpn-circle { width: 96px; height: 96px; border: 2px solid; border-radius: 50%; }
.il-vpn-circle + .il-vpn-circle { margin-left: -44px; }
.il-vpn-circle:last-child { border-color: hsl(var(--c-primary2)); position: relative; z-index: 1; }
.il-vpn-arrow { position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%); color: hsl(var(--c-primary2)); }

@media (min-width: 576px) {
	.il-vpn-circle { width: 108px; height: 108px; }
	.il-vpn-circle + .il-vpn-circle { margin-left: -52px; }
}
@media (min-width: 1100px) {
	.il-vpn-circle { width: 140px; height: 140px; }
	.il-vpn-circle + .il-vpn-circle { margin-left: -68px; }
}

/* Pay Cards */
.il-pcard-group { display: flex; justify-content: center; width: 100%; }
.il-pcard {
	display: flex; align-items: end; justify-content: start;
	border: 2px solid; flex: 1; max-width: 92px; height: 72px; border-radius: 16px; padding: 16px;
}
.il-pcard + .il-pcard { margin-left: 8px; }
.il-pcard:first-child { border-color: hsl(var(--c-primary2)); }
.il-pcard-logo { fill: currentColor; opacity: .4; }

@media (min-width: 576px) {
	.il-pcard { max-width: 160px; height: 88px; }
}
@media (min-width: 1100px) {
	.il-pcard {
		max-width: 160px; height: 112px; border-radius: 20px; padding: 20px;
	}
}

/* Support */
.il-support { display: flex; padding-top: 38px; }
.il-support-cloud { border: 2px solid; }
.il-support-cloud:first-child { border-color: hsl(var(--c-primary2)); width: 156px; height: 102px; border-radius: 70px 70px 5px 70px; }
.il-support-cloud:last-child { width: 120px; height: 76px; border-radius: 70px 70px 70px 5px; margin-top: -28px; margin-left: -56px; }

@media (min-width: 1100px) {
	.il-support-cloud:first-child { width: 212px; height: 140px; }
	.il-support-cloud:last-child { width: 160px; height: 104px; margin-top: -38px; margin-left: -80px; }
}

/* UnLimits */
.il-unlim-group { display: flex; justify-content: end; border: 2px solid hsl(var(--c-primary2)); padding: 6px; border-radius: 72px; }
.il-unlim-tumb { position: relative; width: 80px; height: 80px; margin-left: 80px; border: 2px solid; border-radius: inherit; }
.il-unlim-line {
	position: absolute; left: 50%; top: 50%; width: 148px; height: 2px;
	margin-left: -74px; margin-top: -1px; display: flex; justify-content: space-between;
}
.il-unlim-line:nth-child(1) { transform: rotate(90deg); }
.il-unlim-line:nth-child(2) { transform: rotate(135deg); }
.il-unlim-line:nth-child(3) { transform: rotate(-135deg); }
.il-unlim-line::before, .il-unlim-line::after { content: ""; display: block; width: 13%; height: 0; border-top: 2px solid; border-radius: 1px; }

@media (min-width: 1100px) {
	.il-unlim-group { padding: 10px; }
	.il-unlim-tumb { width: 116px; height: 116px; margin-left: 116px; }
	.il-unlim-line { width: 224px; margin-left: -112px; }
}

/* Reviews */
.review {
	--review-photo: 100%;
	--ic-url: url(../images/quote.svg);
	
	border-radius: var(--r-card); padding: 28px;
	box-shadow: inset 0 0 0 1px var(--c-border);
}
.review > .im { width: 39px; height: 32px; margin-bottom: 28px; opacity: .1; }
html.dark .review > .im { opacity: .2; }
.review-text {
	font-size: inherit; line-height: 1.75em; height: calc(1.75em * 10);
	display: -webkit-box; overflow: hidden; -webkit-line-clamp: 10;
    -webkit-box-orient: vertical; text-overflow: ellipsis;
}
.review-contacts { display: flex; align-items: center; margin-top: 32px; }
.review .cover::before { padding-top: var(--review-photo); }
.review .cover { max-width: 48px; border-radius: 50%; margin-right: 16px; }
.review-pos { opacity: .6; font-size: 15px; }

@media (min-width: 576px) {
	.review { padding: 32px; }
}
@media (min-width: 768px) {
	.review { display: flex; }
	.review > .im { width: 44px; height: 36px; margin-right: 32px; margin-bottom: 0; }
	.review .cover { max-width: 56px; margin-right: 20px; }

	.review-text {
		height: calc(1.75em * 4); -webkit-line-clamp: 4;
	}
}
@media (min-width: 992px) {
	.review { padding: 48px; }
	.review-text { font-size: 20px; }
}

/* Tarifs */
.sect-tarifs .card { display: flex; flex-direction: column; }
.sect-tarifs .card .card-cont { flex: 1 1 auto; min-height: 300px; }
.sect-tarifs .card .title + .desc { margin-top: 16px; }

@media (max-width: 575px) {
	.sect-tarifs .card-list .card + .card { margin-top: var(--g-card); }
	.sect-tarifs .card-list { margin-left: calc(var(--p-wrp)/-1); margin-right: calc(var(--p-wrp)/-1); padding-left: var(--g-card); padding-right: var(--g-card); }
}
@media (min-width: 768px) {
	.sect-tarifs .card .card-cont { min-height: 412px; }
}

/* FAQ */
.sect-faq { --w-wrp: var(--w-limit); }
.faq-item {
	--p-faq-item: 20px;
	border-top: 1px solid var(--c-border);
}
.faq-title { position: relative; z-index: 1; display: flex; padding: var(--p-faq-item) 0; --lh-title: 28px; cursor: pointer; }
.faq-title > span { display: block; flex: 1 1 auto; }
.faq-icon { margin-left: 12px; position: relative; width: var(--lh-title); height: var(--lh-title); }
.faq-icon::after, .faq-icon::before {
	content: ""; position: absolute; left: calc(50% - 7px); top: calc(50% - 1px);
	width: 14px; height: 0; border-top: 2px solid hsl(var(--c-primary2));
	transition: transform .6s ease;
}

.faq-text {
	--fs-desc: inherit;
	padding: var(--p-faq-item) 0 calc(var(--p-faq-item) * 1.5) 0;
	margin-top: calc((var(--p-faq-item) * 1.25)/-1) !important;
}

.faq-item:not(.active):hover .faq-title > span { opacity: 1; }
.faq-item:not(.active) .faq-title > span { opacity: .8; transition: opacity .2s ease; }
.faq-item:not(.active) .faq-icon::before { transform: rotate(270deg); }
.faq-item:not(.active) .faq-icon::after { transform: rotate(180deg); }

@media (min-width: 768px) {
	.faq-item { --p-faq-item: 24px; }
	.faq-title { --lh-title: 32px; }
	.faq-text { --fs-desc: 18px; }
}