/*!
Theme Name: LightOne
Author: Paolo Pizzuti
Version: 1.0.5
License: GNU General Public License v2 or later
License URI: LICENSE
*/

@font-face {
	font-family: 'DM Sans';
	src: url('/wp-content/themes/lightone/css/typeface/DMSans-VariableFont_opsz,wght.ttf') format('truetype-variations'),
		url('/wp-content/themes/lightone/css/typeface/DMSans-VariableFont_opsz,wght.ttf') format('truetype');
	font-weight: 100 1000;
	font-style: normal;
	font-display: swap;
	/* Migliora la performance di caricamento */
}

@font-face {
	font-family: 'Playfair Display';
	src: url('/wp-content/themes/lightone/css/typeface/PlayfairDisplay-Italic-VariableFont_wght.ttf') format('truetype-variations'),
		url('/wp-content/themes/lightone/css/typeface/PlayfairDisplay-Italic-VariableFont_wght.ttf') format('truetype');
	font-weight: 400 900;
	font-style: italic;
	font-display: swap;
}

:root {
	--main-dark-color: #3C3C3C;
	--dark-color: #202A2B;
	--main-color: #9acdd3;
	--main-color-pale: #def0f2;
	/* --main-color-pale: white; */
	--main-color-darker: #8FCFD6;
	/* --main-complementary-color: #EACEC3; */
	--main-complementary-color: #d8beb4;
	--main-complementary-color-lighter: #f4edea;

	--default-padding: 12vw;
	--letter-spacing: .04em;
}

* {
	box-sizing: border-box;
}

/* .mf-cursor, 
body {
  cursor: none;
} */

html {
	font-family: 'DM Sans', helvetica, arial, sans-serif;
	font-size: 16px;
	line-height: 1.2;
	font-weight: light;
	color: var(--dark-color);
	/* scroll-behavior: smooth; */
}

html,
body {
	background-color: var(--dark-color);
}

.noscroll {
	overflow: hidden;
}

#masthead .mobile-nav {
	display: none;
}

/* section.big-intro .rolling-title, */
section:not(.home-intro, .document) h1,
section:not(.home-intro, .document) h2,
section:not(.home-intro, .document) h3,
section:not(.home-intro, .document) p,
section:not(.home-intro) .cta,
section .cta-2,
section .block,
section.contact-us .contact *,
section.contact-us .contact-form {
	opacity: 0;
	transform: translateY(60px);
}

h1,
h2,
h3,
h4,
h5,
h6 {
	font-weight: 200;
	letter-spacing: var(--letter-spacing);
}

:where(h1, h2, h3, h4, h5, h6, .big-sentence p, .prefooter p) em {
	font-family: 'Playfair Display', times, serif;
	/* color: var(--main-color); */
	color: inherit;
	font-style: italic;
	font-weight: 400 !important;
	letter-spacing: 0em;
}

.dark :where(h1, h2, h3, h4, h5, h6) {
	color: white;
}

h1 {
	font-size: 4rem;
	line-height: 1.1;
	margin: 0;
}

h2 {
	font-size: 4vw;
	text-wrap: balance;
	line-height: 1.05;
	margin: 0;
	margin-bottom: 32px;
}

h3 {
	font-size: 3vw;
	text-wrap: balance;
	line-height: 1.1;
	margin: 0;
	margin-bottom: 24px;
}

h5 {
	font-size: 1.5rem;
}

ul {
	padding-left: 16px;
}

p,
li {
	font-size: 1rem;
	margin-top: 16px;
	margin-bottom: 0;
	line-height: 1.4;
	color: var(--dark-color);
	text-wrap: balance;
	font-weight: 300;
}

p:first-of-type {
	margin-top: 0;
}

p {
	font-size: clamp(1rem, 1.2vw, 1.4rem);
}

.dark,
.dark p {
	color: white;
}

strong {
	font-weight: 600;
}

picture {
	display: block;
	font-size: 0;
	overflow: hidden;
}

picture.img-parallax img {
	transform: scale(1.5);
}

img {
	width: 100%;
	height: auto;
	font-size: 0;
}

a.cta {
	position: relative;
	font-size: clamp(1.2rem, 2.4vw, 1.6rem);
	font-weight: 300;
	color: var(--dark-color);
	display: inline-block;
	padding: 4px 0px;
	padding-right: 64px;
	text-decoration: none;
	/* text-transform: uppercase; */
	margin-top: 56px;
	white-space: nowrap;
	border-bottom: 3px solid var(--dark-color);
}

a.cta:after {
	content: url(/wp-content/themes/lightone/images/icon-arrow-dark.svg);
	position: absolute;
	right: 0;
	top: 50%;
	transform: translateY(-50%);
	width: 20px;
	margin-left: auto;
	transition: 1s;
}

.dark a.cta {
	color: white;
	border-color: white;
}

.dark a.cta:after {
	content: url(/wp-content/themes/lightone/images/icon-arrow-white.svg);
}

a.cta-2 {
	position: relative;
	font-size: 1.6rem;
	font-weight: 500;
	color: var(--dark-color);
	background-color: var(--main-color);
	display: inline-block;
	padding: 12px 32px;
	text-decoration: none;
	/* text-transform: uppercase; */
	margin-top: 56px;
	white-space: nowrap;
}

.light-pink a.cta {
	border-color: var(--main-complementary-color);
}

.light-cyan a.cta {
	border-color: var(--main-color);
}


.darken a.cta {
	color: white !important;
}

.darken.light-cyan a.cta:after,
.lighten.light-cyan a.cta:after {
	content: url(/wp-content/themes/lightone/images/icon-arrow-light-cyan.svg);
}

.darken.light-pink a.cta:after,
.lighten.light-pink a.cta:after {
	content: url(/wp-content/themes/lightone/images/icon-arrow-light-pink.svg);
}

/* .black a.cta {
	border-color: var(--main-dark-color);
}

.black a.cta:after {
	content: url(/wp-content/themes/lightone/images/icon-arrow-dark.svg);
} */

.mf-cursor {
	position: fixed;
	width: 30px;
	height: 30px;
	width: 30px;
	height: 30px;
	border-radius: 100%;
	border: 2px solid rgba(169, 218, 224, 1);
	z-index: 1001;
	contain: layout style size;
	direction: ltr;
	left: 0;
	top: 0;
	mix-blend-mode: difference !important;
	transition: width .3s, height .3s, background-color .3s, opacity;
	transform: translate(-50%, -50%);
	pointer-events: none;
	z-index: 1000;
	opacity: 0;
}

.mf-cursor.-pointer {
	opacity: 1;
	width: 70px;
	height: 70px;
	border-color: rgba(169, 218, 224, .05);
	background-color: rgba(169, 218, 224, .3);
}

