@charset "UTF-8";
/* CSS Document */

@-ms-viewport{
  width: device-width;
}

/* ------------------- MAIN BODY STYLES START ------------------- */ 

html, body {
    margin: 0;
    padding: 0;
    width: 100%;
    display: flex;
    justify-content: center;
    align-items: center;
    flex-direction: column; /* Arrange items vertically */
    min-height: 100vh; /* Ensure the body takes full height of the viewport */
    box-sizing: border-box;
	scroll-behavior: smooth;
}

* {
    box-sizing: inherit;
}

body {
	height: 100%;
	color: #CC0000;
	font-family: Archivo;
	word-wrap: break-word;
	background-color: #F2F2F2;
	-webkit-font-smoothing: antialiased;
	text-rendering: optimizelegibility;
}

.not-found {
	align-self: stretch;
	justify-content: center; 
	/*display: inline-flex;*/
	display: flex;
    flex-direction: column;
    flex-wrap: nowrap;
    align-items: center;
	text-align: center;
	max-width: 70vw;
    align-self: center;
}

.not-found-help {
	text-align: center;
	}

a:link {
	color: #CC0000;
	text-decoration: none;
	cursor: pointer;
  	transition-duration: .35s;
}

a:visited {
	color: #CC0000;
	text-decoration: none;
	cursor: pointer;
}

a:hover {
	color: #BA0000;
	text-decoration: none;
	cursor: pointer;
	transition-duration: .35s;
}

a:active {
	color: #BA0000;
	text-decoration: none;
	cursor: pointer;
} 

.fade-in-up {
    opacity: 0;
    transform: translateY(24px);
    transition-delay: 0s; /* Default delay to be overwritten */
}

.fade-in-up.visible {
    opacity: 1;
    transform: translateY(0);
}

.fade-in-on-load {
    opacity: 0;
    transition: opacity 0.8s ease-in-out;
}

.fade-in-on-load.visible {
    opacity: 1;
}

.button-main {
    background: white;
    border-radius: 100px;
    border: 3px #CC0000 solid;
	color: #CC0000;
    display: flex;
    justify-content: center;
    align-items: center;
    cursor: pointer;
    transition: background 0.35s, color 0.35s;
}

.button-main:hover {
    background: #BA0000;
    border: 3px #BA0000 solid;  
    color: white;
}

.button-secondary {
	background-color: transparent;
    border-radius: 100px;
    border: 3px #CC0000 solid;
	color: #CC0000;
    display: flex;
    justify-content: center;
    align-items: center;
    cursor: pointer;
    transition: background 0.35s, color 0.35s;
}

.button-secondary:hover {
	background-color: transparent;	
    color: #BA0000;
    border: 3px #BA0000 solid;
}

.button-area, .button-area-1 {
	display: flex;
    flex-wrap: nowrap;
    justify-content: center;
    align-items: center;
	}

.hero-tiago-title {
	display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    align-content: center;
    justify-content: center;
    align-items: center;
    column-gap: 16px;
}

.hero-tiago-sotenhogrosso {
	display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    justify-content: center;
}

#top {
	text-decoration: none;
}

#european-city {
            transition: opacity 0.5s;
        }
        .fade-out {
            opacity: 0;
        }
        .fade-in {
            opacity: 1;
        }


@media (min-width: 320px) and (max-width: 734px) {
	
	body {
	font-size: 24px;
	font-weight: 500;
	margin-top: 32px;
	}

.not-found {
	margin-left: 24px;
	margin-right: 24px;
	padding-top: 32px;
	/*padding-bottom: 32px;*/		
	width: -webkit-fill-available;
	row-gap: 32px;
}

.not-found-help {
	font-size: 16px;
	width: 100%;
	}
	
	h1 {
	font-size: 56px;
	font-weight: 900;
	letter-spacing: -4px;
	text-transform: uppercase;
	word-wrap: break-word;
	margin: 0;
	}
	
	h2 {
	font-size: 30px;
	font-weight: 900;
	letter-spacing: -1px;
	text-transform: uppercase;
	word-wrap: break-word;
	margin: 0;
	}

	h3 {
	font-size: 24px;
	font-weight: 900;
	letter-spacing: -1px;
	text-transform: uppercase;
	word-wrap: break-word;
	margin: 0;
	text-align: center;
	}
	
	h4 {
	font-size: 40px;
	font-weight: 900;
	letter-spacing: -2px;
	text-transform: uppercase;
	word-wrap: break-word;
	margin: 0;
	}
	
#top-small {
	display: none;
}
	
.button-main, .button-secondary {
    padding-top: 10px;
	padding-bottom: 10px;
	padding-right: 16px;
	padding-left: 16px;
	font-size: 24px;
	font-weight: 500;
	}
	
.button-area {
    align-content: center;
    flex-direction: row;
    flex-wrap: wrap !important;
    row-gap: 16px;
    column-gap: 8px;
	padding-bottom: 40px;
	margin: 0 24px 0 24px;
	}
	
.button-area-1 {
    align-content: center;
    flex-direction: row;
    flex-wrap: wrap !important;
    row-gap: 16px;
    column-gap: 8px;
	padding-top: 24px;
	margin: 0 24px 0 24px;
	}
	
.material-icons, .material-symbols-outlined {
	font-size: inherit !important;
	vertical-align: middle !important;
	}
	
}

