
:root{
	--dur: 3500ms;
	--fade: 600ms;
	--bg: 252,248, 248;
	--black1:36, 36, 36;
	--black2: 51, 51, 51;
	--grey1: 119, 119, 119;
	--grey2: 169, 169, 169;
	--grey3: 230, 230, 230;
	--shadow :  rgba(50, 50, 93, 0.25) 0px 6px 12px -2px, rgba(0, 0, 0, 0.3) 0px 3px 7px -3px;
  --anim-speed: 1.5s;
  --anim-curve: cubic-bezier(0.76, 0, 0.24, 1);

}


* {
	
}



body{
	margin:0;
	place-items:center;
	
	background:rgb(var(--bg));
	font-family: "NB Akademie", sans-serif;
	text-align:left;
	font-size: 10pt;
	line-height: 1.3rem;
	scroll-behavior: smooth;
	align-content: baseline;
	color: rgba(var(--black1));
	font-display: swap;
}
body>*{
	opacity: 1;
	transition: 600ms ease-in-out;
	}


a:visited {
  color: rgba(var(--black1));
}

a {
  color: rgba(var(--black1));


  text-decoration: none; 
  border-bottom: 1.6px dotted rgb(var(--black1)); 
  padding-bottom: 0.05em; 


}
header{
	position: fixed;
  padding-top:1rem;
  font-size: 16pt;
  font-weight: 500;
  opacity: 1 !important;
  /*mix-blend-mode: difference;
  filter: invert(1);*/
  z-index:10000;
  background: linear-gradient(180deg,rgba(var(--bg), 1.0) 0%, rgba(var(--bg), 1) 40%, rgba(var(--bg), 0) 100%);
  height:5rem;
  border:none;

}
header>a{

}


footer{
	bottom: 0rem;
	padding-bottom:1rem;
  position: fixed;
  font-size: 17pt;
  opacity: 1 !important;
  font-weight: 500;
  z-index: 10000;
	/*mix-blend-mode: difference;
	filter: invert(1);*/
	background:linear-gradient(0deg,rgba(var(--bg), 1) 0%, rgba(var(--bg), 1) 40%, rgba(var(--bg), 0) 100%);
	height: 5rem;
	 align-content: flex-end;
}

/* LOAD ANIMATION */
@keyframes top-anim {
  from { transform:  translateY(0.5em); }
  to   { transform:  translateY(0); }
}

@keyframes bottom-anim {
  from { transform: translateY(-0.5em); }
  to   { transform:translateY(0); }
}

.site-header,
.site-footer {
  position: fixed;
  left: 0;
  width: 100%;
  transform: none; /* niente translateX se full-width */
  background: none;
}


.site-header {
	animation: top-anim 0.5s ease forwards;
	top:calc(50svh - 1.75em); 

}
.site-header.loaded{
	 
	 transition: top var(--anim-speed) var(--anim-curve);
	 transition-delay: 1s;
	 top:0;

}
.site-footer {
	animation: bottom-anim 0.5s ease forwards;
	bottom:calc(50svh - 1.75em); 
}

.site-footer.loaded{
	
	transition: bottom var(--anim-speed) var(--anim-curve);
	transition-delay: 1s;
	bottom:0;
}
.home-page .grid-container{
	width: 10vw;
  gap:0em;
  justify-self: center;
    
}
.home-page .grid-container.loaded{
	width: 100vw;
	gap:5em;
	transition:  var(--anim-speed) var(--anim-curve);
	transition-delay: 1s;
}
.slideshow {
	opacity: 0;

}

.slideshow.loaded {
  opacity: 1;
  transition: var(--anim-speed) var(--anim-curve);
  transition-delay: 1s;
}

.no-anim {
  animation: none !important;
  transition: none !important;
}
.site-header.no-anim{
	top:0vh;
}
.site-footer.no-anim{
	bottom:0vh;
}
.home-page .grid-container.no-anim{
	width: 100vw;
	gap:5em;
}
.slideshow.no-anim{
	  transition: 1s ease-in-out !important;
}


p{
	margin:0px;
}
h2{
	font-size: 2rem;
	font-weight: 400;
  line-height: 2.3rem;
}
h2:first-of-type{
	padding-top:1em;
}
h3{
	text-transform: uppercase;
  letter-spacing:0.1em;
  margin: 0px;
  font-weight: 600;
  font-size: 0.9em;
  padding-left: 0rem;
  
}
h4{
	margin:0px;
	font-size: 1.1em;
  font-weight: 500;


}



.grid-container {
    width:100vw  ;
    display: grid;
    grid-template-columns: repeat(6, 1fr);
    gap: 5em;

}
.five-columns{
	width: auto;
	grid-template-columns: repeat(5, 1fr) ;
  gap: 0rem;
  padding:0rem 3vw 0rem 3vw;
}

.column.center p {
	margin:0;
}
.rotate{
	transform: rotate(180deg);
}
.center{
	text-align:center;
	display: flex;
  justify-content: center; 
  align-items: center;     
}
.container {
	/*margin: 4rem 4rem 0rem;*/
	
 opacity: 0;
}
.center-box{
	position:absolute;

  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width:100%;
}
.container.loaded{
	opacity: 1;
	transition: opacity 600ms ease-in-out;
}

