/* !vscloud:CssDoc:5fdf419b491cbc0017b5dcf3 */

@import url("https://fonts.googleapis.com/css2?family=Titillium+Web:wght@200;300;400;600&display=swap");

html {
  font-size: 62.5%;
}
html,
body {
  font-family: "Raleway", sans-serif;
  margin: 0px;
  padding: 0px;
  /*background-color: #000000;*/
}
body {
  --vh: 1vh;
}

button {
  border: none;
  padding: 0;
}

/* Reset default a to invisible */
a {
  text-decoration: none;
  color: #eeeeee;
}
a:hover {
  text-decoration: none;
}

/* other resets */
figure {
  margin: 0;
  padding: 0;
}

/*
p {
  line-height: 160%;
}*/

.Header li {
  list-style: none;
}

.vr-starter {
  display: none !important;
}

#page {
  position: relative;
  margin: 0px;
  padding: 0px;
  width: 100vw;
  height: 100vh;
  overflow: visible;
}

#content {
  position: relative;
  top: 0px;
  left: 0px;
  width: 100%;
  height: auto;
}

/********************************************************************************************
    HEADER
*********************************************************************************************/

.Header {
  position: fixed;
  top: 0px;
  left: 0px;
  width: 100%;
  height: auto;
  z-index: 101;
  background-color: rgb(150 111 255 / 80%);
  background: linear-gradient(to top, transparent, #0a2117);
  --logo-aspect-ratio: 1;
  --logo-height: 4.5rem;
  --logo-height-top: 6rem;
}
.Header.ShowMobileMenu {
  background-color: rgb(36 24 47 / 90%);
}
.Light .Header {
  background-color: rgba(152, 152, 152, 0.7);
  /* border-bottom: 1px solid #aaaaaa;*/
}

header.Header .Section {
  height: 10rem;
  overflow: visible;
}
.Header .Section .ContentColumn {
  display: flex;
  justify-content: space-between;
  overflow: visible;
  transition: padding 0.2s;
  padding-top: 1rem;
}
.Header .Section {
  height: 8.7rem;
  transition: height 0.2s;
}
.Header .ContentColumn {
  max-width: 130rem;
}
.Header .ContentColumn {
  display: flex;
  align-items: center;
  padding-top: 1rem;
}
.Header.Top .ContentColumn {
  padding-top: 2.3rem;
}

.MenuVisible .Header .Section {
  background-color: #000000;
  height:8rem!important;
}

.Header .Logo {
  background-image: url("/img/3A_Logo.png");
  background-repeat: no-repeat;
  transition: width 0.2s, height 0.2s;
  margin-left: 0px;
  background-size: contain;

  height: var(--logo-height);
  width: calc(var(--logo-height) * var(--logo-aspect-ratio));
}
.Header .LogoLink {
  display: flex;
  align-items: center;
}
.Header .LogoText {
  font-size: 1.7rem;
  transition: font-size 0.2s;
  margin-left: 2rem;
  color: #ffffff;
  text-transform: uppercase;
  font-family: "Titillium Web", sans-serif;
  letter-spacing: 3px;
}
.Header .LogoText.WithSub {
  margin-top: 1.8rem;
}
.Header .LogoSubText {
  font-size: 1.6rem;
  color: #ffffff;
  text-transform: uppercase;
}

.Header.Top .Logo {
  height: var(--logo-height-top);
  width: calc(var(--logo-height-top) * var(--logo-aspect-ratio));
}

.Header.Top .LogoText {
  font-size: 2.4rem;
}
.Header.Top .Section {
  height: 10rem;
}

/* Desktop menu-------------------------------- */
.Header .DesktopMenu {
  display: block;
}

.DesktopMenu ul {
  display: flex;
  margin: 0;
  padding: 0;
}

.DesktopMenu li:hover .Item:after {
  width: 100%;
}

.DesktopMenu li {
  width: max-content;
  position: relative;
  float: right;
  font-size: 1.7rem;
  letter-spacing: 0.1rem;
  font-family: "Titillium Web", sans-serif;
  margin-left: 4rem;
  margin-right: 0px;
  padding-bottom:0.4em;
}

.DesktopMenu li:first-of-type {
  margin-left: 0;
}
.DesktopMenu .Item {
  position: relative;
  display: block;
}
.DesktopMenu .Item::after {
  position: absolute;
  height: 2px;
  width: 0%;
  transition: width 0.3s cubic-bezier(0.455, 0.03, 0.515, 0.955);
  content: "";
  background-color: white;
  left: 0;
  bottom: -0.2rem;
  display: block;
}

.DesktopMenu ul ul {
  flex-direction: column;
  position: absolute;
  top: 3rem;
  left: 0em;
  padding: 1em 2.5em 0.75em 1.5em;
  opacity: 0;
  background: rgba(44, 34, 59, 0.8);
  pointer-events: none;
  transition: opacity 0.3s;
}

.DesktopMenu li.HasSubMenu::before {
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 200%;
  /* background-color: red; */
  content: "";
}

.DesktopMenu li.HasSubMenu {
  position: relative;
}

.DesktopMenu li.HasSubMenu li {
  margin-left: 0;
}
.DesktopMenu li.HasSubMenu li a {
  color: #dddddd;
  transition: color 0.3s;
}
.DesktopMenu li.HasSubMenu li:hover a {
  color: #ffffff;
}
.DesktopMenu li.HasSubMenu li .Item::after {
  display: none;
}
.DesktopMenu li.HasSubMenu:hover ul,
.DesktopMenu li ul:hover {
  opacity: 1;
  pointer-events: all;
}

.BurgerMenu {
  transition: width 0.2s, height 0.2s, margin 0.2s;
}

.Header .MobileMenu {
  background: #000000;
  display: none;
  padding: 1rem!important;
}
.Header .MobileMenu .Item {
  border-bottom: 1px solid #656565;
}
.Header .MobileMenu .Item.First {
  border-top: 1px solid #656565;
}

.Header a {
  text-decoration: none;
  color: #ffffff;
}

.Header .BurgerMenu {
  display: none;
  width: 2.6rem;
  height: 1.9rem;
  float: right;
  opacity: 0.8;
  background: -moz-linear-gradient(
    top,
    rgba(255, 255, 255, 1) 0%,
    rgba(255, 255, 255, 1) 10%,
    rgba(0, 0, 0, 0) 11%,
    rgba(0, 0, 0, 0) 44%,
    rgba(255, 255, 255, 1) 45%,
    rgba(255, 255, 255, 1) 55%,
    rgba(0, 0, 0, 0) 56%,
    rgba(0, 0, 0, 0) 89%,
    rgba(255, 255, 255, 1) 90%,
    rgba(255, 255, 255, 1) 100%
  );
  /* FF3.6-15 */
  background: -webkit-linear-gradient(
    top,
    rgba(255, 255, 255, 1) 0%,
    rgba(255, 255, 255, 1) 10%,
    rgba(0, 0, 0, 0) 11%,
    rgba(0, 0, 0, 0) 44%,
    rgba(255, 255, 255, 1) 45%,
    rgba(255, 255, 255, 1) 55%,
    rgba(0, 0, 0, 0) 56%,
    rgba(0, 0, 0, 0) 89%,
    rgba(255, 255, 255, 1) 90%,
    rgba(255, 255, 255, 1) 100%
  );
  /* Chrome10-25,Safari5.1-6 */
  background: linear-gradient(
    to bottom,
    rgba(255, 255, 255, 1) 0%,
    rgba(255, 255, 255, 1) 10%,
    rgba(0, 0, 0, 0) 11%,
    rgba(0, 0, 0, 0) 44%,
    rgba(255, 255, 255, 1) 45%,
    rgba(255, 255, 255, 1) 55%,
    rgba(0, 0, 0, 0) 56%,
    rgba(0, 0, 0, 0) 89%,
    rgba(255, 255, 255, 1) 90%,
    rgba(255, 255, 255, 1) 100%
  );
  /* W3C, IE10+, FF16+, Chrome26+, Opera12+, Safari7+ */
}
.Stripe {
  display: inline-block;
  background: white;
  height: 0.8em;
  position: relative;
  top: 0.05em;
  border-radius: 1em;
}

.Header.ShowMobileMenu .MobileMenu {
  display: block;
}

.Header .MobileMenu .Item {
  padding: 2rem 1rem;
  text-transform: uppercase;
  text-align: center;
  border-bottom: 1px solid #444444;
  color: #ffffff;
  font-size: 2rem;
}
.Header .MobileMenu .Item:hover {
  background-color: #ffffff22;
}
.Header .MobileMenu .Item.First {
  border-top: 1px solid #444444;
}

/* 1025px */
@media screen and (max-width: 64.0625em) {
  .Header {
    --logo-height: 5rem;
  }
}

/* 920px, when burger menu appears */
@media screen and (max-width: 57.5em) {
  .Header.Top .BurgerMenu {
    --height: 1.9rem;
  }
  .Header .BurgerMenu {
    --height: 1.5rem;
    height: var(--height);
    width: calc(var(--height) * 2.6 / 1.9);
  }

  header.Header .ContentColumn {
    padding-top: 2.1rem;
  }
  .Header.Top .ContentColumn {
    padding-top: 1.5rem;
  }
}

/* 400px */
@media screen and (max-width: 25em) {
  .Header.Top .LogoText {
    font-size: 2rem;
  }

  .Header {
    /* margin-top: 2rem; */
    --logo-height-top: 5rem;
    --logo-height: 4rem;
  }

  .Header {
    background: none;

    /* border-bottom: 1px solid #ad8bc7; */
  }
  .Header::before {
    content: "";
    position: absolute;
    width: 100%;
    height: calc(100% + 5px);
    display: block;
    background: linear-gradient(
      to top,
      transparent 0%,
      #0d092175 33%,
      #092117 100%
    );
  }

  .MenuVisible .Header::before {
    display: none;
  }
}

/* 350px */
@media screen and (max-width: 21.875em) {
  .Header {
    --logo-height-top: 4rem;
    --logo-height: 3rem;
    /* margin-top: 2.5rem; */
  }

  .Header.Top .LogoText {
    font-size: 1.8rem;
  }

  .Header .BurgerMenu {
    --height: 1.3rem;
  }
  .Header.Top .BurgerMenu {
    --height: 1.3rem;
  }
}

/* Scroll down icon */
.ScrollDownIcon {
  background-size: contain;
  height: 5rem;
  width: 5rem;
  margin: 0 auto;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='800px' height='800px' viewBox='0 0 24 24' fill='none'%3E%3Cpath d='M12 6V18M12 18L7 13M12 18L17 13' stroke='%23ffffff' stroke-width='1' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
  margin-top:4rem;
}

/***********************************************************************************
    SECTION
************************************************************************************/

.Section {
  position: relative;
  width: 100%;
  height: auto;
  margin: 0px;
  padding: 0px;
  height: auto;
  overflow: hidden;

  height: auto;
  /*border-bottom: 1px solid greenyellow;*/
  /* background-color: rgba(128,128,128,0.3); */
}

.Section .Content a {
  text-decoration: none;
  color: #ffffff;
}
.Section .Content a:hover {
  text-decoration: underline;
}

.Section .Content a.Gray {
  text-decoration: none;
  color: #cccccc;
}
.Section .Content a.Gray:hover {
  text-decoration: underline;
  color: #eeeeee;
}

.Section.Screen {
  min-height: calc(100 * var(--vh));
}

.Section.ScreenHero {
  min-height: 40vh;
}
.Section.ScreenHero2 {
  min-height: 20vh;
}

.Section.Space {
  height: 20vh;
}
.Section.Space1 {
  height: 10vh;
}
.Section.Space2 {
  height: 20vh;
}
.Section.Auto {
  height: auto;
  position: relative;
  min-height: initial;
  /* border-bottom: 1px solid greenyellow; */
}

.Section .ContentColumn {
  position: relative;
  height: auto;
  padding: 0px;
  margin: auto;
  max-width: 130rem;
  width: calc(100% - 16rem);
  overflow: hidden;
}

.Section .Center {
  width: -moz-fit-content;
  width: fit-content;
  margin-left: auto;
  margin-right: auto;
  text-align: center;
}

/* Title / Subtitle / Desc ************************************/

.Section .Title {
  /*position: relative;
    font-size: 54px;
    color:#ffffff;
    text-transform: uppercase;*/
  color: #ffffff;
  font-family: "Titillium Web", sans-serif;
  letter-spacing: 0.3rem;
  width: fit-content;
  width: -moz-fit-content;
  font-weight: 200;
}

.Section h1 {
  margin-top: 10rem;
  margin-bottom: 8rem;
  position: relative;
  color: #ffffff;
  text-transform: uppercase;
  font-family: "Titillium Web", sans-serif;
  letter-spacing: 0.3rem;
  width: fit-content;
  width: -moz-fit-content;
  font-weight: 200;
}

.Section h1 {
  font-size: 5rem;
}

.Section h2 {
  font-size: 4rem;
  font-weight: bold;
  margin-top: 12rem;
  margin-bottom: 6rem;
  position: relative;
  color: #ffffff;
  text-transform: uppercase;
  font-family: "Titillium Web", sans-serif;
  letter-spacing: 0.3rem;
  width: fit-content;
  width: -moz-fit-content;
}

.Section.Portfolio h2 {
  font-size: 4.6rem;
  font-weight: 200;
  margin-bottom: 4rem;
}

.Section h2.SmallGap {
  margin-top: 4rem;
}

.Section h2.Small {
  font-size: 4.6rem;
  letter-spacing: 0.2rem;
}

.Section .Subtitle {
  font-family: "Titillium Web", sans-serif;
  letter-spacing: 0.1rem;
  width: fit-content;
  width: -moz-fit-content;
  font-size: 2rem;
  color: #aaaaaa;
  position: relative;
}

.Section .Subtitle.Line {
  border-top: 1px solid #eeeeee;
  padding-right: 0.5rem;
}

/* .Section.Text .HeadingSmall */
.Section h3 {
  margin-top: 8rem;
  text-transform: uppercase;
  font-family: "Titillium Web", sans-serif;
  color: white;
  letter-spacing: 0.1rem;
  font-size: 1.17em;
  font-weight: bold;
  margin-bottom: 1em;
}
.Section h3.NoGap {
  margin-bottom: 0em !important;
}
.Section h3.Close {
  margin-top: 0px;
  margin-bottom: 0px;
}
.Section .Desc {
  position: relative;
  font-family: "Titillium Web", sans-serif;
  font-size: 2rem;
  color: #dddddd;
  line-height: 140%;
}

/* CTA Button ******************************************/

.Section div.CTAButton {
  /* margin:auto;
    margin-top: 60px; */
  border: 1px solid #999999;
  background-color: rgb(42 42 42 / 52%);
  padding: 1.5rem 2.5rem 1.5rem;
  font-size: 1.5rem;
  color: #e3e3e3;
  text-decoration: none;
  text-transform: uppercase;
  text-align: center;
  width: max-content;
  cursor: pointer;
  letter-spacing: 0.2rem;
  line-height: 94%;
  transition: color 0.5s, border 1s, background-color 1s;
  border-radius: 60px;
  /*margin-top:40px;*/
}
.Section a.CTAButton {
  text-decoration: none !important;
}
.Section div.CTAButton.Wide {
  font-size: 1.8rem;
  padding: 2rem 5rem 1.8rem;
}
.Section div.CTAButton.Narrow,
li.CTAButton.Narrow,
button.CTAButton.Narrow,
a.CTAButton.Narrow {
  font-size: 1.4rem;
  padding: 1rem 2rem 0.9rem;
  margin-top: 1em !important;
}
.Section div.CTAButton.Gap {
  margin-right: 0.5rem;
  margin-left: 0.5rem;
}
.Section div.CTAButton.NoGap {
  margin-top: 0rem !important;
}
.Section div.CTAButton.White {
  border: 1px solid #ffffff;
  background-color: rgb(255 255 255 / 0%);
  color: #ffffff;
}
.Section div.CTAButton.White:hover {
  background-color: rgb(255 255 255 / 33%);
}
.Section .White a.CTAButton {
  text-decoration: none !important;
  color: #ffffff;
}

.Section div.CTAButton.Light {
  border: 1px solid #bfbfbf;
  background-color: rgb(191 191 191 / 29%);
  /* rgb(133 133 133 / 52%)*/
}

.Section div.CTAButton.Light2 {
  border: 1px solid #999999;
  background-color: rgb(133 133 133 / 52%);
}
.Section div.CTAButton:hover {
  border: 1px solid #dddddd;
  color: #ffffff;
  background-color: rgb(42 42 42 / 76%);
}
.Section div.CTAButton.Light2:hover {
  border: 1px solid #dddddd;
  color: #ffffff;
  background-color: rgb(182 179 179 / 52%);
}

.Section .CTAText {
  font-size: 1.6rem;
  color: #ffffff;
  padding: 0px 2rem;
}

/* Box ***********************************************/

.Section .Box {
  padding: 6rem;
  width: fit-content;
  width: -moz-fit-content;
}

.Section .Box.Wide {
  padding: 8rem 12rem;
}

.Section .Box.Narrow {
  padding: 3rem 6rem;
}

.Section .Box.Round {
  border-radius: 1.5rem;
}

.Section .Box.Full {
  width: 100%;
  padding: 0px;
  margin: 0px;
}

.Section .Box.FullPad {
  width: calc(100% - 12rem);
  padding: 6rem;
  margin: 0px;
}

.Section ul.Center {
  text-align: left;
  list-style: inside;
}

.Section ul.Center li {
  padding-bottom: 1rem;
}

/* Example links **********************************************/

.ExampleLink {
  text-decoration: underline;
}
.Content a {
  color: #eeeeee;
}
.Content .Link {
  text-decoration: none;
  color: #ffffff;
}

.Content .Link:hover {
  text-decoration: underline;
}
.Content img.M {
  margin: auto;
  display: block;
  width: 50%;
}
/* List **********************************************/

ul.List {
  width: fit-content;
  width: -moz-fit-content;
  /* letter-spacing: 0.1rem;
  font-size: 2rem;*/
  padding-left: 5rem;
}

.List li {
  text-align: left;
  width: fit-content;
  width: -moz-fit-content;
  padding-bottom: 1rem;
  list-style: disc;
  /*text-align: center;*/
}

.List li.A {
  color: #ffffff;
}

.List li.B {
  color: #eeeeee;
}

.Section .Arrow {
  display: inline-block;
  background: url("https://socialvisuals.com/arrow.png");
  width: 2.4rem;
  height: 2.4rem;
  background-size: cover;
  opacity: 0.6;
}

.Section .GT {
  display: inline-block;
  position: relative;
  top: -0.3rem;
}

.Section .GT:after {
  content: ">";
}

/**********************************************************
    Section Layouts

    Hero
        LandingCenterTitle
        LandingLogoTitleLines

    PageHead

    ShortIntro
    Introduction
    Text

    Tiles
    Portfolio
    Space

    ? ContentBox
    ? ContentBoxCenter
    ? ContentCards
    ? ContentPage
    

****************************/

/********************************************************
  .Section.Hero HERO SECTION
*********************************************************/
.Section.Hero {
  display: flex;
  flex-direction: column;
}

/* Box : holding Title & Subtitle *******************/
.Section.Hero .Box {
  margin-top: 40vh;
}
.Section.Hero .Box.Top {
  margin: auto;
  margin-top: 20rem;
}
.Section.Hero .Box.Narrow {
  padding: 0;
}

/* FullBox :  holding Title & Subtitle ***************/
.Section.Hero .FullBox {
  background: linear-gradient(
    to top,
    rgb(0, 0, 0) 0%,
    rgba(0, 0, 0, 0.8) 57%,
    rgba(0, 0, 0, 0) 100%
  );
  padding-bottom: 2rem;
  padding-top: 2rem;
  margin-top: auto;
  position: relative;
  width: 100%;
}

/* Title & Subtitle *******************************/
.Section.Hero .Title {
  margin-top: 0px;
  font-family: "Titillium Web", sans-serif;
  font-size: 3.6rem;
  color: #eeeeee;
  letter-spacing: 0.1rem;
  text-transform: uppercase;
  font-weight: 300;
  margin-bottom: 0px;
}

.Section.Hero .Title.Big {
  font-size: 4.2rem;
}

.Section.Hero .Subtitle {
  color: #cccccc;
  font-weight: 200;
  letter-spacing: 0.1rem;
  text-transform: uppercase;
  font-size: 3.6rem;
  font-family: "Titillium Web", sans-serif;
}

.Section.Hero h1 {
  margin-top: 40vh;
  font-family: "Titillium Web", sans-serif;
  font-size: 3.6rem;
  color: #eeeeee;
  letter-spacing: 0.1rem;
  text-transform: uppercase;
  font-weight: 300;
}

.Section.Hero h1.Big {
  font-size: 4.2rem;
}

.Section.Hero h2 {
  color: #cccccc;
  font-weight: 200;
  letter-spacing: 0.1rem;
  text-transform: uppercase;
  font-size: 3.6rem;
  font-family: "Titillium Web", sans-serif;
}

.Section.Hero h1.Title {
  font-weight: bold;
}
.Section.Hero p {
  font-size: 2rem;
  color: white;
  font-weight: 200;
  letter-spacing: 2px;
  line-height: 140%;
  /* max-width: min(90vw, 24em);*/
}

/***********************************
    LandingCenterTitle
************************************/

.Section.LandingCenterTitle {
  color: #ffffff;
}

.Section.LandingCenterTitle .Subtitle {
  color: #dddddd;
  text-transform: uppercase;
  letter-spacing: 0.1rem;
}

.Section.LandingCenterTitle .Box.Top {
  margin: auto;
  margin-top: 20rem;
}

.Section.LandingCenterTitle .Box.Center {
  margin: auto;
  margin-top: 35vh;
}

.Section.LandingCenterTitle .Box.Bottom {
  position: absolute;
  bottom: 0px;
  left: 0%;
  width: 100%;
  padding-left: 0px;
  padding-right: 0px;
}

.Section.LandingCenterTitle div.CTAButton {
  margin-top: 4rem;
}

.Section.LandingCenterTitle .Desc {
  padding: 4rem 6rem;
  margin-top: 4rem;
  margin-bottom: 2rem;
}

/***********************************
    LandingLogoTitleLines
************************************/

.Section.LandingLogoTitleLines .Box {
  margin-top: 30vh;
  width: fit-content;
  width: -moz-fit-content;
}

.Section.LandingLogoTitleLines .Desc {
  padding-top: 4rem;
}

/***********************************
  PageHead
*********************************/
.Section.PageHead {
  height: 40vh;
}
.Section.PageHead.Full {
  height: 100vh;
  padding-bottom: 0px !important;
}
.Section.PageHead .ContentColumn {
  height: 100%;
}
.Section.PageHead .Content {
  height: 100%;
}
.Section.PageHead h1 {
  display: block;
  bottom: 10%;
  position: absolute;
  margin-block-end: 0px;
  margin-block-start: 0px;
}
.Section.PageHead.Full .Content {
  display: block;
  bottom: 3rem;
  position: absolute;
  height: fit-content;
}
.Section.PageHead.Full h1 {
  display: inline-block;
  position: static;
  margin-block-end: 0px;
  margin-block-start: 0px;
  margin-bottom: 12rem;
}
.Section.PageHead.Full .ScrollDownIcon {
  margin-top: 6rem !important;
}
/***********************************
    ContentBox
************************************/

.Section.ContentBox .Box.Right {
  float: right;
}

.Section.ContentBox .Desc {
  margin-top: 4rem;
  max-width: 60rem;
}

.Section.ContentBox div.CTAButton {
  margin: auto;
  margin-top: 6rem;
}

/***********************************
    ContentBoxCenter
************************************/

.Section.ContentBoxCenter .Box {
  padding: 14rem 0px;
}

.Section.ContentBoxCenter .Title {
  /*font-size: 52px;*/
  margin-top: 10vh;
  padding-top: 2rem;
}

.Section.ContentBoxCenter .Desc {
  margin-top: 8rem;
  line-height: 2.2rem;
  color: #ffffff;
  max-width: 60%;
}

.Section.ContentBoxCenter .Desc .List {
  padding-top: 4rem;
  padding-bottom: 4rem;
}

/***********************************
    ContentCards
************************************/

.Section.ContentCards .Content {
  position: relative;
  width: 100%;
  height: auto;
  margin-top: 10%;
  margin-bottom: 30%;
}

.Section.ContentCards .Title {
  color: #cccccc;
}

.Section.ContentCards .Content .Title {
  color: #ffffff;
}

.Section.ContentCards .Item {
  width: calc(42% - 2px);
  position: relative;
  border: 1px solid #666666;
  /*background-color: rgba(10,10,10,0.7);*/
  background-color: rgb(56 56 56 / 29%);
  transition: background-color 0.5s;
}

.Section.ContentCards .Item:hover {
  border: 1px solid #cccccc;
  /*background-color: rgba(10,10,10,0.75);(*/
  background-color: rgb(56 56 56 / 45%);
}

.Section.ContentCards .Item.A {
  float: left;
}

.Section.ContentCards .Item.B {
  float: right;
}

.Section.ContentCards .Item .Info {
  width: calc(100% - 12rem);
  padding: 6rem 6rem 6rem 6rem;
  height: 24rem;
}

.Section.ContentCards .Item .Title {
  font-size: 4.5rem;
  letter-spacing: 0.2rem;
}

.Section.ContentCards .Item .Desc {
  margin-top: 4rem;
  color: #cccccc;
}

.Section.ContentCards .Item .Action {
  margin-top: 3rem;
  font-family: "Titillium Web", sans-serif;
  font-size: 1.6rem;
  color: #ffffff;
  cursor: pointer;
  text-transform: uppercase;
}

/***********************************
    Tiles
************************************/
.Section .ContentTiles{
  margin-top: 9rem;
}

.Section .ContentTiles::after {
  content: "";
  display: block;
  clear: both;
}

.Section.Tiles .Content {
  padding: 4.5rem 1rem 0px;
  margin-bottom: 14rem;
}
.Section.Tiles .Content::after {
  content: "";
  clear: both;
  display: table;
}
/*
.Section.Tiles .Content.Photos {
    padding-top: 55px;
    margin-bottom: 260px;
}
*/

/************************************
   Intro
*************************************/

.Section.Intro {
  padding-bottom: 4rem;
}
.Section.Intro a {
  text-decoration: none;
  color: #ffffff;
}
.Section.Intro a:hover {
  text-decoration: underline;
}

.Section.Intro.SA {
  padding-bottom: 12rem;
}

.Section.Intro .Content {
  padding: 2rem 0%;
  color: #f5f5f5;
  font-family: "Titillium Web", sans-serif;
  letter-spacing: 0.1rem;
  width: fit-content;
  width: -moz-fit-content;
  font-size: 2.2rem;
  line-height: 3.2rem;
  position: relative;
}

.Section.Intro .Content p.CTA {
  padding-bottom: 2rem;
  font-weight: bold;
}
.Section.Text .Content p.CTA {
  padding-bottom: 0px;
  font-weight: bold;
  color: #ffffff;
  margin-bottom: 0px;
}

.Section.Intro .Content.Narrow {
  max-width: 70rem;
  margin-left: auto;
  margin-right: auto;
}

.Section.Intro .Content .high {
  color: #ffffff;
}
/************************************************************************************
  SECTION INTRODUCTION
*************************************************************************************/
.Section.Introduction {
  /* background: linear-gradient(
    180deg,
    rgb(33 10 23 / 100%) 0%,
    rgb(12 12 12/ 80%) 57%,
    rgb(13 12 13/ 70%) 100%
  ); */

  /* solid */
  background: linear-gradient(
    155deg,
    rgb(33 10 23 / 100%) 0%,
    rgb(27 4 73) 57%,
    rgb(59 10 123) 100%
  );

  /* temp. same as BackSectionA */
  /*background: linear-gradient(
    to bottom,
    rgb(43 13 89 / 89%) 0%,
    rgb(23 16 37 / 89%) 100%
  );*/

  padding-bottom: 12rem;
  margin-top: auto;
  position: relative;
  width: 100%;
}
.Section.Introduction p {
  font-size: 2rem;
  letter-spacing: 0.2rem;
  line-height: 160%;
  color: #dddddd;
  max-width: 40em;
}

.Section.Introduction h2 {
  font-weight: bold;
  font-size: 4.6rem;
}
/****************************************************************
   .Section.Text  TEXT SECTION
*****************************************************************/
.Section .Content {
  padding: 4rem 15% 0px;
}

.Section.Text {
  padding-bottom: 4rem;
}
.Section.Text.NoGap {
  padding-bottom: 0px;
}

/*
.Section.Text h2:not(.HeadingSmall) {
  line-height: 5.2rem;
  margin-top: 10rem;
  margin-bottom: 2rem;
}
*/
.Section.Text h3.First {
  margin-top: 4rem;
}
.Section.Text h2.Narrow {
  margin-top: 8rem;
  margin-bottom: 3rem;
}
.Section.Text h3.Narrow {
  margin-top: 4rem;
  margin-bottom: 0.5rem;
}
.Section.Text .Content {
  color: #ffffff;
  font-size: 1.8rem;
  line-height: 3rem;
  letter-spacing: 0.1rem;
  /*margin-bottom:140px;*/
  /* text-align: left;*/
}
.Section.Text .Content.Narrow {
  padding-top: 2rem;
}
.Section.Text .Content p {
  margin-block-start: 0.9em;
  margin-block-end: 0.9em;
}
.Section.Text .ContLine {
  width: fit-content;
  margin-bottom: 1rem;
}
.Section.Text .Line {
  background-color: #ffffff33;
  margin: 3px 0px;
  padding: 2px 2rem 2px 1rem;
  font-size: 1.9rem;
}
/*
.Section.Text .TextColumn {
  padding: 4rem 20% 0px;
  color: #eeeeee;
  font-size: 1.8rem;
  line-height: 2.6rem;
  letter-spacing: 0.1rem;
}
*/
.Section.Text .Content .high {
  color: #ffffff;
}

.Section.Text .Content {
  font-size: 2rem;
  letter-spacing: 0.1rem;
}
.Section.Text .Content .Price {
  background-color: rgba(255, 255, 255, 0.5);

  padding: 1rem 2rem;
  width: fit-content;
  margin-top: 4rem;
}
.Section.Text .CTA {
  padding: 2rem 15% 0px;
  color: #aaaaaa;
  margin-bottom: 14rem;
  text-align: center;
}

.Section.Text div.CTAButton {
  margin-top: 4rem;
}

.Section.Break {
  height: 50vh;
}

.Section img.FullWidth {
  width: 100%;
}
.Section.Text .ContentColumn img.FullWidth {
  margin-top: 4rem;
}

/* About Table *********************************************************/

.Section.Text table.Standard {
  margin-bottom: 4rem;
  margin-top: 4rem;
  border-radius: 2rem;
  border-spacing: 0rem;
  overflow: hidden;
  border-collapse: separate;
  border-spacing: 0 1px;
  font-size: 1.5rem;
}
.Section.Text table.Standard.HasTitle {
  margin-bottom: 6rem;
  margin-top: 0rem;
}
.Section.Text .TableTitle {
  text-align: center;
  margin-bottom: 1.5rem;
    margin-top: 6rem;
}
.Section.Text:not table.Standard th {
  text-align: left;
}

.Section.Text table.Standard tr td:first-child {
  color: #ffffff;
  background-color: #68608da1;
  padding: 2.5rem 4rem;
  text-align: center;
  font-family: "Titillium Web";
  font-size: 1.8rem;
}
.Section.Text table.Standard tr td:last-child {
  color: #eeeeee;
  background-color: #4d4273a1;
  padding: 0.75rem 3rem 0.75rem 2rem;
  text-align: left;
  color: #dddddd;
}

/*Pull back default padding-inline-start: 40px a bit */
.Section.Text table.Standard ul {
  margin-left: -20px;
}

/* Portfolio Table *********************************************************/

.Section.Portfolio .InfoBox {
  float: left;
  margin-right: 2rem;
}

.Section.Portfolio table {
  margin-bottom: 2rem;
  line-height: 2.3rem;
}
.Section.Portfolio th {
  text-align: left;
}
.Section.Portfolio .Content table {
  font-size: 1.6rem;
}
.Section.Portfolio tr td:first-child {
  color: #ffffff;
  background-color: #ffffff33;
  padding: 0.4rem 0.5rem 0.4rem 1rem;
  text-align: right;
}
.Section.Portfolio tr td:last-child {
  color: #eeeeee;
  background-color: #99999933;
  padding: 0.4rem 2rem 0.4rem 0.5rem;
  text-align: left;
}

/* margin hack as we can't use margin on td  */
/*
.Section.Text td::after {
  width: 1em;
  height: 1em;
  content: "";
  display: inline-block;
}
*/
/***********************************
    .Section.Text.Portfolio
************************************/

.Section.Portfolio {
  padding-bottom: 10rem;
}

.Portfolio .Content > p:first-child {
  display: none;
}

.Section img.FullWidth {
  height: 100vh;
  object-fit: cover;
}

.Section.Text .Content p {
  margin: 0;
  margin-bottom: 2rem;
}

.ImageCont::before,
.ImageCont::after {
  content: "";
  position: absolute;
  width: 100%;
  left: 0;
  height: 10px;
  z-index: 1;
}
.ImageCont::before {
  background: linear-gradient(
    180deg,
    rgb(100 100 100 / 73%) 0%,
    rgba(0, 0, 0, 0) 100%
  ) !important;
  top: 0;
}
.ImageCont::after {
  background: linear-gradient(
    0deg,
    rgb(100 100 100 / 73%) 0%,
    rgba(0, 0, 0, 0) 100%
  ) !important;
  bottom: 0;
}

.ImageCont button {
  cursor: pointer;
  width: 100%;
}

#videoOverlay {
  position: fixed;
  top: 0;
  left: 0;
  z-index: 999;
  width: 100%;
  height: 100%;
  position: fixed;
  background: rgba(0, 0, 0, 0.5);
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.3s;
}

