/* CSS RESET
---------------------------------------------- */
* {
  box-sizing: border-box;
}
html, body {
	margin: 0;
	padding: 0;
	border: 0;
	font: inherit;
	vertical-align: baseline;
}
table {
	border-collapse: collapse;
	border-spacing: 0;
}
td {
  vertical-align: top;
}
h1, h2, h3, h4, h5 {
  margin-block-start: 0em;
  margin-block-end: 0em;
  font-weight: normal;
  font-size: inherit
}
a {
  text-decoration: none;
  color: inherit;
  outline: none;
}
a:hover {
  outline: none;
}
a:focus,
button:focus {
  outline: none;
}
a:focus-visible{
  outline: 2px solid var(--second-color);
  outline-offset: 3px;
}
a:focus-visible {
  background: none;
}
p {
  margin-block-start: 0rem;
  margin-block-end: 0rem;
  margin-bottom: 1em;
}
p:last-of-type {
  margin-bottom: 0rem;
}
figure {
  margin-block-start: 0em;
  margin-block-end: 0em;
  margin-inline-start: 0px;
  margin-inline-end: 0px;
}
button {
  background: transparent;
  box-shadow: 0px 0px 0px transparent;
  border: 0px solid transparent;
  text-shadow: 0px 0px 0px transparent;
  padding: 0;
}
button:active {
  outline: none;
  border: none;
}
button:focus {
  outline: 0;
}
ol li:not(:last-of-type) {
  margin-bottom: 1rem;
}
ul.unstyled-list {
  display: block;
  list-style-type: none;
  margin-block-start: 0em;
  margin-block-end: 0em;
  margin-inline-start: 0px;
  margin-inline-end: 0px;
  padding-inline-start: 0px;
}
li.unstyled-list-item {
  display: block;
  text-align: -webkit-match-parent;
}
dd {
  margin-inline-start: 0px;
}
*:focus{
  outline: none;
}
input {
  border-radius: 0;
}
textarea, input[type="search"], input[type=text], input[type=button], input[type="submit"], input[type="checkbox"] {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  -webkit-border-radius: 0;
  -moz--border-radius: 0;
  font-weight: 400;
}
select {
  -webkit-border-radius: 0;
  background-color: inherit;
  -webkit-appearance: none;
  /* background-color: white; */
  background-image: url(data:image/svg+xml;base64,PHN2ZyB3aWR0aD0iMTIiIGhlaWdodD0iMTEiIHZpZXdCb3g9IjAgMCAxMiAxMSIgZmlsbD0ibm9uZSIgeG1sbnM9Imh0dHA6Ly93d3cudzMub3JnLzIwMDAvc3ZnIj4KPHJlY3QgeD0iNSIgeT0iMSIgd2lkdGg9IjEiIGhlaWdodD0iOSIgZmlsbD0iYmxhY2siLz4KPHJlY3QgeD0iMSIgeT0iNiIgd2lkdGg9IjEiIGhlaWdodD0iOSIgdHJhbnNmb3JtPSJyb3RhdGUoLTkwIDEgNikiIGZpbGw9ImJsYWNrIi8+Cjwvc3ZnPgo=);
  background-position : right center;
  background-repeat: no-repeat;
  padding-right: 1.5em;
} 

/*! Flickity v2.3.0
https://flickity.metafizzy.co
---------------------------------------------- */
.flickity-enabled {
  position: relative;
}
.flickity-enabled:focus { outline: none; }
.flickity-viewport {
  overflow: hidden;
  position: relative;
  height: 100%;
}
.flickity-slider {
  position: absolute;
  width: 100%;
  height: 100%;
}
/* draggable */
.flickity-enabled.is-draggable {
  -webkit-tap-highlight-color: transparent;
  -webkit-user-select: none;
     -moz-user-select: none;
      -ms-user-select: none;
          user-select: none;
}
.flickity-enabled.is-draggable .flickity-viewport {
  cursor: move;
  cursor: -webkit-grab;
  cursor: grab;
}
.flickity-enabled.is-draggable .flickity-viewport.is-pointer-down {
  cursor: -webkit-grabbing;
  cursor: grabbing;
}

/* VARIABLES
---------------------------------------------- */

:root {
  --white: #ffffff;
  --black: #000000;
  --grey: #A4A4A4;
  --lightgrey: #ECECEC;
  --font-size: 16px;
  --tiny-font: 12px;
  --small-font: 13px;
  --medium-font: 14px;
  --medium-large-font: 21px;
  --large-font: 25px;
  --x-large-font: 28px;
  --xx-large-font: 38px;
  --lr-page-padding: 14px;
  --link-padding: 4px;
  --vh:;
  --menuvh:;
  --alignment: 0vw;
  --small-vertical-margin: 30px;
  --smaller-medium-vertical-margin: 40px;
  --small-medium-vertical-margin: 50px;
  --standard-vertical-margin: 60px; 
  --large-vertical-margin: 75px; 
  --x-large-vertical-margin: 110px; 
  --standard-column-gap: 14px; 
  --large-aligned-text: var(--alignment);
  font-size: var(--font-size);
  font-family: Helvetica, Helvetica Neue, Arial, sans-serif; 
  color: var(--black);
}
body {
  -webkit-font-smoothing: antialiased;
  background: var(--white);
}
html {
  scroll-behavior: smooth;
}
/* SMALLMOBILE VARIABLES
---------------------------------------------- */
@media screen and (max-width: 375px) {
  :root {
    --xx-large-font: 35px;
  }
}
/* DESKTOP VARIABLES
---------------------------------------------- */
@media screen and (min-width: 60rem) {
  :root {
    --large-font: 32px;
    --x-large-font: 36px;
    --xx-large-font: 67px;
    --lr-page-padding: 16px;
    --lr-page-padding: 29px;
    --link-padding: 5px;
    --alignment: 28vw;
    --small-vertical-margin: 45px;
    --smaller-medium-vertical-margin: 50px;
    --small-medium-vertical-margin: 68px;
    --standard-vertical-margin: 78px; 
    --large-vertical-margin: 90px; 
    --x-large-vertical-margin: 130px; 
    --standard-column-gap: 28px; 
    --large-aligned-text: var(--alignment);
  }
}

