.introPage {
  margin: 0;
  padding: 0;
  /* removed by Simon
  top: 0;
  left: 0;
  bottom: 0;
  right: 0;
  */
  height: /*100vh*/ calc(100vh - 55px); /* changed by Simon */
  background: url(https://infrastructure.aecom.com/hubfs/FOI2/img/starrs.jpg) center no-repeat fixed #272726;
  -webkit-background-size: cover;
  -moz-background-size: cover;
  -o-background-size: cover;
  background-size: cover;
  position: relative; /* added by Simon */
  overflow:hidden;


}

body:not(.city) .body-container-wrapper {
    overflow-x: hidden;
}


.introContent {
  position: absolute;
  top: /*10%*/0;
  left:/*40px*/10px;
  z-index: 10;
  pointer-events: none;
}

.introText {
  position: absolute;
  bottom: /*20%*/20px;
  left: /*40px*/10px;
  z-index: 10;
  pointer-events: none;
}

.introPage p {
    color: #fff;
    font-family: aecom_sansbold;
    font-size: /*0.9em*/1em;
    line-height: 1.4em;
    margin-bottom: /*40px*/0;
    font-size: 1.5rem;
}



@media screen and (min-width: 640px) {
  .introContent, .introText {
    left: 20px;
  }
  .introText {
    bottom: 120px;
  }
}

@media screen and (min-width: 1024px) {
   .introContent, .introText {
    left: 40px;
  }
  .introContent {
    /*top: 10%;*/
  }
  .introText {
    bottom: 20%;
  }
}

.introPage h2 {
    /*font-family: EngschriftDIND;
    font-size: 2.4rem;*/ /* Removed by Simon */
    display: inline;
    line-height: 2rem;
    padding: 5px 0;
    width: 100px;
    margin: 10px auto;
}
.introPage h1 {
    color: #ffe400;
    /*letter-spacing: 3px;
    line-height: .8em;
    font-size: 4rem;*/ /* Removed by Simon */
    margin-bottom: 30px;
}
.introPage h2 span {
    display: inline-block;
    line-height: 1;
    padding: 0.05em 0.15em;
    box-decoration-break: clone;
    -webkit-box-decoration-break: clone;
    background-color: white;
    color: #000;
}

#webgl{
  /*width:100vw;*/
  width: 100%;
  height:calc(100vh - 55px);
  overflow:hidden;
}
#webgl canvas{
    display: inline-block;
    vertical-align: baseline;
}

.webgl-error {
  font: 15px/30px monospace;
  text-align: center;
  color: #fff;
  margin: 50px;
}

.webgl-error a {
  color: #fff;
}


.balloon {
  position: absolute;
  color: white;
  background: rgba(0, 0, 0, 0.7);
  border: white 2px solid;
  border-radius: 100px;
  font-family: sans-serif;
  font-size: 20px;
  width: 100px;
  height: 30px;
  text-align: center;
  padding-top: 7px;
  font-family: EngschriftDIND, Arial;
  text-transform: uppercase;
  margin: 0;
  line-height: .7em;
  font-weight: lighter;
  opacity: 0;
  transition: opacity 1s;
  box-sizing: border-box;
  cursor:pointer;
}

.showBallon {
  opacity: 1;
  transition: opacity 1s;
}

.balloon .arrowpointer {
  left: 40px;
  margin-top: 9px;
  border-width: 10px 10px 0px;
  border-color: white transparent transparent;
  position: absolute;
  width: 0px;
  height: 0px;
  border-style: solid;
}

.globemodal {
  position: absolute;
  color: black;
  background: rgba(255, 255, 255, 0.9);
  font-family: aecom_sanslight, Arial;
  font-size: 20px;
  width: 70vw;
  height: 75vh;
  text-align: center;
  padding: 1px
}

.animate_modal {
  transform-origin: 0% 30%;
  animation: growBox 2s;
}

@keyframes growBox {
  0% {
    transform: scale(0)
  }
  40% {
    transform: scale(0)
  }
  100% {
    transform: scale(1)
  }
}

.introPage .globemodal p:first-child {
    color: black;
      font-family: aecom_sansbold;
    font-size: 1.1rem;
    margin-bottom: 1.8rem;
}
.introPage .globemodal p {
  font-family: aecom_sanslight,Helvetica,Arial,sans-serif;
  color: black;
 font-size: 1.1rem;
}
.globemodal p:last-child {
  font-weight: lighter;
  color: black;
  font-size: 0.9rem;
}

