*,
*::after,
*::before {
	box-sizing: border-box;
}

:root {
	font-size: 16px;
  --color-text: #f5f3ee;
  --color-bg: #0e0d0e;
  --color-link: #ffffff;
  --color-link-hover: #FB7260;
	--page-padding: 2rem;
	--grid-gap: 2rem; /*var(--page-padding);*/
	--color-bg-content: #0e0d0e;
	--color-bg-frame: white;/*#FB7260;*/
	--color-border: #46443e;
}

html,
body {
	width: 100vw;
	overflow-x: hidden;
}

html {
	scroll-behavior: smooth;
	/*scroll-padding-top: -2rem;*/
}

body {
	margin: 0;
	color: var(--color-text);
	background-color: var(--color-bg);
	font-family: "Manrope", sans-serif;
	font-optical-sizing: auto;
	/*font-variation-settings: "slnt" 0, "wdth" 100, "wght" 450, "INKT" 0;*/
	font-weight: 400;
	line-height: 1.2;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
}

/* Page Loader */
/*
.js .loading::before,
.js .loading::after {
	content: '';
	position: fixed;
	z-index: 1000;
}

.js .loading::before {
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background: var(--color-bg);
}

.js .loading::after {
	top: 50%;
	left: 50%;
	width: 60px;
	height: 60px;
	margin: -30px 0 0 -30px;
	border-radius: 50%;
	opacity: 0.4;
	background: var(--color-link);
	animation: loaderAnim 0.7s linear infinite alternate forwards;

}

@keyframes loaderAnim {
	to {
		opacity: 1;
		transform: scale3d(0.5,0.5,1);
	}
}
*/


a {
	text-decoration: none;
	color: var(--color-link);
	outline: none;
	cursor: pointer;
}

a:hover {
	text-decoration: underline;
	color: var(--color-link-hover);
	outline: none;
}

/* Better focus styles from https://developer.mozilla.org/en-US/docs/Web/CSS/:focus-visible */
a:focus {
	/* Provide a fallback style for browsers
	 that don't support :focus-visible */
	outline: none;
	background: lightgrey;
}

a:focus:not(:focus-visible) {
	/* Remove the focus indicator on mouse-focus for browsers
	 that do support :focus-visible */
	background: transparent;
}

a:focus-visible {
	/* Draw a very noticeable focus style for
	 keyboard-focus on browsers that do support
	 :focus-visible */
	outline: 2px solid red;
	background: transparent;
}

.menu {
	position:fixed;
	top:0;
	left:0;
	bottom:0;
	right:0;
	background:#fff;
	color:#111;
	z-index: 3;
	padding:var(--page-padding);
	display:flex;
	align-items: center;

	opacity:0;
	pointer-events: none;
	visibility:hidden;
}

.menu-container {

}

.menu .menu-trigger {
	color:#111;
	z-index:4;
}

.menu ul {
	list-style: none;
	padding:0;
	margin:0;
	line-height:1;
}

.menu ul a {
	font-size:clamp(2rem, 7vw, 7.5rem);
	color:#111;
	text-transform: uppercase;
	font-weight:800;
}

.menu-trigger-container {
	position: fixed;
	top:0;
	bottom:0;
	right:0;
	display:flex;
	align-items: center;
	justify-content: center;
	pointer-events: none;
	z-index:2;
	margin-right:1rem;
}

.menu-trigger {
	transform: rotate(-180deg);
	writing-mode: vertical-lr;
	/*transform-origin: top center;*/
	color:#fff;
	text-transform: uppercase;
	font-size: 1.2rem;
	font-weight: 700;
	pointer-events: all;
	line-height:1;
}

.menu-trigger:hover {
	text-decoration: none;
	color:inherit;
}

@media screen and (min-width: 53em) {
.menu-trigger-container {
	margin-right:var(--page-padding);
}

.menu-trigger {
	font-size: 1.5rem;
	font-weight: 700;
}
}




.unbutton {
	background: none;
	border: 0;
	padding: 0;
	margin: 0;
	font: inherit;
	cursor: pointer;
}

.unbutton:focus {
	outline: none;
}

.type-tiny,
.cdawrap {
	font-size: 11px;
	text-transform: uppercase;
	font-weight: 400;
	/*font-variation-settings: "wght" 400;*/
}