.align-center {
	justify-content: center;
}

.align-right {
	justify-content: flex-end;
}

#page {
	background: transparent;
}

#masthead {
	position: fixed;
	width: 100%;
	z-index: 1000;
	padding: 40px var(--container-side-padding);
}

#masthead:before {
	content: "";
	position: absolute;
	width: 100%;
	height: 250%;
	top: 0;
	left: 0;
	background: linear-gradient(180deg, rgba(16, 38, 41, 0.2), rgba(16, 38, 41, 0));
	mix-blend-mode: difference;
	pointer-events: none;
}

#masthead .site-branding {
	position: relative;
	width: 240px;
	font-size: 0;
}

#masthead .site-branding a {
	display: block;
}

#masthead .main-navigation {
	position: absolute;
	top: 0;
	right: 0;
	width: 400px;
	height: 600px;
	overflow: hidden;
	pointer-events: none;
}

.menuopen #masthead .main-navigation {
	pointer-events: all;
}

#masthead .main-navigation .nav-menu {
	position: relative;
	margin-top: var(--container-side-padding);
	margin-right: 64px;
	margin-left: 160px;
	pointer-events: all;
}

#masthead .main-navigation .nav-menu ul {
	position: relative;
	padding: 0;
	margin: 0;
	/* width: 200px; */
	z-index: 10;
	list-style: none;
}

#masthead .main-navigation .nav-menu ul>li {
	margin-top: 0;
	/* margin-bottom: 4px; */
}

#masthead .main-navigation .nav-menu ul>li:last-of-type {
	margin: 0;
}

#masthead .main-navigation .nav-menu ul>li a {
	color: #d8eaec;
	color: white;
	text-decoration: none;
	display: inline-block;
	/* white-space: nowrap; */
	text-wrap: balance;
	transition: .5s;
	padding: 2px 0;
}

/* .page-id-11 #masthead .main-navigation .nav-menu ul > li a {
	color: black;
} */
#masthead .main-navigation .nav-menu ul>li.menu-item-has-children>a {
	display: flex;
}

#masthead .main-navigation .nav-menu ul>li.menu-item-has-children>a:after {
	content: "+";
	display: block;
	margin-left: 4px;
}

/* .menuopen #masthead .main-navigation .nav-menu ul > li a {
	color: var(--dark-color);
} */
#masthead .main-navigation .nav-menu ul>li.current-menu-parent>a,
#masthead .main-navigation .nav-menu ul>li.current-menu-item>a {
	font-weight: 600;
	font-weight: unset;
	color: var(--main-color);
}

/* .menuopen #masthead .main-navigation .nav-menu ul > li.current-menu-item > a {
	color: var(--dark-color);
} */
.menuopen #masthead .main-navigation .nav-menu ul>li.menu-item-has-children.active>a:after {
	transform: rotate(45deg);
}

/* .menuopen #masthead .main-navigation .nav-menu > ul > li:not(.active) > a {
	opacity: .4;
	transition: .5s;
}
.menuopen #masthead .main-navigation .nav-menu > ul > li:not(.active) > a:hover {
	opacity: 1;
} */
#masthead .main-navigation .nav-menu ul>li .sub-menu {
	/* margin-top: 8px; */
	width: calc(100% + 24px);
	height: 0;
	overflow: hidden;
	opacity: 0;
	transition: .7s cubic-bezier(.62, .01, .16, 1);
	transition-delay: 0s;
}

#masthead .main-navigation .nav-menu ul>li .sub-menu li {
	opacity: 0;
	transform: translateX(24px);
	transition: .7s;
	/* margin-bottom: 4px; */
}

#masthead .main-navigation .nav-menu ul>li .sub-menu li a {
	font-size: .9rem;
	padding: 2px 0;
}

#masthead .main-navigation .nav-menu ul>li.current-menu-parent .sub-menu li {
	opacity: 1;
	transform: translateX(0);
	transition: .7s;
	margin-bottom: 4px;
}

#masthead .main-navigation .nav-menu ul>li.active>a

/* #masthead .main-navigation .nav-menu ul > li.current-menu-parent > a */
	{
	margin-bottom: 8px;
}

#masthead .main-navigation .nav-menu ul>li.active .sub-menu {
	visibility: visible;
	height: 140px;
	overflow: hidden;
	opacity: 1;
	padding-left: 16px;
	/* transition-delay: .2s; */
}

#masthead .main-navigation .nav-menu ul>li.active .sub-menu li {
	opacity: 1;
	transform: translateX(0);
}

#masthead .main-navigation .nav-menu ul>li.active .sub-menu li:nth-child(1) {
	transition-delay: .3s;
}

#masthead .main-navigation .nav-menu ul>li.active .sub-menu li:nth-child(2) {
	transition-delay: .4s;
}

#masthead .main-navigation .nav-menu ul>li.active .sub-menu li:nth-child(3) {
	transition-delay: .5s;
}

#masthead .main-navigation .nav-menu ul>li.active .sub-menu li:nth-child(4) {
	transition-delay: .6s;
}

#masthead .main-navigation .nav-menu ul>li.active .sub-menu li:nth-child(5) {
	transition-delay: .7s;
}

#masthead .main-navigation .nav-menu ul>li.active .sub-menu li:nth-child(6) {
	transition-delay: .8s;
}

#masthead .main-navigation .circle {
	isolation: isolate;
	mix-blend-mode: normal;
	position: absolute;
	top: 0;
	right: 0;
	height: 400px;
	width: 400px;
	aspect-ratio: 1;
	border: 32px solid var(--main-color);
	border-radius: 100%;
	transform: translate(50%, -50%);
	opacity: .4;
	transition: .7s cubic-bezier(.27, 0, .11, 1);
}

.menuopen #masthead .main-navigation .circle {
	transform: translate(60%, -35%);
	border: 0px solid var(--main-color);
	/* border-color: rgba(154, 205, 211, .2); */
	height: 900px;
	width: 900px;
	opacity: 1;
	background-color: rgba(154, 205, 211, .6);
	backdrop-filter: blur(10px);
}




/* MENU MOBILE */

#masthead .mobile-nav {
	position: relative;
	display: none;
	/* background-color: red; */
	cursor: pointer;
}
#masthead .mobile-nav .lang-selector {
	transform: translate(-120%, -14px);
}

#masthead .mobile-nav .hamburger {
	position: relative;
	/* position: absolute; */
	/* right: var(--ionic-gutter-x); */
	height: 10px;
	width: 40px;
	z-index: 100;
}