@media screen and (min-width: 67rem) {
  :root {
    --alignment: 38vw;
  }
}

@media screen and ( max-width: 700px ) {
  :root { 
  }
}

/* GLOBAL
---------------------------------------------- */
.visually-hidden {
  position:absolute !important;
  overflow:hidden;
  width:1px;
  height:1px;
  margin:-1px;
  padding:0;
  border:0;
  clip:rect(0 0 0 0);
  clip: rect(1px, 1px, 1px, 1px);
  word-wrap:normal !important
}
.hidden-on-mobile {
  display: none;
}
.center {
  display: flex;
  justify-content: center;
  align-items: center;
}
.uppercase {
  text-transform: uppercase;
}
.not-uppercase {
  text-transform: none !important;
}
.capitalise {
  text-transform: capitalize;
}
.lr-padding {
  padding-left: var(--lr-padding);
  padding-right: var(--lr-padding);
}
img {
  width: 100%;
  display: block;
}
img.auto-height, .auto-height img {
  width: 100%;
  height: auto
}
.relative {
  position: relative;
}
.separated-flex {
  display: flex;
  justify-content: space-between;
}
p a {
  text-decoration: underline;
}
.capitalised-link{
  font-size: var(--small-font);
  padding: var(--link-padding) 0;
  text-transform: uppercase;
  text-decoration: underline;
  text-decoration-color: inherit;
  transition: text-decoration-color 300ms;
}
.underlined-link {
  text-decoration: underline;
  text-decoration-color: inherit;
  transition: text-decoration-color 300ms;
  text-transform: uppercase;
  font-size: var(--medium-font);
}
.not-underlined-link {
  text-decoration: underline;
  text-decoration-color: transparent;
  transition: text-decoration-color 300ms;
}
.unstyled-list {
  list-style-type: none;
}
.lr-page-padding {
  padding-left: var(--lr-page-padding);
  padding-right: var(--lr-page-padding);
}
.bottom-page-margin {
  margin-bottom: 80px
}
.large-centered-width {
  padding: 0 var(--lr-page-padding);
  margin-left: auto;
  margin-right: auto;
  max-width: 1800px
}
.small-centered-width {
  padding: 0 var(--lr-page-padding);
  margin-left: auto;
  margin-right: auto;
  max-width: 965px
}
.half-small-centered-width {
  max-width: 453.5px
}
.standard-page-header {
  margin-top: 114px;
}
.half-standard-page-header {
  padding-top: 57px;
}
.page-header-width-upper-subheading {
  margin-top: 72px;
}
.page-header-width-upper-subheading .split-header {
  margin-top: 28px;
}
.title {
  max-width: 700px
}
.in-text-title {
  margin: var(--large-vertical-margin) 0;
}
.medium-height-image {
  height: 60vw; 
}
.object-fit-wrapper img {
  height: 100%;
  width: 100%;
  object-fit: cover;
}
.absolute-image-wrapper img {
  position: absolute;
}
.font-size-xx-large {
  font-size: var(--xx-large-font);
  line-height: 1.1;
  margin-left: -2px;
}
.font-size-x-large {
  font-size: var(--x-large-font);
}
.font-size-large {
  font-size: var(--large-font);
}
.font-size-medium {
  font-size: var(--medium-font);
}
.font-size-medium-large {
  font-size: var(--medium-large-font);
}
.font-size-regular {
  font-size: var(--font-size);
}
.font-size-small {
  font-size: var(--small-font);
}
.font-size-tiny {
  font-size: var(--tiny-font);
}
.small-top-margin {
  margin-top: var(--small-vertical-margin);
}
.small-medium-top-margin {
  margin-top: var(--small-medium-vertical-margin);
}
.standard-top-margin {
  margin-top: var(--standard-vertical-margin);
}
.small-bottom-margin {
  margin-bottom: var(--small-vertical-margin);
}
.small-medium-bottom-margin {
  margin-bottom: var(--small-medium-vertical-margin);
}
.standard-bottom-margin {
  margin-bottom: var(--standard-vertical-margin);
}
.x-large-bottom-margin {
  margin-bottom: var(--x-large-vertical-margin);
}
.unstyled {
  text-decoration: none;
}
/* BARS
---------------------------------------------- */
.bar {
  padding: 0 calc(var(--lr-page-padding) - 16px) 0 calc(var(--lr-page-padding) - 16px);
  display: flex;
  align-items: flex-end;
  -webkit-align-items: flex-end;
  /* justify-content: space-between; */
} 
.push {
  margin-left: auto;
}

/* NAVBAR
---------------------------------------------- */
.navbar-wrapper {
  position: fixed;
  top: 0;
  width: 100%;
  z-index: 9;
}
.navbar {
  color: var(--white);
  transition: color .2s, background-color .3s;
  font-size: var(--medium-font);
}
.navbar.navbar-over-menu {
  color: var(--black) !important;
  background-color: var(--white) !important;
}
.navbar.dark-navbar .bar-link, .navbar.opaque-navbar .bar-link {
  color: var(--black);
  transition: color .2s, text-decoration-color 300ms;
}
.logo {
  padding: 16px;
  display: block;
}
.logo svg {
  height: 24px
}
.logo svg path {
  fill: var(--white);
  transition: fill .2s;
}
.navbar.dark-navbar .logo svg path, .navbar.opaque-navbar .logo svg path {
  fill: var(--black);
  transition: fill .2s;
}
.navbar.navbar-over-menu .logo svg path {
  fill: var(--black) !important;
}
.navbar ul.navbar-middle-links {
  display: none
}
.navbar .navbar-right-links {
  display: flex;
  flex-direction: row;
}
.navbar-right-links.push {
  align-self: center;
}
.bar-link {
  padding: 4px;
  padding-left: var(--lr-page-padding);
  padding-right: var(--lr-page-padding);
  display: block;
  color: inherit;
}
.navbar ul li:not(:last-of-type) {
  margin-right: 13px
}

