/* --------------------------------

Primary style

-------------------------------- */

@font-face {
    font-family: gt-walsheim-black;
    src: url(../fonts/gt-walsheim-black.woff);
}

@font-face {
    font-family: gt-walsheim-medium;
    src: url(../fonts/gt-walsheim-medium.woff);
}

@font-face {
    font-family: gtsuperdisplay-regular;
    src: url(../fonts/gtsuperdisplay-regular.woff);
}

article,
aside,
details,
figcaption,
figure,
footer,
header,
hgroup,
main,
nav,
section,
summary {
    display: block;
}

audio,
canvas,
video {
    display: inline-block;
    *display: inline;
    *zoom: 1;
}

audio:not([controls]) {
    display: none;
}

[hidden] {
    display: none;
}

h1 {
    font: 3.25vw 'gt-walsheim-medium', arial, sans-serif;
    font-weight: 400;
    color: #052c4b;
    margin-bottom: .75rem;
}

h2 {
    font: 2vw 'gtsuperdisplay-regular', arial, sans-serif;
    font-weight: 400;
    color: #052c4b;
    margin-bottom: .75rem;
}

h3 {
    font: 4.25vw 'gt-walsheim-black', arial, sans-serif;
    font-weight: 400;
    color: #ece847;
    margin-bottom: .75rem;
}

h4 {
    font: 2.75vw 'gtsuperdisplay-regular', arial, sans-serif;
    font-weight: 400;
    letter-spacing: .5px;
    color: #fff;
    margin-bottom: .75rem;
}

p {
    font: 1.33vw 'gt-walsheim-medium', arial, sans-serif;
    font-weight: 400;
    color: #052c4b;
    margin-bottom: .75rem;
}

footer p {
    font: 1vw 'gtsuperdisplay-regular', arial, sans-serif;
    font-weight: 400;
    letter-spacing: 0.1rem;
    margin-bottom: .75rem;
}

footer a {
    font: 2vw 'gt-walsheim-medium', arial, sans-serif;
    font-weight: 400;
    letter-spacing: 0.1rem;
    color: #ece847;
    margin-bottom: .75rem;
    text-decoration: none;
}

footer .made {
    padding-top: 2rem;
    font-size: 80%;
    color: #fff;
}

footer .made a {
    font-size: 100%;
    color: #fff;
}

@media (max-width: 768px) {
    h1 {
        font: 2.75rem 'gt-walsheim-medium', arial, sans-serif;
        font-weight: 600;
        line-height: 0.9em;
        padding-bottom: 1%;
    }
    h2 {
        font: 2rem 'gtsuperdisplay-regular', arial, sans-serif;
    }
    h3 {
        font: 2.25rem 'gt-walsheim-black', arial, sans-serif;
        font-weight: 600;
        margin-bottom: .75rem;
    }
    h4 {
        font: 2rem 'gtsuperdisplay-regular', arial, sans-serif;
        font-weight: 400;
        letter-spacing: .5px;
        color: #fff;
        margin-bottom: .75rem;
    }
    p {
        font: 1.5rem 'gt-walsheim-medium', arial, sans-serif;
        letter-spacing: 0.1rem;
        margin-bottom: .75rem;
    }
    footer p {
        font: 1.5rem 'gtsuperdisplay-regular', arial, sans-serif;
        font-weight: 400;
        letter-spacing: 0.1rem;
        margin-bottom: .75rem;
    }
    footer a {
        font: 1.75rem 'gt-walsheim-medium', arial, sans-serif;
        font-weight: 400;
        letter-spacing: 0.1rem;
        margin-bottom: .75rem;
        text-decoration: none;
    }
}

footer a:hover {
    color: #d4d115;
    text-decoration: underline;
}

.text-white {
    color: #fff;
}

.scroll-top {
    cursor: pointer;
}

*,
*:before,
*:after {
    -moz-box-sizing: border-box;
    -webkit-box-sizing: border-box;
    -o-box-sizing: border-box;
    -ms-box-sizing: border-box;
    box-sizing: border-box;
}

html {
    font-size: 62.5%;
}

body {
    font-size: 1.6rem;
    font-family: 'gt-walsheim-medium', arial, sans-serif;
    font-weight: 400;
    color: #FFF;
    background-color: #052c4b;
    -webkit-font-smootshing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    overflow-x: hidden;
}

header {
    top: 0;
    z-index: 15;
}


/* --------------------------------

Patterns

-------------------------------- */

.container {
    display: flex;
    flex-direction: column;
    align-items: center;
    width: 100%;
    height: 100%;
}

.item {
    position: relative;
    width: 100%;
    min-height: 50px;
}

.module-1 {
    background: #eee;
    width: 100vw;
}

.module-1-logo {
    margin: 0 auto;
    padding: .75rem 0 0;
}

.module-1-logo img {
    width: 50vw;
}

.module-1-tagline {
    color: #fff;
    position: absolute;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%);
    z-index: 3;
    opacity: 1;
}

@media (max-width: 768px) {
    .module-1-logo img {
        width: 75vw;
    }
}

.module-1-bg {
    background-image: url("../img/module-1-bg.jpg");
    background-position: 50%;
    background-repeat: no-repeat;
    background-size: cover;
    margin: 0 auto;
    display: block;
    max-height: 80vh;
    overflow: hidden;
}

.module-1-bg:before {
    content: "";
    display: block;
    padding-bottom: 50%;
}

.module-2 {
    background: #052c4b;
    text-align: left;
    padding: 15% 35.5% 15% 10%;
}

