/* Global styles for the page */
:root {
	/* CI colors, abstract for reuse*/
	/* --ciDark: #1c3423; */
	--ciDark: #212121;
	--ciMid: #3C3C3C;
	--ciLight: #f2efec;
	/* --ciLight: #F7F6F5; */
	--ciWhite: #fefbf9;
	--ciBlack: #19181b;
	/* --ciAccent: #A59065; */
	--ciAccent: #67a97b;/
}

/* Init fonts */

@font-face {
	font-family: 'Leggibilmente';
	src: url('../fonts/leggibilmente/variable/Leggibilmente.woff2') format('woff2'),
		url('../fonts/leggibilmente/variable/Leggibilmente.ttf') format('truetype');
	font-weight: normal;
	font-style: normal;
}

@font-face {
	font-family: 'Leggibilmente';
	src: url('../fonts/leggibilmente/otf/Leggibilmente-RegularRoman.otf') format('opentype'),
		url('../fonts/leggibilmente/ttf/Leggibilmente-RegularRoman.ttf') format('truetype');
	font-weight: 400;
	font-style: normal;
}

@font-face {
	font-family: 'Leggibilmente';
	src: url('../fonts/leggibilmente/otf/Leggibilmente-RegularItalic.otf') format('opentype'),
		url('../fonts/leggibilmente/ttf/Leggibilmente-RegularItalic.ttf') format('truetype');
	font-weight: 400;
	font-style: italic;
}

@font-face {
	font-family: 'Leggibilmente';
	src: url('../fonts/leggibilmente/otf/Leggibilmente-BoldRoman.otf') format('opentype'),
		url('../fonts/leggibilmente/ttf/Leggibilmente-BoldRoman.ttf') format('truetype');
	font-weight: 700;
	font-style: normal;
}

@font-face {
	font-family: 'Leggibilmente';
	src: url('../fonts/leggibilmente/otf/Leggibilmente-BoldItalic.otf') format('opentype'),
		url('../fonts/leggibilmente/ttf/Leggibilmente-BoldItalic.ttf') format('truetype');
	font-weight: 700;
	font-style: italic;
}

@font-face {
	font-family: 'Leggibilmente';
	src: url('../fonts/leggibilmente/otf/Leggibilmente-ExtraBoldRoman.otf') format('opentype'),
		url('../fonts/leggibilmente/ttf/Leggibilmente-ExtraBoldRoman.ttf') format('truetype');
	font-weight: 800;
	font-style: normal;
}

@font-face {
	font-family: 'Leggibilmente';
	src: url('../fonts/leggibilmente/otf/Leggibilmente-ExtraBoldItalic.otf') format('opentype'),
		url('../fonts/leggibilmente/ttf/Leggibilmente-ExtraBoldItalic.ttf') format('truetype');
	font-weight: 800;
	font-style: italic;
}

@font-face {
	font-family: 'Leggibilmente';
	src: url('../fonts/leggibilmente/otf/Leggibilmente-LightRoman.otf') format('opentype'),
		url('../fonts/leggibilmente/ttf/Leggibilmente-LightRoman.ttf') format('truetype');
	font-weight: 300;
	font-style: normal;
}

@font-face {
	font-family: 'Leggibilmente';
	src: url('../fonts/leggibilmente/otf/Leggibilmente-LightItalic.otf') format('opentype'),
		url('../fonts/leggibilmente/ttf/Leggibilmente-LightItalic.ttf') format('truetype');
	font-weight: 300;
	font-style: italic;
}

@font-face {
	font-family: 'Leggibilmente';
	src: url('../fonts/leggibilmente/otf/Leggibilmente-MediumRoman.otf') format('opentype'),
		url('../fonts/leggibilmente/ttf/Leggibilmente-MediumRoman.ttf') format('truetype');
	font-weight: 500;
	font-style: normal;
}

