@charset "UTF-8";

/* Typography
–––––––––––––––––––––––––––––––––––––––––––––––––– */

body 	{
	width: 100%;
	padding: 0;
    margin: 0;
	font-family: 'Oswald', sans-serif;
}

.container-fluid {
	padding: 0;
	margin: 0;
}

#lt-yell {
	color: #fcca1e;
}

#yell {
	color: #ff9c00;
}

#orange {
	color: #ff6600;
}


h1	{
	font-family: 'Oswald', sans-serif;
	text-transform: uppercase;
	font-size: 5vw;
	font-weight: 600;
	letter-spacing: 2px;
    color: #ff9c00;
}

h2  {
	font-family: 'Oswald', sans-serif;
    font-size: 2.5vw;
    color: #3e2700;
}

p {
	font-family: 'Oswald', sans-serif;
    font-size: 1.8vw;
    color: #3e2700;
}

/* Navigation
–––––––––––––––––––––––––––––––––––––––––––––––––– */
nav {
	height: 5vw;
    background-color: #2b1c02e0;
}

nav.navbar.navbar-expand-md.fixed-top {
    padding: 0;
    margin: 0;
}

nav li {
	font-size: 1.6vw;
    height: 4vw;
    padding: 0 .35vw;
    text-transform: uppercase;
}

nav li:nth-child(1) a{
	color: #c596ff;
}

nav li:nth-child(2) a{
	color: #f01493;
}

nav li:nth-child(2), nav li:nth-child(4) {
	padding-bottom: 2vw;
}

nav li:nth-child(3) a{
	color: #ff9a02;
}

nav li:nth-child(4) a{
	color: #fcc31a;
}

nav li:nth-child(5) a{
	color: #70bfa0;
}

nav li:nth-child(6) a{
	color: #41bafd;
}
 
nav li:hover {
    color: red;
}

a.navbar-brand {
    width: 20%;
    vertical-align: bottom;
    margin-bottom: -12vw;
    margin-left: -2vw;
}

a.navbar-brand:hover {
    transform: rotate(360deg);
    transition-duration: 1.4s;
    transition-timing-function: ease-in-out;
}

a.navbar-brand img{
    width: 100%;
}


nav li a:hover {
    color: red;
}

button.navbar-toggler {
    color: #fff;
    letter-spacing: 1px;
    font-size: 2.2vw;
    margin-right: 45%;
}

.navbar .navbar-collapse {
    text-align: center;
}

@media (min-width: 0px) and (max-width: 767.98px) {
    nav {
        height: auto;
    }

    a.nav-link {
        font-size: 4vw;
        padding: 1vw;

    }

    nav li {
        height: auto;
    }
}



/* Index
–––––––––––––––––––––––––––––––––––––––––––––––––– */

#baby {
	background-image: url(../images/baby-animation-spalsh.gif);
    background-repeat: no-repeat;
    background-size: cover;
    height: 42vw;
    width: 60%;
    margin-left: 20%;
    margin-top: 4vw;
}

.home	{
	position: relative;
}

.home header h1	{
	font-family: 'Oswald', sans-serif;
	visibility: hidden;
}

.home header {
	background-image: url(../images/ready-steady-swim.png);
	background-repeat: no-repeat;
    background-size: cover;
    height: 10vw;
    width: 60%;
    margin-left: 21%;
    margin-top: 10vw;
    z-index: 30;
}

.home header h2 {
	font-family: 'Oswald', sans-serif;
	margin-top: 3vw;
}

.home #wave {
	
}

.home p {
    width: 70%;
    margin-left: 16%;
    text-align: center;
}

#blow {
	background-image: url(../images/blow-fish.png);
    background-repeat: no-repeat;
    background-size: cover;
    height: 12vw;
    width: 15%;
    position: absolute;
    top: 52vw;
    left: 7vw;
}