#masthead .mobile-nav .hamburger span {
	position: absolute;
	display: block;
	left: 0;
	width: 100%;
	height: 1px;
	background-color: #fff;
	/* transition: var(--transit-default); */
	transition: transform .3s;
}

#masthead .mobile-nav .hamburger span:nth-of-type(1) {
	top: 0;
}

#masthead .mobile-nav .hamburger span:nth-of-type(2) {
	bottom: 0;
}

.menuopen-mobile #masthead .mobile-nav .hamburger span:nth-of-type(1) {
	transform: translateY(4px) rotate(-20deg);
	top: 0;
}

.menuopen-mobile #masthead .mobile-nav .hamburger span:nth-of-type(2) {
	transform: translateY(-5px) rotate(20deg);
	bottom: 0;
}

#masthead .mobile-nav .mobile-menu {
	position: fixed;
	width: 100vw;
	height: 100vh;
	padding-bottom: 80px;
	left: 0;
	top: 0;
	/* background-color: var(--dark-color); */
	padding: 12vw var(--ionic-gutter-x);
	overflow-y: scroll;
	z-index: 99;
	pointer-events: none;
}

.menuopen-mobile #masthead .mobile-nav .mobile-menu {
	pointer-events: all;
}

#masthead .mobile-nav .mobile-menu>span {
	content: "";
	position: fixed;
	display: block;
	width: calc(200vh + 50vh);
	height: calc(200vh + 50vh);
	top: 0;
	right: 0;
	background-color: var(--main-color);
	/* background-color: red; */
	border-radius: 100%;
	opacity: 0;
	/* transform: translateX(100%); */
	transform-origin: center center;
	transform: translate(50%, -50%) scale(.16);
	transition: 1s cubic-bezier(.61, .01, .39, .99);
}

#masthead .mobile-nav .mobile-menu>span.c4 {
	background-color: var(--dark-color);
}

#masthead .mobile-nav .mobile-menu>span.c1 {
	opacity: 0;
	transform: translate(50%, -50%) scale(.16);
	transition-delay: .5s;
}

#masthead .mobile-nav .mobile-menu>span.c2 {
	opacity: 0;
	transform: translate(50%, -50%) scale(.16);
	transition-delay: .4s;
}

#masthead .mobile-nav .mobile-menu>span.c3 {
	opacity: 0;
	transform: translate(50%, -50%) scale(.16);
	transition-delay: .3s;
}

#masthead .mobile-nav .mobile-menu>span.c4 {
	opacity: 0;
	transform: translate(50%, -50%) scale(.16);
	transition-delay: .2s;
}

.menuopen-mobile #masthead .mobile-nav .mobile-menu>span.c1 {
	opacity: .3;
	transform: translate(50%, -50%) scale(1);
	transition-delay: 0s;
}

.menuopen-mobile #masthead .mobile-nav .mobile-menu>span.c2 {
	opacity: .5;
	transform: translate(50%, -50%) scale(1);
	transition-delay: .1s;
}

.menuopen-mobile #masthead .mobile-nav .mobile-menu>span.c3 {
	opacity: .7;
	transform: translate(50%, -50%) scale(1);
	transition-delay: .2s;
}

.menuopen-mobile #masthead .mobile-nav .mobile-menu>span.c4 {
	opacity: .95;
	transform: translate(50%, -50%) scale(1);
	transition-delay: .3s;
}



#masthead .mobile-nav .mobile-menu>ul {
	transform: translateX(10%);
	opacity: 0;
	transition: 1s cubic-bezier(.61, .01, .39, .99);
	transition-delay: 0s;
}

.menuopen-mobile #masthead .mobile-nav .mobile-menu>ul {
	opacity: 1;
	transform: translateX(0);
	transition-delay: .3s;
}

#masthead .mobile-nav .mobile-menu ul {
	position: relative;
	z-index: 10;
	list-style: none;
}

#masthead .mobile-nav .mobile-menu ul li {
	margin: 0;
	margin-bottom: 4px;
}

#masthead .mobile-nav .mobile-menu ul li a {
	color: white;
	text-decoration: none;
	display: inline-block;
	padding-top: 4px;
	padding-bottom: 4px;
	font-size: 4.2vw;
}

#masthead .mobile-nav .mobile-menu>ul>li>a {
	/* font-weight: 600; */
	text-transform: uppercase;
}

#masthead .mobile-nav .mobile-menu ul.sub-menu>li {
	position: relative;
}

#masthead .mobile-nav .mobile-menu ul.sub-menu>li:before {
	content: "";
	position: absolute;
	width: 16px;
	height: 1px;
	top: 50%;
	left: -16px;
	background-color: white;
}

#masthead .mobile-nav .mobile-menu ul.sub-menu>li>a {
	padding-left: 8px;
}

#masthead .lang-selector {
	display: flex;
	align-items: center;
	position: absolute;
	top: 0;
	left: 0;
	transform: translate(-170%, -6px);
}
#masthead .lang-selector hr {
	width: 1px;
	height: 24px;
	border: 0;
	border-right: 1px solid white;
	flex: 1;
}
#masthead .lang-selector a {
	display: block;
	color: white;
	text-decoration: none;
	font-size: .9rem;
	font-weight: 600;
	letter-spacing: .05em;
	padding: 4px 8px;
}
#masthead .lang-selector a.active-lang {
	pointer-events: none;
	cursor: default;
}
#masthead .lang-selector a.inactive-lang {
	opacity: .4;
	transition: .3s;
}
#masthead .lang-selector a.inactive-lang:hover {
	opacity: 1;
}


section.darken,
section.darken *,
section.lighten,
section.lighten * {
	transition: background-color .7s, color .7s;
}

section.darken.light-active {
	background-color: var(--dark-color) !important;
}

section.darken.light-active.light-cyan * {
	color: var(--main-color);
	color: white;
}

section.darken.light-active.light-pink * {
	color: var(--main-complementary-color);
	color: white;
}

section.darken.light-active.light-cyan em {
	color: var(--main-color);
}

section.darken.light-active.light-pink em {
	color: var(--main-complementary-color);
}

section.lighten.light-cyan.light-active {
	background-color: var(--main-color-pale) !important;
}

section.lighten.light-pink.light-active {
	background-color: var(--main-complementary-color-lighter) !important;
}

section.lighten.light-active.light-cyan * {
	color: var(--main-color);
	color: var(--main-dark-color);
}

section.lighten.light-active.light-pink * {
	color: var(--main-complementary-color);
	color: var(--main-dark-color);
}

section.lighten.light-active.light-cyan em {
	color: var(--main-color) !important;
}

section.lighten.light-active.light-pink em {
	color: var(--main-complementary-color) !important;
}