@font-face {
	font-family: 'Leggibilmente';
	src: url('../fonts/leggibilmente/otf/Leggibilmente-MediumItalic.otf') format('opentype'),
		url('../fonts/leggibilmente/ttf/Leggibilmente-MediumItalic.ttf') format('truetype');
	font-weight: 500;
	font-style: italic;
}

@font-face {
	font-family: 'Leggibilmente';
	src: url('../fonts/leggibilmente/otf/Leggibilmente-SemiBoldRoman.otf') format('opentype'),
		url('../fonts/leggibilmente/ttf/Leggibilmente-SemiBoldRoman.ttf') format('truetype');
	font-weight: 600;
	font-style: normal;
}

@font-face {
	font-family: 'Leggibilmente';
	src: url('../fonts/leggibilmente/otf/Leggibilmente-SemiBoldItalic.otf') format('opentype'),
		url('../fonts/leggibilmente/ttf/Leggibilmente-SemiBoldItalic.ttf') format('truetype');
	font-weight: 600;
	font-style: italic;
}

/* ExtraLight */
@font-face {
	font-family: 'Leggibilmente';
	src: url('../fonts/leggibilmente/otf/Leggibilmente-ExtraLightRoman.otf') format('opentype'),
		url('../fonts/leggibilmente/ttf/Leggibilmente-ExtraLightRoman.ttf') format('truetype');
	font-weight: 200;
	font-style: normal;
}

@font-face {
	font-family: 'Leggibilmente';
	src: url('../fonts/leggibilmente/otf/Leggibilmente-ExtraLightItalic.otf') format('opentype'),
		url('../fonts/leggibilmente/ttf/Leggibilmente-ExtraLightItalic.ttf') format('truetype');
	font-weight: 200;
	font-style: italic;
}

/* News */
@font-face {
	font-family: 'Leggibilmente';
	src: url('../fonts/leggibilmente/otf/Leggibilmente-NewsRoman.otf') format('opentype'),
		url('../fonts/leggibilmente/ttf/Leggibilmente-NewsRoman.ttf') format('truetype');
	font-weight: 450;
	font-style: normal;
}

@font-face {
	font-family: 'Leggibilmente';
	src: url('../fonts/leggibilmente/otf/Leggibilmente-NewsItalic.otf') format('opentype'),
		url('../fonts/leggibilmente/ttf/Leggibilmente-NewsItalic.ttf') format('truetype');
	font-weight: 450;
	font-style: italic;
}

@font-face {
	font-family: 'Singlong';
	src: url('../fonts/singlong/fonts/ttf/') format('opentype'),
		url('../fonts/singlong/Singlong.ttf') format('truetype');
	font-weight: normal;
	font-style: normal;
}

@font-face {
	font-family: 'TT Ricordi Fulmini';
	src: url('../fonts/tt_ricordi/TT Ricordi Trial Fulmini.ttf') format('truetype');
	font-weight: normal;
	font-style: normal;
}

@font-face {
	font-family: 'TT Ricordi Nobili';
	src: url('../fonts/tt_ricordi/TT Ricordi Trial Nobili.ttf') format('truetype');
	font-weight: normal;
	font-style: normal;
}

@font-face {
	font-family: 'TT Ricordi Todi';
	src: url('../fonts/tt_ricordi/TT Ricordi Trial Todi.ttf') format('truetype');
	font-weight: normal;
	font-style: normal;
}

/* Regular */
@font-face {
	font-family: 'FreeSerif';
	src: url('../fonts/freeserif/fonts/freeserif.ttf') format('truetype');
	font-weight: normal;
	font-style: normal;
}

/* Bold */
@font-face {
	font-family: 'FreeSerif';
	src: url('../fonts/freeserif/fonts/freeserifbold.ttf') format('truetype');
	font-weight: bold;
	font-style: normal;
}

/* Italic */
@font-face {
	font-family: 'FreeSerif';
	src: url('../fonts/freeserif/fonts/freeserifitalic.ttf') format('truetype');
	font-weight: normal;
	font-style: italic;
}