@media (min-width: 735px) and (max-width: 1068px) {
	
	body {
	font-size: 32px;
	font-weight: 500;		
	margin-top: 40px;
	}

	.not-found {
	margin-left: 32px;
	margin-right: 32px;
	padding-top: 40px;
	/*padding-bottom: 40px;*/
	width: -webkit-fill-available;
	row-gap: 40px;
}

.not-found-help {
	font-size: 20px;
	width: 80%;
	}
	
	h1 {
	font-size: 64px;
	font-weight: 900;
	letter-spacing: -4px;
	text-transform: uppercase;
	word-wrap: break-word;
	margin: 0;
	}
	
	h2 {
	font-size: 40px;
	font-weight: 900;
	letter-spacing: -2px;
	text-transform: uppercase;
	word-wrap: break-word;
	margin: 0;
	}
	
	h3 {
	font-size: 32px;
	font-weight: 900;
	letter-spacing: -2px;
	text-transform: uppercase;
	word-wrap: break-word;
	margin: 0;
	text-align: center;
	}
	
	h4 {
	font-size: 48px;
	font-weight: 900;
	letter-spacing: -2px;
	text-transform: uppercase;
	word-wrap: break-word;
	margin: 0;
	}
	
.button-main, .button-secondary {
    padding-top: 16px;
	padding-bottom: 16px;
	padding-right: 24px;
	padding-left: 24px;
	font-size: 32px;
	font-weight: 500;
	}
	
.button-area {
    flex-direction: row;
    column-gap: 16px;
	padding-bottom: 64px;
	margin: 0 32px 0 32px;
	}
	
.button-area-1 {
    flex-direction: row;
    column-gap: 16px;
	padding-top: 32px;
	margin: 0 32px 0 32px;
	}
	
.material-icons, .material-symbols-outlined {
	font-size: inherit !important;
	vertical-align: middle !important;
	}
	
}

@media (min-width: 1069px) and (max-width: 3008px) {

	body {
	font-size: 40px;
	font-weight: 500;	
	margin-top: 48px;
	/*max-width: 1648px;*/
	}

	.not-found {
	margin-left: 40px;
	margin-right: 40px;
	padding-top: 48px;
	/*padding-bottom: 48px;*/
	width: -webkit-fill-available;
	row-gap: 48px;
}

.not-found-help {
	font-size: 24px;
	width: 70%;
	}
	
	h1 {
	font-size: 104px;
	font-weight: 900;
	letter-spacing: -4px;
	text-transform: uppercase;
	word-wrap: break-word;
	margin: -19px;
	}
	
	h2 {
	font-size: 64px;
	font-weight: 900;
	letter-spacing: -2px;
	text-transform: uppercase;
	word-wrap: break-word;
	margin: 0;
	}
	
	h3 {
	font-size: 40px;
	font-weight: 900;
	letter-spacing: -2px;
	text-transform: uppercase;
	word-wrap: break-word;
	margin: 0;
	text-align: center;
	}
	
	h4 {
	font-size: 56px;
	font-weight: 900;
	letter-spacing: -2px;
	text-transform: uppercase;
	word-wrap: break-word;
	margin: 0;
	}
	
.button-main, .button-secondary {
    padding-top: 24px;
	padding-bottom: 24px;
	padding-right: 32px;
	padding-left: 32px;
	font-size: 40px;
	font-weight: 500;
	}
	
.button-area {
    flex-direction: row;
    column-gap: 24px;
	padding-bottom: 96px;
	margin: 0 40px 0 40px;
	}
	
.button-area-1 {
    flex-direction: row;
    column-gap: 24px;
	padding-top: 40px;
	margin: 0 40px 0 40px;
	}
	
.material-icons, .material-symbols-outlined {
	font-size: inherit !important;
	vertical-align: middle !important;
	}
	
}

/* ------------------- MAIN BODY STYLES END ------------------- */ 

/* ------------------- TIAGO HEADER + FOOTER + LIST START ------------------- */

.hero-header {
	height: 100%; 
	flex-direction: column; 
	justify-content: flex-start; 
	align-items: flex-start; 
	display: inline-flex;
	width: -webkit-fill-available;
}

.hero-description {
	align-self: stretch;
	background: #F2F2F2; 
	border-bottom: 3px #CC0000 solid;
	justify-content: center; 
	align-items: center; 
	display: inline-flex;
}

.hero-footer {
	height: 100%;
	background: #F2F2F2;
	border-top: 3px #CC0000 solid;
	margin-top: auto;
	position: sticky;
	top: 100vh;
	width: -webkit-fill-available;
}

.hero-worklist {
	align-self: stretch;
	justify-content: center; 
	/*display: inline-flex;*/
	display: flex;
    flex-direction: column;
    flex-wrap: nowrap;
    align-items: center;
}

.list-item {
	text-align: center;
	position: relative;
}

.hover-image {
    position: absolute;
    display: none;
    pointer-events: none;
    z-index: 1000;
	border: 3px #CC0000 solid;
}

/* Small screens */
@media (min-width: 320px) and (max-width: 734px) {
    .hover-image {
        width: 60vw;
        height: auto;
		border-radius: 16px;
		background-color: #FFFFFF;
    }
}

/* Medium screens */
@media (min-width: 735px) and (max-width: 1068px) {
    .hover-image {
        width: 50vw;
        height: auto;
		border-radius: 24px;
		background-color: #FFFFFF;
    }
}

/* Large screens */
@media (min-width: 1069px) and (max-width: 3008px) {
    .hover-image {
        width: 32vw;
        height: auto;
		border-radius: 32px;
		background-color: #FFFFFF;
    }
}


@media (min-width: 320px) and (max-width: 734px) {
	
	.hero-header {
		margin-left: 24px;
		margin-right: 24px;
	    width: -webkit-fill-available;
	}
	
	.hero-description {
		padding-top: 32px;
		padding-bottom: 32px;
	}
	
	.hero-tiago {
		align-self: stretch; 
		text-align: center;
		position: static;
		/*position: -webkit-sticky; 
		position: sticky; 
		top: 32px;*/
	}
	
	.hero-footer {
		margin-left: 24px;
        margin-right: 24px;
        padding-top: 24px;
        padding-bottom: 24px;
		column-gap: 8px;
        row-gap: 8px;
        display: flex;
        flex-direction: row;
        justify-content: center;
        height: auto;
        flex-wrap: wrap;
		width: -webkit-fill-available;
	}
	
	#copyright {
		grid-row-start: 1;
		grid-column-start: 1;
		grid-row-end: 2;
		grid-column-end: 7;
	}
	
	#menu {
		grid-row-start: 1;
		grid-column-start: 8;
		grid-row-end: 2;
		grid-column-end: 13;
		text-align: center;
		
		display: flex;
        flex-direction: row;
        align-content: center;
        justify-content: flex-end;
        column-gap: 24px;
	}
	
	.hero-worklist {
	margin-left: 24px;
	margin-right: 24px;
	padding-top: 32px;
	padding-bottom: 32px;		
	width: -webkit-fill-available;
	row-gap: 32px;
}
	
	.list-item {
		color: blue;
	}

}

