:root {
    --wine_colorP: #F4D7D9;
    --wine_colorS: #960018;
    --beer_colorP: #C8E8FF;
    --beer_colorS: #1034A6;
    --cocktail_colorP: #F0D9FF;
    --cocktail_colorS: #5E17EB;
}

li {
    list-style: none;
}

h1 {
    font-family: 'Oswald';
}

h2, h3, p, a {
    font-family: 'Montserrat';
}

body{
    overflow-x: hidden;
}

body a {
    text-decoration: none;
}

a .text-dark {
    color: black !important;
}

a .text-light {
    color: white !important;
}

/* LR margin for everything on the screen */

.container-fluid {
    padding-left: 5vw !important;
    padding-right: 5vw !important;
}

.underline {
    height: 1.5px;
    width: 100%;
    display: block;
    margin-top: 1.5%;
    margin-bottom: 3vw;
}



.bg-light {
    background-color: white important;
    color: black;
}

.bg-true-dark {
    background-color: black !important;
    color: white;
}

/* Desktop */

@media screen and (min-width:1100px) {
    .section-title-lg {
        font-size: calc(5.5rem + 1vw) !important;
    }

    .section-title {
        font-size: calc(3.5rem + 1vw) !important;
    }

    .section-title2 {
        font-size: calc(1.7rem + 1vw) !important;
    }

    .section-subtitle {
        font-size: calc(0.75rem + 1vw) !important;
        font-weight: 400;
    }

    .section-label {
        font-size: calc(0.6rem + 1vw) !important;
    }

    .section-body {
        font-size: calc(0.18rem + 1vw) !important;
    }
}

/* Landscape phones - Small Laptops */

@media screen and (min-width:576px) and (max-width:1100px) {
    .section-title-lg {
        font-size: calc(3.5rem + 1vw) !important;
        white-space: pre-wrap !important;
    }

    .section-title {
        font-size: calc(2.5rem + 1vw) !important;
    }

    .section-title2 {
        font-size: calc(1.3rem + 1vw) !important;
    }

    .section-subtitle {
        font-size: calc(0.9rem + 1vw) !important;
    }

    .section-label {
        font-size: calc(0.45rem + 1vw) !important;
    }

    .section-body {
        font-size: calc(0.49rem + 1vw) !important;
    }

    .container-fluid {
        padding-left: 5% !important;
        padding-right: 5% !important;
    }
}

/* phone */

@media screen and (max-width:576px) {
    .section-title-lg {
        font-size: calc(2.5rem + 1vw) !important;
        white-space: pre-wrap !important;
    }

    .section-title {
        font-size: calc(2.20rem + 1vw) !important;
    }

    .section-title2 {
        font-size: calc(1.2rem + 1vw) !important;
    }

    .section-subtitle {
        font-size: calc(1rem + 1vw) !important;
    }

    .section-label {
        font-size: calc(0.95rem + 1vw) !important;
    }

    .section-body {
        font-size: calc(0.8rem + 1vw) !important;
    }
}

#home {
    padding-bottom: 16%;
}

/* Navagation */

header {
    text-align: center;
    padding-bottom: 5%;
    height: fit-content;
}

.brand {
    text-align: center;
    display: block;
}

.brand img {
    padding-top: 18px;
    width: 18vw !important;
}

.nav-item {
    padding: 0 1.4vw;
}

.navbar-nav {
    display: flex;
    flex-direction: row !important;
    margin: auto;
    list-style: none;
}

header nav.navbar {
    padding: 0 !important;
}

/*--------- Home content ---------*/

#home .container-fluid {
    position: relative;
}

#home .row {
    padding-top: 3%;
}

.usp, .tagline, .btn {
    margin: 3% 0;
}

.usp {
    font-weight: bold;
    line-height: 1.5;
}

#home .btn-lg {
    padding: 15px 15px;
    border-radius: .3rem;
}

#home .btn-danger {
    color: #fff;
    background-color: #8F041C;
}

#bottle-carousel {
    position: relative;
    height: inherit;
}

#bottle-carousel img {
    display: block;
    margin: auto;
    width: inherit;
    max-width: 30rem;
}

@media screen and (max-width:960px) {
    .brand img {
        padding-top: 18px;
        width: 25vw !important;
    }

    #home, #steps {
        text-align: center;
        line-height: 1;
    }

    .container-fluid {
        margin-top: 0px;
        padding-top: 0% 11% 8% !important;
        padding-left: 5vw !important;
        padding-right: 5vw !important;
    }

    #home img {
        width: 50%;
    }

    /* remove button on mobile */
    #home button {
        visibility: hidden;
    }
}

