
body {
    background: #666666;
    margin: 0;

    font-family: Arial,sans-serif !important;
  font-size: 12px;
  background-color:#666 !important;

  height: 100vh;
}
html{



    height: 100vh;
}
p{
    text-align: left;
}

.loading-overlay {
    display: none;
    background: rgba( 26, 26, 26, 0.7 );
    position: fixed;
    width: 100%;
    height: 100%;
    z-index: 9998;
    top: 0;
}
.loading-overlay-image-container {
    display: none;
    position: fixed;
    z-index: 9999;
    top: 50%;
    left: 50%;
    transform: translate( -50%, -50% );
}
.loading-overlay-img {
    width: 50px;
    height: 50px;
    border-radius: 5px;
}
input{
    z-index: 2000;
    cursor: text;
    pointer-events: fill;
}
.airport-input{
    width: 320px;
    height: 2.2em;
    font-size: 1.1em;
    border-radius: 3px;
    border: 1px solid #999;
    max-width: 100%;
}

.tipTrigger{
    z-index: 2000;
    background-color: #666677;
    color: #fff;
    font-weight: 700;
    font-style: italic;
    border-radius: 50px;
    padding: 5px 10px;
    font-size: 0.85em;
    display: inline-block;
    width: 1em;
    height: 1em;
    position: relative;
    cursor: pointer;
}

.section{

    display: block;
    width: inherit;
    opacity: 1;
}
#pagewrapper{
    width: 100vw;
    height: 100vh;

    display: block;
    position: absolute;
    overflow: hidden;
}
#mapLayer{
    width: 100vw;
    height: 100vh;
}

#header {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    max-width: 100%;
    display: flow-root;
    flex-flow: column wrap;
    text-align: center;
    transform-origin: top center;
    transform:scale(0.8);
}
@media only screen and (min-width: 800px) {
    #header {
        transform:scale(1);
    }
}
@media only screen and (min-width: 1024px) {
    #header {
        transform:scale(1.3);
    }
}
@media only screen and (min-width: 1500px) {
    #header {
        transform:scale(1.5);
    }
}

.flexwrap{
    display: inline-block;
    margin-top: 8px;
    max-width: 100%;
    width: 375px;
    color: #fff;
    margin-right: 10px;
    
}

.flexwrap .lbl{
    padding: 5px;
    font-size: 1em;
}

.resized-splitflap{
    transform: scale(1);
    width: 100%;
}
#sf01{
    transform-origin: top right;
}
#sf02{
    transform-origin: top left;
}
/* 
@media only screen and (min-width: 380px) {
    .resized-splitflap{
        width: 100%;
    }
    .flexwrap .lbl{
        font-size: 1em;
    }
} */


.titlebar{
    position: relative;
    top: 0;
    left: 0;
    right: 0;
    padding: 3px;
    height: auto;
    background-color: #e3e3e3;
    border-bottom: 1px solid #d3d3d3;
    font-weight: bold;
}
.contentpane{
    padding: 15px;
    font-size: 0.8em;
}

@media only screen and (min-width: 500px) {
    .contentpane{
        font-size: 1em;
    }
}


#footer {
    position: fixed;
    bottom: 0;
    left: 0;
    right: 0;
    height: 20px;
    padding: 5px 0 0 0;
    background-color: #e3e3e3;
    text-align: center;
    font-weight: 700;
    color: #333;
}
#content {
    position: absolute;
    left: 0;
    bottom:0;
    right: 0;
    overflow: auto;
    border:none;
}
#tracefld{
    background: #eee;
    border: 1px solid #000;
    display: block;
    position: absolute;
}

#content *{
    pointer-events: none;

}

#entry-box{
    display: block; 
    margin: 20px auto; 
    width: 80%; 
    pointer-events: all;
}

#messages{
    pointer-events: none;
}

.large-message{
    opacity: 0;
    margin: 150px 0 0;
    left: 0;
    width: 100%;
    display: block;
    position: absolute;
    top: 0;
    padding: 0;
    font-size: 6em;
    font-weight: 700;
    color: rgba(255,255,255,0.8);
    transition: all 0.75s linear;
    text-align: center;
}

.medium-message{
    opacity: 0;
    margin: 250px 0 0;
    left: 0;
    width: 100%;
    display: block;
    position: absolute;
    top: 0;
    padding: 0;
    font-size: 3em;
    font-weight: 700;
    color: rgba(255,255,255,0.8);
    transition: all 0.75s linear;
    text-align: center;
}



/* // no of <li> elements, has to be an even number. Still learning how sass works, I'm getting a warning when an odd number is used. */
/* // use this number to divide both animation duration for <ul> and animation delay for <li>. Controls the speed of the animation. Greater = faster. */


  .message-li {
    position: absolute;
    top: 0;
    transform: translateY(100vh);
    font-size: 1.2rem;
    line-height: 1.6rem;
    font-family: sans-serif;
    font-weight: normal;
    list-style: none;
    padding-bottom: 24rem;
  }
        .message-li-smaller{
            font-size: 1rem;
            line-height: 1.3rem;
        }

  #str-li-info-box-en-0{
      font-weight: 700 !important;
  }

  @keyframes slide-up {
    0% {
      transform: translateY(101vh);
    }
    100% {
      transform: translateY(-100vh) ;
    }
  }
  
  @media only screen and (min-width: 480px) {
    .message-li{
        font-size: 1.5rem;
        line-height: 1.8rem;
    }
    .message-li-smaller{
        font-size: 1.1rem;
        line-height: 1.4rem;
    }
    }
    @media only screen and (min-width: 800px) {
        .message-li{
            font-size: 2.0rem;
            line-height: 2.6rem;
            font-weight: lighter;
        }
        .message-li-smaller{
            font-size: 1.6rem;
            line-height: 2.0rem;
        }
      }

  