/* Bold Italic */
@font-face {
	font-family: 'FreeSerif';
	src: url('../fonts/freeserif/fonts/freeserifbolditalic.ttf') format('truetype');
	font-weight: bold;
	font-style: italic;
}

@font-face {
	font-family: 'Montserrat';
	src: url('../fonts/montserrat/Montserrat-Bold.ttf') format('truetype');
	font-weight: bold;
}

@font-face {
	font-family: 'Montserrat';
	src: url('../fonts/montserrat/Montserrat-Regular.ttf') format('truetype');
	font-weight: normal;
}

html, body {
	overflow: hidden;
	width: 100dvw;
	height: 100dvh;
	margin: 0;
	padding: 0;
	contain: layout;
	clip-path: inset(0 0 0 0);
	mask: none;
}

/* Default styles */
a, .hotlink {
	text-decoration: unset;
	cursor: pointer;
}

h1, h2, h3, h4, h5, h6 {
	font-family: 'Montserrat';
}

h1:first-child, h2:first-child, h3:first-child, h4:first-child, h5:first-child, h6:first-child {
	margin-top: 0;
}

h1 {
	font-size: 34px;
}

h2 {
	font-size: 30px;
}

h3 {
	font-size: 24px;
}

h4 {
	font-size: 20px;
}

h5 {
	font-size: 18px;
}

h6 {
	font-size: 16px;
}

:link, :visited {
	color: var(--ciAccent);
}

:link:hover {
	color: var(--ciLight);
}

iframe {
	display: block;
	width: 100%;
	height: 100%;
	border: none;
	min-height: 24rem;
	min-width: 22rem;
}

[id^="anchor"] {
	visibility: collapse;
	transform: translateY(calc(-3.5rem + -5dvh));
}

/* General styles*/
body {
	font-family: 'Leggibilmente';
	font-size: 1rem;
	background-color: var(--ciLight);
	color: var(--ciDark);
	display: grid;
	grid-template-rows: 4rem auto 2rem;
}

/* For global content centering and aligning */
.content {
	max-width: 96rem;
	margin-left: auto;
	margin-right: auto;
}

/* Main elements */
header {
	position: relative;
	background-color: var(--ciDark);
	/* backdrop-filter: blur(.5rem) saturate(.5); */
	z-index: 100;
	height: 100%;
}

header .content {
	height: 100%;
}

footer {
	position: relative;
	background-color: var(--ciDark);
	color: var(--ciWhite);
	z-index: 100;
	height: 100%;
	overflow: hidden;
	padding: 0 1.5rem;
}

footer>.content {
	display: grid;
	gap: 1rem;
	grid-template-columns: auto max-content;
	height: 100%;
}

footer>.content>div {
	margin: auto 0;
}

footer p {
	margin: 0;
	padding: 0;
	width: fit-content;
}

[role="main"] {
	height: calc(100dvh - 6rem);
	width: 100dvw;
	overflow-x: hidden;
	scrollbar-width: thin !important;
	scroll-behavior: smooth;
	grid-row: 2;
}

.hotlink {
	display: block;
	width: fit-content;
	padding: .6rem 1.2rem;
	border-radius: 1.5rem;
	background-color: var(--ciAccent);
	color: var(--ciWhite);
	font-weight: 500;
}

p+.hotlink {
	margin-top: 1.6rem;
}

section {
	margin: 0 0 8rem 0;
}

.panel {
	background-color: var(--ciWhite);
	box-shadow: 0 .5rem 1rem -.25rem #0002;
	border-radius: 1.5rem;
	overflow: hidden;
	border: none;
}

.panel>article {
	padding: 3rem;
	margin: auto;
}

@media (max-width: 920px) or (max-height: 640px) {
	.panel>article {
		padding: 1.5rem;
	}
}

/* Intro logo */

.introLogo {
	height: calc(100dvh - 6rem);
}

.introLogo.static {
	opacity: calc(1 + 2 * var(--fxjs-screen));
}