#videoOverlay.Open {
  opacity: 1;
  pointer-events: all;
}

#videoOverlay > div {
  display: flex;
  flex-direction: column;
  align-content: center;
}

#videoOverlay button {
  cursor: pointer;
  margin-left: auto;
  font-size: 2rem;
  padding: 1em;
  margin-bottom: 2rem;
}

/***************************************************************************
    Footer
****************************************************************************/

.Footer {
  position: relative;
  top: 0px;
  width: 100%;
  height: auto;
  padding-top: 6rem;
  padding-bottom: 6rem;
  text-align: left;
  line-height: 3.2rem;
  font-size: 1.8rem;
  color: #cccccc;
  overflow: hidden;
  background-color: rgb(36 24 47 / 67%);
  z-index: 100;
  border-top: 1px solid #333333;
}

.Footer .Section {
  height: 100%;
}

#footerLeft {
  position: relative;
  float: left;
  width: 25rem;
  height: auto;
}

#footerRight {
  position: relative;
  float: right;
  margin-right: 18%;
}

.Footer div.CTAButton {
  margin-top: 1rem;
}

#footerTitle {
  color: #ffffff;
  font-size: 2.2rem;
  text-transform: uppercase;
  font-family: "Titillium Web", sans-serif;
  letter-spacing: 0.15rem;
}