img.globestatic {
  height:85vh;
  position:absolute;
  top:100px;
  right:120px;
  
  
}
.OutlineCTA{
    
 
    color: #000000;
    background: 0 0;
    font-family: aecom_sansbold;
    font-size: .85rem;
    text-transform: uppercase;
    white-space: nowrap;
    border: 2px solid #000000;
    border-radius: 1.5em;
    padding: .9em 1.5em .6em;
    transition: all .3s ease;
    position: absolute;
    bottom: 40px;
    text-decoration:none;

  
}
.globemodalclose {
    position: absolute;
    width: 70px;
    height: 70px;
    right: 10px;
    margin-top: 5px !important;
}



.modalHeader {
  width: 100%;
  color: white;
  margin-bottom: 10px;
}


.modalHeader h3 {
    color: white;
    font-size: 2em;
    margin-bottom: 15px;
    margin-top: 35px !important;
    padding-left: 5px;
}

.CityName {
  color: white;
  font-size: 3rem;
  margin-bottom: 20px;
  margin-top: 10px;
  padding-left: 5px;
}

.weather {
  position: absolute;
  float: left;
  width: 50px;
  height: 50px;
    right: 60px;
    margin-top: 23px !important;
}





.Time {
  font-size: 2rem;
  font-family: EngschriftDIND, Arial;
  text-transform: uppercase;
  color: white;
  position: absolute;
right: 130px;
  padding-top: 4px;
  margin-top: 23px !important;
}


.LatLong {
  font-size: 1.3rem;
  font-family: EngschriftDIND, Arial;
  text-transform: uppercase;
  color: white;
  padding-left: 5px;
}


.Outline {
  color: yellow;
  font-size: 6.5rem;
  font-family: EngschriftDIND, Arial;
  text-transform: uppercase;
  margin: 0;
  line-height: .7em;
  font-weight: lighter;
  -webkit-text-fill-color: rgba(0, 0, 0, 0);
  /* Will override color (regardless of order) */
  -webkit-text-stroke-width: 3px;
  -webkit-text-stroke-color: #ffe400;
}

.introPage .arrow {
  position: absolute;
  bottom: 20px;
}

.bounceArrow {
  animation-name: bounce;
}

.animatedArrow {
  animation-iteration-count: infinite;
  animation-fill-mode: both;
  animation-duration: 3s;
}


.globemodal p.modalsubhead{
    font-family: aecom_sanslight,Arial;
    font-size: .8rem;
    font-weight: normal;
    line-height: 1.4;
    margin-bottom: 5px;
    margin-top: 5px;
}


.Loader{
position:absolute;
top:0;
left:0;
width:100vw;
height:100vh;
z-index:6000;

}
.globe {
	border: 2px solid #ffe500;
	border-radius: 50%;
	height: 140px;
	left: 50%;
	overflow: hidden;
	position: relative;
    top: 40%;
    transform: translate(-50%, -40%);
	width: 140px;
}

.globe svg {
	animation: rotation 5s linear 0s infinite;
}

.globe svg path {
	stroke: #ffe500;
}

@keyframes rotation {
	from {
		transform: translateX(0);
	}

	from {
		transform: translateX(-50%);
	}
}

.loader_text {
    text-align: center;
    font-size: 0.9rem;
    color: #ffe500;
    font-family: aecom_sanslight,Helvetica,Arial,sans-serif;
    left: 50%;
    overflow: hidden;
    position: relative;
    top: 37%;
    transform: translate(-50%, -37%);
  width:300px;
  
}
.loader_text p:first-child{
      font-size: 1.5rem;
    font-family: EngschriftDIND,Arial;
    text-transform: uppercase;
  
}


.loader_text p{
        font-size: 1rem;
  text-align:center;
  font-size:0.9rem;
  color:#ffe500;
 font-family: aecom_sanslight,Helvetica,Arial,sans-serif;
}






@media screen and (max-width:1025px) {
.introPage, .modalHeader {
  background-attachment: scroll!important;
}
}

/* Landscape */
@media only screen 
  and (min-width: 1024px) 
  and (max-height: 768px) 
  and (orientation: landscape) 
  and (-webkit-min-device-pixel-ratio: 1.5) {
    
    .hide-medium{
    display:none
    }
    .medium-100{
    width:100%!important;
    }

}

@media screen and (max-height:800px) and (min-width:640px)  {
  .globemodal{
  width:60vw;
    height:90vh;
    overflow:hidden;
  }
  
  
  .introPage .globemodal p {
    font-size:1rem
  }
  .introPage .globemodal p:first-child {

    font-size: 1rem;
    margin-bottom: 1.2rem;
}
  .Outline{
    font-size: 6rem;
    
  }
.modalHeader h3 {
   
    font-size: 1.5em!important;
    margin-bottom: 15px!important;
    margin-top: 25px !important;

}
  .Time {
    font-size: 1.5rem!important;
    margin-top: 13px !important;
  }
  .weather {
    width: 30px;
    height: 30px;
    right: 75px;
    margin-top: 20px !important;
  }
  
  
}

