html {
    background-color: #2e2e2e;
}

body {
    margin: 0;
    font-family: 'Kumbh Sans', sans-serif;
}

h3 {
    letter-spacing: 6px;
    margin-top: 0;
    margin-bottom: 25px;
}

a {
    color: #ddd;
    text-decoration: none;
}

a:hover {
    color: #333;
}

.intro {
    position: relative;
    height: 690px;
    color: #eeeeee;
    background-color: #2c2c2c;
    overflow: hidden;
    z-index: 1;
}

.intro:after {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    bottom: 0;
    right: 0;
    background-image: url(/side-by-side-dark3.jpg);
    background-size: cover;
    background-repeat: no-repeat;
    background-position: center;
    filter: brightness(1.2);
}

.intro .logo {
    position: absolute;
    top: 0;
    left: 5px;
    width: 400px;
    z-index: 1;
}

.intro .links {
    position: absolute;
    top: 15px;
    right: 15px;
    z-index: 1;
    letter-spacing: 6px;
    color: #ddd;
}

.intro .links a {
    color: #ddd;
}

.intro .links a:hover {
    color: #ddd;
    padding-bottom: 3px;
    border-bottom: 3px #ddd solid;
    -webkit-text-stroke: 1px #ddd;
}

.email {
    position: absolute;
    left: 10px;
    right: 10px;
    bottom: 30px;
    text-align: center;
    z-index: 1;
}

.email .note {
    /* font-family: 'Architects Daughter', cursive; */
    font-size: 30px;
    color: #aeaeae;
    text-shadow: 0 0 1px #70707080;
    letter-spacing: 5px;
}

.email .note span {
    white-space: nowrap;
}

#email-input {
    font-size: 20px;
    width: 400px;
    color: #606060;
    padding: 8px 20px;
    margin: 0;
    border: 0;
    border-radius: 5px;
    max-width: 100%;
    background-color: #d9d9d9;
}

#submit {
    display: inline-block;
    background-color: #7b7b7b;
    color: #ddd;
    border: none;
    padding: 8px 20px;
    text-align: center;
    text-decoration: none;
    border-radius: 5px;
    margin-top: 10px;
    text-transform: uppercase;
    letter-spacing: 5px;
    font-size: 20px;
}

#submit:hover {
    background-color: #56565a;
    cursor: pointer;
}

#spinner-container {
    display: none;
    width: 142px;
    height: 40px;
    position: relative;
    top: 11px;
    margin-top: -2px;
}

#spinner {
    height: 40px;
}

#submit-notification {
    background-color: #2c2c2c;
    text-align: center;
    padding-bottom: 25px;
    display: none;
}

#submit-notification .red {
    color: red;
}

#submit-notification .green {
    color: darkgreen;
}

#purchase {
    padding: 20px 30px;
    border-radius: 5px;
    background-color: #bb7900;
    position: relative;
    bottom: 35px;
    white-space: nowrap;
}

#purchase:hover {
    background-color: #eca522;
    color: white;
}

::placeholder {
    color: #909090;
    text-align: center;
    text-transform: uppercase;
    letter-spacing: 5px;
}

.no-spam {
    color: #4c4c4c;
    font-size: 14px;
    display: inline-block;
    width: 150px;
    margin: 15px 0 0 15px;
    position: relative;
    top: -2px;
}

.grecaptcha-badge {
    visibility: hidden;
}

.features {
    position: relative;
    display: table;
    width: 100%;
    border-width: 5px;
    border-spacing: 10px;
    padding-bottom: 3px;
    background-color: #dfdfdf;
    z-index: 0;
    margin-top: -10px;
}

.icon-container {
    display: block;
}

.icon-container img {
    width: 50px;
    filter: invert(1) opacity(.6);
    margin: 0 10px 0 0;
    vertical-align: middle;
}

.box {
    background-color: #4a4a4a;
    display: table-cell;
    border-radius: 5px;
    border: none;
    margin: 0 5px;
    padding: 20px;
    text-align: center;
    vertical-align: top;
    font-size: 20px;
    line-height: 28px;
    position: relative;
    width: 20%;
    color: #efe5e5c5;
}

.box .text {
    margin-top: 10px;
    display: inline-block;
}

.box .small-text {
    position: absolute;
    right: 18px;
    bottom: 3px;
    font-size: 10px;
}

.box .asterisk {
    font-size: 10px;
    position: relative;
    top: -6px;
}

.box:nth-of-type(1) {
    background-color: #1a3c6377;
}

.box:nth-of-type(2) {
    background-color: #0d421077;
}

.box:nth-of-type(3) {
    background-color: #673f0c77;
}

.box:nth-of-type(4) {
    background-color: #67090977;
}

.panel {
    text-align: center;
    margin: 0;
    padding: 35px 20px 50px 20px;
}

.verylight {
    background-color: #ececec;
    color: #333;
}

.light {
    background-color: #bdbdbd;
    color: white;
}