#squid {
	background-image: url(../images/squid.png);
    background-repeat: no-repeat;
    background-size: cover;
    height: 15vw;
    width: 7%;
    position: absolute;
    top: 48vw;
    right: 7vw;
}

#sea-scape {
	background-image: url(../images/sea-scape.png);
    background-repeat: no-repeat;
    background-size: cover;
    height: 28vw;
    width: 100%;
}

footer  {
    background-color: #422a01;
    padding: 1vw 4%;
    color: #faf5e2;
    letter-spacing: 1px;
}

footer #date {
    display: inline-block;
    float: right;
}

footer a {
    color: #fff000;
}

footer a:hover, footer a:active, footer a:focus {
    color: #f1b0de;
    text-decoration: none;
}

/* Lesson
–––––––––––––––––––––––––––––––––––––––––––––––––– */
.lesson header {
    background-image: url(../images/lesson-background.jpg);
    position: relative;
    background-repeat: no-repeat;
    background-size: cover;
    height: 66vw;
    margin-top: -3vw;
    
}
.lesson .card-grid {
    position: relative;
    display: grid;
    grid-template-columns: 1fr 1fr 1fr;
    grid-column-gap: 4vw;
    margin-left: 10%;
    margin-right: 10%;
    margin-top: 8%;
}

.lesson .card {
    position: relative;
    margin-top: 30%;
    border-radius: 4.6vw;
}

.lesson .card h1 {
    text-transform: capitalize;
    font-size: 2vw;
    color: #422a01;
    letter-spacing: 1.2px;
    margin-left: 4vw;
}

.lesson .card h2 {
    font-size: 1.3vw;
    margin-left: 4vw;
    margin-top: 6vw;
}

.lesson .card h3 {
    font-size: 1.5vw;
    font-weight: 200;
    margin-left: 4vw;
}

.lesson .card button {
    background: #f2b0de;
    border-radius: 1.5vw;
    text-transform: uppercase;
    color: #fff;
    font-weight: 100;
    font-size: 1.4vw;
    padding: .4vw 2vw;
    margin-left: 55%;
    margin-top: 1vw;
}

.lesson #private button {
    margin-left: 10%;
    margin-top: 120%;
}

.lesson #private h2 {
    margin-top: 2vw;
}


.lesson .details {
    visibility: none;
	opacity: 0;
	background-color: #fff;
    height: 45vw;
    position: absolute;
    border-radius: 4.6vw;
    padding: 2vw;
    transition: 0.6s;
    line-height: 2.5vw;
    padding-top: 4vw;
   
}

.lesson .details h1 {
	color: #70bfa0;
	font-size: 2.2vw;
	margin-left: 3vw;
	margin-bottom: 1.8vw
}

.lesson .card:hover .details, .lesson .card:focus .details, .lesson .card:active .details {
	opacity: 1;
    visibility: visible;
}

.lesson #coarse {
    background-image: url(../images/card-1a.jpg);
    background-repeat: no-repeat;
    background-size: cover;
    height: 45vw;
    box-shadow: -1px -1px 20px 9px #0404041c; 
}

.lesson #trial {
    background-image: url(../images/card-2a.jpg);
    background-repeat: no-repeat;
    background-size: cover;
    height: 45vw;
    box-shadow: -1px -1px 20px 9px #0404041c; 
}

.lesson #private {
    background-image: url(../images/card-3a.jpg);
    background-repeat: no-repeat;
    background-size: cover;
    height: 45vw;
    box-shadow: -1px -1px 20px 9px #0404041c; 
}

.lesson .office a {
    text-transform: uppercase;
    font-size: 6vw;
    font-weight: 500;
    color: #fff;
    margin-left: 7%;
    margin-top: 2vw;
}

.lesson .office a:hover, .lesson .office a:focus, .lesson .office a:active {
    text-decoration: none;
    color: #66cc99;
    transition: .5s;
}    

.lesson .office h3 {
    color: #664001;
    margin-top: -1.4vw;
    margin-left: 22vw;
    text-transform: uppercase;
    font-size: 1.6vw;
    letter-spacing: .8px;
    margin-bottom: 1vw;
}    