@media (min-width: 735px) and (max-width: 1068px) {
	
	.hero-header {
		margin-left: 32px;
		margin-right: 32px;
	}
	
	.hero-description {
		padding-top: 40px;
		padding-bottom: 40px;
	}
	
	.hero-tiago {
		align-self: stretch; 
		text-align: center;
		position: static;
		/*position: -webkit-sticky; 
		position: sticky; 
		top: 40px;*/
	}
	
	.hero-footer {
		margin-left: 32px;
        margin-right: 32px;
        padding-top: 40px;
        padding-bottom: 40px;
		column-gap: 16px;
        row-gap: 16px;
        display: flex;
        flex-direction: row;
        justify-content: space-between;
        height: auto;
        flex-wrap: nowrap;
        align-items: flex-start;
		width: -webkit-fill-available;
	}
	
	#copyright {
		grid-row-start: 1;
		grid-column-start: 1;
		grid-row-end: 2;
		grid-column-end: 7;
	}
	
	#menu {
		grid-row-start: 1;
		grid-column-start: 8;
		grid-row-end: 2;
		grid-column-end: 13;
		text-align: center;
		
		display: flex;
        flex-direction: row;
        align-content: center;
        justify-content: flex-end;
        column-gap: 24px;
	}
	
	.hero-worklist {
	margin-left: 32px;
	margin-right: 32px;
	padding-top: 40px;
	padding-bottom: 40px;
	width: -webkit-fill-available;
	row-gap: 40px;
}
	
	.list-item {
		color: blue;
	}	
	
}

@media (min-width: 1069px) and (max-width: 3008px) {

	.hero-header {
		margin-left: 40px;
		margin-right: 40px;
		max-width: 1648px;
	}
	
	.hero-description {
		padding-top: 48px;
		padding-bottom: 48px;
	}
	
	.hero-tiago {
		align-self: stretch; 
		text-align: center; 
		position: static;
		/*position: -webkit-sticky; 
		position: sticky; 
		top: 48px;*/
	}
	
	.hero-footer {
		margin-left: 40px;
        margin-right: 40px;
        padding-top: 48px;
        padding-bottom: 48px;
        column-gap: 24px;
        display: grid;
        height: auto;
        grid-template-rows: 1fr;
        grid-template-columns: 1fr 1fr 1fr 1fr 1fr 1fr 1fr 1fr 1fr 1fr 1fr;
        grid-template-rows: auto auto;
        width: calc(100% - 80px);
        max-width: 1648px;
		justify-content: flex-end;
		align-items: center;
	}
	
	#copyright {
		grid-row-start: 1;
		grid-column-start: 1;
		grid-row-end: 2;
		grid-column-end: 7;
	}
	
	#menu {
		grid-row-start: 1;
		grid-column-start: 8;
		grid-row-end: 2;
		grid-column-end: 13;
		text-align: center;
		
		display: flex;
        flex-direction: row;
        align-content: center;
        justify-content: flex-end;
        column-gap: 24px;
	}
	
	.hero-worklist {
	margin-left: 40px;
	margin-right: 40px;
	padding-top: 48px;
	padding-bottom: 48px;
	width: -webkit-fill-available;
	row-gap: 48px;
}
	
	.list-item {
		color: blue;
	}
	
}
/* ------------------- TIAGO HEADER + FOOTER + LIST END ------------------- */

/*///////////// ---------------------- ABOUT GRID NEW START ----------------------- //////////////*/ 

.about-grid-2 {
	display: flex;
	text-align: center;
}

.right-column {
	display: flex;
    flex-direction: column;
    justify-content: space-between;
    flex-wrap: nowrap;
    align-items: center;
	margin-bottom: 0;
	padding-bottom: 0;
}
		
.picture-container {
	display: flex;
	width: 100%; 
	background: #FFFFFF;
	/*background-image: url(https://tiagosotenho.com/assets/images/tiago_sotenho_picture.jpg);
	background-repeat: no-repeat;
	background-position: 51% 20%;*/
	border: 3px #CC0000 solid;
}
		
.empty-container {
	display: flex;
	width: 100%; 
	background: #CC0000; 
	border: 3px #CC0000 solid;
	height: -webkit-fill-available !important;
}

@media (min-width: 320px) and (max-width: 734px) {
	
.left-column {
  width: 100%;
  
}

.right-column {
	width: 100%;
	row-gap: 16px;
}
  
.about-grid-2 {
	flex-direction: column-reverse;
	margin-left: 24px;
	margin-right: 24px;
	padding-top: 32px;
	padding-bottom: 40px;
	column-gap: 8px;
	row-gap: 16px;
}
	
.picture-container {
	height: 100%;
	border-radius: 16px;
}
	
.empty-container {
		display: none;
}
	
.picture-container {
	background-size: 125vw;
	height: 50vh;
    min-height: 300px;
}
  
}

@media (min-width: 735px) and (max-width: 1068px) {
	  
.about-grid-2 {
	margin-left: 32px;
	margin-right: 32px;
	padding-top: 40px;
	padding-bottom: 64px;
	column-gap: 16px;
	row-gap: 16px;
}
	
.left-column {
	width: 50%;
	}
	
.right-column {
	width: 50%;
	grid-row-gap: 24px;
	}
	
.empty-container {
	border-radius: 24px;
	align-self: stretch !important;
}
	
.picture-container {
	border-radius: 24px;
	height: -webkit-fill-available !important;
	max-height: 100%;
	background-size: cover;
	}
  
}