section.home-intro .swiper .swiper-slide {
	width: 100%;
	height: 100vh;
	height: 100svh;
	min-height: 720px;
	/* clip-path: ellipse(100% 200% at right); */
	overflow: hidden;
	padding: calc(var(--container-side-padding)*2) var(--container-side-padding);
	display: flex;
	align-items: flex-end;
	justify-content: space-between;
}

section.home-intro .swiper .swiper-slide.swiper-slide-next .title,
section.home-intro .swiper .swiper-slide.swiper-slide-next picture img {
	transform: translateX(-90%);
	transition: 1s; /* Deve avere lo stesso valore impostato nella funzione JS */
}

section.home-intro .swiper .swiper-slide.swiper-slide-active .title,
section.home-intro .swiper .swiper-slide.swiper-slide-active picture img {
	transform: translateX(0);
	transition: 1s; /* Deve avere lo stesso valore impostato nella funzione JS */
}

section.home-intro .swiper .swiper-slide .title {
	position: relative;
	z-index: 10;
}

section.home-intro .swiper .swiper-slide .title :where(h1, h2, h3, h4, h5, h6) {
	color: white;
	margin-bottom: 48px;
}

section.home-intro .swiper .swiper-slide .title :where(h1, h2, h3, h4, h5, h6) em {
	color: var(--main-color);
}

section.home-intro .swiper .swiper-slide .title :where(h1, h2) {
	font-size: clamp(2rem, 6vw, 5rem);
}

section.home-intro .swiper .swiper-slide .title p {
	color: var(--main-color);
	max-width: 576px;
	font-size: 1.2rem;
}

section.home-intro .swiper .swiper-slide .title a.cta {
	color: var(--main-color);
	border-color: var(--main-color);
	border-width: 1px;
	font-size: 1.2rem;
	margin-top: 16px;
}

section.home-intro .swiper .swiper-slide .title a.cta:after {
	content: url(/wp-content/themes/lightone/images/icon-arrow-light-cyan.svg);
}

section.home-intro .swiper .swiper-slide picture {
	display: block;
	position: absolute;
	width: 100%;
	height: 100%;
	left: 0;
	top: 0;
	background-size: cover;
	background-position: center center;
}

section.home-intro .swiper .swiper-slide picture:before {
	content: "";
	position: absolute;
	width: 100%;
	height: 100%;
	top: 0;
	left: 0;
	background: linear-gradient(180deg, rgba(0, 0, 0, .9) 0%, rgba(0, 0, 0, 0) 30%);
	z-index: 9;
}

section.home-intro .swiper .swiper-slide picture:after {
	content: "";
	position: absolute;
	width: 100%;
	height: 100%;
	top: 0;
	left: 0;
	background: linear-gradient(25deg, rgba(0, 0, 0, .6) 0%, rgba(0, 0, 0, .05) 80%);
	/* background: linear-gradient(25deg,red 0%,blue 80%); */
	/* background: linear-gradient(25deg, red 30%, blue 65%); */
	z-index: 8;
}

section.home-intro .swiper .swiper-slide picture img {
	object-fit: cover;
	object-position: center center;
	width: 100%;
	height: 100%;
	z-index: 1;
}

section.home-intro .swiper .swiper-navigation :where(.swiper-button-next, .swiper-button-prev) {
	position: relative;
	right: unset;
	left: unset;
	top: unset;
	bottom: unset;
	display: block;
	margin: 0;
	height: unset;
	width: unset;
	color: white;
	padding: 12px;
}

section.home-intro .swiper .swiper-navigation :where(.swiper-button-next, .swiper-button-prev):after {
	font-size: 22px;
}

section.home-intro .swiper .swiper-navigation {
	position: absolute;
	/* background-color: red; */
	display: flex;
	gap: 64px;
	z-index: 20;
	bottom: calc(var(--container-side-padding)*2);
	right: var(--container-side-padding);
}

section.big-sentence {
	padding-top: var(--default-padding);
	padding-bottom: var(--default-padding);
}
section.big-sentence:first-of-type {
	padding-top: calc(var(--default-padding) * 2);
	padding-bottom: calc(var(--default-padding) * 2);
}

section.big-sentence p {
	font-size: 3.2vw;
	font-weight: 200;
	text-wrap: balance;
}

section.text-image {
	padding-top: var(--default-padding);
	padding-bottom: var(--default-padding);
	background-repeat: no-repeat;
	background-position: center top;
	z-index: 2;
}

section.light-cyan em {
	color: var(--main-color);
}

section.light-pink em {
	color: var(--main-complementary-color);
}

section.black em {
	color: var(--dark-color);
}


section.text-image .title * {
	margin-bottom: 0;
}

section.text-image-1 .text,
section.text-image-2 .text,
section.text-image-3 .text,
section.text-image-5 .text {
	margin-top: 40px;
	width: 70%;
	/* max-width: 550px; */
	max-width: 720px;
}

section.text-image-5 .text {
	margin-top: 0;
}

section.text-image-2 .container {
	max-width: 80%;
}

section.text-image-2 .row {
	justify-content: center;
}

section.text-image-2 .row:first-of-type {
	align-items: flex-end;
	margin-bottom: 40px;
}

section.text-image-2 .title {
	transform: translateY(-24px);
}

section.text-image-2 .text {
	width: 100%;
	max-width: unset;
}

section.text-image-2 .image {
	position: relative;
}

section.text-image-2 .image picture {
	position: relative;
	z-index: 10;
}

section.text-image-2 .image .image-blur {
	/* display: none; */
	position: absolute;
	width: 100%;
	height: 100%;
	bottom: 20%;
	left: 40%;
	filter: blur(100px);
	opacity: .5;
	pointer-events: none;
}

/* section.text-image-2 .image .image-blur img {
	filter: blur(100px);
} */
section.text-image-3 .row.images,
section.text-image-4 .row.images {
	margin-bottom: 80px;
}

section.text-image-4 .title {
	text-align: right;
}

section.text-image-4 .text {
	transform: translateY(24px);
}

section.text-image-5 .image {
	/* margin-top: 80px; */
}

section.rolling-title {
	background-color: white;
	padding-top: calc(var(--default-padding)/2);
	padding-bottom: calc(var(--default-padding)/2);
	overflow-x: hidden;
	flex-shrink: 0;
}

section.rolling-title p {
	font-size: 9vw;
	width: 100%;
	text-wrap: nowrap;
	/* overflow: hidden;  */
	white-space: nowrap;
	margin: 0;
	margin-left: var(--container-side-padding);
	margin-right: calc(var(--container-side-padding) * 4);
}

section.rolling-title p em {
	font-family: "Playfair Display", Times, serif;
}