.FooterStripe {
  background-color: #ffffff;
  width: 100%;
  height: 1px;
  margin-bottom: 1.8rem;
}

a.FooterLink {
  display: block;
  color: #eeeeee;
  text-decoration: none;
}

a.FooterLink:hover {
  color: #ffffff;
}

#footerAddress {
  margin-top: 2rem;
  color: #eeeeee;
  font-size: 1.6rem;
  line-height: 125%;
}

/*****************************************************************************************************************************
    RESPONSIVE RULEZ
*************************************************************************************************************************/
/*
      1600
    1400
      1222
    1025
    920
      768

*/

@media screen and (max-width: 75em) {
  .Section.Introduction {
    padding-bottom: 10rem;
  }
  .Section.Introduction h2 {
    line-height: 5.5rem;
  }
}
@media screen and (max-width: 48em) {
  .Section.Introduction.MobileFullWidth {
    padding-bottom: 8rem;
  }
}
@media screen and (max-width: 44em) {
  .Section.Introduction h2 {
    font-size: 4rem;
    line-height: 5rem;
  }

  table.Standard tr {
    display: flex;
    flex-direction: column;
  }
  .Section.Text table.Standard tr td:first-child {
    padding: 1.5rem;
  }
  .Section.Text table.Standard tr td:last-child {
    padding: 2rem;
  }
}

