/* general */
* {
    box-sizing: border-box;
}
html {
    height: 100%;
}
html, body {
    margin: 0;
    padding: 0;
    font-family: Helvetica, Arial, sans-serif;
    font-weight: normal;
    font-size: 18px;
    line-height: 1.3rem;
    background-color: #ffffff;
    color: #231f20;
}
.d-lg-inline {
    display: none;
}
a {
    color: #231f20;
    text-decoration: underline;
    display: inline-block;
}
#live_hero {
    background-color: #231f20;
    color: #fff;
    display: flex;
    flex-direction: column;
    position: relative;
    line-height: 1.5;
}
#live_hero_photo {
    position: relative;
    overflow: hidden;
    background-image: url(/img/2022-piccadilly-lights.jpg);
    background-position: right 35%;
    background-size: cover;
    height: 350px;
}
#live_hero_text {
    padding: 3rem 1rem;
}
#live_hero_text a {
    color: #fff;
    display: inline;
}
@media (min-width: 1140px) {
    body.home .wrap {
        padding: 0 3rem;
    }
    #live_hero {
        flex-direction: row;
    }
    #live_hero_photo {
        position: absolute;
        width: 100%;
        height: 100%;
        z-index: 1;
    }
    #live_hero_photo:after {
        content: "";
        position: absolute;
        top: 0;
        right: 0;
        bottom: 0;
        left: 0;
        background: -moz-linear-gradient(90deg, rgba(35,31,32,1) 25%, rgba(35,31,32,0.2) 50%, rgba(255,255,255,0) 75%);
        background: -webkit-linear-gradient(90deg, rgba(35,31,32,1) 25%, rgba(35,31,32,0.2) 50%, rgba(255,255,255,0) 75%);
        background: linear-gradient(90deg, rgba(35,31,32,1) 25%, rgba(35,31,32,0.2) 50%, rgba(255,255,255,0) 75%);
    }
    #live_hero_text {
        width: 40%;
        padding: 3rem;
        z-index: 2;
        text-shadow: 1px 1px 1px rgba(0,0,0,0.8);
    }
}
main, .wrap {
    margin: 0 auto;
    padding: 0 16px;
    max-width: 380px;
}
main.wide {
    max-width: 760px;
    margin-bottom: 2em;
}
h1 {
    font-size: 30px;
}
h1 a {
    display: inline-block;
}
#logo-link {
    text-decoration: none;
    font-size: 1.5em;
    margin: 16px 0 32px 0;
}
body.home #logo-link {
    margin: 0;
    display: inline-block;
}
#logo {
    height: 53px;
    max-width: 100%;
}
#logo path {
    transition: fill .25s;
}
#logo:hover path:nth-child(2), #logo:active path:nth-child(2) {
    fill: #58c6b3;
}
section {
    padding: 32px 0;
}
small {
    font-size: 12px;
}
.btn {
    display: inline-block;
    width: 100%;
    background-color: #231f20;
    border: 0;
    color: #ffffff;
    text-align: center;
    text-decoration: none;
    font-size: 18px;
    font-weight: bold;
    line-height: 1.5;
    padding: 8px 12px;
    cursor: pointer;
}
.btn.small {
    width: auto;
    font-weight: normal;
    font-size: 16px;
}
.btn + .btn {
    margin-top: 4px;
}
.btn[disabled] {
    background-color: #999999;
    cursor: not-allowed;
}
.btn.accent {
    background-color: #64c0bb;
}
nav {
    height: 63px;
    background-color: #231f20;
    color: #ffffff;
    z-index: 1000;
}
nav .wrap, nav .wrap div:first-child {
    display: -ms-flexbox;
    display: flex;
    -ms-flex-align: center;
    align-items: center;
    -ms-flex-pack: justify;
    justify-content: space-between;
    width: 100%;
}
nav .wrap {
    -ms-flex-direction: column;
    flex-direction: column;
    max-width: 760px;
    height: 100%;
    padding-right: 0;
}
#nav-open, #nav-close, #search-close, #search-btn {
    padding: 16px;
    line-height: 31px;
    margin-left: auto;
}
nav ul {
    display: none;
    list-style: none;
    margin: 0;
    padding: 0 16px;
}
nav li + li {
    margin-top: 16px;
}
nav a {
    color: #ffffff;
}
nav a + a, #nav-open svg {
    margin-left: 8px;
}
nav .btn {
    width: auto;
}
nav li .btn {
    border: 2px solid #64c0bb;
    color: #64c0bb;
}
#nav-close, #nav-footer {
    display: none;
    padding: 16px;
    color: #ffffff;
}
#nav-close {
    font-size: 2em;
    text-decoration: none;
}
#nav-footer {
    text-align: center;
}
body.nav-open {
    height: 100%;
}
body.nav-open nav, body.home.sticky.nav-open #sticky {
    position: fixed !important;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: 2000;
}
body.nav-open #nav-open {
    display: none;
}
body.nav-open #nav-close, body.nav-open nav ul, body.nav-open #nav-footer {
    display: block;
}