@media screen and (max-height:700px)and (min-width:640px)  {
  
    .globemodal{
    width: 60vw;
    height: 85vh;
    margin-top: 30px;
  }
  .globalmodal .index_thumbs.Thumbs_small{
   display:none!important; 
  }
  
  
  .introPage .globemodal p {
       font-size: 0.9rem;
  }
  .introPage .globemodal p:first-child {

       font-size: 0.9rem;
    margin-bottom: 1.2rem;
}
    .Outline{
    font-size: 5rem;
    
  }
 
  
}
@media screen and (max-height:600px) and (min-width:640px) {
  
    .globemodal{
      margin-top: 60px;
  }
  
  
  .introPage .globemodal p {
       font-size: 0.8rem;
  }
  .introPage .globemodal p:first-child {

       font-size: 0.8rem;
    margin-bottom: 1rem;
}
 
  
}

@media screen and (min-width:321px) and (max-width:640px) {
  
  
  
  .introPage p {
     font-size: 1.1rem!important;
}

  .balloon {
    position: absolute!important;
    color: white!important;
    background: rgba(0, 0, 0, 0.7)!important;
    border: white 2px solid!important;
    border-radius: 100px!important;
    font-size: 15px!important;
    width: 75px!important;
    height: 22px!important;
    text-align: center!important;
    padding-top: 4px!important;
    font-family: EngschriftDIND, Arial!important;
    text-transform: uppercase!important;
    margin: 0!important;
    line-height: .7em!important;
    font-weight: lighter!important;
  }


  .globemodal {
    font-family: aecom_sanslight, Arial!important;
    font-size: 14px!important;
    width: 100vw!important;
    height: 90vh!important;
     margin-top: 0!important;

}


.LatLong {
    font-size: 1rem!important;
}
.Outline {

    font-size: 7rem!important;

}

.modalHeader h3 {

    font-size: 2em!important;

}

.Time {
    font-size: 1.3rem!important;
    font-family: EngschriftDIND,Arial!important;
    text-transform: uppercase!important;
    color: white!important;
    position: absolute!important;
    right: 86%!important;
    top: -25px!important;
    padding-top: 4px!important;
}

.weather {
    position: absolute!important;
    float: left!important;
    width: 40px!important;
    height: 30px!important;
    right: 50px!important;
    top: -22px!important;

}
  
  .introText {
    bottom: 140px!important;
  }
  
  .loader_text {
    text-align: center;
    font-size: 0.9rem;
    color: #ffe500;
    font-family: aecom_sanslight,Helvetica,Arial,sans-serif;
    left: 50%;
    overflow: hidden;
    position: relative;
    top: 35%;
    transform: translate(-50%, -35%);
    width: 300px;
}
  
  .globe {
    border: 2px solid #ffe500;
    border-radius: 50%;
    height: 100px;
    left: 50%;
    overflow: hidden;
    position: relative;
    top: 35%;
    transform: translate(-50%, -35%);
    width: 100px;
  }
  
  
  
  
}





@media only screen and (min-device-width: 320px) and (max-device-height: 568px) and (-webkit-device-pixel-ratio: 2)and (orientation : landscape) { #buttons-wrapper, .introText{display:none; }}

    /* iphone 6, 6s, 7, 8 */
    @media only screen and (min-device-width: 375px) and (max-device-height: 667px) and (-webkit-device-pixel-ratio: 2)and (orientation : landscape) { #buttons-wrapper, .introText{display:none; }}

    /* iphone 6+, 6s+, 7+, 8+ */
    @media only screen and (min-device-width: 414px) and (max-device-height: 736px) and (-webkit-device-pixel-ratio: 3)and (orientation : landscape) { #buttons-wrapper, .introText{display:none; }}

    /* iphone X */
    @media only screen and (min-device-width: 375px) and (max-device-height: 812px) and (-webkit-device-pixel-ratio: 3)and (orientation : landscape) { #buttons-wrapper, .introText{display:none; }}

    /* iphone XR */
    @media only screen and (min-device-width : 414px) and (max-device-height : 896px) and (-webkit-device-pixel-ratio : 2)and (orientation : landscape) { #buttons-wrapper, .introText{display:none; }}

   /* iphone XS */
    @media only screen and (min-device-width : 375px) and (max-device-height : 812px) and (-webkit-device-pixel-ratio : 3)and (orientation : landscape) { #buttons-wrapper, .introText{display:none; }}

   /* iphone XS Max */
    @media only screen and (min-device-width : 414px) and (max-device-height : 896px) and (-webkit-device-pixel-ratio : 3)and (orientation : landscape) { #buttons-wrapper, .introText{display:none; }}