/* 550px */
@media only screen and (max-width: 34.375em) {
  .Section.Hero .FullBox {
    background: none;
  }

  .Section.Hero {
    --gradient-end: black;
  }
  .Section.Hero .SlideContainer {
    overflow: unset;
  }
  /* Above the hero image */
  .Section.Hero .SlideContainer::after {
    content: "";
    display: block;
    position: absolute;
    bottom: 0;
    left: 0;
    height: 10rem;
    width: 100%;
    background: linear-gradient(
      to top,
      var(--gradient-end),
      rgb(13 12 13/ 0%) 100%
    );
  }
  /* After the hero image reaching next section's start */
  .Section.Hero .SlideContainer::before {
    content: "";
    display: block;
    position: absolute;
    /* Height of the gradient is calculated as screen height minus image height */
    --height: calc(100 * var(--vh) - 70%);
    bottom: calc(-1 * var(--height));
    left: 0;
    height: var(--height);
    width: 100%;
    background: linear-gradient(
      to bottom,
      var(--gradient-end),
      rgb(33 10 23/ 100%) 100%
    );
  }

  .Section.Introduction h2 {
    font-size: 3.5rem;
    line-height: 4rem;
    margin-top: 10rem;
  }
  .Section.Introduction p {
    font-size: 1.8rem;
    line-height: 140%;
  }
}