/* moments grid */
.moments-grid-wrap {
    border: 4px solid black;
    padding: 16px;
}
.moments-grid {
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    max-width: 380px;
    margin: -8px;
}
.moments-grid > div {
    width: calc(100% / 3);
    padding: 4px;
}
.moments-grid figure {
    position: relative;
    width: 100%;
    height: 0;
    padding-bottom: 100%;
    margin: 0;
    background-color: #ffffff;
    color: #dedede;
    overflow: hidden;
}
.moments-grid img, .moments-grid .yours {
    position: absolute;
    width: 100%;
    height: auto;
}
.moments-grid.yours {
    height: 0;
    overflow: hidden;
    padding-top: calc(8px + 100% + 8px);
    position: relative;
}
.moments-grid.yours > div {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
}
.moments-grid .yours {
    display: -ms-flexbox;
    display: flex;
    -ms-flex-direction: column;
    flex-direction: column;
    -ms-flex-align: center;
    align-items: center;
    -ms-flex-pack: center;
    justify-content: center;
    text-align: center;
    text-decoration: none;
    height: 100% !important;
    background-color: #ffffff;
    color: #231f20;
    border: 2px dashed #231f20;
    font-size: 14px;
    font-weight: bold;
}
.moments-grid.random img {
    opacity: 0.5;
}
.moments-grid#selector, #randomiser .moments-grid {
    max-width: none;
}

/* form */
.field + .field {
    margin-top: 16px;
}
.field.error {
    color: #dc3545;
}
.field.error .input {
    border: 1px solid #dc3545;
}
.input {
    display: block;
    width: 100%;
    font-size: 18px;
    line-height: 1.3;
    padding: 4px 8px;
}
.error-block {
    color: #721c24;
    background-color: #f8d7da;
    border: 1px solid #f5c6cb;
    padding: 12px 22px;
    margin-bottom: 18px;
}
.help-block {
    color: #64c0bb;
    background-color: #f1f9f9;
    border: 1px solid #d7eeec;
    padding: 12px 22px;
    margin-bottom: 18px;
}
#card-element {
    margin-bottom: 18px;
}