section.rolling-title .section-content {
	display: flex;
	align-items: center;
}

section.solutions {
	padding-bottom: var(--default-padding);
}

section.solutions .row {
	flex-wrap: wrap;
	flex-direction: row;
	align-items: flex-start;
}

section.solutions .text {
	padding-right: 12vw;
	position: sticky;
	top: 160px;

}

section.solutions .block {
	margin-bottom: 120px;
}

section.solutions .block:last-of-type {
	margin-bottom: 0;
}

section.solutions .block a {
	text-decoration: none;
	color: inherit;
}

section.solutions .block .block-title {
	position: relative;
	display: flex;
	font-size: clamp(2rem, 5vw, 3.6rem);
	line-height: 1;
	font-weight: 200;
	padding-top: 16px;
	padding-bottom: 16px;
}

section.solutions .block .block-title:after {
	content: url(/wp-content/themes/lightone/images/icon-arrow-dark.svg);
	position: relative;
	display: block;
	/* right: 0;
	top: 50%; */
	/* transform: translateY(5%); */
	width: 48px;
	margin-left: 24px;
}

section.solutions .block .block-description p {
	max-width: 768px;
	text-wrap: balance;
}

section.solutions .block a picture {
	aspect-ratio: 3 / 2;
}

section.solutions .block a picture img {
	object-fit: cover;
	width: 100%;
	height: 100%;
	transition: .3s;
}

section.solutions .block a:hover picture img {
	opacity: .8;
}

section.big-intro {
	position: relative;
	padding-top: 20vw;
	background-size: cover;
	background-position: center center;
	padding-bottom: var(--default-padding);
}

section.big-intro:before {
	content: "";
	background: linear-gradient(180deg, rgba(0, 0, 0, .9), rgba(0, 0, 0, 0));
	width: 100%;
	height: 30vw;
	position: absolute;
	left: 0;
	top: 0;
	z-index: 2;
}

section.big-intro .background-image {
	position: absolute;
	width: 100%;
	height: 1000px;
	left: 0;
	top: 0;
	z-index: 0;
	mask-image: linear-gradient(180deg, rgba(0, 0, 0, 1) 40%, rgba(0, 0, 0, 0) 100%);
	pointer-events: none;
}

section.big-intro .background-image img {
	object-fit: cover;
	width: 100%;
	height: 100%;
	object-position: center center;
}

section.big-intro .background-image:before {
	content: "";
	position: absolute;
	width: 100%;
	height: 100%;
	top: 0;
	left: 0;
	background: linear-gradient(90deg, rgba(0, 0, 0, .6), rgba(0, 0, 0, 0));
	background: linear-gradient(90deg, rgba(0, 0, 0, .6) 0%, rgba(0, 0, 0, 0) 100%);
}

section.big-intro .section-content {
	position: relative;
	z-index: 10;
}

section.big-intro .rolling-title {
	/* margin-top: -400px;
	margin-bottom: 300px; */
	margin-bottom: 15vw;
	overflow: hidden;
	display: flex;
	align-items: center;
	padding-left: var(--container-side-padding);
}

section.big-intro .rolling-title :where(h1, h2, h3, h4, h5, h6, em) {
	font-size: 8vw;
	color: white;
	text-wrap: nowrap;
	white-space: nowrap;
}

section.big-intro .rolling-title :where(h1, h2, h3, h4, h5, h6) {
	margin-right: 25vw;
}

section.big-intro-1 .row {
	justify-content: space-between;
}

section.big-intro .text {
	position: relative;
	padding-right: 10vw;
}

section.big-intro .text :where(h1, h2, h3, h4, h5, h6) {
	text-wrap: balance;
}

section.big-intro .image {
	position: relative;
	padding-right: 10vw;
}

section.single-video-image {
	padding-top: calc(var(--default-padding)/1);
	padding-bottom: calc(var(--default-padding)/1);
}

section.single-video-image .video {
	position: relative;
	font-size: 0;
	background-size: cover;
	background-repeat: no-repeat;
	background-position: center center;
	z-index: 10;
}

section.single-video-image .video video {
	width: 100%;
}

section.single-video-image .video .icon-play {
	position: absolute;
	width: 100%;
	height: 100%;
	background-image: url(/wp-content/themes/lightone/images/icon-play-white.svg);
	background-repeat: no-repeat;
	background-size: 80px 80px;
	background-position: center center;
	background-color: rgba(0, 0, 0, .5);
	cursor: pointer;
	transition: .5s;
	z-index: 10;
}

section.single-video-image .video .icon-play:hover {
	background-color: rgba(0, 0, 0, .3);
}

section.single-video-image .video .icon-play.played {
	opacity: 0;
}


section.slide-thumb {
	padding-top: var(--default-padding);
	padding-bottom: var(--default-padding);
}

section.slide-thumb .section-content {
	padding-left: 30%;
}

section.slide-thumb .text-content {
	margin-bottom: 80px;
	max-width: 820px;

}

section.slide-thumb .slide-content {
	/* padding-left: 30%; */
}

section.slide-thumb .swiper-slide {
	position: relative;
	aspect-ratio: 9 / 13;
	width: 420px;
}

section.slide-thumb .swiper-slide .name {
	position: relative;
	font-size: 2.2rem;
	font-weight: 300;
	color: white;
	position: absolute;
	bottom: 32px;
	left: 40px;
	z-index: 1;
	pointer-events: none;
}

section.slide-thumb .swiper-slide a {
	position: absolute;
	left: 0;
	top: 0;
	width: 100%;
	height: 100%;
	display: block;
	font-size: 0;
	background-color: rgba(0, 0, 0, .4);
	transition: .3s;
}

section.slide-thumb .swiper-slide a:hover {
	background-color: rgba(0, 0, 0, .2);
}

section.slide-thumb .swiper-slide img {
	object-fit: cover;
	object-position: center center;
	width: 100%;
	height: 100%;
}

section.slide-thumb .swiper .swiper-navigation :where(.swiper-button-next, .swiper-button-prev) {
	position: relative;
	right: unset;
	left: unset;
	top: unset;
	bottom: unset;
	display: block;
	margin: 0;
	height: unset;
	width: unset;
	color: white;
	padding: 12px;
}

section.slide-thumb .swiper .swiper-navigation :where(.swiper-button-next, .swiper-button-prev):after {
	font-size: 22px;
}

section.slide-thumb .swiper .swiper-navigation {
	position: relative;
	/* background-color: red; */
	display: flex;
	gap: 48px;
	z-index: 20;
	margin-top: 24px;
}

section.pluses {
	padding-top: var(--default-padding);
	padding-bottom: var(--default-padding);
	background-repeat: no-repeat;
	background-position: top center;
}