.container.loaded>*:not(.tooltip){
	opacity: 1;
	transition: opacity 600ms ease-in-out;
}
.column.side{
	grid-column: 1 / 2;
	padding-left:0vw;
	position: fixed;
	bottom:5rem;
}
.column.main{
	grid-column: 2 / 5;
	padding-left:0vw;
}
.column.main>p:first-of-type{
	padding-top:3rem;
}
.column.main>p:last-of-type{
	padding-bottom:6rem;
}

.left{
	grid-column: 1 / 2;
   margin-top: 1rem;
   	padding-left:0vw;

}
.right {
	grid-column: 2 / 5;
  margin-top: 1rem;
  padding-left:0vw;


}

.line{
	border-bottom: 	1px solid rgba(var(--grey1));
	margin-top:5rem;
	grid-column: 2 / 5;
}
.cv-trigger {
  display: inline-block;  
  cursor: default;
}

.table-block {
	width:100%;
}
.table-block td {
  border-bottom: 1px dotted rgba(var(--grey1));
  padding: 0.2rem 0rem;
}

.table-block tr:last-child td {
  border-bottom: none;
}
.bio {
    white-space: pre-line;
}
.anno{
	color:rgba(var(--grey1));
	width: 25%;
}
.ruolo{

}
.slideshow{
  width: 100vw;
  position: relative;
  overflow: hidden;
  height: 100vh;
}

.slide{
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.6s ease-in-out;
  z-index: 0;
}

.slide.active{
  opacity: 1;
  pointer-events: auto;
  z-index: 1000;
}

/* Wrapper dell'immagine */
.img-wrap {
  position: relative;
  display: inline-block; /* prende dimensione reale dell'immagine */
}

/* Immagine */
.img-wrap img {
	object-fit: contain;
	max-width:80vw;
  display: block;
  max-height: 80vh;

  /*box-shadow: var(--shadow);*/
}

.slide-title {
  position: absolute;
  bottom: 1rem;
  padding:0rem 1rem;
	font-size: 7.1pt;
  line-height: 0.9rem;
  letter-spacing: 0.07rem;
  font-weight: 400;
	text-align: center;  
	justify-self: center;

  color: var(--grey2);
  text-transform: uppercase;
  mix-blend-mode: hard-light;

  opacity: 0;
  transition: opacity 0.25s ease-in-out;
  pointer-events: none;

          
}
.tooltip {
	position: fixed;
  top: 0;
  left: 0;
  max-width: 600px;
  pointer-events: none;
  font-size: 7.5pt;
  padding: 0.4rem;
  line-height: 0.8rem;
  text-align: left;
  justify-self: left;
  align-self: flex-end;
  background: white;
  border: 1px solid rgba(var(--grey3));
  color: rgba(var(--grey1));
  mix-blend-mode: luminosity;
  opacity: 0;
  transition: opacity 0.15s ease;
  z-index: 9999;
  /* border-radius: 2rem; */
  box-shadow: var(--shadow)
}

.tooltip.visible {
  opacity: 1;
}



/* ______________________
			
		 MOBILE
	_______________________ */



@media (max-width: 768px) {






body.home-page {
    margin: 0;
    padding: 0;
    overflow-x: hidden; 
    display: flex;
    flex-direction: column;
    align-items: center; 
}

.site-header.loaded,.site-footer.loaded{
}
.home-page .grid-container{
	justify-content: center; /*IMPORTANTE*/
}
.home-page .grid-container.loaded {
  gap: 1em;
  left:0;
}

	body{

	}
	header{
		font-size: 15pt;
		padding-top:1rem;
	}
	header div a .grid-container{
		column-gap: 1em;
	}
	footer{
		font-size: 15pt;
		padding-bottom:1rem;

	}
	footer div a .grid-container{
		column-gap: 1rem;
	}
	.slide-title{
		opacity: 0;
}
.tooltip{
	/*opacity: 0 !important;*/
}
	.about{
		padding: 1rem;

	}
	/*.slideshow{
		width:calc(100vw - 2rem);
	}*/

	.img-wrap img {
	max-width:100vw ;
  max-height:70vh ;
}


	.grid-container.five-columns {
		grid-template-columns: repeat(1, 1fr) !important;	    
		grid-auto-flow: row;                  
	}
	.container:has(.snap-container){
		 margin: 0rem; 
	}
	.container>.column {
	    width: 100%;   
	    padding-left:0rem;    
	}
	
	
	h2{
		font-size:1.5rem;
		grid-column: 1/6;
		padding:0rem;
		line-height: 2rem;

	}
	
	h3{
		grid-column: 1/6;
		padding:0rem;
	}
	h4{
		grid-column: 1/6;

	}

	.left{
		grid-column: 1/1;

	}
	.right{
		grid-column: 1/6;
		padding:0rem;

	}
	.line{
		grid-column: 1/6;
	}
	.right.table{
		grid-column: 1/6;

	}
	.column.main{
		order: 0; 
		grid-column: 1/6;
		padding:0rem;
	}
	.column.side{
		grid-column: 1/1;
		position: relative;
		order: 1;
	}

	.table-block td {
    font-size: 0.65rem;
    padding: 0.2rem 0rem;
  }

	
}