/* HAMBURGER BUTTON
---------------------------------------------- */
.hamburger-wrapper {
  padding-left: 10vw;
  padding-right: 11px;
  display: flex;
  flex-direction: column;
  justify-content: center;
}
.hamburger-container {
  padding: 5px;
  cursor: pointer;
  margin-top: -4px;
}
.hamburger {
  width: 20px;
  height: 20px;
  position: relative;
}
.hamburger > div {
  position: absolute;
  top: 0;
  right: 0;
  width: 20px;
  height: 1px;
  transition: .5s;
  background: var(--white);
  transform: translateY(-50%) rotate(0);
  opacity: 1;
  display: block;
}
.navbar.dark-navbar .hamburger > div, .navbar.opaque-navbar .hamburger > div {
  background: var(--black);
}
.navbar.navbar-over-menu .hamburger > div {
  background: var(--black) !important;
}
.hamburger div:nth-child(1){
  top: 20%;
}
.hamburger div:nth-child(2){
  top: 50%;
}
.hamburger div:nth-child(3){
  top: 80%;
}
.hamburger-container.active-menu .hamburger div:nth-child(1){
  top: 50%;
  transform: translateY(-50%) rotate(45deg);
}
.hamburger-container.active-menu .hamburger div:nth-child(2){
  opacity: 0;
}
.hamburger-container.active-menu .hamburger div:nth-child(3){
  top: 50%;
  transform: translateY(-50%) rotate(-45deg);
}

/* OVERLAY MENU
---------------------------------------------- */
.overlay {
  position: fixed;
  background: var(--white);
  width: 100%;
  height: 0%;
  overflow-x: hidden;
  opacity: 1;
/*  top: 0; */
  bottom: 0;
  display: none;
  z-index: 8;
}
.menu-container.center {
  justify-content: initial;
  display: initial;
  align-items: initial;
  padding: 25vh var(--lr-page-padding) 10vh;
  padding-top: 114px;
}
.vertical-menu-list.unstyled-list {
  margin-left: var(--large-aligned-text);
}
.vertical-menu-list li:not(:last-of-type) {
  margin-bottom: 5px;
}
.vertical-menu-list a {
  line-height: 1.1;
  text-decoration: underline;
  text-decoration-color: transparent;
  transition: text-decoration-color 300ms;
}
.menu {
  opacity: 0;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  height: 100%;
}
.menu-footer {
 margin-top: auto;
}

/* FOOTER-BAR
---------------------------------------------- */
.bar.footer {
  align-items: flex-start;
  -webkit-align-items: flex-start;
  justify-content: space-between;
  flex-direction: column-reverse;
  font-size: var(--tiny-font)
}
.bar.footer > * {
  margin-bottom: var(--lr-page-padding)
}
.footer ul {
  display: flex;
  flex-direction: column;
}
.footer-middle-links {
  display: flex;
  flex-direction: column;
}
.footer-middle-links > div:not(:last-of-type) {
  margin-right: 13px
}
.footer-right-links.push {
  margin-left: initial
}
/* HOME TEMPLATE
---------------------------------------------- */
#seperator {
  height: 0px
}
/* PROJECTS TEMPLATE
---------------------------------------------- */
.project-cards {
  padding: 0 var(--lr-page-padding);
  margin-top: 50px;
}
.project-cards > div:not(:last-of-type) {
  margin-bottom: 45px;
}
.project-card {
  display: grid;
  grid-template-columns: 1fr;
  column-gap: var(--standard-column-gap);
}
.card-image {
  width: 100%;
  height: initial;
}
.card-image img {
  object-fit: cover;
  width: 100%;
  height: 60vw;
}
.project-card-top-text-container > div:first-of-type {
  font-size: var(--x-large-font);
  padding: 14px 0;
}
.project-card-top-bottom-container {
  display: flex;
  flex-direction: column;
  justify-content: end;
  -webkit-justify-content: flex-end;
  margin-top: 14px
}
.card-delivery-date {
  margin-top: 14px
}
.card-link {
  margin-top: 24px
}

/* PROJECT TEMPLATE
---------------------------------------------- */
.proyecto-template .banner {
  height: 100vh; /* Use vh as a fallback for browsers that do not support Custom Properties */
  height: calc(var(--vh, 1vh) * 100);
}
.project-intro-grid {
  display: grid;
  grid-template-rows: 1fr 1fr;
  grid-template-columns: 1fr 1fr;
  grid-template-areas: 
    "a a"
    "b b";
  column-gap: var(--standard-column-gap);
}
.project-intro-grid-full-height {
  grid-row-start: span 2;
}
.project-intro-grid-full-height > div:first-of-type {
  margin-bottom: 34px;
}
.project-intro-top-bottom-container {
  display: flex;
  flex-direction: column;
  justify-content: end;
  -webkit-justify-content: flex-end;
}
.gif-container {
  display: flex;
  justify-content: end;
  -webkit-justify-content: flex-end;
  margin-top: calc(var(--standard-vertical-margin) / 2);
  margin-bottom: var(--large-vertical-margin);
}
.gif-container > div {
  margin-right: 34px;
  width: 60%
}
.architect.standard-grid > div:first-of-type {
  order: 0
}
.architect.standard-grid .architect-text {
  order: 1
}
.architect.standard-grid > div {
  order: 2
}
.architect.standard-grid > div:not(:last-of-type) {
  margin-bottom: var(--small-vertical-margin);
}
.project-carousel {
  padding-bottom: 57.3%;
}
.project-carousel .flickity-viewport {
  position: absolute;
  width: 100%;
}
.project-carousel .carousel-cell {
  height: 100%;
  width: initial !important
}
.project-carousel .carousel-cell img {
  height: 100%;
  width: auto
}
.carousel-footer {
  display: flex;
  justify-content: space-between;
  margin-top: 24px;
}
.carousel-button {
  display: none;
}
.suburb-carousel-header {
  display: flex;
  justify-content: space-between;
  flex-direction: column;
}
.hour-button-group {
  margin-top: 14px;
  border-bottom: 1px solid var(--grey);
  display: flex;
  justify-content: space-between;
}
.hour-button-group > button {
  padding: .7rem 0;
  color: var(--grey);
  transition: color .3s;
  font-size: var(--medium-font);
}
.hour-button-group > button:not(:last-of-type) {
  margin-right: 20px
}
.hour-button-group > button.active-button {
  color: var(--black)
}
.plan-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
  gap: calc(var(--standard-column-gap)*2);
  row-gap: calc(var(--standard-column-gap)*2);
}
.plan-grid button.plan-grid-item {
  text-align: left;
  color: var(--black);
  font-size: 1rem
}
.availability {
  font-weight: bold;
  padding-bottom: 3px
}
.plan-grid-item > div:first-of-type {
  border-bottom: 1px solid var(--black);
  padding-bottom: 10px;
}
.plan-grid-item > div:last-of-type {
  padding-top: 7px;
}
.proyecto-template .form-title, .proyecto-template .form-intro{
  margin-bottom: var(--small-medium-vertical-margin);
}
.map-header > div:first-of-type {
  margin-bottom:  var(--small-vertical-margin);
}