/* Remove images on small screens */

@media screen and (max-width:650px) {
    .brand img {
        padding-top: 18px;
        width: 38vw !important;
    }

    #home img {
        width: 85%;
    }

    .container-fluid {
        margin-top: 0px;
        padding-left: 2vw !important;
        padding-right: 2vw !important;
    }
}

/*--------- How it works ---------*/

#how-it-works {
    padding-top: 6%;
    padding-bottom: 11%;
    overflow: hidden !important;
}

/* STANDARD LR MARGIN */

#how-it-works .title {
    margin-left: 6%;
    margin-right: 6%;
}

#how-it-works .text_wrapper {
    margin-left: 6vw;
    display: grid;
    grid-template-columns: 10% 90%;
    grid-template-rows: 45% 55%;
    grid-column-gap: 10px;
    grid-row-gap: 15px;
    width: 75%;
}

#how-it-works .step_number {
    width: 80%;
    grid-column: 1/2;
    grid-row: 1/2;
    align-self: center;
}

#how-it-works .step_title {
    white-space: nowrap;
    align-self: center;
    font-size: 6rem;
    grid-column: 2/3;
    grid-row: 1/2;
}

#how-it-works .step_description {
    width: 75%;
    min-width: 16rem;
    grid-column: 2/3;
    grid-row: 2/3;
    padding-left: 1%;
}

.step {
    padding-top: 20px;
}

.step .text_wrapper {
    padding-bottom: 5%;
}

/* step 1 img edits */

.step_1 .img_wrapper {
    text-align: right;
    margin-left: auto;
    margin-right: auto;
    padding-bottom: 5%;
}

.step_1 .img_flex img {
    width: 100%;
}

.step_1 .img_wrapper .img_description {
    margin-left: auto;
    width: 50%;
}

.step_1 .img_flex {
    --bs-gutter-x: 5.5rem;
    justify-content: space-between;
}

.wrapper {
    position: relative;
    overflow: hidden;
}

.img_cover {
    width: 100%;
    height: 100%;
    background-color: black;
    position: absolute;
    top: 0;
    z-index: 50;
}

.removeCover {
    transition-duration: 2s;
    transition-timing-function: ease-out;
    transform: translateX(100%);
}

/* step 2 Introduce Yourself */

.step_2 .img_wrapper {
    display: grid;
    grid-template-columns: 1fr 1fr 1fr;
    grid-template-rows: 1fr;
    height: 115vw;
    padding-bottom: 20px;
}

.step_2 .img_wrapper .wrapper:nth-child(1) {
    position: relative;
    width: 90%;
    grid-column: 1/2;
    z-index: 5;
}

.step_2 .img_wrapper img:nth-child(1) {
    width: 90%;
    grid-column: 1/2;
}

.step_2 .img_wrapper .wrapper:nth-child(2) {
    position: relative;
    width: 160%;
    align-self: center;
    justify-self: center;
    grid-column: 2/3;
    z-index: 10;
}

.step_2 .img_wrapper img:nth-child(2) {
    width: 100%;
}

.step_2 .img_wrapper .wrapper:nth-child(3) {
    position: relative;
    width: 85%;
    grid-column: 3/4;
    align-self: end;
    z-index: 20;
}

.step_2 .img_wrapper img:nth-child(3) {
    width: 85%;
}

/* Remove images on small screens */

@media screen and (max-width:650px) {
    #how-it-works .text_wrapper {
        width: 100%;
        grid-column-gap: 5px;
        grid-row-gap: 0px;
    }

    .step_1 .img_flex {
        --bs-gutter-x: 0rem !important;
    }

    #how-it-works .title {
        margin-left: 12px;
    }

    #how-it-works .img_wrapper, #how-it-works img {
        display: none;
    }

    #how-it-works .step_description {
        width: 84%;
        grid-column: 1/3;
        grid-row: 2/3;
    }

    #how-it-works .text_wrapper {
        margin-left: 8px;
    }

    #how-it-works .step_title {
        white-space: normal;
        align-self: center;
        font-size: 6rem;
        grid-column: 1/3;
        grid-row: 1/2;
    }
}

/* step 3 We Deliver, You Enjoy */

.step_3 .img_wrapper img {
    width: 100%;
}

.step_3 .img_wrapper .wrapper:nth-child(1) {
    position: relative;
    width: 55%;
    overflow: hidden;
}

.step_3 .img_wrapper .wrapper:nth-child(2) {
    position: relative;
    width: 35%;
    margin-top: 15rem;
    margin-left: auto;
}