.dark {
    background-color: #535353;
    color: #ddd;
}

.verydark {
    background-color: #2c2c2c;
    color: #ddd;
}

.footer {
    font-family: 'Caveat', cursive;
    font-size: 20px;
    text-align: center;
    padding: 20px 0;
    color: #b7b7b7;
}

.smash-logo {
    height: 64px;
    vertical-align: middle;
}

.pictures img {
    display: inline-block;
    width: 15vw;
    height: 15vw;
    object-fit: cover;
    filter: brightness(1.1);
}

.img-container {
    display: inline-block;
    position: relative;
    border: 5px solid #656565;
    border-radius: 5px;
    margin: 0 5px 10px 5px;
}

.img-container:hover {
    cursor: zoom-in;
    border-color: #505050;
}

.img-container:after {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    bottom: 0;
    right: 0;
    background: radial-gradient(circle, transparent 40%, #303030 150%);
}

.img-modal {
    display: none;
    position: fixed;
    width: 100%;
    height: calc(100% - 100px);
    z-index: 3;
    padding: 50px 0;
    left: 0;
    top: 0;
    background-color: rgb(0,0,0);
    background-color: rgba(0,0,0,0.7);
    overflow: auto;
}

.img-modal .image {
    margin: auto;
    display: block;
    width: 80%;
    height: 90%;
    object-fit: contain;

    animation-name: ss-zoom;
    animation-duration: 0.1s;

    cursor: zoom-out;
}

@keyframes ss-zoom {
    from {transform:scale(0)}
    to {transform:scale(1)}
}

#demo iframe {
    max-width: calc(100% - 10px);
    max-height: calc((100vw - 10px) * 0.5625);
    border: 5px solid #373737;
    border-radius: 5px;
    margin: 0 5px;
}

.faq-list {
    display: inline-block;
    text-align: left;
    max-width: 900px;
    line-height: 1.25;
}

.faq-list .illustration {
    width: 400px;
    margin: 25px 0 0 0;
    display: block;
}

.faq-list a:hover {
    color: #595959;
}

#grips {
    filter: invert(1);
}

#faq {
    padding: 35px 40px 50px 40px;
}

#faq .ques {
    font-size: 1.1em;
    margin-bottom: 20px;
    letter-spacing: 1px;
}

#faq .ans {
    letter-spacing: 0.5px;
    margin-left: 40px;
}

#faq .ans:not(:last-child) {
    margin-bottom: 65px;
}

#reach-out {
    padding-top: 45px;
}

.social-links {
    margin-top: 18px;
}

.social-links a {
    margin: 0 5px;
}

.social-links a img {
    height: 26px;
    filter: invert(1);
}

.social-links a:hover img {
    filter: opacity(0.2);
}

.settings-icon {
    width: 25px;
    position: relative;
    top: 7px;
}

@media screen and (max-width: 1700px) {
    .intro .links {
        display: none;
    }
}

@media screen and (max-width: 1300px) {
    .box {
        min-height: 0px;
        margin-bottom: 10px;
        font-size: 16px;
    }

    .box .small-text {
        bottom: -3px;
    }
    
    .box .text {
        margin-top: 5px;
    }
    
    .intro {
        height: 650px;
    }
    
    .icon-container img {
        width: 30px;
    }
}

@media screen and (max-width: 750px) {
    .intro {
        height: 500px;
    }

    .intro:after {
        background-image: url(/alone-dark.jpg);
        top: 40px;
        top: 0; /*SOLD OUT*/
        /*bottom: -40px; /* AMAZON */
        bottom: -80px;
    }
    
    .intro .logo {
        width: 250px;
    }
    
    .box {
        display: block;
        width: calc(100% - 50px);
    }
    
    .no-spam {
        margin: 20px 0 5px 0;
        width: 100%;
    }
    
    .email {
        bottom: 30px;
    }

    .email .note {
        font-size: 30px;
        margin-bottom: 10px;
    }
    
    .email .note span {
        display: block;
    }
    
    .email .g-recaptcha {
        font-size: 25px;
    }
    
    .intro .button {
        width: 400px;
        max-width: 100%;
    }

    #faq {
        padding: 35px 20px 50px 20px;
    }
    
    #faq .ans {
        margin-left: 0;
    }
    
    #faq .ans:not(:last-child) {
        margin-bottom: 70px;
    }
    
    .pictures img {
        width: 35vw;
        height: 35vw;
    }

    .pictures .img-container {
        margin-bottom: 10px;
    }

    .img-modal {
        padding: 0;
        width: 100%;
        height: 100%;
    }

    .img-modal .image {
        width: 100%;
        height: 100%;
    }
    
    #spinner-container {
        top: 4px;
        width: 100%;
        margin-top: 5px;
    }
    
    #purchase {
        display: block;
        width: calc(100% - 74px);
        left: 8px;
    }
}

@media screen and (max-width: 460px) {
    .icon-container {
        display: block;
    }

    .faq-list .illustration {
        width: 100%;
    }
}