/* 550px w 600px height*/
@media only screen and (max-width: 34.375em) and (max-height: 37.5em) {
  .Section.Hero .FullBox {
    background: none;
    padding-bottom: 7rem;
  }
}

/* 1700px */
@media screen and (max-width: 106.25em) {
  .Section.ContentCards .Item {
    width: calc(46% - 2px);
  }
  .Section.ContentCards .Item .Info {
    width: calc(100% - 10rem);
    padding: 5rem;
  }
  .Section.ContentCards .Item .Title {
    font-size: 4.2rem;
    letter-spacing: 0.2rem;
  }
  .Section.ContentCards .Item .Desc {
    margin-top: 4rem;
    font-size: 1.8rem;
  }
}
/* 1500px) */
@media screen and (max-width: 93.75em) {
  .Section.ContentCards .Item {
    width: calc(47% - 2px);
  }
  .Section.ContentCards .Item .Info {
    width: calc(100% - 8rem);
    padding: 4rem;
  }
  .Section.ContentCards .Item .Title {
    font-size: 4.1rem;
    letter-spacing: 0.2rem;
  }
  .Section.ContentCards .Item .Desc {
    margin-top: 3rem;
    font-size: 1.8rem;
    line-height: 122%;
  }
}

/* 1450px */
@media screen and (max-width: 90.625em) {
  .Section {
    /* width:1100px;*/
  }
  .Content img.M {
    width: 60%;
  }
  .Section .Content {
    padding: 4rem 5% 0px;
  }
  /*
  .Section.Text .TextColumn {
    padding: 4rem 15% 0px;
  }*/
}
/* 1222px */
@media screen and (max-width: 76.375em) {
  .Section .Title {
    font-size: 4.8rem;
  }
  .Section .Subtitle {
    font-size: 2rem;
  }
  .Section .Desc {
  }
  .Section.Hero .Subtitle {
    font-size: 3.2rem;
  }
  .Section.Hero .Subtitle.Big {
    font-size: 3.6rem;
  }
  .Section.ContentBoxCenter .Desc {
    max-width: 80%;
  }
  .Section.Intro .Subtitle {
    padding: 4rem 5% 0px;
  }
  .Section.Text .Subtitle {
    padding: 4rem 5% 0px;
  }
  .Section .Content {
    padding: 4rem 0% 0px;
  }
}