/* home */
body.home.sticky #sticky {
    position: sticky;
    top: 0;
}
body.home main, body.home .wrap {
    max-width: none;
}
body.home main {
    padding: 32px 16px 48px 16px;
}
body.home main p {
    max-width: 568px;
}
body.home main .btn {
    border: 2px solid #ffffff;
}
.sm-centre {
    text-align: center;
}
body.home .moments-grid {
    margin: 0 auto;
    max-width: none;
    position: relative;
    background-color: #ffffff;
    z-index: 1000;
    padding: 2px;
}
body.home .moments-grid > div {
    padding: 2px;
}
body.home .moments-grid img {
    opacity: 0;
    -webkit-transition: opacity 1s ease-in;
    -moz-transition: opacity 1s ease-in;
    -ms-transition: opacity 1s ease-in;
    -o-transition: opacity 1s ease-in;
    transition: opacity 1s ease-in;
}
body.home .moments-grid img.loaded, body.home .moments-grid img.error {
    opacity: 1;
}
body.home .moments-grid .yours {
    background-color: #64c0bb;
    color: #ffffff;
    border: 0;
}
body.home .moments-grid:not(.show-public) .public {
    display: none;
}
body.home .moments-grid.show-public .public {
    display: block;
}
body.home .moments-grid .hide {
    display: none;
}
@keyframes highlight { 0% { opacity: 0; } 100% { opacity: 1; } }
@-webkit-keyframes highlight { 0% { opacity: 0; } 100% { opacity: 1; } }
body.home .moments-grid .highlight {
    -webkit-animation: highlight 3s ease-in 1;
    -moz-animation: highlight 3s ease-in 1;
    -ms-animation: highlight 3s ease-in 1;
    -o-animation: highlight 3s ease-in 1;
    animation: highlight 3s ease-in 1;
}
body.home .moments-grid .mobile { display: block; }
body.home .moments-grid .desktop:not(.mobile) { display: none; }
body.home .moments-grid:not(.show-public) .famous.last ~ .prompt {
    display: none !important;
}
@media (min-width: 480px) {
    body.home .btn { width: auto; }
    .sm-centre { text-align: left; }
}
@media (min-width: 768px) {
    .d-lg-inline { display: inline; }
    body.home .moments-grid > div { width: calc(100% / 5); }
    body.home .moments-grid .mobile:not(.desktop) { display: none; }
    body.home .moments-grid .desktop { display: block !important; }
}
#search-wrap {
    display: -ms-flexbox;
    display: flex;
    max-width: 320px;
    margin-left: auto;
    border: 0;
}
#search-close {
    color: #ffffff;
    padding: 16px;
    display: none;
}
@media (max-width: 480px) {
    body.search-open #search-close {
        display: inline-block;
    }
    body.search-open nav .wrap div:first-child > a {
        display: none;
    }
}
body.search-open #search-wrap {
    width: 100%;
}
body.search-open #search {
    display: block;
}
#search {
    -ms-flex: 1;
    flex: 1;
    border: 0;
    display: none;
    height: 35px;
    margin-top: 12px;
}
#search-btn {
    -ms-flex: 0;
    flex: 0;
    background-color: #231f20;
    border: 0;
    padding: 16px;
}
body.home #nav-open, body.home #nav-close {
    margin-left: 0;
}
#back-top, #toggle-public {
    position: fixed;
    top: -50px;
    width: auto;
    font-size: 10px;
    border: 2px solid #ffffff;
    -webkit-transition: top 1s ease-in;
    -moz-transition: top 1s ease-in;
    -ms-transition: top 1s ease-in;
    -o-transition: top 1s ease-in;
    transition: top 1s ease-in;
    z-index: 1000;
}
#back-top {
    left: 8px;
}
#toggle-public {
    right: 8px;
}
.scrolled #back-top, .scrolled #toggle-public {
    top: 8px;
    margin: 0;
}
@media (min-width: 568px) {
    #back-top {
        left: 50%;
        -ms-transform: translateX(-50%);
        -moz-transform: translateX(-50%);
        -webkit-transform: translateX(-50%);
        transform: translateX(-50%);
    }
}
@media (min-width: 568px) and (max-width: 768px) {
    body.home .moments-grid .yours {
        font-size: 18px;
    }
}
@media (min-width: 960px) {
    body.home .moments-grid .yours {
        font-size: 18px;
    }
    .moments-grid#selector > div {
        width: calc(100% / 5);
    }
}

/* fontawesome */
.svg-inline--fa, .fa {
    display: inline-block;
    font-size: inherit;
    height: 1em;
    overflow: visible;
    vertical-align: -0.125em;
}
.btn .svg-inline--fa, .btn .fa {
    height: 1em;
    margin-right: 0.25em;
}

/* youtube */
.youtube-video {
    position: relative;
    margin: 16px auto 0 auto;
}
.youtube-video div {
    width: 100%;
    height: 0;
    padding-bottom: 56.25%;
    overflow: hidden;
}
.youtube-video iframe {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
}