/* PLAN MODAL
---------------------------------------------- */

/* The Modal (background) */
.modal {
  display: none; /* Hidden by default */
  position: fixed; /* Stay in place */
  z-index: 99; /* Sit on top */
  left: 0;
  top: 0;
  width: 100%; /* Full width */
  height: 100%; /* Full height */
  overflow: auto; /* Enable scroll if needed */
  /* -webkit-animation-name: fadeIn;
  -webkit-animation-duration: 0.4s;
  animation-name: fadeIn;
  animation-duration: 0.4s; */
  background-color: rgb(0,0,0); /* Fallback color */
  background-color: rgba(0,0,0,0.4); /* Black w/ opacity */
  background-color: transparent;
  -webkit-backdrop-filter: blur(15px) brightness(1);
  -moz-backdrop-filter: blur(15px) brightness(1);
  backdrop-filter: blur(15px) brightness(1);
}
.modal.visible {
  display: block;
}

.modal-container {
  padding: var(--standard-column-gap);
  height: 100%
}

/* Modal Content */
.modal-content {
  padding: var(--standard-column-gap);
  height: 100%;
  /*position: fixed;
  bottom: 0; */
  background-color: var(--lightgrey);
  width: 100%;
  /* -webkit-animation-name: slideIn;
  -webkit-animation-duration: 0.4s;
  animation-name: slideIn;
  animation-duration: 0.4s */
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--standard-column-gap);
}
.modal .plan-info {
  display: flex;
  flex-direction: column;
  height: 100%;
}
.modal .availability {
  margin-top: 24px
}
.plan-specs {
  margin-top: 24px;
  display: grid;
  grid-template-columns: 1fr 2fr;
  column-gap: var(--standard-column-gap);
}
.plan-specs > div {
  margin-bottom: 4px;
}
.apartment-number:not(:last-of-type)::after {
  content: ", ";
}
.plan-selector {
  background-color: inherit;
  margin-top: auto;
  margin-bottom: calc(var(--standard-column-gap) * 3);
  margin-left: 0px !important;
  width: 100% !important;
  max-width: 200px !important;
}
.plan-container {
  height: 40vh;
  position: relative;
  order: -1;
}
.plan-manipulation-buttons {
  position: absolute;
  top: 0;
  right: 0;
  display: flex;
  flex-direction: column;
  align-items: flex-end;
}
.plan-manipulation-buttons > *:not(:last-child) {
  margin-bottom: 10px
}
.zoom-button, .download-plan-button {
  height: 50px;
  width: 50px;
  background-color: var(--white);
}
/* The Close Button */
.close-modal {
  margin-bottom: 25px !important;
  color: var(--black)
}
.plan-swiper {
  position: absolute;
  left: 0;
  bottom: 0;
  z-index: 10000;
}
.plan-swiper-right {
  left: 40px;
}

/* PLAN MODAL ZOOM IMAGE
---------------------------------------------- */
.myWindow {
  cursor: grab;
  display: flex;
  align-items: center;
  justify-content: center;
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 100%;
  border: 0;
}
.myContent {
  position: relative;
  display: flex;
  align-items: center;
}
/* .embed-responsive::before {
  padding-top: 75%;
   display: block;
  content: "";
} */
.embed-responsive {
  display: block;
  width: 100%;
  height: 100%;
  overflow: hidden;
  position: relative;
}
img.myContent {
  width: initial;
}

/* BLOG TEMPLATE
---------------------------------------------- */
.two-third-grid {
  display: grid;
  grid-template-columns: 1fr;
}
.blog-header .standard-page-header {
  display: flex;
  flex-direction: column;
}
.blog-categories {
  font-size: var(--medium-font);
}
ul.category-list {
  display: flex;
  margin-left: 0px;
  margin-top: 20px
}
ul.category-list li:not(:last-of-type) {
  margin-right: 10px
}
ul.category-list li a {
  display: block;
  padding: 5px 0;
}
ul.category-list li a.active-category {
  text-decoration: underline;
}
.blog-search {
  align-self: end;
  max-width: 100%;
  border-bottom: 1px solid var(--grey);
  margin-bottom: 4px;
  margin-top: 14px;
}
.blog-search form {
  display: flex;
  justify-content: space-between;
  padding-bottom: 3px;
}
.blog-search input {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  border-width: 0px;
  border-style: initial;
  border-color: initial;
  border-image: initial;
  border: none;
  padding: 0px;
  margin-inline-start: 0px;
  margin-inline-end: 0px;
  padding-block-start: 0em;
  padding-inline-start: 0em;
  padding-inline-end: 0em;
  padding-block-end: 0em;
  min-inline-size: min-content;
  width: 100%;
  font-size: var(--medium-font)
}
.blog-search input::placeholder, .blog-search input:-ms-input-placeholder, .blog-search input::-ms-input-placeholder { 
  color: var(--grey);
  opacity: 1;
  font-size: 1rem !important;
}
button[type=submit] {
  font-size: var(--medium-font);
}
/* clears the 'X' from search input */
input[type=search]::-ms-clear {  display: none; width : 0; height: 0; }
input[type=search]::-ms-reveal {  display: none; width : 0; height: 0; }
input[type="search"]::-webkit-search-decoration,
input[type="search"]::-webkit-search-cancel-button,
input[type="search"]::-webkit-search-results-button,
input[type="search"]::-webkit-search-results-decoration { display: none; }