section.pluses .title {
	margin-bottom: 80px;
}

section.pluses .list .block {
	border-bottom: 1px solid #ddd;
	padding-top: 40px;
	padding-bottom: 40px;
}

section.pluses .list .block:last-of-type {
	border-bottom: 0;
}

section.pluses .list .block .text {
	max-width: 576px;
}

section.pluses.pluses-1 .row {
	justify-content: space-between;
}

section.pluses.pluses-2 .block {
	display: flex;
	align-items: flex-start;
	border-top: 2px solid white;
	border-bottom: 0;
}

section.pluses.pluses-2 .list {
	margin-top: 120px;
}

section.pluses.pluses-2.light-cyan .block {
	border-top-color: var(--main-color);
}

section.pluses.pluses-2.light-pink .block {
	border-top-color: var(--main-complementary-color);
}

section.pluses.pluses-2 .block .title {
	width: 30vw;
	min-width: unset;
	flex-shrink: 0;
	padding-right: 80px;
}

section.pluses.pluses-2 .block .title * {
	/* font-family: 'Playfair Display', times, serif; */
	/* letter-spacing: -0.01em; */
	font-size: 2.5vw;
	text-wrap: balance;
}

section.pluses.pluses-2.light-cyan .block .title * {
	color: var(--main-color);
}

section.pluses.pluses-2.light-pink .block .title * {
	color: var(--main-complementary-color);
}

section.pluses.pluses-2 .block .text {
	max-width: unset;
}

section.rolling-images {
	padding-top: var(--default-padding);
	/* padding-bottom: var(--default-padding); */
}

section.rolling-images .section-content {
	overflow: hidden;
}

section.rolling-images .section-content .images {
	display: flex;
	flex-direction: row;
	justify-content: space-between;
	gap: 24px;
	width: 100%;
	height: 40vh;
}

section.rolling-images .section-content .images>* {
	flex: 1;
	height: 100%;
	flex-shrink: 0;
}


section.accordion-text {
	padding-top: var(--default-padding);
	padding-bottom: var(--default-padding);
}

section.accordion-text.light-cyan :where(h1, h2, h3, h4, h5, h6) {
	color: var(--main-color) !important;
}

section.accordion-text.light-pink :where(h1, h2, h3, h4, h5, h6) {
	color: var(--main-complementary-color) !important;
}

section.accordion-text .accordion {
	/* max-width: 1370px; */
	margin: 0 auto;
}

section.accordion-text .accordion * {
	color: white;
}

section.accordion-text .accordion-row:first-of-type {
	border-top: 0;
}

section.accordion-text .accordion-row {
	border-top: 1px solid rgba(255, 255, 255, .6);
}

section.accordion-text .accordion-row button {
	appearance: none;
	-webkit-appearance: none;
	-moz-appearance: none;
	border: 0;
	background-color: transparent;
	padding-top: 40px;
	padding-bottom: 40px;
	width: 100%;
	display: flex;
	align-items: center;
	justify-content: space-between;
	cursor: pointer;
}

section.accordion-text .accordion-row:first-of-type .accordion-block {
	display: block;
}

section.accordion-text .accordion-row .accordion-block .row {
	justify-content: space-between;
}

section.accordion-text .accordion-row button .accordion-block-title {
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
	text-align: left;
	font-size: 4vw;
	font-weight: 200;
	opacity: .4;
	/* transition: opacity .3s; */
}

section.accordion-text .accordion-row button:hover .accordion-block-title,
section.accordion-text .accordion-row button.is-open .accordion-block-title {
	opacity: 1;
}

section.accordion-text .accordion-row button .accordion-block-toggle {
	transform: rotate(0deg);
	transform-origin: center center;
	transition: transform 0.3s ease;
}

section.accordion-text .accordion-row button .accordion-block-toggle svg {
	fill: white;
	width: 32px;
}

section.accordion-text .accordion-row>button.is-open .accordion-block-toggle {
	transform: rotate(45deg);
	transform-origin: center center;
}

section.accordion-text .accordion-row .accordion-block {
	display: none;
	padding-top: 80px;
	padding-bottom: 80px;
}

section.accordion-text .accordion-row .accordion-block .process {
	margin-bottom: 72px;
}

section.accordion-text .accordion-row .accordion-block .process h3 {
	font-size: 2.8vw;
}

section.numbers .text {
	max-width: 720px;
	margin-bottom: 140px;
}

section.numbers .number-counter {
	max-width: 1024px;
	margin: 0 auto;
}

section.numbers .number-counter .block {
	margin: 80px 0;
}

section.numbers .number-counter .block .text-value {
	color: white;
	display: flex;
	justify-content: space-between;
	align-items: flex-end;
}

section.numbers .number-counter .block .text-value .number-value {
	font-size: 2.8rem;
	font-variant-numeric: tabular-nums;
	min-width: 3ch;
	/* evita “salti” orizzontali durante il count */
	font-weight: 200;
	text-align: right;
}

section.numbers .number-counter .block .text-value .description-value {}

section.numbers .number-counter .block .text-value .description-value .title {
	display: block;
	font-size: 2.4rem;
	line-height: 1;
	font-weight: 200;
	margin-bottom: 4px;
}

section.numbers .number-counter .block .text-value .description-value .caption {
	display: block;
	/* font-size: 1rem; */
	font-weight: 200;
	opacity: .5;
}

section.numbers .number-counter .block .counter {
	position: relative;
	width: 100%;
	height: 3px;
	background-color: rgba(255, 255, 255, .15);
	margin-top: 16px;
	/* overflow: hidden; */
	border-radius: 999px;
}

/* imposta il colore una volta sola */
section.numbers .number-counter .block .counter .counter-fill {
	position: absolute;
	inset: 0 auto 0 0;
	width: 0%;
	color: var(--main-color);
	/* colore “sorgente” del glow */
	background: currentColor;
	border-radius: inherit;
	box-shadow:
		0 0 4px currentColor,
		0 0 12px rgba(154, 205, 211, .45);
	/* leggero alone più ampio */
	will-change: width;
	/* l’animazione resta fluida */
}

section.prefooter {
	background-color: var(--dark-color);
	padding-top: calc(var(--default-padding)/2);
	padding-bottom: calc(var(--default-padding)/1.2);
	display: flex;
	align-items: center;
	flex-direction: column;
}

section.prefooter p {
	font-size: clamp(2rem, 3.8vw, 3.4rem);
	font-weight: 200;
	letter-spacing: var(--letter-spacing);
	color: white;
	text-wrap: balance;
	text-align: center;
}

section.prefooter p em {
	color: var(--main-color) !important;
}