.step_3 .img_wrapper .wrapper:nth-child(3) {
    position: relative;
    width: 40%;
    margin-top: 13rem;
    margin-left: 15%;
}

.step_3 .img_wrapper .wrapper:nth-child(4) {
    position: relative;
    width: 25%;
    margin-left: auto;
    margin-top: 10rem;
    margin-right: 13%;
}

.step_3 .img_wrapper .wrapper:nth-child(1) {
    position: relative;
    width: 43%;
    margin-left: auto;
    margin-right: auto;
    margin-top: 0rem;
}

/* -------- Subscriptions --------- */

#subscriptions {
    padding-top: 6%;
    padding-bottom: 16%;
    position: relative;
    overflow: hidden !important;
}

#subscriptions .header {
    text-align: center;
    margin: auto;
    font-weight: bold;
    margin-top: 2rem;
    margin-bottom: 1rem;
}

.subscription .tagbtn {
    justify-content: center;
}

.subscription:nth-child(1):hover h3 {
    background-color: var(--wine_colorP);
    color: var(--wine_colorS);
    border-color: var(--wine_colorS);
}

.subscription:nth-child(2):hover h3 {
    background-color: var(--cocktail_colorP);
    color: var(--cocktail_colorS);
    border-color: var(--cocktail_colorS);
}

.subscription:nth-child(3):hover h3 {
    background-color: var(--beer_colorP);
    color: var(--beer_colorS);
    border-color: var(--beer_colorS);
}

.subscription h3 {
    margin-top: 2rem;
    padding: 0.5rem;
    border: solid black 2px;
    border-radius: 60px;
    font-weight: bold;
    color: black;
}

img.tag {
    display: block;
    margin: auto;
    width: 70%;
}

img.tag {
    margin-top: 2rem;
    /* filter: drop-shadow(5px 3px 3px #7e7e7e); */
    transition: 0.3s;
}

.dropshadow {
    Box-shadow: 0 10px 20px rgba(0, 0, 0, 0.19), 0 6px 6px rgba(0, 0, 0, 0.23);
}

.tagPreEntry {
    opacity: 0;
    transition: 0.3s;
    transform: translateY(50%);
}

.tagEntry {
    transform: translateY(0);
    opacity: 1 !important;
    transition: 0.5s !important;
    transition-delay: calc(0.3s * var(--order)) !important;
}

/* Mobile */

@media screen and (max-width:650px) {
    .tagPreEntry {
        opacity: 0;
        transition: 0.25s;
        transform: translateY(0px);
    }
}

/* ----- about ------ */

#about {
    padding-top: 7%;
    padding-bottom: 11%;
    line-height: 1.5;
    overflow: hidden;
    z-index: 100;
}

#about .row {
    --bs-gutter-x: 0.5rem;
    --bs-gutter-y: 1rem;
}

#about .section-title {
    padding: 1rem 0 3rem 0;
}

#about .section-subtitle {
    width: 90%;
}



#about .section-body {
    font-size: 1.1rem;
    padding-left: 1rem;
}

.headerlinks {
    margin-top: 2%;
    margin-bottom: 3%;
}

#about .body {
    padding-top: 2%;
}

#cirleText {
    font-family: 'Montserrat', Arial;
    font-weight: bold;
    fill: white;
    margin: auto;
    font-size: calc(0.8rem + 1vw) !important;
}

#circleText div {
    max-height: 15.8em !important;
}

.circle {
    position: relative;
}

.pledge {
    position: absolute;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%);
    width: 40%;
    text-align: center;
    font-size: 0.85rem !important;
}

@media screen and (min-width:1200px) {
    #about .section-title {
        font-size: calc(5.5rem + 1.5vw) !important;
    }
}

/* change quote on phone to the same size as the body text */
@media screen and (max-width:992px) {
    
    #about .section-subtitle {
        font-size: calc(0.49rem + 1vw) !important;
    }
}

@media screen and (max-width:576px) {
    
    #about .section-subtitle {
        font-size: calc(0.8rem + 1vw) !important;
    }
}

/* after this the circle doesnt make sense */

@media screen and (max-width:1380px) {
    .circle {
        display: none;
    }

    #about .section-body {
        padding-left: 0rem;
    }
}


/* Footer */

#footer {
    padding-top: 2%;
    position: relative;
    /* background-color: white; */
    color: black;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    /* height: 100vh;*/
    height: 950px;
    max-height: 100vh;

}

/* Absoluted */
#footer .wrapper {
    position: absolute;
    top: 15px;
    left: 0;
    right: 0;
    z-index: 10;
    margin-left: 5vw;
    margin-right: 5vw;
}