@media (min-width: 1069px) and (max-width: 3008px) {
  
.about-grid-2 {
	max-width: 1648px;
	margin-left: 40px;
	margin-right: 40px;
	padding-top: 48px;
	padding-bottom: 96px;
	column-gap: 24px;
	row-gap: 32px;
}
	
.left-column {
	width: 50%;
	}
	
.right-column {
	width: 50%;
	grid-row-gap: 32px;
	}
	
.empty-container {
	min-height: 20vh;
	border-radius: 32px;
	align-self: stretch !important;
}
	
.picture-container {
	border-radius: 32px;
	height: -webkit-fill-available !important;
	max-height: 100%;
	background-size: cover;
	}
  
}

/*///////////// ---------------------- ABOUT GRID NEW END ----------------------- //////////////*/ 

/* ------------------- INFO + CONTACTS START ------------------- */

.info-description {
	align-self: stretch;
	background: #F2F2F2; 
	border-bottom: 3px #CC0000 solid;
	display: flex;
    flex-direction: column;
    flex-wrap: nowrap;
    align-content: center;
    align-items: center;
    justify-content: center;
}

.dud {
  color: blue;
}

.random-text {
  color: green;
}

.about-grid {
	display: grid;
    height: auto;
    grid-template-rows: auto auto;
    width: -webkit-fill-available;
}

#time {
	display: flex;
	flex-direction: row;
    flex-wrap: wrap;
    align-content: center;
    justify-content: center;
    align-items: center;
	text-align: center;
}

#about {
	display: flex;
	flex-direction: column;
    flex-wrap: wrap;
    align-content: center;
    justify-content: center;
    align-items: center;
	text-align: center;
}

#pic {
	display: flex;
	width: 100%; 
	height: 100%; 
	background: #FFFFFF; 
	background-image: url(https://tiagosotenho.com/assets/images/tiago_headshot.jpg);
	background-repeat: no-repeat;
	background-position: 51% 20%;
	border: 3px #CC0000 solid;
}

#role {
	display: flex;
	flex-direction: row;
    flex-wrap: wrap;
    align-content: center;
    justify-content: center;
    align-items: center;
	text-align: center;
}

.reviews-grid-background {
	width: 100%;
	background-color: #FFFFFF !important;
}

.reviews-grid {
	display: grid;
    height: auto;
    grid-template-rows: auto auto;
    width: -webkit-fill-available;
	justify-content: center;
    align-items: start;
	max-width: 1648px;
	margin: 0 auto;
}

#header, #review-1, #review-2, #review-3, #review-4, #read-more {
	display: flex;
	flex-direction: column;
    flex-wrap: wrap;
    align-content: center;
    justify-content: center;
    align-items: center;
	text-align: center;
    transition: opacity 0.6s ease-out, transform 1s ease-out;
}

.more-module {
	width: -webkit-fill-available;
	height: 100%;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	display: inline-flex;
    transition: opacity 0.6s ease-out, transform 1s ease-out;
	}
	
#hero-more {
	align-self: stretch;
	text-align: center; 
	width: 100%; 
	}

.more-content {
    display: flex;
    flex-direction: row;
    flex-wrap: nowrap;
    justify-content: center;
    align-items: center;
	}
	
.row-more {
	align-self: stretch;
    text-align: center;
    display: flex;
    flex-wrap: wrap;
    flex-direction: row;
    justify-content: center;
    align-content: center;
    align-items: center;
	}

@media (min-width: 320px) and (max-width: 734px) {

	.info-description {
		padding-top: 32px;
		padding-bottom: 32px;
		row-gap: 16px;
		line-height: 23px;
	}	
	
.about-grid {
    grid-template-rows: 1fr 1fr 1fr 1fr;
    grid-template-columns: 1fr 1fr 1fr 1fr 1fr 1fr 1fr 1fr;
	margin-left: 24px;
	margin-right: 24px;
	padding-top: 32px;
	padding-bottom: 40px;
	column-gap: 8px;
	row-gap: 16px;
	grid-template-rows: auto auto;
}

#time {
	grid-row-start: 4;
	grid-column-start: 1;
	grid-row-end: 5;
	grid-column-end: 9;
}

#about {
	grid-row-start: 2;
	grid-column-start: 1;
	grid-row-end: 3;
	grid-column-end: 9;
}

#pic {
	grid-row-start: 3;
	grid-column-start: 1;
	grid-row-end: 4;
	grid-column-end: 9;
	border-radius: 16px;
	background-size: calc( 65vw * 2);
	height: 80vw !important;
}
	
#role {
	grid-row-start: 1;
	grid-column-start: 1;
	grid-row-end: 2;
	grid-column-end: 9;
}
	
.reviews-grid {
    grid-template-rows: 1fr 1fr 1fr 1fr 1fr 1fr 1fr 1fr;
    grid-template-columns: 1fr 1fr 1fr 1fr 1fr 1fr 1fr 1fr;
	padding-left: 24px;
	padding-right: 24px;
	padding-top: 40px;
	padding-bottom: 40px;
	column-gap: 8px;
	row-gap: 24px;
	grid-template-columns: auto;
    grid-template-rows: auto;
	}

#header {
	grid-row-start: 1;
	grid-column-start: 1;
	grid-row-end: 2;
	grid-column-end: 9;
	font-size: 30px;
	font-weight: 900;
	letter-spacing: -1px;
	text-transform: uppercase;
	word-wrap: break-word;
	margin-bottom: 0;
    padding-bottom: 18px;
	}
	
#review-1 {
	grid-row-start: 2;
	grid-column-start: 1;
	grid-row-end: 3;
	grid-column-end: 9;
	row-gap: 16px;
	}
	
#review-2 {
	grid-row-start: 3;
	grid-column-start: 1;
	grid-row-end: 4;
	grid-column-end: 9;
	row-gap: 16px;
	}
	
#review-3 {
	grid-row-start: 4;
	grid-column-start: 1;
	grid-row-end: 5;
	grid-column-end: 9;
	row-gap: 16px;
	}
	
#review-4 {
	grid-row-start: 5;
	grid-column-start: 1;
	grid-row-end: 6;
	grid-column-end: 9;
	row-gap: 16px;
	}
	
#read-more {
	grid-row-start: 6;
	grid-column-start: 1;
	grid-row-end: 7;
	grid-column-end: 9;
	}
	