/* 1200px */
@media screen and (max-width: 75em) {
  .Section {
    width: 100%;
    box-sizing: border-box;
    padding: 0rem;
    margin: 0 auto;
  }
  .Header .Section {
    width: 100%;
  }
  .Section.Tiles .Subtitle {
    padding: 4rem 0px 0px;
  }
  .Content img.M {
    width: 66%;
  }
}

/* 1025px) */
@media screen and (max-width: 64.0625em) {
  .Section {
    padding: none;
  }
  .Section .DesktopOnly {
    display: none;
  }
  .Header .Section {
    height: 9rem;
  }
  .Header .LogoText {
    /* margin-top: 2.9rem; */
    /* font-size: 2rem; */
    letter-spacing: 0.1rem;
    margin-left: 2rem;
  }

  .DesktopMenu li {
    font-size: 1.5rem;
    /* margin-top: 3.4rem; */
    margin-left: 4rem;
  }
  .Section .Title {
    font-size: 4.6rem;
    letter-spacing: 0.2rem;
  }
  .Section .Subtitle {
    letter-spacing: 0.1rem;
    font-size: 1.8rem;
  }
  .Section .Desc {
    /* font-size: 18px;
        line-height: 26px;*/
  }
  .Section .Box {
    padding: 4rem;
  }
  .Section div.CTAButton {
    /*border: 1px solid #777777;
        background-color: rgba(20,20,20,0.6);*/
    padding: 1.3rem 2.5rem 1.2rem;
    font-size: 1.5rem;
    letter-spacing: 0.1rem;
    line-height: 100%;
  }
  /*
  .Section ul.List {
    letter-spacing: 0.1rem;
    font-size: 1.6rem;
  }
  */
  /* Layouts */
  .Section.Hero .Subtitle {
    font-size: 2.8rem;
  }
  .Section.Hero .Subtitle.Big {
    font-size: 3.6rem;
  }
  .Section.ContentBoxCenter .Desc {
    margin-top: 4rem;
  }
  .Section.ContentCards .Item {
    width: calc(47% - 2px);
  }
  .Section.ContentCards .Item:hover {
    border: 1px solid #cccccc;
  }
  .Section.ContentCards .Item.A {
    float: left;
  }
  .Section.ContentCards .Item.B {
    float: right;
  }
  .Section.ContentCards .Item .Info {
    width: calc(100% - 8rem);
    padding: 4rem 4rem 4rem 4rem;
    height: 24rem;
  }
  .Section.ContentCards .Item .Title {
    font-size: 3.8rem;
    letter-spacing: 1px;
  }
  .Section.ContentCards .Item .Desc {
    margin-top: 3rem;
  }
  .Section.ContentCards .Item .Action {
    margin-top: 2rem;
    font-size: 1.5rem;
  }
  .Footer {
    padding: 3rem 0px;
  }
  #footerRight {
    margin-left: 10rem;
  }
  .Section .Content {
    padding: 4rem 0% 0px;
  }
  .Section.Intro .Content {
    padding: 2rem 0%;
  }
}
/* 920px */
@media screen and (max-width: 57.5em) {
  .Header .DesktopMenu {
    display: none;
  }
  .Header .BurgerMenu {
    display: block;
    cursor: pointer;
  }
}
/* 900px */
@media screen and (max-width: 56.25em) {
  .Header .LogoText {
    margin-left: 1.5rem;
  }
  #footerRight {
    margin-right: 0px;
  }
}