.introLogo img {
	height: calc(100vmin - 6rem);
	position: absolute;
	top: calc(50% - (50vmin - 4rem));
	left: calc(50% - (50vmin - 3rem));
	pointer-events: none;
}

.introLogo .inner {
	opacity: calc(1 + 2 * var(--fxjs-screen));
	z-index: -1;
}

.introLogo.static .inner {
	transform: none;
	opacity: 1;
	z-index: 80;
}

.introLogo .outer {
	will-change: transform;
	transform: scale(calc(1 - 5 * min(0, var(--fxjs-screen))));
	box-shadow: 0 0 0 30vmax #FCFDFE;
	z-index: 50;
}

.introLogo.static .outer {
	transform: none;
	opacity: 1;
	box-shadow: none;
	z-index: 80;
}

.introLogo .bg {
	top: 4rem;
	left: 0;
	height: calc(100% - 6rem);
	width: 100%;
	object-fit: cover;
	z-index: 60;
	mask: radial-gradient(circle, #000 calc((33vmin - 2rem) * (1 - 5 * min(0, var(--fxjs-screen)))), #fff calc((33vmin - 2rem) + 14vmin));
	mask-position: center center;
	mask-mode: luminance;
}

.introLogo.static .bg {
	mask: none;
}

.introLogo:not(.inFocus) * {
	display: none;
}

.introLogo p {
	background: var(--ciLight);
	width: fit-content;
	margin: auto;
	border-radius: 15vmin;
	padding: .8vmin 2.8vmin;
}

.introLogo a {
	height: 0;
	position: absolute;
	top: calc(50% + 20dvh + 14vmin - (130vmin * var(--fxjs-screen)));
	margin: 0 auto 0 auto;
	padding: 0;
	max-width: 96rem;
	width: 100%;
	font-family: 'Montserrat';
	text-align: center;
	font-size: max(1.8rem, 4.5vmin);
	z-index: 70;
}

.introLogo svg {
	height: max(1.2rem, 3vmin);
	width: max(1.2rem, 3vmin);
	fill: currentColor;
	margin-left: 2vmin;
}

/* Holiday homes */

#houses {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(24rem, 1fr));
	gap: 1.5rem;
	justify-items: center;
}

.house {
	position: relative;
	display: flex;
	flex-direction: column;
	overflow: hidden;
}

.house img {
	width: 100%;
	height: 18rem;
	border-radius: 1.5rem 1.5rem;
	overflow: hidden;
	object-fit: cover;
	box-shadow: 0 .5rem 1.5rem -1rem #0008;
	display: block;
}

.house> :first-child {
	position: absolute;
	width: 100%;
	height: 2rem;
	top: 8rem;
	padding: 6.5rem 0 1.5rem 0;
	margin: 0;
	text-align: center;
	background: linear-gradient(#0000, #0003, #0008);
	color: var(--ciWhite);
	border-radius: 0 0 1.5rem 1.5rem;
	font-weight: 900;
}

.house p {
	text-align: center;
	margin: 2rem;
	padding: 0;
}

.house .actionbar {
	display: grid;
	grid-template-columns: repeat(1, max-content);
	margin: auto auto 2rem auto;
	gap: 1rem;
	width: min-content;
}

.house .hotlink {
	position: relative;
	bottom: 0;
}

.overview {
	background-color: var(--ciLight);
}

[page^="house"] .lytHead {
	margin-top: 5rem;
}

.features, .featureButtons {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(8rem, 1fr));
	grid-template-rows: repeat(auto-fit, 4rem);
	grid-gap: 1rem;
	grid-auto-flow: dense;
	height: fit-content;
}

.features>*, .featureButtons>* {
	display: grid;
	grid-template-columns: 4rem 1fr;
	grid-template-rows: 4rem;
	height: min-content;
	padding: 0 0.5rem;
}

.features svg, .featureButtons svg, .features img, .featureButtons img {
	padding: 1.1rem;
	margin: auto;
	height: calc(100% - 2.2rem);
}