.more-module {
	margin: 0 24px 0 24px;
	gap: 24px;
	padding: 40px 0 40px 0;
	}
	
#hero-more {
	margin-bottom: 0;
    padding-bottom: 8px;
	}

.more-content {
	gap: 16px;
	flex-direction: column !important;
	}
	
.row-more {
	gap: 8px;
	flex-direction: column !important;
	}
	
}

@media (min-width: 735px) and (max-width: 1068px) {
	
	.info-description {
		padding-top: 40px;
		padding-bottom: 40px;
		row-gap: 24px;
		line-height: 25px;
	}
	
.about-grid {
    grid-template-rows: 3fr;
    grid-template-columns: 1fr 1fr 1fr 1fr 1fr 1fr 1fr 1fr 1fr 1fr 1fr 1fr;
	margin-left: 32px;
	margin-right: 32px;
	padding-top: 40px;
	padding-bottom: 64px;
	column-gap: 16px;
	row-gap: 16px;
	grid-template-rows: auto auto;
}
	
#time {
	grid-row-start: 4;
	grid-column-start: 8;
	grid-row-end: 5;
	grid-column-end: 13;
}

#about {
	grid-row-start: 1;
	grid-column-start: 1;
	grid-row-end: 5;
	grid-column-end: 8;
}

#pic {
	grid-row-start: 2;
	grid-column-start: 8;
	grid-row-end: 4;
	grid-column-end: 13;
	border-radius: 32px; 
	background-size: calc( 60vw * 2);
}
	
#role {
	grid-row-start: 1;
	grid-column-start: 8;
	grid-row-end: 2;
	grid-column-end: 13;
}
	
.reviews-grid {
    grid-template-rows: 3fr;
    grid-template-columns: 1fr 1fr 1fr 1fr 1fr 1fr 1fr 1fr 1fr 1fr 1fr 1fr;
	padding-left: 32px;
	padding-right: 32px;
	padding-top: 64px;
	padding-bottom: 64px;
	column-gap: 16px;
	row-gap: 32px;
	}
	
#header {
	grid-row-start: 1;
	grid-column-start: 1;
	grid-row-end: 2;
	grid-column-end: 13;
	font-size: 40px;
	font-weight: 900;
	letter-spacing: -2px;
	text-transform: uppercase;
	word-wrap: break-word;
	margin-bottom: 0;
    padding-bottom: 16px;
	}
	
#review-1 {
	grid-row-start: 2;
	grid-column-start: 1;
	grid-row-end: 3;
	grid-column-end: 7;
	row-gap: 24px;
	}
	
#review-2 {
	grid-row-start: 2;
	grid-column-start: 7;
	grid-row-end: 3;
	grid-column-end: 13;
	row-gap: 24px;
	}
	
#review-3 {
	grid-row-start: 3;
	grid-column-start: 1;
	grid-row-end: 4;
	grid-column-end: 7;
	row-gap: 24px;
	}
	
#review-4 {
	grid-row-start: 3;
	grid-column-start: 7;
	grid-row-end: 4;
	grid-column-end: 13;
	row-gap: 24px;
	}
	
#read-more {
	grid-row-start: 4;
	grid-column-start: 1;
	grid-row-end: 5;
	grid-column-end: 13;
	row-gap: 24px;
	}
	
.more-module {
	margin: 0 32px 0 32px;
	gap: 40px;
	padding: 64px 0 64px 0;
	max-width: 778px;
	}
	
#hero-more {
	margin-bottom: 0;
    padding-bottom: 16px;
	}

.more-content {
	gap: 24px;
	}
	
.row-more {
	gap: 16px;
	}
	
}

@media (min-width: 1069px) and (max-width: 3008px) {
	
	.info-description {
		padding-top: 48px;
		padding-bottom: 48px;
		row-gap: 32px;
		line-height: 29px;
	}
	
.about-grid {
    grid-template-rows: 1fr 1fr 1fr 1fr;
    grid-template-columns: 1fr 1fr 1fr 1fr 1fr 1fr 1fr 1fr 1fr 1fr 1fr 1fr;
	max-width: 1648px;
	margin-left: 40px;
	margin-right: 40px;
	padding-top: 48px;
	padding-bottom: 96px;
	column-gap: 24px;
	row-gap: 32px;
	grid-template-rows: auto auto;
    align-items: center;
}
	
#time {
	grid-row-start: 4;
	grid-column-start: 8;
	grid-row-end: 5;
	grid-column-end: 13;
}

#about {
	grid-row-start: 1;
	grid-column-start: 1;
	grid-row-end: 5;
	grid-column-end: 8;
}

#pic {
	grid-row-start: 2;
	grid-column-start: 8;
	grid-row-end: 4;
	grid-column-end: 13;
	border-radius: 32px; 
	background-size: calc( 50vh * 2);
	max-height: 150vh;
}
	
#role {
	grid-row-start: 1;
	grid-column-start: 8;
	grid-row-end: 2;
	grid-column-end: 13;
}
	
.reviews-grid {
    grid-template-rows: 3fr;
    grid-template-columns: 1fr 1fr 1fr 1fr 1fr 1fr 1fr 1fr 1fr 1fr 1fr 1fr;
	max-width: 1648px;
	padding-left: 40px;
	padding-right: 40px;
	padding-bottom: 96px;
	padding-top: 96px;
	column-gap: 24px;
	row-gap: 48px;
	}
	
#header {
	grid-row-start: 1;
	grid-column-start: 1;
	grid-row-end: 2;
	grid-column-end: 13;
	font-size: 56px;
	font-weight: 900;
	letter-spacing: -3px;
	text-transform: uppercase;
	word-wrap: break-word;
	margin-bottom: calc(-28px + 16px);
    padding-bottom: 16px;
	}
	
#review-1 {
	grid-row-start: 2;
	grid-column-start: 1;
	grid-row-end: 3;
	grid-column-end: 7;
	row-gap: 32px;
	}
	