.autocomplete-items{
    z-index: 2000;
    text-align: left;
    cursor: pointer;
    pointer-events: fill;
    position: absolute;
    background: #f9f9f9;
    padding: 1px 1px;
    border: 1px solid #eee;
    height: auto;
    max-height: 170px;
    overflow: auto;
    border-radius: 5px;
    width: 320px;
    max-width: 100%;
}
.autocomplete-items > div{
    border-bottom: 1px solid #ccc;
    padding: 0.4rem 0.4rem;
    max-width: 100%;
}
.autocomplete-items > div:hover{
    background: #dde;
}
.autocomplete-active{
    background: #dde;
}
.autocomplete-items > div:last-child{
    margin-bottom: 90px;
}

@media only screen and (min-width: 480px) {

    .autocomplete-items > div:last-child{
        margin-bottom: 3px;
    }
}


#info-box, #info-box-en{
    pointer-events: none !important;
    height: 100%;
    min-height: 150px;
    bottom: 0;
    background: none;
    color: rgba(255,255,255,0.8);
    display: block;
    position: absolute;
    width:55%;
    line-height: 6rem;
}
#info-box{
    margin-left: 2vw;
    text-align: left;
    left:0;
}
#info-box-en{
    margin-right: 2vw;
    text-align: right;
    right:0;
    padding-top: 1.85rem;
}

.uilayer{
    z-index: 2000;
    display: block;
    height: 100vh;
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    user-select: none;
    pointer-events:none;
}

.uimask{
    z-index: 1950;

    position: absolute;
    background: rgba(0,0,0,0.7);
    height: 100%;
    width: 100%;

    display: none;
    align-items: center;
}
.alertP{
    z-index: 2000;

    border:1px solid #d3d3d3;
    border-radius: 5px;
    box-shadow: 1px 1px 5px rgba(0,0,0,0.6);
    background: #efefef;
    display: block;
    position: relative;
    width: 700px;
    max-width: calc(100% - 30px);
    margin:  auto;

    height: 600px;
    /* min-height: 300px; */
    max-height: calc(100% - 30px);

    top: 50%;
    transform: translateY(-50%);

    text-align: center;
    align-items: center;
    align-content: center;
}
.alertP > p {
    display: inline-block; 
    margin: 20px auto 0; 
    width: 80%;
}
.alertP > .contentpane > p {
    display: inline-block; 
    margin: 20px auto 0; 
    width: 80%;
}
.alertP p.intro {
    font-size: 1.8em; 
    font-weight: 700; 
    line-height: 1.3em; 
    margin-top: 20px; 
    display: inline-block; 
    color: #666;
}

@media only screen and (min-width: 500px) {

    .alertP p.intro {
        font-size: 2em; 
    }
}
@media only screen and (min-width: 800px) {

    .alertP p.intro {
        font-size: 2.5em; 
    }
}
.buttonbar{

    position: relative;
    margin: 20px auto;
    left: 0;
    right: 0;
    height: auto;
}
.button{
    display: inline-block;
    padding: 8px 10px;
    min-width: 80px;
    margin: 15px;
    border-radius: 3px;
    color: #ffffff;
    background: rgb(39, 89, 181);
    border: 1px solid #2e2e69;
    box-shadow: 1px 1px 5px rgba(0,0,0,0.7);
    cursor: pointer;
    opacity: 1;
    pointer-events: fill;
}
.button:hover{
    background: rgb(23, 53, 109);
    box-shadow: 1px 1px 2px rgba(0,0,0,0.4);
    transform:translate(1px,1px);
}
.button-disabled{
    pointer-events: none;
    opacity: 0.75;
}
.button-centered{
    position: absolute;
    margin-left:-40px;
    left:50%;
    top:50%;
    text-align: center;
}
.button-centered-bottom{
    position: absolute;
    margin-left:-40px;
    left:50%;
    top:unset;
    bottom:40px;
    text-align: center;
}

.white-outline{
    outline-offset: 2px;
    outline: 2px white solid;
}





/* MAP STYLES */



.mark{
    pointer-events: none;

    stroke: #ffffff;
    stroke-width: 2;
}


.travels{
    fill:none;
    stroke: #00ccff;
    stroke-width: 2;
    stroke-dasharray: 5,5,2,5;

}

.maskline{
    fill:none;
    stroke: #9999cc;
    stroke-width: 6;
    /* stroke-dasharray: 10,10; */

}

.country-shape{

    stroke-width: 0.6;
    stroke-opacity: 1;
    stroke: #666666;
    fill: #000;
}

.shape-hilight{
    fill:rgb(179, 107, 0);
}

.path-hilight, xpath:hover {
    stroke-width: 1.5;
    stroke-opacity: 1;
    stroke: rgb(179, 107, 0);
    z-index: 380;
  }
  
  .graticule{
    stroke-width: 0.5 !important;
    stroke: #1a1a1a !important;
    fill: none;
  }
  
  .graticule:hover{
    stroke-width: 0.5 !important;
    stroke: #1a1a1a !important;
    fill: none;
  }
  
  .sphere{
    stroke-width: 0.5 !important;
    stroke: #aaa !important;
    fill: #000000;
  }
  
  .sphere:hover{
    stroke-width: 0.5 !important;
    stroke: #aaa !important;
    fill: #000000;
  }
  