.frame {
	padding: var(--page-padding);
	text-transform: uppercase;
	position: relative;
	display: grid;
	line-height: 1;
	height: 100dvh;
	grid-row-gap: 0.5rem;
	grid-column-gap: 2rem;
	justify-items: start;
	align-content: start;
	background: var(--color-bg-frame);
	grid-template-columns: auto auto;
	grid-template-rows: auto auto auto 1fr;
	grid-template-areas: 'logo' 'tags' 'sponsor' 'subline' 'title';
}

.frame #cdawrap {
  justify-self: start;
}

.frame__title {
	white-space: nowrap;
  grid-area: title;
  font-size: clamp(6rem,15vw,20rem); /*clamp(2rem,20vw,20rem);*/
  margin: 0;
  letter-spacing: -0.05em;
  padding-top: 0.15em;
  font-weight: 700;
  line-height: 0.8;
  text-indent: -0.065em;
  word-spacing: 0.15em;
  /*font-family: "bricolage-grotesque-48", sans-serif;*/
}

.frame__subline {
	grid-area: subline;
}

.frame__tags {
  grid-area: tags;
}

.frame__logo {
	grid-area: logo;
	padding-bottom: 0.15rem;
	font-size: 1.5rem;
	/*font-family: "bricolage-grotesque-48", sans-serif;*/
}

.flex-line {
	display: flex;
	gap: 1rem;
	flex-wrap: wrap;
}

.content {
	position: relative;
	min-height: 100dvh;
	background: var(--color-bg-content);
	align-content: center;
}

.content--cutoff {
	overflow: hidden;


}

.content--padded {
	padding: var(--page-padding);
}

.content--full {
	display: grid;
	height: 100vh;
	place-items: center;
	grid-template-areas: 'main';
	grid-template-rows: 100%;
	grid-template-columns: 100%;
}

.content__text {
	font-size: 1.7rem;
	max-width: 1225px;
	line-height: 1.4;
	margin: 0.5rem 0;
	font-weight: 400;
	/*font-variation-settings: "wght" 500;*/
	text-wrap: balance;
	letter-spacing: -0.025em;
}

.grid {
	grid-area: main;
	display: grid;
	width: 100%;
	height: 100%;
	grid-template-columns: repeat(8,1fr);
	grid-template-rows: 1fr 1fr 1fr;
}

.grid--spaced {
	gap: var(--grid-gap);
}

.grid--zoomed {
	gap: 2rem;
	grid-template-columns: repeat(3, 70%);
	grid-template-rows: repeat(3, 60%);
	justify-content: center;
	align-content: center;
	aspect-ratio: 2 / 1;
}

.grid--zoomed .grid__img {
	width: 100%;
	height: 100%;
}

.grid--columns {
  grid-template-columns: repeat(5,1fr);
	grid-template-rows: repeat(2,min-content);
  align-content: center;
}

.grid--single {
  height: auto;
  justify-self: center;
}

.grid--column {
	grid-template-columns: repeat(15, calc((100% - 14 * 10px) / 15));
  gap: 10px;
	grid-template-rows: auto;
}

.grid__img:has(.grid__img-inner) {
	position: relative;
	overflow: hidden;
	display: grid;
	place-items: center;
	max-height: 100%;
	min-width: 100%;
}

.grid__img .grid__img-inner {
	width: 100%;
	height: 100%;
	background-size: cover;
	background-position: 50% 50%;
	will-change: transform;
}

.ar-wide {
	aspect-ratio: 4/3;
}

.ar-narrow {
	aspect-ratio: 2/3;
}

.ar-rect {
	aspect-ratio: 1;
}

.span-2 {
	grid-column: auto / span 2;
}

.span-3 {
	grid-column: auto / span 3;
}

.grid--small {
	grid-template-columns: repeat(9,1fr);
	grid-auto-rows: 1fr;
}

.grid--tiny {
	height: 60vh;
	grid-template-columns: repeat(14,1fr);
	grid-auto-rows: auto;
}

.grid--wide {
	grid-template-columns: repeat(5,1fr);
	grid-template-rows: repeat(4,1fr);
}