.office i.far.fa-paper-plane {
    font-size: 8vw;
    padding-left: 2vw;
    padding-top: 3vw;
}

.lesson #location {
    position: relative;
    display: grid;
    padding-top: 3vw;
    grid-template-columns: 1fr 1fr;
    margin-bottom: 6vw;

}

.lesson address h1 {
    font-size: 2.8vw;
    color: #422a01;
    padding-top: 2vw;
}

.lesson address h2 {
    color: #66cc99;
    padding-top: 1vw;
}

.lesson address {
    font-size: 2.8vw;
    color: #422a01;
    font-weight: 300;
    width: 60%;
    margin-left: 20%;
}

.lesson #map iframe {
    height: 100%;
    width: 83%;
}

/* Voucher
–––––––––––––––––––––––––––––––––––––––––––––––––– */

.voucher header {
    margin-top: 5vw;
}

.voucher header video {
    display: flex;
    width: 100%;
    z-index: -1;
}

.voucher header h1  {
    position: absolute;
    top: 20%;
    right: 16%;
    text-shadow: 1px 2px 6px #000000bf;

}

.voucher #sea-scape {
    position: relative;
    margin-top: -20vw;
    z-index: 4;
}

.vouche-img {
    position: relative;
    display: inline-block;
    width: 60%;
    padding: 2vw 4vw;
    
}

.vouche-img img {
    box-shadow: 0px 0px 20px 0px #0000005e; 
}

.voucher-info {
    display: inline-block;
    width: 40%;
    float: right;
    background-color: #d2eefc;
    padding: 6vw 2vw;
}

.voucher-info h2 {
    font-size: 2.2vw;
    font-weight: 500;
}

.voucher-info a {
    color: #fff;
    font-size: 2vw;
    font-weight: 300;
    letter-spacing: .8px;
    margin-left: 15%;
}

.voucher i.far.fa-paper-plane {
    font-size: 4vw;
}

.voucher-info a:hover, .voucher-info a:focus, .voucher-info a:active {
    text-decoration: none;
    color: #ee2992; 
    transition: .5s;
}




/* Approach
–––––––––––––––––––––––––––––––––––––––––––––––––– */

.approach header h1 {
    width: 75%;
    text-align: center;
    margin-left: 19%;
    margin-top: 10vw;
    text-shadow: 2px 3px #3e2700;
}

section#mission {
    padding-top: 4vw;
    line-height: 2.2vw;
}

section#mission img {
    width: 34%;
    margin-left: 8%;
    margin-top: -49vw;
}

.approach header h2 {
    margin-top: 4vw;
    color: #8d71b0;
}

section#mission p {
    font-family: helvetica;
}

.mission-state {
    display: inline-block;
    width: 51%;
}

.approach header #baby {
    background-image: url(../images/baby-animation-trans.gif);
    position: relative;
}

.stage {
    background-color: #fceeb3;
    padding: 4vw;
    border-radius: 60% 60% 60% 60%;
}

.stage h1 {
    text-align: center;
}

.stage p {
    line-height: 2.2vw;
    text-align: center;
}

#cherub-img {
    background-image: url(../images/cherub.png);
    background-repeat: no-repeat;
    position: absolute;
    background-size: contain;
    width: 41vw;
    height: 100vh;
    top: 4vw;
    left: 30vw;
}

#moon-img {
    background-image: url(../images/moon.png);
    background-repeat: no-repeat;
    position: absolute;
    background-size: contain;
    width: 25vw;
    height: 100vh;
    top: 11vw;
    right: 0vw;
}

#butterfly-img {
    background-image: url(../images/butterfly.png);
    background-repeat: no-repeat;
    position: absolute;
    background-size: contain;
    width: 41vw;
    height: 100vh;
    top: 30vw;
    left: -5vw;
}