#review-2 {
	grid-row-start: 2;
	grid-column-start: 7;
	grid-row-end: 3;
	grid-column-end: 13;
	row-gap: 32px;
	}
	
#review-3 {
	grid-row-start: 3;
	grid-column-start: 1;
	grid-row-end: 4;
	grid-column-end: 7;
	row-gap: 32px;
	}
	
#review-4 {
	grid-row-start: 3;
	grid-column-start: 7;
	grid-row-end: 4;
	grid-column-end: 13;
	row-gap: 32px;
	}
	
#read-more {
	grid-row-start: 4;
	grid-column-start: 1;
	grid-row-end: 5;
	grid-column-end: 13;
	row-gap: 32px;
	}
	
.more-module {
	margin: 0 40px 0 40px;
	max-width: 1540px;
	gap: 48px;
	padding: 96px 0 96px 0;
	}
	
#hero-more {
	margin-bottom: calc(-28px + 16px);
    padding-bottom: 16px;
	}

.more-content {
	gap: 24px;
	}
	
.row-more {
	gap: 24px;
	}
	
}

/* ------------------- INFO + CONTACTS END ------------------- */


/* ------------------ PROJECT PAGE START ------------------------ */

.project-name, .project-name-2 {
	align-self: stretch;
	display: flex;
    flex-direction: column;
    flex-wrap: nowrap;
    align-content: center;
    align-items: center;
    justify-content: center;
	border-bottom: 3px #CC0000 solid;
}

.about-project-grid {
	display: grid;
    height: auto;
    width: -webkit-fill-available;
}

#about-project-title {
	text-align: center;
}

#about-project-description {
	text-align: center;
}

.project-module-full, .project-module-full-bottom, .project-module-full-bottom-2, .project-module-full-middle {
	align-self: center;
	display: flex;
    flex-direction: column;
    flex-wrap: nowrap;
    align-content: center;
    align-items: center;
    justify-content: center;
	/*background-color: #FFFFFF;*/
}

.project-module-2up {
    display: flex;
    flex-direction: row;
    align-items: center;
    justify-content: center;
    gap: 24px;
	width: -webkit-fill-available;
	width: 100vw; 
	max-width: 1648px;
}

.container-project-module-2up, .container-project-module-2up-bottom, .container-project-module-2up-middle, .container-project-module-2up-middle-2 {
	display: flex; 
	align-self: center; 
	flex-direction: row; 
	flex-wrap: nowrap; 
	justify-content: center; 
	align-items: center;
}

.project-module-4up {
    display: flex;
    flex-direction: row;
    align-items: center;
    justify-content: center;
    /*gap: 24px;*/
	width: -webkit-fill-available;
	width: 100vw; 
	max-width: 1648px;
}

.container-project-module-4up {
	display: flex; 
	align-self: center; 
	flex-direction: row; 
	flex-wrap: nowrap; 
	justify-content: center; 
	align-items: center;
}


.project-module-text, .project-module-text-middle {
	align-self: center;
	display: flex;
    flex-direction: column;
    flex-wrap: nowrap;
    align-content: center;
    align-items: center;
    justify-content: center;
	width: -webkit-fill-available;
	/*max-width: 1648px;*/
}

.project-module-text-description {
	text-align: center;
	max-width: 1648px;
    transition: opacity 0.6s ease-out, transform 1s ease-out;
	}

.module-text-image-grid {
	display: grid;
    height: auto;
    width: -webkit-fill-available;
}

.module-text-image-title {
	text-align: center;
	/*transform: translateY(0);*/
    transition: opacity 0.6s ease-out, transform 1s ease-out;
}

.module-text-image-description, .module-text-image-description-2 {
	text-align: center;
    transition: opacity 0.6s ease-out, transform 1s ease-out;
}

.module-text-image-bg {	
	display: flex; 
	align-self: center; 
	flex-direction: row; 
	flex-wrap: nowrap; 
	justify-content: center; 
	align-items: center;
}

.project-navigation-grid {
	display: grid;
    height: auto;
    width: -webkit-fill-available;
}
	
#center-navigation-grid {
	display: flex;
    justify-content: center;
	align-items: center;
	}

#left-navigation-grid {
	display: flex;
    justify-content: flex-start;
	align-items: center;
	}

#right-navigation-grid {
	display: flex;
    justify-content: flex-end;
	align-items: center;
	}

/* Container for the link */
        .truncated-link {
            display: flex;
            align-items: center;
            width: 100%; /* Ensure it takes full width of the parent */
            overflow: hidden; /* Ensure overflow is hidden */
        }

        /* Text container to be truncated */
        .truncated-link .text {
            white-space: nowrap; /* Prevent text from wrapping */
            overflow: hidden; /* Hide overflow text */
            text-overflow: ellipsis; /* Show ellipsis when text is truncated */
            flex: 1; /* Allow it to grow and fill available space */
        }

        /* Arrow container to remain visible */
        .truncated-link .arrow {
            flex-shrink: 0; /* Prevent it from shrinking */
        }

        /* Specific styles for left and right arrows */
        .left-arrow .arrow {
            margin-right: 8px; /* Add some space between arrow and text */
        }

        .right-arrow .arrow {
            margin-left: 8px; /* Add some space between text and arrow */
        }


@media (min-width: 320px) and (max-width: 734px) {

.project-name, .project-name-2 {
	padding-top: 32px;
	padding-bottom: 32px;
	row-gap: 16px;
	}
	
.about-project-grid {
    grid-template-rows: 1fr 1fr 1fr 1fr;
    grid-template-columns: 1fr 1fr 1fr 1fr 1fr 1fr 1fr 1fr;
	margin-left: 24px;
	margin-right: 24px;
	padding-top: 32px;
	padding-bottom: 40px;
	column-gap: 8px;
	row-gap: 24px;
    grid-template-rows: auto auto;
}
	
#about-project-title {
	grid-row-start: 3;
	grid-column-start: 1;
	grid-row-end: 4;
	grid-column-end: 9;
	display: flex;
    flex-direction: column;
	justify-content: center;
	}
	