.features span, .featureButtons span {
	margin: auto;
	font-weight: 600;
	font-size: 1.2rem;
}

.houseView p {
	padding: 1.5rem;
	font-size: 1.1rem;
}

.houseintro h1 {
	position: absolute;
	bottom: 1.5rem;
	font-family: 'FreeSerif';
	font-weight: 600;
	font-size: 4.8rem;
	padding-bottom: 0;
	color: var(--ciWhite);

	background: linear-gradient(#0000, #0003, #0008);
}

[page^="house"] .equipment {
	display: grid;
	gap: 2rem;
	grid-auto-flow: dense;
	grid-template-columns: repeat(auto-fit, minmax(24rem, 1fr));
	grid-template-rows: auto;
}

[page^="house"] .equipment img {
	width: 100%;
	height: 100%;
	object-fit: contain;
}

[page^="house"] .equipment .blueprint {
	display: grid;
}

[page^="house"] .equipment .blueprint h3 {
	margin: auto;
}

/* ========= Layout ========= */

/* Header or introduction */

.lytHead {
	text-align: center;
	margin-bottom: 6rem;
}

.lytHead * {
	text-align: center;
	margin: 0;
}

.lytHead h1 {
	font-family: 'FreeSerif';
	font-weight: 400;
	font-size: 4.8rem;
	padding-bottom: 0;
}

.lytHead p {
	font-size: 1.4rem;
}

/* Spotlight Overview or Summary */

.lytSpotView {
	display: grid;
	width: 100%;
	gap: 2rem;
	grid-auto-flow: dense;
	grid-template-columns: repeat(auto-fit, minmax(24rem, 1fr));
	/* grid-template-rows: auto min-content; */
}

.lytSpotView> :nth-child(1) {
	display: flex;
	font-size: 1.1rem;
}

.lytSpotView> :nth-child(1)>* {
	margin: auto;
}

.lytSpotView> :nth-child(2) {
	height: 100%;
	grid-column: span 2;
	grid-row: span 2;
}

.lytSpotView>* {
	margin: 0;
}

.lytSpotView>img {
	width: 100%;
	object-fit: cover;
}


@media (max-width: 920px) or (max-height: 640px) {
	.lytSpotView {
		grid-template-columns: 1fr;
		gap: 1.5rem;
	}

	.lytSpotView> :nth-child(2) {
		grid-column: 1;
		grid-row: span 2;
		/* padding: ; */
	}
}


.layoutTwoThirds {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(24rem, 1fr));
}

.layoutTwoThirds>article, .layoutTwoThirds>div {
	margin: auto;
	padding: 3rem;
}

/* .layoutTwoThirds img {
	max-height: 50vmin;
	width: 100%;
	height: 100%;
	object-fit: cover;
	border-radius: 1.5rem;
	grid-column: span 2;
} */

.layoutTwoThirds .large {
	max-height: 55vmin;
	width: 100%;
	height: 100%;
	object-fit: cover;
	border-radius: 1.5rem;
	grid-column: span 2;
}

.layoutTwoThirds .small {
	max-height: 50vmin;
	width: 100%;
	height: 100%;
	object-fit: cover;
	border-radius: 1.5rem;
	grid-column: span 1;
}

/* Contact */

#contact {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(8rem, 1fr));
	background-color: var(--ciDark);
	color: var(--ciWhite);
	box-shadow: 0 50vmax 0 50vmax var(--ciDark);
	padding: 5rem 1.5rem 1.5rem 1.5rem;
	gap: 4rem;
}

/* FXJS */

/* [fxjs] {
	opacity: 0;
	transition: .5s;
}

[fxjs].inFocus {
	opacity: 1;
} */

nav {
	display: flex;
	background-color: var(--ciDark);
}

nav a {
	color: var(--ciWhite) !important;
	/* Important is for firefox mobile */
	padding: .4rem .8rem;
}

nav>* {
	margin: auto 0;
}

nav .logo {
	display: contents;
}

nav .logo.small img {
	width: 1.5rem;
}