#fire-img {
    background-image: url(../images/fire.png);
    background-repeat: no-repeat;
    position: absolute;
    background-size: contain;
    width: 64vw;
    height: 100vh;
    top: 96vw;
    right: 0;
    z-index: -4;
}

#dragon-img {
    background-image: url(../images/dragon.png);
    background-repeat: no-repeat;
    position: absolute;
    background-size: contain;
    width: 56vw;
    height: 100vh;
    top: 148vw;
    left: -2vw;
}

#lion-img {
    background-image: url(../images/lion.png);
    background-repeat: no-repeat;
    position: absolute;
    background-size: contain;
    width: 52vw;
    height: 100vh;
    top: 186vw;
    right: 0;
}


#cherub {
    width: 45%;
    margin-left: -2vw;
    margin-top: 4vw;
}

#moon {
    width: 47%;
    margin-left: 52vw;
    margin-top: 7vw;
}


#butterfly {
    width: 43%;
    margin-left: 16vw;
    margin-top: 2vw;
}

#fire {
    width: 50%;
    margin-left: -2vw;
    margin-top: 4vw;
}

#dragon {
    width: 50%;
    margin-left: 48vw;
    margin-top: 15vw;
}

#lion {
    width: 50%;
    margin-left: 1vw;
    margin-top: 24vw;
}

section.levels {
    z-index: -4;
    position: relative;
    margin-top: -22vw;
    background-color: #2d9ad5;
    background-image: url(../images/river.png);
    background-repeat: no-repeat;
    background-size: cover;
}



section#class-vid {
    position: relative;

}

section#class-vid video {
    width: 70%;
    margin-left: 15%;
    margin-top: 9%;
    z-index: -12;
    position: absolute;
}


section#class-vid h2 {
    display: inline-block;
    margin-top: 53%;
    background-color: #fd6666;
    padding: 1vw 2vw 1vw 8vw;
}

section#class-vid h2 a {
    color: #ffc107;
}

section#class-vid h2 a:hover, section#class-vid h2 a:focus, section#class-vid h2 a:active {
    text-decoration: none;
    color: #f8f9fa;
}

section#class-vid svg.svg-inline--fa.fa-paper-plane.fa-w-16 {
    position: absolute;
    bottom: -65vw;
    left: 32vw;
    color: #f9e3e7;
    font-size: 8vw;
    z-index: -44;
    
}

section.teacher {
    margin: 5vw 8vw;
}

section.teacher h1 {
        text-shadow: 2px 3px #3e2700;
        text-align: center;
        padding-bottom: 2vw;
}

/* Contact
–––––––––––––––––––––––––––––––––––––––––––––––––– */

.contact .contact-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    margin-top: 10vw;
    margin-bottom: 12vw;
}


.contact section {
    display: grid;
    grid-template-rows: 2fr;
    grid-auto-columns: 1fr;
    margin-left: 34%;
}

.contact section h1 {
    text-transform: capitalize;
    color: #422a01;
    font-size: 4vw;
}

.contact section a, .contact section address {
    display: block;
    color: #422a01;
    font-size: 3vw;
    font-weight: 300;
}

.contact section #cont-1 {
    border-bottom: 4px solid #ff9c00;
    padding-bottom: 4vw;
}

.contact section #cont-1 a:hover {
    text-decoration: none;
    color: #66cc99;
}

.contact section .cont-2 {
    padding-top: 4vw;
}

.contact .cont-3 h2 {
    transform: rotate(90deg);
    font-weight: 300;
    position: absolute;
    top: 30vw;
}

.contact i.fas.fa-mobile-alt {
    display: inline-block;
    font-size: 40vw;
    color: #000;
    margin-left: 22%;
}

.contact i.fas.fa-mobile-alt:hover {
    color: #66cc99;

}

.contact i.fab.fa-facebook-f {
    color: #000;
    position: absolute;
    display: inline-block;
    margin-left: -17.8vw;
    margin-top: 12vw;
    font-size: 9vw;
    background-color: #61abfb;
    padding: 2vw 2vw 0vw 4vw;
    box-shadow: inset 0px -20px 0px 5px white;
}


