body {
	margin: 0;
	padding: 0;
	overflow-x: hidden;
	font-family: 'EB Garamond', serif;
	font-weight: 500;
	font-size: 16px;
	background: #f2f2f2;
	color: #232323;
	-webkit-tap-highlight-color: rgba(0, 0, 0, 0);
}
body.menu-open {
	overflow: hidden;
}
.smooth-wrapper {
	position: fixed;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	overflow: hidden;
}
.smooth-content {
	will-change: transform;
	transform: translate3d(0,0,0) scale(1.0001); /*TRICK TO AVOID JITTER*/
}
*:focus {
	outline: none;
}
.nowrap {
	flex-wrap: nowrap;
}
.padding-0 {
	padding: 0;
}
.padding-10 {
	padding: 10px;
}
.padding-20 {
	padding: 20px;
}
.margin-top-5 {
	margin-top: 5px;
}
.margin-top-10 {
	margin-top: 10px;
}
.margin-top-200 {
	margin-top: 200px;
}
.margin-bottom-10 {
	margin-bottom: 10px;
}
.gap-5 {
	gap: 5px;
}
.gap-10 {
	gap: 10px;
}
.gap-20 {
	gap: 20px;
}
.height-100 {
	height: 100%;
}
.width-100 {
	width: 100% !important;
}
.color-gray {
	color: gray;
}
.relative {
	position: relative;
}
.debug {
	border: 1px red solid;
}
.flex{
	display: flex;
}
.align-center {
	align-items: center;
}
.space-between {
	justify-content: space-between;
}
.wrap {
	flex-wrap: wrap;
}
.text-tiny {
	font-size: .7em;
}
.text-small {
	font-size: .8em;
}
.text-big {
	font-size: 1.4em;
}
.opacity-40 {
	opacity: .4;
}
nav {
	position: fixed;
	top: 0;
	display: inline-flex;
	align-items: center;
	justify-content: space-between;
	height: 60px;
	width: 100vw;
	/*background: #fff;*/
	z-index: 3;
	transition: background .2s;
	font-family: 'League Spartan', sans-serif;
}
nav a {
	height: 100%;
}
nav > a {
	display: flex;
	justify-content: center;
	align-items: center;
	font-size: 1.2em;
	width: 120px;
	height: 100%;
	gap: 10px;
	color: white;
}
nav .logo-stable {
	display: none;
}
nav.inverted {
	background: white;
}
nav.inverted .logo-stable {
	display: block;
}
nav.inverted .logo-stable-white {
	display: none;
}
nav.inverted .flip-mask {
	color: #232323;
}
nav.inverted .default-text {
	text-shadow: 0px 1.1em 0px #232323;
}
.mobile-nav {
	position: absolute;
	z-index: 2;
	display: none;
	width: 60px;
}
.mobile-nav img {
	height: 25px;
}
.mobile-menu {
	position: absolute;
	top: 0;
	left: 0;
	width: 100dvw;
	height: 100dvh;
	background:  #1b1c1b;
	clip-path: polygon(0% 0%, 100% 0%, 100% 0%, 0% 0%);
	transition: clip-path 0.6s cubic-bezier(0.77, 0, 0.175, 1);
	color: #f2f2f2;
	display: flex;
	flex-direction: column;
	justify-content: space-between;
	padding: 40px;
	box-sizing: border-box;
}
.mobile-menu-pages {
	display: flex;
	flex-direction: column;
	gap: 20px;
	line-height: 1;
	font-size: 2.5em;
}
.mobile-menu-pages div {
	color: #f2f2f2;
}
.mobile-menu img {
	height: 20px;
}
.mobile-menu.visible {
	clip-path: polygon(0% 0%, 100% 0%, 100% 100%, 0% 100%);
}
.mobile-menu-pages .disclaimer {
	font-size: .7rem;
	color: #7d7d7d;
	margin-top: 5px;
}
a {
	text-decoration: none;
	color: #232323;
}
.logo img {
	height: 60%;
}
.logo div {
	font-size: 2em;
	font-family: 'EB Garamond', serif;;
	font-weight: 600;
}
section {
	margin-bottom: 200px;
}
footer {
	position: relative;
	left: -20px;
	bottom: -20px;
	display: flex;
	justify-content: space-between;
	align-items: center;
	width: 100vw;
	height: 60px;
	background: #232323;
	color: #f2f2f2;
	padding: 0 20px;
	box-sizing: border-box;
	font-family: 'League Spartan', sans-serif;
	font-weight: 300;
}
.email {
	display: flex;
	gap: 20px;
}
.email a img {
	height: 15px;
}
.hero {
	position: relative;
	width: 100vw;
	left: -20px;
	background: #1b1c1b;
	padding-top: 30%;
}
.hero-logo {
	position: absolute;
	top: 26%;
	left: 50%;
	transform: translate(-50%, -50%);
	z-index: 2;
	width: 30%;
	max-width: 550px;
}
.hero-bg {
	position: relative;
	object-fit: cover;
	width: 100%;
	margin-bottom: -6px;
}
.hero-video {
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	z-index: 2;
	text-align: center;
	width: 100%;
}
.project-hero {
	position: relative;
	top: 0px;
	left: -20px;
	width: 100vw;
	height: 100vh;
	color: white;
/*	padding: 40px;
	box-sizing: border-box;*/
}
.project-hero .type {
	color: white;
}
.project-hero-image {
	position: absolute;
	top: 0;
	left: 0;
	z-index: 0;
	height: 100%;
	width: 100%;
	object-fit: cover;
	filter: brightness(.4);
}
.dictionary {
	display: flex;
	flex-direction: column;
	justify-content: center;
	/*height: calc(100vh - 60px);*/
	top: 50%;
	transform: translate(0, -50%);
	width: 100%;
	padding: 0 100px;
	position: absolute;
	/*top: 35%;*/
	box-sizing: border-box;
	z-index: 1;
}
.dictionary-stable {
	height: 100vh;
	display: flex;
	align-items: center;
}
.dictionary-stable > div {
	padding-left: 100px;
}
.type {
	color: gray;
	font-size: 1.3em;
	font-family: 'League Spartan', sans-serif;
	margin-bottom: 10px;
}
.title {
	font-size: 5em;
	width: 100%;
	font-weight: 800;
	line-height: normal;
}
.title.centered {
	text-align: center;
}
.definition {
	font-size: 1.5em;
	margin-top: 20px;
	max-width: 1050px;
}
.definition a {
	text-decoration: underline;
	color: white;
}
.synonyms {
	display: flex;
	font-size: 2em;
	font-family: 'League Spartan', sans-serif;
	color: #bdbdbd;
	margin-top: 50px;
	line-height: 2.5em;
}
.italic {
	font-style: italic;
}
.synonyms span {
	margin-left: 100px;
	max-width: 600px;
}
.synonyms span a {
	text-decoration: underline;
	color: #a2c4d2;
}
.dark {
	position: relative;
	left: -20px;
	background: #232323;
	padding: 200px 20px;
	box-sizing: border-box;
	color: #f2f2f2;
	margin-bottom: 0;
}
.dark .feature, .dark a {
	color: #f2f2f2;
}
.dictionary.darkmode .title, .dictionary.darkmode .definition {
	color: #f2f2f2;
}
.dictionary.darkmode .synonyms {
	color: gray;
}
.slider_container {
	position: relative;
	left: -20px; 
	width: 100vw;
	height: 80vh;
	overflow: hidden;
	margin-bottom: 100px;
}
.slider {
	position: absolute;
	top: 50%;
	left: 0;
	height: 500px;
	width: max-content;
	display: grid;
	grid-template-columns: repeat(10, 1fr);
	gap: 20px;
	pointer-events: none;
	transform: translate(0, -50%);
}
.slider div {
	height: 100%;
	width: 500px;
}
.slider div img {
	display: flex;
	width: 100%;
	height: 100%;
	object-fit: cover;
	aspect-ratio: 1;
}
.slider_icon {
	position: absolute;
	bottom: 0;
	left: 50%;
	width: 50px;
	height: 50px;
	font-size: 2em;
	text-align: center;
	z-index: 2;
	transform: translate(-50%, 0);
}
.content {
	margin: 0;
	padding: 20px;
	padding-top: 0;
/*	padding-top: 60px;
*/	box-sizing: border-box;
	min-height: 100vh;
}
.content_email_sent {
	height: 100vh;
}
.content_email_sent .dictionary {
	height: 100vh;
}
.row {
	display: flex;
	align-items: flex-start;
	flex-wrap: wrap;
	width: 100%;
	gap: 20px;
	margin: 20px auto;
}
.row > .feature_description {
	margin-top: -10px;
}
.mosaic {
	display: flex;
	flex-wrap: wrap;
	width: 100%;
	margin: 20px auto;
	gap: 20px;
}
.mosaic.nowrap {
	flex-wrap: nowrap;
}
.mosaic .tile {
	flex: 1 1 calc(25% - 15px);
	box-sizing: border-box;
	aspect-ratio: 1/1;
	overflow: hidden;
	cursor: pointer;
}
.mosaic .tile.double-width {
	flex: 2 1 calc(50% - 10px);
	aspect-ratio: 2/1;
}
.tile > img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: center;
}
.devices-mockup {
	position: relative;
	max-height: 100vh;
}
.grid {
	display: flex;
	justify-content: space-evenly;
	align-items: flex-start;
	flex-wrap: wrap;
	gap: 20px;
	margin-top: 200px;
}
.grid > div {
	max-width: 35%;
	padding: 20px;
	box-sizing: border-box;
}
.grid img {
	width: 30px;
}
.grid .title {
	font-size: 2em;
	margin-top: 7px;
}
.grid .type {
	font-size: 1em;
}
.feature {
	display: flex;
	flex-direction: column;
	gap: 20px;
	width: calc(50% - 10px);
	margin-bottom: 100px;
}
.marginless {
	margin: 0 auto;
}
.marginless .feature {
	width: 100%;
}
.image {
	position: relative;
	display: flex;
	flex-direction: column;
	width: calc(50% - 10px);
	aspect-ratio: 1.2;
	overflow: hidden;
	cursor: pointer;
}
.watch-button {
	position: absolute;
	bottom: 0;
	left: 50%;
	width: 100%;
	transform: translate(-50%, 0);
	z-index: 1;
	cursor: pointer;
}
/*.image:hover, .tile:hover {
	cursor: zoom-in;
}*/
.image:hover > img, .tile:hover > img {
	transform: scale(1.01);
	transition: transform .2s ease;
}
.image.solo {
	width: 100%;
	aspect-ratio: 2.4;
}
.image.expanded {
	position: absolute;
	top: 0;
	left: 0;
	width: 100vw;
	height: 100vh;
	aspect-ratio: unset;
	z-index: 10;
	cursor: zoom-out;
}
.image img {
	height: 100%;
	object-fit: cover;
	transform: scale(1.0);
	transition: transform .2s ease;
}
.image span {
	font-family: 'League Spartan', sans-serif;
	margin-top: 10px;
}
.image .flip-click {
	margin-top: 10px;
}
.expanded img {
	object-fit: contain;
}
.section_title {
	font-family: 'League Spartan', sans-serif;
	margin-top: 400px;
}
.row_other_projects {
	gap: 10px;
}
.row_other_projects a {
	flex: 1;
}
.row_other_projects > a:last-child  {
	display: none;
}
.other_projects {
	flex: 1;
	aspect-ratio: 1;
	position: relative;
}
.other_projects img {
	height: 100%;
	width: 100%;
	object-fit: cover;
}
.other_projects > div {
	position: absolute;
	width: 100%;
	bottom: 0;
	padding-top: 10px;
	background: #f2f2f2;
	font-family: 'League Spartan', sans-serif;
}
.plans img {
	object-fit: contain;
}
.about, .contacts {
	width: 50%;
	height: calc(100vh - 60px);
	background: #232323;
	padding: 200px 50px;
	box-sizing: border-box;
}
.about div {
	color: white;
	font-size: 2em;
}
.row_contacts {
	display: flex;
}
.field {
	display: flex;
	flex-direction: column;
	align-items: flex-start;
	margin-bottom: 30px;
	color: white;
	font-family: 'League Spartan', sans-serif;
}
input, textarea {
	width: 400px;
	max-width: 100%;
	background: none;
	border: none;
	border-bottom: 3px #3e3e3e solid;
	padding: 10px 0;
	color: lightgray;
	border-radius: none;
}
input:focus, textarea:focus {
	color: white;
	border-bottom: 3px white solid;
	transition: .5s ease;
}
lable {
	color: white;
	font-family: 'League Spartan', sans-serif;
}
button {
	background: white;
	margin-top: 30px;
	padding: 10px 20px;
	color: #232323;
	border: none;
	cursor: pointer;
}
.socia_media {
	display: flex;
}
.icon {
	height: 25px;
	max-width: 40px;
	margin-right: 20px;
	margin-top: 30px;
}
.icon-tiny {
	height: 13px;
}
.feature_title {
	width: 100%;
	font-size: 3em;
	margin: 10px 0;
	font-family: "Overpass Mono", monospace;
	font-weight: bold;
}
.feature_images {
	display: flex;
	gap: 20px;
	width: 100%;
	height: 400px;
}
.feature_images div {
	display: flex;
	height: 100%;
	flex: 1;
	overflow: hidden;
}
.feature_images img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}
.feature_description {
	font-family: 'League Spartan', sans-serif;
	margin-top: 10px;
}
.feature_description a {
	margin-top: 20px;
}
.bim {
	position: relative;
	top: -20px;
	left: -20px;
	height: 100vh;
	width: 100vw;
	padding: 20px;
	box-sizing: border-box;
	background: #232323;
	color: #f2f2f2;
}
.logo_signature {
	position: relative;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	height: 50px;
}
.email a {
	color: white;
}
#panorama {
	width: 100%;
	height: 80vh;
	background: #000000;
	margin: 0 auto;
}
#imageviewer-wrapper {
	position: fixed;
	top: 0;
	left: 0;
	z-index: 99999;
	width: 100vw;
	height: 100vh;
	background-color: #232323;
	overflow: auto;
}
#imageviewer-image {
	cursor: zoom-out;
	height: 100%;
	width: 100%;
	object-fit: contain;
}
#imageviewer-close, #video-close {
	position: fixed;
	top: 20px;
	right: 20px;
	z-index: 100000;
	cursor: pointer;
	padding: 20px;
	background: white url('../images/icon_close.png') no-repeat center;
	background-size: 20px;
	border-radius: 50%;
}
#video-close {
	position: absolute;
}
.pnlm-load-button {
	top: 0 !important;
	left: 0 !important;
	width: 100% !important;
	height: 100% !important;
	margin: 0 !important;
	background-color: rgba(0,0,0,.6) !important;
	border-radius: 0 !important;
	font-size: 3em !important;
	color: #f2f2f2 !important;
	font-family: 'League Spartan', sans-serif !important;
}
.video {
	position: relative;
	width: 100%;
	aspect-ratio: 3.3;
}
.video-full-width {
	object-fit: cover;
	object-position: center;
}
.play-button {
	position: absolute;
	left: 50%;
	top: 50%;
	height: 100px;
	width: 100px;
	transform: translate(-50%, -50%);
	cursor: pointer;
	z-index: 10;
}
.planoalto-video-placeholder {
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: center;
	filter: brightness(.7);
}
.unmute-button {
	position: absolute;
	right: 50px;
	bottom: 50px;
	height: 60px;
	width: 60px;
	cursor: pointer;
	z-index: 10;
}
.featured-project {
	width: 100%;
}
.featured-projects {
	margin: 300px 0;
}
.full-width {
	width: 100vw;
}
.thousand {
	position: relative;
}
.thousand .title {
	position: absolute;
	top: 25%;
	left: 0;
	width: 100%;
	color: #f2f2f2;
	z-index: 2;
}
.thousand > img {
	width: 100%;
	height: 80vh;
	object-fit: cover;
	object-position: center 30%;
}
.button {
	background: #eabb13;
	color: #fff;
	padding: 15px 25px;
	font-family: 'League Spartan', sans-serif;
	text-align: center;
	font-weight: normal;
	font-size: 1em;
	line-height: normal;
	margin: 0 auto;
}
.button a {
	color: #fff;
}
.citadel {
	position: relative;
	left: -20px;
	width: 100vw;
	height: 80vh;
	background: #131313;
	overflow: hidden;
}
.citadel img,
.citadel .dim,
.citadel .blank {
	position: absolute;
	bottom: 0;
	left: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
} 
.citadel img.gsap-layer {
	opacity: 0;
}
.citadel .dim {
	height: 100%;
	/*opacity: 0;*/
	background: #000000a1;

}
.dim > div {
	position: absolute;
	top: 200px;
	left: 50%;
	transform: translate(-50%, 0%);
	color: #f2f2f2;
	white-space: nowrap;
	margin: 0;
	width: fit-content;
}
.dim .title {
	font-weight: 400;
}
.citadel .blank {
	height: 100%;
	opacity: 0;
	pointer-events: none;
}
#citadel-play {
	position: absolute;
	top: 40px;
	left: 50%;
	transform: translate(-50%, 0);
	background: #484848;
	padding: 10px 20px;
	border-radius: 30px;
	text-align: center;
	color: white;
	cursor: pointer;
	z-index: 1;
}
.flip-click{
	cursor: pointer;
	font-family: 'League Spartan', sans-serif;
}
.flip-mask {
	line-height: 1em;
	overflow: hidden;
}
.default-text {
	text-shadow: 0px 1.1em 0px #232323;
	transition: transform 0.545s cubic-bezier(0.16, 1, 0.3, 1);
}
.default-text.white-shadow {
	text-shadow: 0px 1.1em 0px white;
}
.flip-click:hover .default-text {
	transform: translateY(-1em);
}
.office {
	position: relative;
	left: -20px;
	padding: 200px 20px;
	box-sizing: border-box;
	margin-bottom: 0;
}
.office .video,
.office img {
	aspect-ratio: 1.7;
	max-height: 80vh;
}
.office img {
	width: 100%;
	object-fit: cover;
	object-position: center;
}
.office .hero-video {
	color: #fff;
	width: unset;
	white-space: nowrap;
}
.units {
	padding-top: 200px;
}
.units img {
	width: 100%;
	object-fit: cover;
}
.gallery {
	display: flex;
	gap: 20px;
	flex-wrap: wrap;
}
.gallery > a {
	width: calc(25% - 15px);
	margin-bottom: 30px;
	aspect-ratio: 1;
}
.gallery > a img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}
.pantone {
	font-family: 'League Spartan', sans-serif;
	font-size:1em;
}
.video.citadel_cinematic {
	background-image: url('../images/citadel_02.webp');
	background-size: cover;
	background-position: bottom;
}
.citadel_cinematic > img,
.citadel_cinematic > video {
	width: 100%;
}
.buttons-row {
	display: flex;
	gap: 20px;
}
.buttons-row a,
.buttons-row > div {
	flex: 1;
	cursor: pointer;
}
#video-overlay {
	position: fixed;
	left: 0;
	width: 100vw;
	height: 100vh;
	background-color: #000;
	z-index: 1000;
}
#video-container {
	position: absolute;
	top: 50%;
	left: 50%;
	width: 90vw;
	max-width: 1200px;
	max-height: 100vh;
	aspect-ratio: 16/9;
	box-sizing: border-box;
	transform: translate(-50%, -50%);
}
#close-video {
	position: absolute;
	top: 20px;
	right: 20px;
}
.no-scroll {
	overflow: hidden;
}
.youtube-bypass {
	display: none;
}
.bp-container {
	position: relative;
	max-height: 80vh;
	width: 100%;
	aspect-ratio: 16/9;
	background: black;
	overflow: hidden;
}
.bp-container > img {
	position: absolute;
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: center;
}
.bp-hover-zone {
	position: absolute;
	bottom: 0;
	left: 0;
	width: 100%;
	height: 50%;
}
.bp-sidebar-line, .bp-sidebar-tour {
	position: absolute;
	height: calc(100% - 35px);
	width: 300px;
	top: 0;
	right: -330px;
	margin: 20px;
	background: #141414c7;
	transition: right 0.3s ease;
	font-family: "Overpass Mono", monospace;
	border-radius: 15px;
	padding: 10px;
	box-sizing: border-box;
	font-size: 16px;
	overflow: auto;
}
.bp-sidebar-line.visible, .bp-sidebar-tour.visible {
	right: 0;
}
.bp-sidebar-header {
	display: flex;
	align-items: center;
	justify-content: space-between;
	color: white;
	height: 100px;
	padding: 15px;
	box-sizing: border-box;
	border-radius: 10px;
	background: #ff3d33;
}
.bp-sidebar-content {
	color: white;
	border: 1px #444 solid;
	background: #262626;
	border-radius: 5px;
	margin-top: 10px;
}
.bp-sidebar-content > div {
	margin: 15px;
	box-sizing: border-box;
	width: calc(100% - 30px);
}
.bp-sidebar-content .machines > div {
	width: 116px;
	background: #18ba5f;
	border-radius: 5px;
	padding: 10px;
	box-sizing: border-box;
	color: white;
}
.bp-sidebar-content .machines > div > div {
	height: 7px;
	width: 7px;
	float: right;
	border-radius: 50%;
	background: white;
}
.switch {
	position: relative;
	width: 35px;
	height: 15px;
	background: #d7d7d7;
	border-radius: 15px;
	padding: 5px;
}
.switch > div {
	position: absolute;
	top: 50%;
	left: 10%;
	transform: translate(0, -50%);
	border-radius: 50%;
	height: 70%;
	aspect-ratio: 1;
	background: #ff3d33;
}
.bp-navbar {
	position: absolute;
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 40px;
	height: 60px;
	bottom: 20px;
	left: 50%;
	transform: translate(-50%, 0%);
	background: #ff3d33;
	padding: 15px 20px;
	box-sizing: border-box;
	border-radius: 10px;
}
.bp-navbar > img {
	height: 100%;
	cursor: pointer;
	opacity: .6;
}
.bp-navbar > img.selected {
	opacity: 1;
}
.project-logo {
	max-width: 150px;
}
.spacer-logo {
	display: flex;
	justify-content: center;
	align-items: center;
	margin: 300px 0;
}
.spacer-logo img {
	max-width: 400px;
	max-height: 150px;
}
.three-display {
	position: relative;
	width: 100%;
	height: 80vh;
	font-family: 'League Spartan', sans-serif;
	overflow: hidden;
}
.three-display canvas { 
	display: block; 
	width: 100%; 
	height: 100%; 
	pointer-events: none;
	cursor: grab;
}
.three-overlay {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	display: flex;
	align-items: flex-end;
	justify-content: center;
	z-index: 100;
	cursor: pointer;
	text-align: center;
	transition: opacity 0.3s ease;
	line-height: 4em;
}
.three-overlay.hidden {
	opacity: 0;
	pointer-events: none;
}
.three-ui img, .three-hover-card img {
	height: 20px;
}
.three-icon-mobile {
	display: none;
}
.three-icon-desktop {
	display: block;
}
.three-ui {
	position: absolute;
	bottom: -70px;
	left: 50%;
	z-index: 10;
	display: flex;
	gap: 5px;
	align-items: center;
	transform: translate(-50%, 0);
	color: #fff;
	transition: bottom 0.6s ease-in-out;
}
.three-ui.visible {
	bottom: 20px;
}
.button-ui {
	display: flex;
	align-items: center;
	gap: 20px;
	background: #5e5e5e;
	padding: 10px 15px;
	box-sizing: border-box;
	height: 55px;
}
.button-ui > div {
	display: flex;
	align-items: center;
	flex-direction: column;
	gap: 5px;
	width: 30px;
	font-size: .6rem;
}
.button-ui:not(:first-child) {
	cursor: pointer;
}
.button-ui.selected {
	background: #ff3d33;
}
.three-hover-card {
	position: absolute;
	bottom: 80px;
	left: 20px;
	display: flex;
	align-items: center;
	gap: 17px;
	background: #ff3d33;
	border-radius: 5px;
	padding: 5px;
	box-sizing: border-box;
	font-size: 1rem;
}
.three-hover-card img {
	height: 20px;
}