section.prefooter a.cta-2 {
	display: block;
}

section.contact-us {
	padding-top: calc(var(--default-padding) + 140px);
	padding-bottom: var(--default-padding);
}

section.contact-us .container {
	max-width: 1380px;
}

section.contact-us .contact h1 {
	margin-bottom: 32px;
}

section.contact-us .contact p {
	text-wrap: balance;
}

section.contact-us .company-info {
	margin-top: 80px;
	font-size: 2rem;
}
section.contact-us .company-info address {
	font-style: unset;
	margin-bottom: 40px;
}

section.contact-us .company-info address p {
	font-size: 1.4rem;
}

section.contact-us .company-info a {
	display: inline-block;
	position: relative;
	color: var(--dark-color);
	text-decoration: none;
	margin: 4px 0;
}

section.contact-us .company-info a:before {
	content: "";
	position: absolute;
	bottom: -2px;
	left: 0;
	width: 100%;
	height: 2px;
	background-color: var(--main-dark-color);
}



section.contact-us .contact-form form {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	gap: 24px;
}

section.contact-us .contact-form .field {
	position: relative;
	flex-basis: calc(50% - 20px);
	margin-bottom: 8px;
}

section.contact-us .contact-form form .field.full-width {
	flex-basis: 100%;
}

section.contact-us .contact-form form .field label {
	font-size: 1.4rem;
}

section.contact-us .contact-form form .field input,
section.contact-us .contact-form form .field textarea,
section.contact-us .contact-form form .field select {
	width: 100%;
	padding: 16px 20px;
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
	border: 0;
	font-size: 1.2rem;
	font-weight: 400;
	margin-top: 8px;
	color: var(--dark-color);
	outline: 1px solid var(--dark-color);
	background-color: transparent;
}

section.contact-us .contact-form form .field.choose>label {
	display: block;
	margin-bottom: 8px;
}

section.contact-us .contact-form form .field.choose .wpcf7-form-control {
	display: flex;
	flex-wrap: wrap;
	gap: 10px;
}

section.contact-us .contact-form form .field.choose .wpcf7-list-item {
	position: relative;
	display: inline-block;
	margin: 0;
}

section.contact-us .contact-form form .field.choose .wpcf7-list-item .wpcf7-list-item-label {
	display: block;
	z-index: 2;
	font-size: 1.2rem;
	position: relative;
	padding: 18px 24px;
	pointer-events: none;
	text-wrap: nowrap;
}

section.contact-us .contact-form form .field.choose input[type=checkbox] {
	z-index: 1;
	position: absolute;
	width: 100%;
	height: 100%;
	left: 0;
	top: 0;
	outline: 1px solid var(--dark-color);
	padding: 0;
	margin: 0;
	cursor: pointer;
	transition: .3s;
}

section.contact-us .contact-form form .field.choose input[type=checkbox]:checked {
	/* outline: 1px solid var(--main-color); */
	background-color: var(--main-dark-color);
}

section.contact-us .contact-form form .field.choose input[type=checkbox]:checked+span {
	color: var(--main-color) !important;
}

section.contact-us .contact-form form .field.privacy input[type=checkbox] {
	position: relative;
	width: 22px;
	height: 22px;
	padding: 0;
	margin: 0;
	margin-right: 8px;
	cursor: pointer;
	flex-shrink: 0;
}

section.contact-us .contact-form form .field.privacy input[type=checkbox]:checked:before {
	content: "";
	position: absolute;
	width: 14px;
	height: 14px;
	top: 4px;
	left: 4px;
	background-color: var(--dark-color);
}

section.contact-us .contact-form form .field.privacy input[type=checkbox]:checked {
	/* outline: 1px solid var(--main-color); */
	/* outline-style: inset; */
}

section.contact-us .contact-form form .field.privacy label {
	display: flex;
	align-items: center;
	cursor: pointer;
}

section.contact-us .contact-form form .field.privacy .wpcf7-list-item {
	padding: 0;
	margin: 0;
}

section.contact-us .contact-form form .field.privacy .wpcf7-list-item-label {
	font-size: .8rem;
	line-height: 1.2;
	max-width: 550px;
	width: 100%;
}

section.contact-us .contact-form form .field.submit {
	display: flex;
	align-items: center;
	justify-content: flex-start;
	flex-direction: row-reverse;
	color: var(--main-dark-color);
}

section.contact-us .contact-form form .field.submit input[type=submit] {
	width: 240px;
	cursor: pointer;
}

.wpcf7-spinner {
	/* visibility: visible; */
}

.wpcf7-form-control-wrap {
	display: block;
}

.wpcf7-not-valid-tip {
	display: block;
	position: absolute;
	bottom: 0;
	left: 0;
	font-size: .8rem;
	font-weight: 300;
	top: 110%;
}

.wpcf7-response-output {
	width: 100% !important;
	padding: 24px !important;
	margin-top: 16px !important;
	font-size: 1.2rem !important;
	text-align: center;
}


#cmplz-document, .editor-styles-wrapper .cmplz-unlinked-mode {
	max-width: unset;
}
section.document {
	padding-top: 200px;
	padding-bottom: 200px;
}
section.document * {
	color: white;
}
section.document .container {
	max-width: 1024px;
	margin: 0 auto;
}
section.document .container,
section.document .container p,
section.document .container li {
	font-size: 1.3rem !important;
}
section.document .container h1 {
	font-size: 2rem !important;
	font-weight: 600 !important;
	margin-bottom: 56px !important;
}
section.document .container h2 {
	font-size: 1.7rem !important;
	font-weight: 700 !important;
	margin-top: 80px !important;
	margin-bottom: 24px !important;
}



footer.site-footer {
	padding-top: calc(var(--default-padding)/1.5);
	padding-bottom: calc(var(--default-padding)/2);
	background-color: #2E3738;
	clip-path: ellipse(120% 100% at bottom);
	margin-top: -5%;
}

footer.site-footer * {
	color: white;
	text-decoration: none;
	font-size: 1.1rem;
}

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

footer.site-footer .info {
	line-height: 1.6;
}

footer.site-footer .info .logo {
	margin-bottom: 40px;
}

footer.site-footer .info .logo img {
	max-width: 260px;
}
footer.site-footer .info .company-name {
	font-weight: 700;
	display: block;
}
footer.site-footer .info address {
	margin-top: 24px;
	margin-bottom: 24px;
	font-style: normal;
}

footer.site-footer .info a {
	display: block;
}

section.error-404 {
	padding-top: 200px;
	padding-bottom: 200px;
	height: 100vh;
	display: flex;
	align-items: center;
	justify-content: center;
}
section.error-404 * {
	color: white;
	text-align: center;
}
section.error-404 h1 {
	font-size: clamp(2.8rem, 12vw, 4rem);
	margin-bottom: 24px;
}