#about-project-description {
	grid-row-start: 4;
	grid-column-start: 1;
	grid-row-end: 5;
	grid-column-end: 9;
	display: flex;
    flex-direction: column;
	justify-content: center;
	}
	
.project-module-full {
	padding-top: 40px;
}
	
.project-module-full-bottom {
	padding-bottom: 40px;
	}

	.project-module-full-bottom-2 {
		padding: 24px 0 40px 0;
		}
	
.project-module-full-middle {
	padding: 40px 0 40px 0;
	}

.project-module-full-middle-2 {
	padding: 24px 0 24px 0;
	}
	
.project-module-2up {
    flex-wrap: wrap;
	gap: 24px;
	margin: 0 24px 0 24px;
}
	
.container-project-module-2up {
	padding-top: 40px;
}
	
.container-project-module-2up-bottom {
	padding-bottom: 40px;
}

.container-project-module-2up-middle {
	padding-bottom: 0px;
}

.container-project-module-2up-middle-2 {
	padding: 24px 0 0 0;
}
	
.project-module-4up {
    flex-wrap: wrap;
	gap: 24px;
	margin: 0 24px 0 24px;
}
	
.container-project-module-4up {
	padding-top: 40px;
}
	
.project-module-text {
	gap: 24px;
	padding-top: 40px;
	}
	
.project-module-text-middle {
	gap: 24px;
	padding-bottom: 40px ;
	}
	
.project-module-text-description, .project-module-text-title {
	margin: 0 24px 0 24px;
	}

.module-text-image-grid {
    grid-template-rows: 1fr 1fr 1fr 1fr;
    grid-template-columns: 1fr 1fr 1fr 1fr 1fr 1fr 1fr 1fr;
	margin-left: 24px;
	margin-right: 24px;
	padding-top: 32px;
	column-gap: 8px;
	row-gap: 24px;
    grid-template-rows: auto auto;
}

.module-text-image-title {
	grid-row-start: 3;
	grid-column-start: 1;
	grid-row-end: 4;
	grid-column-end: 9;
	display: flex;
    flex-direction: column;
	justify-content: center;
	}
	
.module-text-image-description, .module-text-image-description-2 {
	grid-row-start: 4;
	grid-column-start: 1;
	grid-row-end: 5;
	grid-column-end: 9;
	display: flex;
    flex-direction: column;
	justify-content: center;
	}
	
.module-text-image-bg {
	padding-bottom: 40px;
	}
	
.project-navigation-grid {
    grid-template-rows: 1fr;
    grid-template-columns: 1fr 1fr 1fr 1fr 1fr 1fr 1fr 1fr 1fr 1fr 1fr 1fr;
	margin: 0 24px 32px 24px;
	padding-top: 40px;
	column-gap: 8px;
    grid-template-rows: auto auto;
}
	
#left-navigation-grid {
	grid-row-start: 1;
	grid-column-start: 1;
	grid-row-end: 1;
	grid-column-end: 5;
	}
	
#center-navigation-grid {
	grid-row-start: 1;
	grid-column-start: 5;
	grid-row-end: 1;
	grid-column-end: 9;
	}
	
#right-navigation-grid {
	grid-row-start: 1;
	grid-column-start: 9;
	grid-row-end: 1;
	grid-column-end: 13;
	}
	
}

@media (min-width: 735px) and (max-width: 1068px) {
	
.project-name, .project-name-2 {
	padding-top: 32px;
	padding-bottom: 40px;
	row-gap: 24px;
	/*line-height: 25px;*/
	}
	
.about-project-grid {
    grid-template-rows: 1fr 1fr 1fr;
    grid-template-columns: 1fr 1fr 1fr 1fr 1fr 1fr 1fr 1fr 1fr 1fr 1fr 1fr;
	margin-left: 32px;
	margin-right: 32px;
	padding-top: 48px;
	padding-bottom: 64px;
	column-gap: 16px;
	row-gap: 24px;
    grid-template-rows: auto auto;
}
	
#about-project-title {
	grid-row-start: 1;
	grid-column-start: 7;
	grid-row-end: 2;
	grid-column-end: 13;
	display: flex;
    flex-direction: column;
	justify-content: center;
	}
	
#about-project-description {
	grid-row-start: 2;
	grid-column-start: 7;
	grid-row-end: 3;
	grid-column-end: 13;
	display: flex;
    flex-direction: column;
	justify-content: center;
	}
	
.project-module-full {
	padding-top: 64px;
}
	
.project-module-full-bottom {
	padding-bottom: 64px;
	}

.project-module-full-bottom-2 {
	padding: 32px 0 64px 0;
	}
	
.project-module-full-middle {
	padding: 64px 0 64px 0;
	}

.project-module-full-middle-2 {
	padding: 16px 0 16px 0;
	}
	
.project-module-2up {
    flex-wrap: nowrap;
	gap: 16px;
	margin: 0 32px 0 32px;
}
	
.container-project-module-2up {
	padding-top: 64px;
}
	
.container-project-module-2up-bottom {
	padding-bottom: 64px;
}

.container-project-module-2up-middle {
	padding-bottom: 0px;
}

.container-project-module-2up-middle-2 {
	padding: 16px 0 0 0;
}
	
.project-module-4up {
    flex-wrap: nowrap;
	gap: 16px;
	margin: 0 32px 0 32px;
}
	
.container-project-module-4up {
	padding-top: 64px;
}
	
.project-module-text {
	gap: 40px;
	padding-top: 64px;
	}
	
.project-module-text-middle {
	gap: 40px;
	padding-bottom: 64px ;
	}
	
.project-module-text-description, .project-module-text-title {
	margin: 0 32px 0 32px;
	}

.module-text-image-grid {
    grid-template-rows: 1fr 1fr 1fr;
    grid-template-columns: 1fr 1fr 1fr 1fr 1fr 1fr 1fr 1fr 1fr 1fr 1fr 1fr;
	margin-left: 32px;
	margin-right: 32px;
	padding-top: 64px;
	column-gap: 16px;
	row-gap: 24px;
    grid-template-rows: auto auto;
}