@media (max-width: 800px) {
	.smooth-wrapper {
		position: unset;
	}
	.mobile-nav {
		display: flex;
	}
	.mobile-menu {
		top: -20px;
		left: -20px;

	}
	.desktop-nav {
		display: none;
	}
	nav {
		top: 20px;
		left: 20px;
		width: 60px;
		border-radius: 50%;
	}
	nav.inverted {
		background: #232323;
	}
	section {
		margin-bottom: 100px;
	}
	.logo {
		width: 60px;
		overflow: hidden;
		justify-content: flex-start;
	}
	.logo img {
		margin-left: 15px;
	}
	.hero {
		left: -20px;
		height: 100vh;
		padding-top: 70%;
	}
	.hero-logo {
		width: 60%;
	}
	.hero-bg {
		height: 100%;
	}
	.dictionary {
		width: calc(100% - 40px);
		padding: 0;
	}
	.dictionary-stable > div {
		padding: 0;
	}
	.title {
		margin-top: 0;
		font-size: 3em;
	}
	.title.centered {
		box-sizing: border-box;
		padding: 0 10px;
	}
	.definition {
		font-size: 1.5em;
	}
	.synonyms {
		flex-direction: column;
		font-size: 1.3em;
		line-height: 1.5em;
	}
	.synonyms span {
		margin-left: 0;
	}
	.project_title {
		font-size: 4em;
		line-height: 60px;
	}
	.project_description {
		width: 100%;
	}
	.row_contacts {
		flex-direction: column;
	}
	.image, .image.solo {
		width: 100%;
		aspect-ratio: 0.8;
	}
	.row_other_projects > a {
		width: calc(50% - 5px);
		flex: unset;
	}
	.other_projects {
		aspect-ratio: .8;
	}
	.flip-mask {
		line-height: unset;
	}
	.about, .contacts {
		width: 100vw;
		height: unset;
		padding: 50px 20px;
	}
	.about div {
		margin-top: 50px;
	}
	.icon {
		margin-top: 0;
	}
	footer {
		left: -20px;
		bottom: -20px;
	}
	footer div:last-child {
		display: none;
	}
	.email {
		width: 100%;
	}
	.email a:last-child {
		margin-left: auto;
	}
	.slider_container {
		height: 100vh;
		width: 100vw;
		overflow: auto;
		left: -20px;
	}
	.slider {
		height: 400px;
	}
	.slider div {
		aspect-ratio: 1;
		width: unset;
	}
	.feature {
		width: 100%;
	}
	.feature_title {
		font-size: 2em;
	}
	.dark {
		left: -20px;
		padding: 100px 20px;
	}
	.dark video, .thousand > img {
		filter: brightness(.6);
	}
	.video {
		aspect-ratio: 1;
	}
	.office {
		margin-top: 100px;
		left: -20px;
		padding: 100px 10px;
		box-sizing: border-box;
	}
	.office .title.centered {
		line-height: normal;
	}
	.office .video {
		aspect-ratio: .8;
	}
	.unmute-button {
		bottom: 30px;
		right: 30px;
		height: 40px;
		width: 40px;
	}
	.citadel {
		height: calc(100vh - 60px);
		left: -20px;
	}
	.citadel img {
		height: 100%;
		width: 100%;
		object-fit: cover;
	}
	.citadel .title {
		font-size: 4em;
	}
	.thousand > img {
		aspect-ratio: 0.8;
	}
	.thousand .title {
		top: 50%;
		left: 50%;
		transform: translate(-50%, -50%);
	}
	.gallery {
		gap: 10px;
	}
	.gallery > a {
		width: calc(50% - 5px);
	}
	#panorama {
		height: 400px;
	}
	.pnlm-load-button {
		font-size: 2em !important;
	}
	#imageviewer-image.expanded {
		height: 100vh !important;
	}
	#imageviwer-text {
		display: block;
	}
	.buttons-row a,
	.buttons-row div {
		margin: 0;
	}
	.button {
		padding: 10px 20px;
	}
	.units {
		padding-top: 100px;
	}
	.units img {
		aspect-ratio: 0.8;
	}
	.watch-button {
		display: none;
	}
	.youtube-bypass {
		display: block;
	}
	.watch-cinematic,
	.watch-office,
	.watch-surroundings,
	.watch-walkthrough {
		display: none;
	}
	.mosaic .tile {
		flex: unset;
	}
	.mosaic .tile.double-width {
		flex: unset;
		aspect-ratio: 1/1;
	}
	.grid > div {
		max-width: 100%;
		padding: 0;
		margin-bottom: 50px;
	}
	.bp-container {
		aspect-ratio: 0.8;
	}
	.bp-sidebar-line, .bp-sidebar-tour {
		display: none;
	}
	.bp-navbar {
		gap: 30px;
		height: 50px;
		padding: 10px 12px;
	}
	.bp-navbar > img {
		height: 75%;
	}
	.project-hero {
		padding: 20px;
		box-sizing: border-box;
	}
	.spacer-logo img {
		max-height: 70px;
		max-width: 250px;
	}
	.three-ui {
		background: none;
		border: none;
	}
	.three-icon-desktop {
		display: none;
	}
	.three-icon-mobile {
		display: block;
	}
	.flip-click:hover .default-text {
		transform: none;
	}
	.project-logo {
		max-width: 120px;
	}
}

@media (min-width: 1900px) {
	body {
		font-size: 20px;
	}
	.hero-logo {
		top: 22%;
	}
	.hero {
	padding-top: 15%;
	}
	.row_other_projects > a:last-child  {
		display: block;
	}
	.feature {
		width: calc(50% - 10px);
		margin: 100px auto;
	}
	.feature_images {
		height: 600px;
	}
	.image {
		aspect-ratio: 1.7;
	}
	.image.solo {
		aspect-ratio: 3.4;
	}
	section {
		padding: 0 200px;
		box-sizing: border-box;
	}
	.dictionary {
		padding: 200px;
	}
	.dark {
		padding: 200px;
	}
	.citadel .feature_description {
		padding: 0 220px;
	}
	#panorama {
		height: 800px;
	}
	.office {
		padding: 200px;
	}
	.units {
		position: relative;
		left: -20px;
		width: 100vw;
	}
	#video-container {
		max-width: 1500px;
	}
	.citadel-logo {
		padding: 0 200px;
		box-sizing: border-box;
	}
	.gallery > a {
		width: calc(20% - 16px);
	}
	.dictionary-stable > div {
		padding-left: 200px;
	}
}