/* 800px */
@media screen and (max-width: 50em) {
  .Header .DesktopMenu .Item {
    margin-left: 2rem;
    letter-spacing: 0px;
  }
}
.Desktop {
  display: block;
}
.Mobile {
  display: none;
}
/* 768px */
@media screen and (max-width: 48em) {
  .Desktop {
    display: none;
  }
  .Mobile {
    display: block;
  }
  .BackDark2Mobile {
    /*background-color:rgb(15 10 21 / 76%);*/
    background-color: rgb(26 13 39 / 66%);
  }
  .BackDark {
    background-color: rgb(26 13 39 / 66%);
  }
  .BackDarkFade {
    background: linear-gradient(
      to bottom,
      rgb(26 13 39 / 66%) 0%,
      /* rgba(128,128,128,0) 20%,*/ rgb(45 37 53 / 0%) 100%
    );
  }
  .OnlyWide {
    display: none;
  }
  .Header .DesktopMenu {
    display: none;
  }
  .Header .BurgerMenu {
    display: block;
  }
  .Section {
    padding: none;
  }
  .Section .ContentColumn {
    width: 80%;
  }
  .Section .ContentColumn.MobileFullWidth {
    width: 100%;
  }
  .Section.Text .Content {
    font-size: 1.7rem;
  }
  .Section .Box.MobileDark {
    background-color: rgb(45 37 53 / 29%);
  }
  .Section.MobileFullWidth {
    width: 100%;
    padding: 0px 0px;
  }
  .Section.MobileNoScreen {
    min-height: initial;
  }
  .Section.Space {
    height: 20vh;
  }
  .Section .Box {
    padding: 2rem;
  }
  .Section .Box.Dark {
    background-color: rgb(45 37 53 / 80%);
  }
  .Section .Box.DarkGray {
    background-color: rgb(35 35 35 / 70%);
  }
  .Section .Box.Narrow {
    padding: 1.5rem 2rem;
  }
  .Section .Box.Narrow.MobileFullWidth {
    width: calc(100% - 4rem);
  }
  .Section .Title {
    font-size: 3.8rem;
    letter-spacing: 0.1rem;
  }
  .Section .Desc {
    /*  font-size: 16px;
        line-height: 22px;*/
  }
  .Section .CTAText {
    font-size: 1.5rem;
  }
  /*
  .Section ul.List {
    letter-spacing: 0.1rem;
    font-size: 1.5rem;
    line-height: 2rem;
  }*/
  /* Layouts ********************/
  .Section.Hero .Title {
    /* text-align: center;
    margin-left: auto;
    margin-right: auto; */
  }
  .Section.Hero .Title.Big {
    font-size: 3.6rem;
  }
  .Section.Hero .Subtitle {
    text-align: center;
    font-size: 2.5rem;
    margin-left: auto;
    margin-right: auto;
  }
  .Section.Hero .Subtitle.Big {
    font-size: 3.6rem;
  }
  .Section.Hero .Box.Narrow {
    padding: 2rem 2rem;
  }
  .Section.Hero .Box.Narrow.MobileFullWidth {
    width: calc(100% - 4rem);
  }
  .Section.LandingLogoTitleLines .Box {
    padding: 4rem;
    width: calc(100% - 8rem);
  }
  .Section.LandingLogoTitleLines .Title {
    width: 100%;
    text-align: center;
  }
  .Section.LandingCenterTitle .Box.Bottom {
    bottom: 6rem;
  }
  .Section.ContentBox .Box {
    margin: auto;
    padding: 4rem;
    width: calc(100% - 8rem);
    margin-bottom: 50vh;
  }
  .Section.ContentBox .Title {
    margin: auto;
    text-align: center;
    font-size: 4rem;
  }
  .Section.ContentBox .Desc {
    margin: auto;
    text-align: center;
    margin-top: 4rem;
    font-size: 1.8rem;
  }
  .Section.ContentBox div.CTAButton {
    margin-top: 3rem;
  }
  .Section.ContentBoxCenter .Box {
    margin-top: 10vh;
    padding: 6rem 2rem;
    width: calc(100% - 4rem);
  }
  .Section.ContentBoxCenter .Title {
    margin-top: 0px;
    padding-top: 0px;
  }
  .Section.ContentBoxCenter .Desc {
    max-width: 100%;
  }
  .Section.ContentCards .Content {
    /*margin-top: 30%;*/
  }
  .Section.ContentCards .Title {
    margin: auto;
  }
  .Section.ContentCards .Info .Title {
    margin: initial;
  }
  .Section.ContentCards .Desc {
    margin-top: 4rem;
  }
  .Section.ContentCards .Item {
    width: calc(100% - 2px);
    margin: auto;
    margin-bottom: 10rem;
    max-width: 44rem;
  }
  .Section.ContentCards .Item .Info {
    height: auto;
  }
  .Section.ContentCards .Item.A {
    float: none;
  }
  .Section.ContentCards .Item.B {
    float: none;
  }

  .Section.Intro .Subtitle {
    padding: 4rem 5% 0px;
    color: #cccccc;
    margin-bottom: 8rem;
  }
  .Section.Tiles .Content {
    padding: 0px 2rem;
  }
  /* Footer **************/
  #footerLeft {
    float: none;
    line-height: 2.8rem;
    margin: auto;
  }
  #footerAddress {
    margin-top: 1.5rem;
    font-size: 1.6rem;
    line-height: 100%;
  }
  #footerRight {
    width: 25rem;
    margin-left: 0px;
    float: none;
    margin: auto;
    margin-bottom: 4rem;
  }
  .Section .Content {
    padding: 4rem 0% 0px;
  }

  .Section.Intro .Content {
    padding: 2rem 0%;

    letter-spacing: 0.1rem;

    font-size: 2rem;
    line-height: 3.2rem;
  }
  p {
    line-height: 140%;
  }
  .Content img.M {
    width: 75%;
  }
}