.pos-1 { grid-area: 1 / 1; }
.pos-2 { grid-area: 1 / 3; }
.pos-3 { grid-area: 1 / 4; }
.pos-4 { grid-area: 1 / 5; }
.pos-5 { grid-area: 1 / 7; }
.pos-6 { grid-area: 2 / 1; }
.pos-7 { grid-area: 2 / 3; }
.pos-8 { grid-area: 2 / 4; }
.pos-9 { grid-area: 2 / 6; }
.pos-10 { grid-area: 2 / 7; }
.pos-11 { grid-area: 2 / 8; }
.pos-12 { grid-area: 3 / 1; }
.pos-13 { grid-area: 3 / 2; }
.pos-14 { grid-area: 3 / 4; }
.pos-15 { grid-area: 3 / 5; }
.pos-16 { grid-area: 3 / 7; }
.pos-17 { grid-area: 3 / 8; }
.pos-18 { grid-area: 2 / 5; }

.grid__img {
	background-size: cover;
	background-position: 50% 50%;
	pointer-events: none;
	will-change: transform;
	transform: translateZ(0.1px);
}

.grid--columns .grid__img {
	height: min-content;
	aspect-ratio: 2 / 3;
}

.content__title {
	grid-area: main;
	position: relative;
	display: flex;
	flex-direction: column;
	text-transform: uppercase;
}

.content__title-main {
	font-size: clamp(2rem, 7vw, 7.5rem);
	line-height: 1;
	margin: 0.5rem 0 0;
	font-weight: 700;
	/*font-variation-settings: "wght" 500;*/
	text-wrap: balance;
	letter-spacing: -0.025em;
}

.content__title-main + p {
	margin: 0;
	max-width: 100px;
}

.center {
	text-align: center;
}

.right {
	text-align: right;
}

.end {
	align-self: end;
}

.acenter {
	align-self: center;
}

.page-footer {
	padding: var(--page-padding);
	position: relative;
	display: grid;
	width: 100%;
	grid-row-gap: 1rem;
	grid-column-gap: 2rem;
	justify-items: start;
	/*margin-top: 40vh;*/
	grid-template-columns: auto;
	justify-content: space-between;
}

/*
@media (max-aspect-ratio: 16/9) {
  .grid:not(.grid--zoomed) {
    width: 100%;
    height: auto;
    aspect-ratio: 16/9;
  }
}
*/


@media screen and (min-width: 53em) {
	/*body {
		--page-padding: 1rem;
	}*/
	.frame {
		grid-template-columns: 20% 1fr 1fr;
		grid-template-rows: min-content 1fr auto;
		grid-row-gap: 15vh;
		align-items: center;
		grid-template-areas: 'logo tags sponsor' '... ... subline' 'title title title' ;
	}
	.frame__links {
		margin-left: 3rem;
	}
	.frame__subline {
		align-self: end;
	}
	.frame__title {
		align-self: end;
	}
	.frame #cdawrap {
		text-align: right;
		max-width: 250px;
		justify-self: end;
	}
	.page-footer {
		grid-template-columns: repeat(3,auto);
	}
}



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

	/* griglia generale */
	.grid {
		grid-template-columns: repeat(2,2fr);
	}

	.grid--spaced {
		gap:3px;
	}


}






/* Timeline */
.tns-outer{padding:0 !important}.tns-outer [hidden]{display:none !important}.tns-outer [aria-controls],.tns-outer [data-action]{cursor:pointer}.tns-slider{-webkit-transition:all 0s;-moz-transition:all 0s;transition:all 0s}.tns-slider>.tns-item{-webkit-box-sizing:border-box;-moz-box-sizing:border-box;box-sizing:border-box}.tns-horizontal.tns-subpixel{white-space:nowrap}.tns-horizontal.tns-subpixel>.tns-item{display:inline-block;vertical-align:top;white-space:normal}.tns-horizontal.tns-no-subpixel:after{content:'';display:table;clear:both}.tns-horizontal.tns-no-subpixel>.tns-item{float:left}.tns-horizontal.tns-carousel.tns-no-subpixel>.tns-item{margin-right:-100%}.tns-no-calc{position:relative;left:0}.tns-gallery{position:relative;left:0;min-height:1px}.tns-gallery>.tns-item{position:absolute;left:-100%;-webkit-transition:transform 0s, opacity 0s;-moz-transition:transform 0s, opacity 0s;transition:transform 0s, opacity 0s}.tns-gallery>.tns-slide-active{position:relative;left:auto !important}.tns-gallery>.tns-moving{-webkit-transition:all 0.25s;-moz-transition:all 0.25s;transition:all 0.25s}.tns-autowidth{display:inline-block}.tns-lazy-img{-webkit-transition:opacity 0.6s;-moz-transition:opacity 0.6s;transition:opacity 0.6s;opacity:0.6}.tns-lazy-img.tns-complete{opacity:1}.tns-ah{-webkit-transition:height 0s;-moz-transition:height 0s;transition:height 0s}.tns-ovh{overflow:hidden}.tns-visually-hidden{position:absolute;left:-10000em}.tns-transparent{opacity:0;visibility:hidden}.tns-fadeIn{opacity:1;filter:alpha(opacity=100);z-index:0}.tns-normal,.tns-fadeOut{opacity:0;filter:alpha(opacity=0);z-index:-1}.tns-vpfix{white-space:nowrap}.tns-vpfix>div,.tns-vpfix>li{display:inline-block}.tns-t-subp2{margin:0 auto;width:310px;position:relative;height:10px;overflow:hidden}.tns-t-ct{width:2333.3333333%;width:-webkit-calc(100% * 70 / 3);width:-moz-calc(100% * 70 / 3);width:calc(100% * 70 / 3);position:absolute;right:0}.tns-t-ct:after{content:'';display:table;clear:both}.tns-t-ct>div{width:1.4285714%;width:-webkit-calc(100% / 70);width:-moz-calc(100% / 70);width:calc(100% / 70);height:10px;float:left}