.article-category {
  margin-top: 12px;
}
.first-article h2 {
  margin-top: 14px;
  margin-bottom: 12px;
}
.first-article p {
  display: none
}
.first-article .article-button {
  margin-top: 12px;
}
.standard-grid.blog-small-card-grid {
  grid-template-columns: 1fr;
}
.standard-grid.blog-small-card-grid > div {
  margin-bottom: var(--standard-vertical-margin);
}
.small-card h2 {
  margin-top: 9px;
  margin-bottom: 12px
}

/* ARTICLE TEMPLATE
---------------------------------------------- */
.article-cover-image {
  margin-top: 1rem
}
.article-title {
  margin-top: 20px;
  margin-left: auto;
  margin-right: auto;
  text-align: center;
}
.article-title h1 {
  margin-top: 14px
}
.article-contents > section:not(last-of-type) {
  margin-bottom: calc(var(--standard-column-gap)*1.5);
}
.article-contents .layout-grid:first-of-type .block-type-text:first-of-type p {
  font-size: var(--large-font);
}
.layout-grid {
  display: grid;
  gap: var(--standard-column-gap)
}
.article-contents h2, .conditions-content h2 {
  margin-top: 2rem;
  margin-bottom: 1.7rem;
  font-weight: bold;
}
.article-contents h3, .conditions-content h3 {
  margin-top: 2rem;
  margin-bottom: 1.7rem;
  font-weight: bold;
}
.article-contents ul, .article-contents ol, .conditions-content ul, .conditions-content ol {
  margin-block-start: 0px;
  margin-inline-start: 0px;
  padding-inline-start: 1rem;
}
.blocks > section:not(last-of-type) {
  margin-bottom: 1rem;
}
.block:first-child {
  margin-top: 0px;
}
.block > *:not(:last-of-type) {
  margin-bottom: 1rem
}
/* NOSOTROS TEMPLATE
---------------------------------------------- */
.split-header {
  display: flex;
  justify-content: space-between;
  flex-direction: column;
}
.split-header > div:last-of-type {
  font-size: var(--large-font);
  padding-right: initial;
}
.nosotros-template .split-header > div:last-of-type {
  padding-top: 30px;
}
.split-header > div:last-of-type dd {
  margin-bottom: 26px;
}
.split-header > div:last-of-type a {
  padding: initial
}
.teamcontent, .directorscontent {
  display: none;
}
.team-section, .manifesto-section {
  display: grid;
  grid-template-columns: 1fr;
  column-gap: var(--standard-column-gap);
}
.team-photos {
  display: grid;
  grid-template-columns: 1fr;
  grid-gap: .6rem;
}
.team-photos .teamlinks:not(:first-of-type), .team-photos .directorslinks:not(:first-of-type) {
  margin-top: 45px;
}
.team-photos h3 {
  margin-top: 14px;
}
.team-bios {
  max-width: 470px;
  position: sticky;
  top: 5rem;
  align-self: start;
}
.bio {
  margin-top: 26px
}
.directors-heading {
  margin: calc(var(--large-vertical-margin) / 2) 0
}
.manifesto-text {
  margin-top: 45px
}
.manifesto-text > p:first-of-type {
  font-size: var(--large-font);
}


/* CONDITIONS TEMPLATE
---------------------------------------------- */
.conditions-content {
  margin-top: var(--smaller-medium-vertical-margin)
}
/* CONTACT FORM
---------------------------------------------- */
.contacto-template .form, .contacto-template .form-header, .home-template .form, .alignment {
  padding-left: var(--alignment)
}
.home-template .standard-page-header.form-header {
  display: flex;
  padding-top: 10px;
  align-items: flex-end;
  -webkit-align-items: flex-end;
}
.form-intro {
  max-width: 380px;
  margin-top: 20px;
}
.contacto-template .form-intro, .login-template .form-intro {
  margin-top: var(--smaller-medium-vertical-margin);
  margin-bottom: 30px
}
.home-template .form-block {
  margin-top: 50px
}
.form-block-field {
  overflow: hidden;
} 
.form-block-field input {
  font-size: var(--medium-font);
}
.form-block-field input:not([type=radio]):not([type=checkbox]), .form-block-field textarea, fieldset.form-block-field {
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  border-width: 0px;
  border-style: initial;
  border-color: initial;
  border-image: initial;
  border: none;
  width: 100%;
  padding: 0px;
  margin-inline-start: 0px;
  margin-inline-end: 0px;
  padding-block-start: 0em;
  padding-inline-start: 0em;
  padding-inline-end: 0em;
  padding-block-end: 0em;
  min-inline-size: min-content;
}
.form-block-button input[type=submit] {
  border: 0;
  border-radius: 0rem;
  background: transparent;
  color: var(--black);
  font-family: inherit;
  white-space: nowrap;
  padding: 0.25rem 0rem;
  margin: 0rem;
  margin-top: 20px;
  cursor: pointer;
}
.form-block-field select, select.plan-selector {
  border: none;
  width: 100%;
  padding: 0px;
  text-indent: 0px;
}
option {
  padding: 0px 0px 0px;
}
.form-block-field-checkbox {
  padding-top: .25rem !important;
}
.form-block-field .checkbox-label {
  display: grid;
  grid-template-columns: 1em auto;
  gap: 0.5em;
  font-size: var(--tiny-font)
}
.form-block-field input[type=checkbox] {
  /* Add if not using autoprefixer */
  -webkit-appearance: none;
  /* Remove most all native input styles */
  appearance: none;
  /* For iOS < 15 */
  background-color: var(--form-background);
  /* Not removed via appearance */
  margin: 0;
  font: inherit;
  color: currentColor;
  width: 1em;
  height: 1em;
  border: 1px solid var(--black);
  transform: translateY(0);
  display: grid;
  place-content: center;
}
.form-block-field input[type=checkbox]::before {
  content: "";
  width: 1em;
  height: .9em;
  transform: scale(0);
  transition: 120ms transform ease-in-out;
  box-shadow: inset 1em 1em var(--black);
}
.form-block-field input[type=checkbox]:checked::before {
  transform: scale(1);
}
.form-block-field input:not([type=radio]):not([type=checkbox]), .form-block-field textarea, .form-block-field select, select.plan-selector {
  border-bottom: 1px solid var(--black);
}
textarea {
  font-family: Helvetica, Helvetica Neue, Arial, sans-serif;
  color: var(--black);
  opacity: 1;
  font-size: var(--medium-font) !important;
  resize: vertical;
  padding-top: 2px!important;
}
.form-block ::placeholder, select { 
  color: var(--black);
  opacity: 1;
  font-size: var(--medium-font);
  text-transform: uppercase;
}
.form-block :-ms-input-placeholder { 
  color: var(--black);
  opacity: 1;
  font-size: var(--medium-font);
  text-transform: uppercase;
}
.form-block ::-ms-input-placeholder {
  color: var(--black);
  opacity: 1;
  font-size: var(--medium-font);
  text-transform: uppercase;
}
.form-block.standard-grid > * {
  margin-bottom: 10px;
}
/* Form */
.tm-hon {
  position: absolute;
  left: -9999px;
}
.alert.error {
  font-size: var(--tiny-font);
}
.button-loader {
  display: none;
  border: 1px solid #ccc;
  width: 10px;
  height: 10px;
  border-radius: 50%;
  border-top-color: var(--black);
  border-left-color: var(--black);
  animation: spin 1s infinite ease-in;
  margin-left: 5px
}
@keyframes spin {
  0% {
    transform: rotate(0deg);
  }
  100% {
    transform: rotate(360deg);
  }
}