.module-text-image-title {
	grid-row-start: 1;
	grid-column-start: 7;
	grid-row-end: 2;
	grid-column-end: 13;
	display: flex;
    flex-direction: column;
	justify-content: center;
	}
	
.module-text-image-description {
	grid-row-start: 2;
	grid-column-start: 7;
	grid-row-end: 3;
	grid-column-end: 13;
	display: flex;
    flex-direction: column;
	justify-content: center;
	}

.module-text-image-description-2 {
	grid-row-start: 1;
	grid-column-start: 7;
	grid-row-end: 3;
	grid-column-end: 13;
	display: flex;
    flex-direction: column;
	justify-content: center;
	}
	
.module-text-image-bg {
	padding-bottom: 64px;
	}
	
.project-navigation-grid {
    grid-template-rows: 1fr;
    grid-template-columns: 1fr 1fr 1fr 1fr 1fr 1fr 1fr 1fr 1fr 1fr 1fr 1fr;
	margin: 0 32px 48px 32px;
	padding-top: 64px;
	column-gap: 16px;
    grid-template-rows: auto auto;
}
	
#left-navigation-grid {
	grid-row-start: 1;
	grid-column-start: 1;
	grid-row-end: 1;
	grid-column-end: 5;
	}
	
#center-navigation-grid {
	grid-row-start: 1;
	grid-column-start: 5;
	grid-row-end: 1;
	grid-column-end: 9;
	}
	
#right-navigation-grid {
	grid-row-start: 1;
	grid-column-start: 9;
	grid-row-end: 1;
	grid-column-end: 13;
	}
	
}

@media (min-width: 1069px) and (max-width: 3008px) {
	
.project-name {
	padding-top: 48px;
	padding-bottom: 48px;
	row-gap: 32px;
	line-height: 29px;
	}

.project-name-2 {
	padding-top: 48px;
	padding-bottom: 48px;
	row-gap: 32px;
	line-height: normal !important;
	}
	
.about-project-grid {
    grid-template-rows: 1fr 1fr 1fr;
    grid-template-columns: 1fr 1fr 1fr 1fr 1fr 1fr 1fr 1fr 1fr 1fr 1fr 1fr;
	max-width: 1648px;
	margin-left: 40px;
	margin-right: 40px;
	padding-top: 48px;
	padding-bottom: 96px;
	column-gap: 24px;
	row-gap: 32px;
    grid-template-rows: auto auto;
}
	
#about-project-title {
	grid-row-start: 1;
	grid-column-start: 7;
	grid-row-end: 2;
	grid-column-end: 13;
	display: flex;
    flex-direction: column;
	justify-content: center;
	}
	
#about-project-description {
	grid-row-start: 2;
	grid-column-start: 7;
	grid-row-end: 3;
	grid-column-end: 13;
	display: flex;
    flex-direction: column;
	justify-content: center;
	}
	
.project-module-full {
	padding-top: 96px;
}
	
.project-module-full-bottom {
	padding-bottom: 96px;
	}

	.project-module-full-bottom-2 {
		padding: 40px 0 96px 0;
		}
	
.project-module-full-middle {
	padding: 96px 0 96px 0;
	}

.project-module-full-middle-2 {
	padding: 24px 0 24px 0;
	}
	
.project-module-2up {
    flex-wrap: nowrap;
	gap: 24px;
	margin: 0 40px 0 40px;
}
	
.container-project-module-2up {
	padding-top: 96px;
}

.container-project-module-2up {
	padding-top: 96px;
}
	
.container-project-module-2up-bottom {
	padding-bottom: 96px;
}

.container-project-module-2up-middle {
	padding-bottom: 0px;
}

.container-project-module-2up-middle-2 {
	padding: 24px 0 0 0;
}
	
.project-module-text {
	gap: 48px;
	padding-top: 96px;
	}
	
.project-module-text-middle {
	gap: 48px;
	padding-bottom: 96px ;
	}
	
.project-module-text-description, .project-module-text-title {
	margin: 0 40px 0 40px;
	}

.module-text-image-grid {
    grid-template-rows: 1fr 1fr 1fr;
    grid-template-columns: 1fr 1fr 1fr 1fr 1fr 1fr 1fr 1fr 1fr 1fr 1fr 1fr;
	max-width: 1648px;
	margin-left: 40px;
	margin-right: 40px;
	padding-top: 96px;
	column-gap: 24px;
	row-gap: 32px;
    grid-template-rows: auto auto;
}

.module-text-image-title {
	grid-row-start: 1;
	grid-column-start: 7;
	grid-row-end: 2;
	grid-column-end: 13;
	display: flex;
    flex-direction: column;
	justify-content: center;
	}
	
.module-text-image-description {
	grid-row-start: 2;
	grid-column-start: 7;
	grid-row-end: 3;
	grid-column-end: 13;
	display: flex;
    flex-direction: column;
	justify-content: center;
	}

.module-text-image-description-2 {
	grid-row-start: 1;
	grid-column-start: 7;
	grid-row-end: 3;
	grid-column-end: 13;
	display: flex;
    flex-direction: column;
	justify-content: center;
	}
	
.module-text-image-bg {
	padding-bottom: 96px;
	}
	
.project-navigation-grid {
    grid-template-rows: 1fr;
    grid-template-columns: 1fr 1fr 1fr 1fr 1fr 1fr 1fr 1fr 1fr 1fr 1fr 1fr;
	max-width: 1648px;
	margin: 0 40px 48px 40px;
	padding-top: 96px;
	column-gap: 24px;
    grid-template-rows: auto auto;
}
	
#left-navigation-grid {
	grid-row-start: 1;
	grid-column-start: 1;
	grid-row-end: 1;
	grid-column-end: 5;
	}
	
#center-navigation-grid {
	grid-row-start: 1;
	grid-column-start: 5;
	grid-row-end: 1;
	grid-column-end: 9;
	}
	
#right-navigation-grid {
	grid-row-start: 1;
	grid-column-start: 9;
	grid-row-end: 1;
	grid-column-end: 13;
	}
	
}

/* ------------------ PROJECT PAGE END ------------------------ */