@media screen and (max-width: 1200px) {
	section.contact-us .contact-form .field {
		flex-basis: 100%;
	}

	section.text-image-2 .title {
		transform: none;
	}

	section.text-image-5 .image {
		margin-bottom: 40px;
	}
	section.big-intro {
		padding-top: 25vw;
	}
	section.big-intro .rolling-title {
		/* margin-bottom: 12vw; */
	}
	footer.site-footer {
		padding-top: calc(var(--default-padding));
		padding-bottom: calc(var(--default-padding));
		clip-path: ellipse(150% 100% at bottom);
	}
}

@media screen and (max-width: 1024px) {
	section.slide-thumb .swiper-slide .name {
		font-size: 1.6rem;
		bottom: 16px;
		left: 24px;
	}
}
@media screen and (max-width: 768px) {
	:root {
		--default-padding: 20vw;
	}

	.nav-menu {
		display: none;
	}
	#masthead {
		display: flex;
		justify-content: space-between;
		align-items: center;
	}
	#masthead .mobile-nav {
		display: block;
	}
	#masthead .main-navigation .circle {
		height: 300px;
		width: 300px;
		aspect-ratio: 1;
		border: 26px solid var(--main-color);
	}
	h2 {
		font-size: 6vw;
	}
	
	#masthead .site-branding {
		width: 25vw;
	}

	h3 {
		font-size: 4.5vw;
	}
	section.home-intro .swiper .swiper-slide .title :where(h1, h2) {
		font-size: clamp(2rem, 8vw, 5rem);
	}
	section.rolling-title p {
		font-size: 12vw;
	}
	section.big-intro {
		padding-top: 50vw;
	}
	section.big-intro .image {
		/* position: relative; */
		margin-top: 40px;
		padding-right: unset;
	}
	section.big-intro .rolling-title :where(h1, h2, h3, h4, h5, h6, em) {
		font-size: 10vw;
	}
	section.big-sentence p {
		font-size: 6vw;
	}

	section.text-image-1 .title {
		margin-bottom: 40px;
	}

	section.text-image-2 .row:first-of-type {
		flex-direction: column-reverse;
	}

	section.solutions .text {
		position: relative;
		top: unset;
		margin-bottom: 40px;
	}

	section.accordion-text .accordion-row .accordion-block {
		padding-top: 40px;
		padding-bottom: 40px;
	}

	section.accordion-text .accordion-row .accordion-block .process {
		margin-bottom: 40px;
	}

	section.accordion-text .accordion-row button .accordion-block-title {
		font-size: 5vw;
	}

	section.accordion-text .accordion-row .accordion-block .process h3 {
		font-size: 4.5vw;
		margin-bottom: 8px;
	}
	section.pluses.pluses-2 .block .title {
		width: 50%;
	}
	section.pluses.pluses-2 .block .title * {
		font-size: 4vw;
	}
	

	section.numbers .text {
		margin-bottom: 80px;
	}

	section.numbers .number-counter .block {
		/* margin: 56px 0; */
	}
	
	section.contact-us .company-info {
		margin-bottom: 80px;
	}
	section.contact-us .contact-form form .field label {
		font-size: 1.1rem;
	}
	section.contact-us .contact-form form .field.submit {
		flex-direction: column;
	}
	section.contact-us .contact-form form .field.submit input[type=submit] {
		width: 100%;
		margin-bottom: 8px;
	}
	section.contact-us .contact-form form .field.choose .wpcf7-list-item .wpcf7-list-item-label {
		font-size: 1rem;
		padding: 14px 18px;
	}
	
	section.slide-thumb .swiper-slide .name {
		font-size: 1.2rem;
	}
	
	footer.site-footer {
		padding-top: calc(var(--default-padding)*1.2);
		clip-path: ellipse(200% 100% at bottom);
	}
	footer.site-footer div[class*='col-'] {
		margin-bottom: 24px;
	}
}

@media screen and (max-width: 576px) {
	:root {
		--ionic-gutter-x: 20px;
		--container-side-padding: 20px;
	}

	h2 {
		font-size: 11vw;
	}

	#masthead .site-branding {
		width: 40vw;
	}

	section.home-intro .swiper .swiper-slide .title {
		margin-bottom: 72px;
	}
	section.text-image-1 .text,
	section.text-image-2 .text,
	section.text-image-3 .text,
	section.text-image-5 .text {
		width: 100%;
		max-width: unset;
	}
	section.pluses.pluses-1 .text h3 {
		font-size: 8vw;
	}
	section.accordion-text .accordion-row button .accordion-block-title {
		font-size: 7vw;
	}
}

@media screen and (max-width: 480px) {

	a.cta {
		padding-right: 32px;
		margin-top: 32px;
		white-space: unset;
	}

	section.big-sentence p {
		font-size: 7.5vw;
	}
	section.big-intro .rolling-title {
		margin-bottom: 25vw;
	}
	section.home-intro .swiper .swiper-slide {
		min-height: unset;
	}

	section.home-intro .swiper .swiper-slide .title :where(h1, h2, h3, h4, h5, h6) {
		margin-bottom: 24px;
	}

	section.home-intro .swiper .swiper-slide .title p,
	section.home-intro .swiper .swiper-slide .title a.cta {
		font-size: 1rem;
	}

	section.home-intro .swiper .swiper-navigation {
		gap: 32px;
	}

	section.text-image-2 .container {
		max-width: unset;
	}

	section.slide-thumb .section-content {
		padding-left: var(--ionic-gutter-x);
	}
	section.slide-thumb .swiper-slide .name {
		font-size: 1.4rem;
	}
	
	section.pluses.pluses-2 .block {
		display: block;
	}
	section.pluses.pluses-2 .block .title {
		width: 100%;
		padding-right: unset;
		margin-bottom: 32px;
	}
	section.pluses.pluses-2 .block .title * {
		font-size: 8vw;
	}
	footer.site-footer {
		clip-path: ellipse(250% 100% at bottom);
	}
	section.document {
		padding-top: 180px;
		padding-bottom: 180px;
	}
	section.document .container,
	section.document .container p,
	section.document .container li {
		font-size: 1.1rem !important;
	}
}

/* DEBUG */
/* * { outline: 2px dotted red }
* * { outline: 2px dotted green }
* * * { outline: 2px dotted orange }
* * * * { outline: 2px dotted blue }
* * * * * { outline: 1px solid red }
* * * * * * { outline: 1px solid green }
* * * * * * * { outline: 1px solid orange }
* * * * * * * * { outline: 1px solid blue }   */