.module-2-logo {
    margin: 0 auto;
    text-align: center;
    padding: .75rem 0 0;
}

.module-2-logo img {
    width: 15%;
    min-width: 160px;
}

.module-2 .paws {
    position: absolute;
    top: 0;
    left: 50%;
    height: 100%;
    width: 50%;
    opacity: 1;
}

.module-2 .paw {
    position: relative;
    top: -2vh;
    left: 65%;
    width: 13vw;
}

.module-2 .paw:nth-child(2) {
    position: relative;
    top: 2vh;
    left: 38%;
}

.module-2 .paw:nth-child(3) {
    position: relative;
    top: 5vh;
    left: 65%;
}

.module-2 .paw:nth-child(4) {
    position: relative;
    top: 10vh;
    left: 38%;
}

@media (max-width: 768px) {
    .module-2 .paws {
        opacity: .33;
    }
}

.module-3-logo {
    position: absolute;
    top: 50%;
    left: 75%;
    transform: translate(-50%, -50%);
    width: 16%;
}

.module-3-services {
    position: absolute;
    top: 50%;
    left: 25%;
    transform: translate(-50%, -50%);
    width: 50%;
    height: 100%;
    padding: 10vh;
    color: #fff;
    background: #ece847;
}

@media (max-width: 768px) {
    .module-3-services {
        position: relative;
        top: 0%;
        left: 0%;
        width: 100%;
        height: 100%;
        padding: 10vh;
        transform: translate(0%, 0%);
    }
    .module-3-services p {}
    .module-3-services h1 {}
    .module-3-logo {
        position: absolute;
        top: 16.5%;
        left: 50%;
        transform: translate(-50%, -50%);
        width: 16%;
    }
}

.module-3-service {
    padding: 5% 0;
}

.module-3-bg {
    position: relative;
    margin: 0 auto;
    display: inline-block;
    max-height: 100vh;
    width: 100vw;
    overflow: hidden;
}

.module-3-bg img {
    position: absolute;
    top: 50%;
    left: 50%;
    width: auto;
    height: auto;
    min-width: 100%;
    min-height: 100%;
    -webkit-transform: translate(-50%, -50%);
    -moz-transform: translate(-50%, -50%);
    -ms-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
    transition: all linear .5s;
    opacity: 0;
}

@media (max-width: 768px) {
    .module-3-bg img {
        position: absolute;
        top: 50%;
        left: 50%;
        width: 120vw;
        height: auto;
        min-width: 100%;
        min-height: 100%;
        -webkit-transform: translate(-50%, -50%);
        -moz-transform: translate(-50%, -50%);
        -ms-transform: translate(-50%, -50%);
        transform: translate(-50%, -50%);
        transition: all linear .5s;
        opacity: 0;
    }
}

.module-3-bg img.img-hover-1 {
    opacity: 1;
}

.home,
.baby,
.travel {
    cursor: crosshair;
}

.module-3-bg:before {
    content: "";
    display: block;
    padding-bottom: 55%;
}

.module-4 {
    flex-grow: 3;
    background: #052c4b;
    text-align: center;
    padding: 8% 10% 4%;
}

.module-4-logo {
    width: 100%;
    margin: 0 auto;
    text-align: center;
    padding: 2% 0% 0 0%;
}

.module-4-logo img {
    width: 10vw;
    min-width: 100px;
    padding-bottom: 2rem;
}

@media (max-width: 768px) {
    .module-2 {
        padding: 16% 10% 21%;
    }
    .module-4-logo img {
        width: 40%;
    }
    .module-4-logo {
        flex-grow: 3;
        margin: 0 auto;
        text-align: center;
        padding: 20% 10% 20%;
    }
    .module-4 {
        flex-grow: 3;
        text-align: center;
        padding: 20% 10% 10%;
    }
}

footer {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    width: 80%;
    margin: 0 auto;
    padding-bottom: 5%;
}

.footer-item {
    width: 33%;
    text-align: center;
    padding: 4% 2rem;
    margin: auto;
}

.footer-item p {
    color: #fff;
}

.footer-subitem {
    width: 100%;
    text-align: center;
    padding: 6% 2rem;
    margin: auto;
}

.footer-subitem a {
    padding: 7.5% 1rem;
    margin: auto;
}

.footer-subitem a svg path {
    fill: #ece847;
}

.footer-subitem a:hover svg path {
    fill: #d4d115;
}

@media (max-width: 768px) {
    .footer-item {
        width: 100%;
        text-align: center;
        padding: 4rem 2rem;
        margin: auto;
        border-right: none;
    }
    .footer-item:nth-child(4) {
        border-right: none;
        padding-bottom: 6rem;
    }
}

header {
    position: relative;
    height: 87vh;
}


/* Style the video: 100% width and height to cover the entire window */

.fullscreen-bg {
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    overflow: hidden;
    z-index: -100;
    /* border: solid 4rem #fff; */
}

.fullscreen-bg__video {
    position: absolute;
    top: 50%;
    left: 50%;
    width: auto;
    height: auto;
    min-width: 100%;
    min-height: 100%;
    -webkit-transform: translate(-50%, -50%);
    -moz-transform: translate(-50%, -50%);
    -ms-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
    background: #fff;
}

@media (max-width: 768px) {
    .fullscreen-bg {
        width: 100vw;
        height: 80vh;
        background: url('../img/intro.jpg') center center / cover no-repeat;
    }
    header {
        height: 83vh;
    }
    .fullscreen-bg__video,
    .hero-controls {
        /*   display: none;*/
    }
}