#footer .footer-content {
    position: absolute;
    bottom: 15px;
    left: 0;
    right: 0;
    margin-left: 4.5vw;
    margin-right: 4.5vw;
}




#footer a {
    color: black;
}

#footer .headerlinks {
    margin-top: 1%;
    display: flex;
    justify-content: space-between;
}


#footer .headerlinks p:hover, #footer .headerlinks a:hover, .credit:hover {
    color: #AA2C42;
    cursor: pointer;
}


#footer ul {
    margin-top: -12px;
}

#footer .underline {
    margin: 25px 0px 0px 0px;
}

.link:nth-child(2):hover .hide, .link:nth-child(3):hover .hide, .link:nth-child(5):hover .hide {
    opacity: 1;
    transform: translateX(0);
    transition: 0.5s;
}

.hide {
    opacity: 0;
    transition: 0.3s;
    transform: translateX(25px);
}


#footer .content .body {
    position: relative;

    display: flex;
    justify-content: space-between;
    align-items: flex-end;
    overflow-x: hidden;
}

#footer .content .text img {
    width: 95%;
}

#footer .content .logo img {
    width: 59%;
    height: 59%;
    margin-bottom: 20px;
    border-radius: 30rem;
    padding: 1px;
    float: right;
}

#footer .credits {
    display: flex;
    justify-content: space-between;
    padding-bottom: 12px;
}

#footer .LinkPreEntry {
    opacity: 0;
    transition: 0.3s;
    transform: translateY(-35px);
}

#footer .LinkEntry {
    transform: translateY(0);
    opacity: 1 !important;
    transition: 0.7s !important;
    transition-delay: calc(0.3s * var(--order)) !important;
}



@media screen and (max-width:1010px) {
    #footer .logo img {
        display: none;
    }
}

/* Mobile */

@media screen and (max-width:585px) {
    #footer {
        max-height: 106vh;
    }

    .credits {
        flex-direction: column;
    }

    #footer .headerlinks .title {
        margin-top: 1vh;
    }

    #footer .headerlinks {
        padding-top: 10px;
        flex-direction: column;
        gap: 0px;
    }

    #footer .content {
        flex-direction: column;
        margin-top: 9vh;
    }

    .hide {
        opacity: 1;
        transition: 0.3s;
        transform: translateX(0px);
    }

    #footer img {
        margin-bottom: 5px;
    }

    #footer p {
        margin-bottom: 0.5rem;
    }

    #footer .footer-content {
        bottom: 1px;
    }

    #footer .credit, #footer .credit a {
        font-size: 0.9rem !important;
    }

    #footer .credits {
        padding-bottom: 0px;
    }
}

/* circle */

#cirleText {
    -webkit-animation-name: rotate;
    -moz-animation-name: rotate;
    -ms-animation-name: rotate;
    -o-animation-name: rotate;
    animation-name: rotate;
    -webkit-animation-duration: 15s;
    -moz-animation-duration: 10s;
    -ms-animation-duration: 10s;
    -o-animation-duration: 10s;
    animation-duration: 10s;
    -webkit-animation-iteration-count: infinite;
    -moz-animation-iteration-count: infinite;
    -ms-animation-iteration-count: infinite;
    -o-animation-iteration-count: infinite;
    animation-iteration-count: infinite;
    -webkit-animation-timing-function: linear;
    -moz-animation-timing-function: linear;
    -ms-animation-timing-function: linear;
    -o-animation-timing-function: linear;
    animation-timing-function: linear;
}

@-webkit-keyframes rotate {
    from {
        -webkit-transform: rotate(360deg);
    }

    to {
        -webkit-transform: rotate(0);
    }
}

@-moz-keyframes rotate {
    from {
        -moz-transform: rotate(360deg);
    }

    to {
        -moz-transform: rotate(0);
    }
}

@-ms-keyframes rotate {
    from {
        -ms-transform: rotate(360deg);
    }

    to {
        -ms-transform: rotate(0);
    }
}

@-o-keyframes rotate {
    from {
        -o-transform: rotate(360deg);
    }

    to {
        -o-transform: rotate(0);
    }
}

@keyframes rotate {
    from {
        transform: rotate(360deg);
    }

    to {
        transform: rotate(0);
    }
}

.transition-circle {
    height: 10px;
    width: 10px;
    z-index: 10;
    background-color: lightpink;
}

.transition-slide {
    transition-duration: 1s;
    position: absolute;
    left: 0px;
    top: 0px;
    height: 100%;
}

.addTransition {
    width: 100vw;
}

/* email sub */

#footer button {
    border: none !important;
    background: none;
}