/* BANNER IMAGES
---------------------------------------------- */
.banner {
  height: calc(100vh - 25px); /* Use vh as a fallback for browsers that do not support Custom Properties */
  height: calc(calc(var(--vh, 1vh) * 100) - 25px);
  overflow: hidden;
}
.fullwidth-background-mini {
  background-position: center;
  background-repeat: no-repeat;
  background-size: cover;
  filter: blur(50px);
  position: absolute;
  height: 100%;
  width: 100%;
  z-index: -1;
  transform: scale(1);
  transition: filter 1s;
  overflow: hidden;
}
.transition-image .fullwidth-background-mini {
  top: 0;
}
.transition-image.image-loaded .fullwidth-background-mini {
  filter: blur(0px);
}
.transition-image img {
  transition: filter .6s, opacity .6s linear;
  opacity: 0;
  filter: blur(50px);
  z-index: 1;
  transform: scale(1);
}
.transition-image.image-loaded img {
  opacity: 1;
  filter: blur(0px);
}
/* CAROUSEL
---------------------------------------------- */
.carousel-cell {
  height: 100%;
  width: 100%;
}
/* Project Slide */
.project-slide {
  height: 100%;
  width: 100%
}
.project-slide img {
  position: absolute;
  width: 100%;
  height: 100%;
  object-fit:cover;
}
.project-slide-text-content {
  color: var(--white);
  position: absolute;
  left: var(--large-aligned-text);
  top: 0;
  padding: var(--lr-page-padding);
  height: 100%;
  max-width: 600px;
  display: flex;
  flex-direction: column;
  z-index: 1;
}
.project-slide-text-content > div:first-of-type {
  margin-top: 30vh;
}
.project-slide-text-content > div:first-of-type h3 {
  margin-top: .7em
}
.project-slide-text-content > div:last-of-type {
  margin-top: 3rem;
}

/* TEXT CAROUSEL SLIDE
---------------------------------------------- */
.text-slide .text-slide-heading {
  margin-top: 80px;
  max-width: 700px;
}
.text-slide .text-slide-side-b {
  margin-top: 20px;
  padding-left: 0vw;
  display: grid;
  grid-template-columns: .75fr 1fr;
  column-gap: var(--standard-column-gap)
}
.text-slide img {
  height: auto;
}
.text-slide .text-slide-paragraph {
  max-width: 400px
}
.text-slide-paragraph a {
  margin-top: 34px;
  display: block;
  padding: 0px
}
.font-size-large.text-slide-paragraph {
  font-size: 1.1em
}

/* ACCORDION
---------------------------------------------- */
.accordion {
  cursor: pointer;
  padding: 5px var(--lr-page-padding);
  width: 100%;
  outline: none;
  display: flex;
  justify-content: center;
}
.chevron {
  transition: transform 0.2s ease-in-out;
  transform-origin: 50% 50%;
  height: .8rem;
  width: auto;
}
/* .accordion:hover .chevron {
  transform: rotate(90deg);
  transition: transform 0.2s ease-in-out;
}
.active-accordion .chevron {
  transform: rotate(180deg);
} */
.panel {
  /* position: relative;
  max-height: 0;
  overflow: hidden;
  transition: max-height .2s ease-out, opacity 1.3s;
  opacity: 0; */
}


/* BENEFITS TEMPLATE
---------------------------------------------- */
.benefit-header {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--standard-column-gap);
}
.benefit-header > div:nth-of-type(1) {
  order: 1
}
.benefit-header-text {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
}
.store {
  display: grid;
  grid-template-columns: 1fr;
  padding-bottom: 1rem;
}
.store img {
  padding-right: 0vw;
}
.store-text-detail {
  display: grid;
  grid-template-columns: 1fr 2.5fr;
  padding-bottom: 1.3rem;
}
.store-text-detail:not(:last-of-type) {
  border-bottom: 1px solid var(--black);
  margin-bottom: 1.3rem;
}
.store-text h2 {
  max-width: initial;
  margin-top: var(--standard-column-gap);
}
.store-text-detail p {
  max-width: initial;
}
.benefits-intro-heading {
  max-width: 300px;
  text-align: center;
  margin-left: auto;
  margin-right: auto;
}