nav .extendable:not(:hover, :active)::after {
	opacity: 1;
	top: 0;
	transition-delay: .4s;
}

nav .extendable:not(:hover, :active) .sub {
	top: 0;
	opacity: 0;
	transition-delay: .4s;
	visibility: collapse;
}

nav a.pageActive {
	background-color: var(--ciMid);
	border-radius: 2rem;
}

.sub {
	display: flex;
	flex-direction: column;
	position: absolute;
	width: max-content;
	min-width: 100%;
	top: 2.6rem;
	z-index: 100;
	background: var(--ciDark);
	border-radius: 0 0 1.5rem 1.5rem;
	transition: .2s cubic-bezier(0, .7, .3, 1);
	padding: 0.5rem;
	left: -.5rem;
}

nav .extendable {
	position: relative;
}

nav .extendable>a:first-child {
	padding-right: 1.8rem;
}

nav .extendable::after {
	content: '';
	display: block;
	position: absolute;
	width: 0.8rem;
	height: 100%;
	top: 1rem;
	right: 0.6rem;
	opacity: 0;
	transition: .2s cubic-bezier(0, .7, .3, 1);
	background: center no-repeat url("data:image/svg+xml,%3csvg viewBox='0 0 14 14' xmlns='http://www.w3.org/2000/svg'%3e%3cpath d='m7 12.5 7-7-2-2-5 5-5-5-2 2z' fill='%23fff'/%3e%3c/svg%3e");
}

.hamburger {
	display: none;
	line-height: 64px;
	user-select: none;
}

.menuOpen {
	color: var(--ciAccent) !important;
}

span>h1 {
	margin-bottom: 0;
}

.doubleColContainer {
	display: flex;
}

.doubleColContainer>* {
	width: 49%;
}

.equipmentImgContainer>img {
	width: 49%;
}

@media (min-width: 921px) and (min-height: 641px) {
	.hideOnDesktop {
		display: none;
	}

	[page] {
		padding: 0 1em;
	}
}

/* mobile */
@media (max-width: 920px) or (max-height: 640px) {
	.hideOnMobile {
		display: none;
	}

	/* .layoutTwoThirds img {
		grid-row: 1;
	} */

	#houses {
		display: unset !important;
		margin-bottom: 1rem;
	}

	.house {
		margin-bottom: 2rem;
	}

	/*navbar*/
	.hamburger {
		display: unset;
		min-width: 64px !important;
		color: var(--ciWhite);
		text-align: center;
		cursor: pointer;
	}

	nav>div.extendable, nav>a:not(.logo) {
		display: none;
	}

	.menuShow {
		display: unset !important;
	}

	nav {
		display: flex;
		flex-wrap: wrap;
		height: unset !important;
		background-color: var(--ciDark);
	}

	nav>*:not(.logo) {
		min-width: 100%;
	}

	nav.logo {
		max-width: 64px;
	}

	nav>.logo>img {
		max-width: 64px;
	}

	.sub {
		border: 1px solid white;
	}

	.layoutTwoThirds .large {
		grid-row: 1;
	}

	.layoutTwoThirds .small {
		grid-row: 1;
	}

	body {
		/* font-size: .8rem; */
	}

	section {
		margin: 0 0 4rem 0;
	}

	#houses {
		gap: 3rem;
	}

	footer {
		font-size: .8rem;
		padding: 0 .5rem;
	}

	.houseView {
		height: auto;
		grid-template-rows: auto;
		gap: 1.5rem;
	}

	.houseView .overview {
		grid-column: auto;
		grid-row: auto;
	}

	.lytHead h1 {
		font-size: 3.8rem;
	}

	.layoutTwoThirds>article, .layoutTwoThirds>div {
		padding: 1rem;
	}

	.introLogo a {
		left: 0;
	}

	.doubleColContainer {
		display: block;
	}

	.doubleColContainer>* {
		width: 100%;
	}
}

img[src="img/soon.webp"] {
	object-fit: contain;
	background: #2a6d49;
}