.tns-outer {
	margin:3rem calc( var(--page-padding) * -1 );
	position: relative;
	margin-top:0;
}
.timeline-progress {
	margin-top: 1.5rem;
	margin-left: calc( var(--page-padding) * -1 );
	margin-right: calc( var(--page-padding) * -1 );
	width:100vw;
}

.timeline {
    /*margin:5rem 0;*/
    user-select:none;
}

.timeline-bg {
    position:relative;
    aspect-ratio:calc(1/0.7);
}
.timeline-bg img {
    position:absolute;
    top:0;
    left:0;
    width:100%;
    height:100%;
    object-fit:contain;
    padding:0;
    object-position:center;
    aspect-ratio: 1;
}

.js .js-opacity-0 {
    opacity: 0;
}

.timeline-bg img.cover {
    object-fit:cover;
    padding: 0;
}

.timeline-bg img.padding {
	padding: 2rem;
}

.timeline-txt {
	padding: var(--page-padding);
	display:flex;
	flex-direction: column;
}
.timeline-txt > * {
	flex: 1 1 auto;
	width: 100%;
	height:50%;
}
.timeline-title {
	display:flex;
}


.timeline-descr {
    padding:0;
    margin:0;
    font-size:1rem;
    max-width:400px;
    padding-top:2rem;
}

.tns-controls {
	/*position:absolute;
	bottom: calc( var(--page-padding) * 2 );*/
	width: 100%;
	display: flex;
	justify-content: space-between;
}

.tns-controls button {
  appearance: none;
  background-color: rgba(0,0,0,0.3);
  color: #fff;
  border: 0 none;
  font-size: 4rem;
  padding: .2rem var(--page-padding);
  margin: 0;
  line-height: 1;
  text-box: trim-both cap alphabetic;
  transition: all .12s cubic-bezier(.455,.03,.515,.955);
}

.presume-mouse .tns-controls button:hover {
	background-color: rgba(0,0,0,0.6);
}

.presume-mouse .tns-controls button:active {
	background-color: rgba(0,0,0,0.9);
}

.tns-controls button:disabled {
	opacity:0;
	pointer-events: none;
}

.timeline-progress {
	height:3px;
	background-color:rgba(255,255,255,0.1);
	position:relative;
}
.timeline-progress-cursor {
	position:absolute;
	height:3px;
	width:0%;
	top:0;
	left:0;
	background-color:rgba(255,255,255,0.8);
	transition: all .8s cubic-bezier(.455,.03,.515,.955);
}


@media screen and (min-width: 53em) {
    .md-flex {
        display: flex;
    }
    .md-flex > * {
        flex: 1 1 auto;
        width:50%;
    }

  .timeline-bg {
    position:relative;
    aspect-ratio:calc(1/0.8);
  }

  .timeline-bg img.padding {
  	padding: 5rem;
  }

  .timeline-txt {
	padding:4rem;
  }

  .tns-controls {
    position: absolute;
    bottom: calc(var(--page-padding) * 2);
  }

}


.transition-fast {
  transition: all .12s cubic-bezier(.455,.03,.515,.955);
}