/* 630px */
@media screen and (max-width: 39.375em) {
  .Section.Tiles.Wide {
    padding: 0px 0px;
    width: 100%;
  }
  .Section.Tiles.Wide .Content {
    padding: 0px 0px;
  }
  ul.List {
    padding-left: 3rem;
  }
  .Section h2 {
    font-size: 4.2rem;
    line-height: 4.5rem;
  }
  .Section.Portfolio .InfoBox {
    float: none;
    margin-right: 0;
    display: flex;
    flex-direction: column;
    align-items: center;
  }
  .Portfolio .Content > p {
    display: none;
  }
  .Portfolio .Content > p:first-child {
    display: block;
  }
  .Section.Portfolio .InfoBox div.CTAButton {
    margin-bottom: 2rem;
  }
  .Section.Portfolio h2 {
    margin-top: 4rem;
    margin-bottom: 2rem;
    line-height: 120%;
    font-size: 4rem;
  }
}

.Section br.Break480 {
  display: none;
}
.Section br.MobileBreak {
  display: none;
}
.Section br.MobileNoBreak {
  display: initial;
}

/* 530px */
@media screen and (max-width: 33.125em) {
  .Section.ContentBox .Title {
    margin: auto;
    font-size: 3.7rem;
  }
  .Section.ContentBox .Desc {
    margin: auto;
    text-align: center;
    margin-top: 4rem;
    font-size: 1.7rem;
  }
  .Section br.MobileBreak {
    display: initial;
  }
  .Section br.MobileNoBreak {
    display: none;
  }
}


/* 480px */
@media screen and (max-width: 30em) {
  .Section {
    padding: none;
  }
  .Section .ContentColumn {
    width: 90%;
  }
  .Section h1 {
    font-size: 4rem;
  }
  .Section.Tiles {
    padding: 0;
  }
  .Section.MobileFullWidth {
    width: 100%;
    padding: 0px 0px;
  }
  .Section.Last {
    padding-bottom: 8rem;
  }
  .Section br.Break480 {
    display: initial;
  }

  .Section .Title {
    letter-spacing: 2px;
    font-size: 3.6rem;
  }
  .Section .Box {
    padding: 1.5rem;
  }
  .Section .Box.Narrow {
    padding: 1.5rem 1.5rem;
  }
  /* Layout *************************/
  .Section.Hero .Title.Big {
    font-size: 3.0rem;
  }
  .Section.Hero .Subtitle {
    font-size: 2.2rem;
  }
  .Section.Hero .Subtitle.Big {
    font-size: 2.6rem;
  }
  .Section.LandingLogoTitleLines .Box {
    padding: 2rem;
    width: calc(100% - 4rem);
  }
  .Section.ContentBox .Box {
    padding: 3rem 1.5rem;
    width: calc(100% - 3rem);
  }
  .Section.ContentBox .Title {
    font-size: 3.6rem;
  }
  /*
  .Section.InfoBox .Subtitle {
    font-size: 1.8rem;
    letter-spacing: 0px;
  }
  */
  .Section.Tiles .Content {
    padding: 4rem 0px 0px;
  }
  .Section.Intro .Title {
    margin-top: 8rem;
  }
  .Section.Intro .Subtitle {
    padding: 4rem 0px 0px;
    margin-bottom: 3rem;
    letter-spacing: 0.1rem;
    line-height: 2.2rem;
  }
  .Footer {
    /*margin-top:100px;*/
  }
  .Section .Content {
    padding: 2rem 0% 0px;
  }
  .Content img.M {
    margin: auto;
    display: block;
    width: 100%;
  }
  .Section.Intro .Content {
    padding: 2rem 0%;

    letter-spacing: 0.1rem;

    font-size: 1.9rem;
    line-height: 3.2rem;
  }
  .Section h2 {
    font-size: 3.6rem;
    line-height: 4rem;
  }
}

@media screen and (max-width: 24em) {
  .Section.Introduction h2 {
    font-size: 2.8rem;
    line-height: 3.5rem;
    margin-top: 9rem;
    margin-bottom: 5rem;
  }
  .Section.Introduction p {
    font-size: 1.5rem;
    line-height: 130%;
  }
}

/* 365px */
@media screen and (max-width: 22.8125em) {
  .Header .LogoText {
    letter-spacing: 0.1rem;
    margin-left: 1rem;
  }
  .Section.Text .Content .Price {
    padding: 1rem 1.5rem;
    font-size: 1.6rem;
    margin-top: 3rem;
  }
}