/* ERROR TEMPLATE
---------------------------------------------- */
.error-content {
  min-height: calc(100vh - 222px)
}
.hide-on-mobile {
  display: none;
}

.hide-above-mobile, .hide-above-tablet {
  display: block;
}


@media screen and (min-width: 30rem) {
  .blog-header .standard-page-header {
    flex-direction: row;
    align-items: flex-end;
  }
  ul.category-list {
    margin-left: 45px;
    margin-top: 0px
  }
}
@media screen and (min-width: 45rem) {
  .hide-on-mobile {
    display: block;
  }
  .hide-above-mobile {
    display: none;
  }
  .bar.footer {
    flex-direction: row;
  }
}

@media screen and (min-width: 60rem) {


  .hide-above-tablet {
    display: none;
  }
  .navbar ul.navbar-middle-links {
    display: flex;
    flex-direction: row;
  }
  .navbar-right-links.push {
    align-self: initial;
  }
  .bar > div:first-of-type {
    width: var(--alignment)
  }

  .bar-link {
    padding: 16px;
  }

  /* OVERLAY MENU
  ---------------------------------------------- */
  .menu-container.center {
    padding: 25vh var(--lr-page-padding) 10vh;
    display: flex;
    align-items: center;
  }
  .vertical-menu-list li:not(:last-of-type) {
    margin-bottom: 0px;
  }

  /* FOOTER-BAR
  ---------------------------------------------- */
  .bar.footer {
    justify-content: initial;
  }
  .footer ul {
    flex-direction: row;
  }
  .footer-middle-links {
    flex-direction: row;
  }
  .footer-middle-links > div:not(:last-of-type) {
    margin-right: 13px
  }
  .footer-right-links.push {
    margin-left: auto;
  }
  .bar.footer > * {
    margin-bottom: initial;
  }

  /* CONTACT FORM
  ---------------------------------------------- */
  .form-intro {
    margin-top: initial
  }
  .contacto-template .form-intro {
    margin-top: var(--smaller-medium-vertical-margin);
    margin-bottom: 80px
  }
  .home-template .form-block {
    margin-top: 80px
  }
  .form-block-button input[type=submit] {
    margin-top: 0px;
  }
  .form-block.standard-grid > * {
    margin-bottom: initial;
  }

  /* TEXT CAROUSEL SLIDE
  ---------------------------------------------- */
  .text-slide .text-slide-heading {
    margin-top: 124px;
  }
  .text-slide .text-slide-side-b {
    margin-top: -25px;
    padding-left: 33vw;
    grid-template-columns: 1fr 1fr;
    column-gap: 80px
  }
  .text-slide-paragraph a {
    margin-top: 34px;
    display: block;
    padding: 0px
  }
  .font-size-large.text-slide-paragraph {
    font-size: var(--large-font)
  }

  /* PROJECTS TEMPLATE
  ---------------------------------------------- */
  .project-cards {
    margin-top: 85px;
  }
  .project-cards > div:not(:last-of-type) {
    margin-bottom: 72px;
  }
  .project-card {
    grid-template-rows: 1fr 1fr;
    grid-template-columns: 2fr 1fr;
    grid-template-areas: 
      "a a"
      "b b";
  }
  .project-card-image-container {
    grid-row-start: span 2;
  }
  .card-image img {
    height: 544px;
  }
  .project-card-top-text-container > div:first-of-type {
    padding-top: 0px;
    padding-bottom: 24px
  }
  .project-card-top-bottom-container {
    margin-top: initial
  }
  .card-link {
    margin-top: 24px
  }

  /* PROJECT TEMPLATE
  ---------------------------------------------- */
  .project-intro-grid > div:nth-child(odd) {
    padding-right: 5rem
  }
  .gif-container {
    margin-top: calc(var(--standard-vertical-margin) / 2.5);
  }
  .gif-container > div {
    width: 40%
  }
  .suburb-carousel-header {
    flex-direction: row;
  }
  .hour-button-group {
    margin-top: 0px;
    display: block;
  }
  .hour-button-group > button {
    font-size: var(--tiny-font);
  }
  .plan-grid {
    grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  }
  .architect.standard-grid > div:not(:last-of-type), .map-header > div:first-of-type {
    margin-bottom: 0px;
  }
  /* PLAN MODAL
  ---------------------------------------------- */
  .modal-content {
    height: 100%;
    grid-template-columns: 1fr 3fr;
  }
  .modal .plan-info {
    border-right: 1px solid var(--black);
    padding-right: var(--standard-column-gap);
  }
  button:hover {
    background: transparent;
    box-shadow: 0px 0px 0px transparent;
    border: 0px solid transparent;
    text-shadow: 0px 0px 0px transparent;
    cursor: pointer;
  }
  .plan-container {
    order: initial;
    height: initial;
  }
  .plan-swiper {
    left: initial;
    right: 40px;
    bottom: 0;
  }
  .plan-swiper-right {
    right: 0;
    left: initial;
  }

  /* NOSOTROS TEMPLATE
  ---------------------------------------------- */
  .nosotros-template .medium-height-image {
    height: 460px
  }
  .split-header {
    flex-direction: row;
  }
  .nosotros-template .split-header > div:last-of-type {
    font-size: var(--large-font);
    padding-top: 5px;
    padding-right: 145px;
  }
  .split-header > div:last-of-type dd {
    margin-bottom: 26px;
  }
  .teamlinks, .directorslinks {
    cursor: pointer;
  }
  .teamlinks img, .directorslinks img {
    opacity: .35;
    transition: .3s ease-in-out;
  }
  .teamlinks.active img, .directorslinks.active img {
    opacity: 1
  }
  .team-section, .manifesto-section {
    grid-template-columns: 1.5fr 1fr;
  }
  .manifesto-section > div:first-of-type {
    padding: 0 12vw;
  } 
  .team-photos {
    grid-template-columns: 1fr 1fr;
  }
  .team-photos .teamlinks:not(:first-of-type), .team-photos .directorslinks:not(:first-of-type) {
    margin-top: 0px;
  }
  .team-photos h3 {
    margin-top: 0px;
  }
  .manifesto-text {
    margin-top: 0px
  }

  /* BLOG TEMPLATE
  ---------------------------------------------- */
  .two-third-grid {
    grid-template-columns: 2fr 1fr;
    gap: var(--standard-column-gap)
  }
  ul.category-list {
    margin-left: 65px;
  }
  ul.category-list li:not(:last-of-type) {
    margin-right: 20px
  }
  ul.category-list li a {
    padding: 7px
  }
  .blog-search {
    max-width: 355px;
    margin-top: 0px;
  }
  .first-article h2 {
    max-width: 305px;
    margin-top: 18px;
    margin-bottom: 32px;
  }
  .first-article p {
    max-width: 355px;
    display: block;
  }
  .standard-grid.blog-small-card-grid {
    grid-template-columns: 1fr 1fr 1fr;
  }
  .small-card h2 {
    margin-bottom: 20px
  }
  .blog-template .blog-small-card-grid .card-image img {
    height: 18vw;
  }
  .standard-grid.blog-small-card-grid > div {
    margin-bottom: 0px;
  }
  /* ARTICLE TEMPLATE
  ---------------------------------------------- */
  .article-cover-image img {
    height: 50vw
  }
  .article-title {
    margin-top: 40px;
  }
  .article-title h1 {
    margin-top: 22px
  }
  .article-contents > section:not(last-of-type) {
    margin-bottom: calc(var(--standard-column-gap)*1.5);
  }
  .article-contents .layout-grid:first-of-type .block-type-text:first-of-type p {
    font-size: var(--large-font);
  }
  .layout-grid {
    display: grid;
    gap: var(--standard-column-gap)
  }
  .article-contents h2, .conditions-content h2 {
    margin-top: 2rem;
    margin-bottom: 1.7rem;
  }
  .article-contents h3, .conditions-content h3 {
    font-size: calc(var(--large-font) * .75);
    margin-top: 2rem;
    margin-bottom: 1.7rem;
  }
  .article-contents ul, .article-contents ol, .conditions-content ul, .conditions-content ol {
    margin-block-start: 0px;
    margin-inline-start: 0px;
    padding-inline-start: 1rem;
  }
  .blocks > section:not(last-of-type) {
    margin-bottom: 1rem;
  }
  .block:first-child {
    margin-top: 0px;
  }
  .block > *:not(:last-of-type) {
    margin-bottom: 1rem
  }


  .font-size-xx-large {
    margin-left: -4px;
  }

  .standard-page-header {
    margin-top: 162px;
  }
  .half-standard-page-header {
    padding-top: 81px;
  }
  .page-header-width-upper-subheading {
    margin-top: 114px;
  }
  .page-header-width-upper-subheading .split-header {
    margin-top: 34px;
  }
  .bottom-page-margin {
    margin-bottom: 160px;
  }

  .capitalised-link:hover, .underlined-link:hover {
    text-decoration-color: transparent;
  }
  a.not-underlined-link:hover, .vertical-menu-list a:hover {
    text-decoration-color: inherit;
  }
  .column-text {
    column-count: 2;
    column-gap: var(--standard-column-gap);
  }
  .hidden-on-desktop {
    display: none;
  }
  .hidden-on-mobile {
    display: block;
  }
  .img-hover-zoom {
    overflow: hidden;
  }
  .img-hover-zoom img {
    transition: transform .7s ease;
  }
  .transition-image .img-hover-zoom img {
    transition: transform .7s ease, filter .4s, opacity .4s linear;
  }
  .img-hover-zoom:hover img {
    transform: scale(1.02);
  }
  .standard-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: var(--standard-column-gap);
  }
  .masonry {
    grid-template-columns: repeat(2, 1fr);
    grid-template-rows: masonry;
  }
  .carousel-button {
    position: absolute;
    display: block;
    height: 100%;
    width: 50%;
    z-index: 1;
    top: 0px;
    padding: 10px;
    color: var(--white);
  }
  .carousel-button.button--next{
    right: 0px;
  }
  .carousel-button.button--previous span{
    float: left
  }
  .carousel-button.button--next span{
    float: right
  }
  .layout-grid {
    grid-template-columns: repeat(12, 1fr);
  }
  .layout-grid > .layout-column {
    grid-column: span var(--columns);
  }
  .layout-grid > .layout-column.centered-column {
    grid-column-start: 3;
    grid-column-end: 11;
  }
  button.zoom-button:hover {
    background-color: var(--white);
  }
  /* BENEFITS TEMPLATE
  ---------------------------------------------- */
  .benefit-header {
    grid-template-columns: 2fr 1fr;
  }
  .benefit-header > div:nth-of-type(1) {
    order: 0;
  }
  .store {
    grid-template-columns: 1fr 1fr;
    padding-bottom: 1rem;
    gap: var(--standard-column-gap);
  }
  .store img {
    padding-right: 8vw
  }
  .store-text-detail {
    grid-template-columns: 1fr 2.5fr;
  }
  .store-text h2 {
    max-width: 400px;
  }
  .store-text-detail p {
    max-width: 400px;
  }
  .benefits-intro-heading {
    max-width: 550px;
    text-align: center;
    margin-left: auto;
    margin-right: auto;
  }
  .store-text h2 {
    margin-top: initial;
  }
}
  /* ERROR TEMPLATE
  ----------------------------------------------  */

@media screen and (min-width: 70rem) {
  /* HOME TEMPLATE
  ---------------------------------------------- */
  .home-template .form-header {
    display: flex;
    align-items: flex-end;
    -webkit-align-items: flex-end;
  }
  .home-template .form-title {
    width: var(--alignment);
    max-width: var(--alignment)
  }
  .home-template .form-intro {
    margin-bottom: 7px;
  }
}

@media only screen and (min-width: 100px) and (max-width: 1020px) {
  
}

@media only screen and (min-width: 100px) and (max-width: 700px) {
}