@media (min-width: 0px) and (max-width: 767.98px) {
    .contact .contact-grid {
        grid-template-columns: 1fr; 
         grid-template-rows: 3fr;
    }

    .contact .cont-3 {
        margin-top: 5vw;
    }

    .contact .cont-3 h2 {
        top: 92vw;
        left: 25%;
    }

    .contact i.fas.fa-mobile-alt {
        margin-left: 38%;

    }

    .contact i.fab.fa-facebook-f {
        box-shadow: inset 0px -20px 0px 0px white;
    }

}

/* Kids
–––––––––––––––––––––––––––––––––––––––––––––––––– */

.kids header {
    position: relative;
    background-image: url(../images/kids-banner.jpg);
    background-repeat: no-repeat;
    background-size: cover;
    height: 34vw;
    margin-top: 5vw;
}


.kids .sketches {
    display: grid;
    grid-template-columns: 1fr 1fr 1fr;
    grid-gap: 5vw;
    margin-left: 5vw;
    margin-right: 5vw;
    padding-top: 4vw;
    margin-bottom: 8vw;
}

.kids #dl-title {
    background-color: #f9c11a;
    height: 6vw
}

.kids #dl-title h1 {
    margin-left: 15%;
}
.kids #dl-title h2 {
    margin-top: -5vw;
    margin-left: 50%;
}

.kids #game {
    display: flex;
    width: 100vw;
}

.kids .colour-me-in {
    margin: 2vw;
}

.kids .colour-me-in img {
    box-shadow: 0px 0px 10px 3px #00000029;
    margin-bottom: 4vw;

}

.kids .colour-me-in a{
    margin-left: 19%;
    background-color: #ff9c00;
    padding: 1vw 3vw;
    border-radius: 4vw;
    color: #fff;
    text-transform: uppercase;
    font-size: 2.2vw;
    letter-spacing: .6px;
}


/* Small Devices
–––––––––––––––––––––––––––––––––––––––––––––––––– */

@media (min-width: 0px) and (max-width: 767.98px) {

    .kids .sketches {
        grid-template-columns: 1fr 1fr;

}


@media (min-width: 0px) and (max-width: 767.98px) {
    .home header {
        margin-top: 17vw;
    }

    h2  {
        font-size: 3.2vw;
    }

    p {
        font-size: 2vw;
    }

    footer {
        font-size: 2.2vw;
    }

    .lesson header {
        height: 72vw;
        margin-top: 9vw;
    } 

    .voucher header {
    margin-top: 9.3vw;
    } 

    .voucher header h1 {
        top: 12%;
    } 

    .voucher footer {
        margin-top: 6vw;
    } 

    section#mission p {
        font-size: 2.2vw;
    }

    .approach header h1 {
        margin-top: 16vw;
    }

    .stage p {
        font-size: 2.2vw;
        line-height: 3vw;
    }

    .stage h1 {
        font-size: 4vw;
    }

    .stage {
        padding-top: 6vw;
    }

    #cherub {
        margin-left: 0;
        width: 48%;
    }

    #cherub-img {
        left: 40vw;
    }

    #moon {
        margin-top: 16vw;
    }

    #moon-img {
        top: 28vw;
    }

    #butterfly {
        margin-left: 20vw;
        margin-top: -4vw;
        width: 50%;
    }

    #butterfly-img {
        top: 57vw;
    }

    #fire.stage {
        margin: 3vw;
        padding: 6vw;
        width: 62%;
    }

    #fire-img {
        top: 120vw;
        width: 100vw;
    }

    #dragon-img {
        top: 190vw;
    }

    #dragon {
        margin-top: 35vw;
    }

    #lion {
        width: 55%;
        margin-top: 11vw 
    }

    #lion-img {
        top: 233vw;
    }
}


