html {
    background: #000;
    overflow-x: hidden !important;

}
.checkout .heading {
    background: #8cc63e;
}
#category .category,
#category .product {
    font-size: 1em;

}
.homepage-text {
    width: 80%;
    font-size: 15px;
    margin: auto;
    padding: 15px;

}
.homepage-text p {
    color: #fff;
}
#homepagetext-wrapper {
    background: #000;
    color: #fff;
}
.storefront-primary-navigation {
    font-size: 1rem !important;
}
.woocommerce-active .site-header .storefront-primary-navigation nav.main-navigation {
    width: 100%;
    margin-left: auto;
    margin-right: auto;
    float: none;
}
.main-navigation ul li a, 
.site-title a, 
ul.menu li a, 
.site-branding h1 a, 
button.menu-toggle, 
button.menu-toggle:hover, 
.handheld-navigation .dropdown-toggle, 
.main-navigation ul li:hover > a {
    color: #000;
}
.main-navigation ul.menu ul.sub-menu, .main-navigation ul.nav-menu ul.children {
    background: #fff;
}
@media (min-width: 768px) {
    .site-header {
        padding-top: 0;
        margin-bottom: 0;
    }
    .site-header .site-branding img {
        max-width: 350px;
    }
    .woocommerce-active .site-header .site-branding {
        margin-bottom: 0;
    }
    .main-navigation ul.menu, .main-navigation ul.nav-menu {
        margin-left: auto;
        margin-right: auto;
    }
    .main-navigation ul.menu>li>a, 
    .main-navigation ul.nav-menu>li>a {
        padding: 0.6rem 1rem;
        margin: 0;
        width: 100%;
    }
}

.storefront-primary-navigation ul {
    margin: auto;
    width: auto;
    float: none;
}

#category .category .name,
#category .product .name {
    color: #000;
    font-size: 1.2em;

}
.dark {
    background: #000;
    color: #fff;
}
#gallery {
    background: #fff;
}
#addons {

    margin-top: 30px;
}
h5 {
    text-align: center;
    font-size: 4.5em;
    font-family: 'Qwitcher Grypen', cursive;
}

p {
    margin: 0 15px 25px;
    color: #000;
    font-size: 1.2em;
    line-height: 1.2;

    font-family: "proxima-nova",sans-serif;
    font-weight: 100;
    font-style: normal;
    text-align: justify;

    text-rendering: optimizeLegibility;
}
h2 {
    margin-left: 20px;
    font-size: 2em;
    font-family: 'Open Sans Condensed', sans-serif;

}
body {
    float: left;
    width: 100%;
    padding: 0;
    margin: 0 auto;
    background: #FFF;
    color: #000;
    font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Helvetica, Arial, sans-serif;
}
#category .product .price,
#product .price {

    color: #000;

}
a {
    color: #000;

}
.btn-link {
    color: #f00;
    font-weight: normal;

    font-size: 1.5em;
    border: 1px solid #DDD;
    border-radius: 2px;

}
#product .values label:hover {
    color: #000;

}

a:hover {
    color: #000;

}
#product .product-name {
    color: #000;
}
#product .description {
    color: #000;
}

#header {
    /*	background: url(images/header-bg.png) repeat;*/
    background: #000;

}
.container.go-wide {
    max-width: 2500%;
    margin: 0 auto;

}
/*#homepage-banner{
	/*border-left:15px solid #8cc63e;
	border-right:15px solid #8cc63e;*/
/*	margin-left:-35px;
	margin-right:-35px;
		background-color: #000;

}*/

#homepage-banner .img-responsive {
    /* width: 100%;*/
    /*  max-width: auto;*/
}
.banner-rotator .banner {

    height: 430px;

}
/*collection banner stuff*/
.collection-banner .img-responsive {
    width: 100%;
    max-width: auto;
}
.collection-banner img {
    margin: auto;
}

.collection-banner .banner-title::after {
    position: absolute;
    display: block;
    content: "shop now";
    background: #759916;
    width: 170px;
    text-transform: uppercase;
    text-align: center;
    /*	font-weight: bold;*/
    font-size: 0.7em;
    left: 50%;
    margin-left: -85px;
    top: 70%;
    margin-top: 21px;
    line-height: 50px;
    color: #fff;
    z-index: 500;
}
.banner-title {
    position: absolute;
    z-index: 200;
    top: 37%;
    margin-top: -1.5em;
    width: 100%;
    text-align: center;
    color: #fff;
    text-shadow: 0 0 5px rgba(0, 0, 0, 1), 0 0 50px rgba(0, 0, 0, 1);
    font-size: 2em;

    /*	font-weight: bold;
	/*font-family: 'Bitter', serif;*/
}

.main-banner {
    width: 100%;
    height: 650px;
    background-position: center;

    background-repeat: no-repeat;
    background-size: cover;

}

.banner {
    width: 100%;

}

/*collection banner*/
#hours {
    background: #8cc63e;
    padding: 10px;
    font-size: 1em;
    color: #000;
    text-align: center;
    border-bottom: 5px solid #000;
}

.tagline-text {

    font-size: 1em;
    line-height: 1.2em;
    color: #000;
    margin-top: 20px;
}

#logo {
    padding: 0;
    margin: 0;
    width: 100%;
    max-width: 327px;
    height: 127px;
    background: url("images/Bloomsters-Logo.jpg") no-repeat center center;
    background-size: 100% auto;
}

#logo a {
    display: block;
    width: 100%;
    height: 100%;
    text-indent: -50000px;
    overflow: hidden;
}

#address {
    cursor: default;
    margin-top: 15px;
    color: #fff;
    font-family: 'Open Sans Condensed', sans-serif;
    line-height: 0.8em;

    text-align: right;
}

.phone,
.street,
.town {
    display: block;
    font-size: 1.4em;

}
.phone {
    font-weight: bold;
    font-size: 1.4em;
    font-family: 'Open Sans Condensed', sans-serif;
    margin-bottom: 5px;
}

.storefront-primary-navigation {
    margin-left: -30px;
    border-bottom: 1px solid #000;
    box-shadow: 0 0 10px rgba(0, 0, 0, .8);
    position: relative;
    z-index: 1000;
    background: #fff;
    font-size: 1.2em;
    margin: auto;

}
.storefront-primary-navigation li {
    border-bottom: 1px solid rgba(0,0,0,.1);
    /*width: auto;*/
}
.storefront-primary-navigation a {
    color: #000;
    font-family: 'Open Sans Condensed', sans-serif;

}

.storefront-primary-navigation li a:hover {
    color: #000 !important;
}

.storefront-primary-navigation ul ul {
    border-bottom: 3px solid #000;
}

.storefront-primary-navigation li ul a,
.storefront-primary-navigation li a:hover + ul a {
    color: #000;
}

#page {
    }

.container-widest {
    width: 100%;
    margin: 0 auto;
    max-width: 1920px;
}

.square {
    display: block;
    float: left;
    position: relative;
    background-size: 100% auto;
    max-height: 500px;
    background: no-repeat;
    border: 10px solid #fff;
}
.square1 {
    display: block;
    float: left;
    position: relative;
    background-size: 100% auto;
    max-height: 250px;
    background: no-repeat;
    border: 10px solid #fff;
}
.square1::after {
    display: block;
    content: '';
    padding-top: 100%;
}
.square1:hover .caption {
    margin-top: -5px;
    background: rgba(0, 0, 0, .9);
}

.square1:hover .caption {
    margin-top: -5px;
    background: rgba(0, 0, 0, .9);
}

.square::after {
    display: block;
    content: '';
    padding-top: 100%;
}

.square:hover .caption {
    margin-top: -5px;
    background: rgba(0, 0, 0, .9);
}

.square-third {
    width: 33.333%;
}
.square-one {
    width: 100%;
}

.square-half {
    width: 50%;
}

.caption {

    position: absolute;
    top: 50%;
    left: 20%;
    width: 60%;
    padding: 20px;
    line-height: 1.6em;

    text-align: center;
    transform: translate(0, -50%);
    background: rgba(0, 0, 0, .6);
    transition: 0.2s;
    max-width: 350px;
}

.super-title {
    color: #9ECC3B;
    font-size: 0.9em;
}

.title {
    color: #fff;
    font-size: 1.3em;
}

.option .title {
    color: #000;
    font-size: 1em;
}

.columns {
    padding-left: 0;
    padding-right: 0;
}

#content {
    background: #fff;

    margin: auto;
    padding-bottom: 30px;

}
h1 {
    font-size: 2.5em;
    font-family: 'Open Sans Condensed', sans-serif;

    padding-left: 10px;
}

#breadcrumbs {
    background: transparent;
    color: #999;

}
#breadcrumbs a {
    color: #000;
}
.btn-primary,
.btn-primary:visited {
    background: #161616;
    border-color: #292929;
}

.btn-primary:active,
.btn-primary:focus,
.btn-primary:hover {
    background: #060606;
    border-color: #262626;
}

#category .product .button {
    width: 5em;
    margin: auto;
}

#footer {
    clear: both;
    padding: 30px 0;
    color: #fff;

    background: #000;

    border-top: 15px solid #000;
}

#footer a {
    color: #fff;
    text-decoration: none;
}
#footer .footer-title {
    font-weight: bold;

}

#footer ul {
    position: relative;
    padding: 20px 0;
    list-style-type: none;
}

#footer2 {
    padding: 20px 0;
    color: #fff;

    font-size: 0.8em;
    background: #000;

}

.checkout #footer2 {
    background: #000;
}

#footer2 a {
    color: #fff;
}

#footer2 a:hover {
    color: #fff;
}
img.alignleft {
    float: left;
    margin: 0 15px 5px 0;
}

img.alignright {
    float: right;
    margin: 0 0 5px 15px;
}

img.alignabove {
    margin: 0 0 10px;
}
.areas-served {
    text-align: center;
    background: url("images/header-bg.png");
    color: #fff;
}
.footer-text {
    color: #fff;

    font-size: 0.8em;
}
.social.blog {
    background: #ef8731;
}
.fa fa-blog-f:before,
.fa-blog:before {
    content: "\f09e";
}
#header ul {
    position: relative;
    padding: 2px 0;
    list-style-type: none;

}

.wedding-main img {
    margin: 0 0 0 -15px;
    max-width: 103%;
    border-bottom: 1px solid #000;
}

.wedding-sm-txt {
    text-align: center;
    font-size: 2em;
    margin-top: -8px;
    margin-bottom: 27px;
}
.wedding-logo img {
    margin: auto auto 20px;
}
.wedding-txt {
    line-height: 2em;
    font-size: 1.2em;
}

.callout-btn {
    border: 1px solid #000;
    margin: 11px auto;
    width: 100px;
    padding: 9px;
    font-size: 1em;
    text-transform: uppercase;
}
.callout-title {
    margin-bottom: 0.5em;
    padding: 0;
    font-size: 2.125rem;
    text-align: center;
    font-family: "ff-good-headline-web-pro-con",sans-serif;
    font-style: normal;
    /*	padding-top: 20px;*/
    top: 50%;

}
.callout-text-color {
    background: #d6dbcc;
}
.callout-text {
    /*background: #fff;*/
    /*	width: 50%;
	float: left;*/
    top: 50%;
}
.callout-text-2 {
    background: #d6dbcc;
    width: 50%;
    float: right;
}

.wedding-pic {
    position: relative;
    float: right;
    width: 50%;
    overflow: hidden;
}

.wedding-pic img {
    height: 100%;
}

.wedding-pic-2 img {
    width: 50%;
    background: contain;
    height: 100%;
    float: left;

}

.callout-description {
    /*    font-family: inherit;
    font-weight: normal;
    font-size: 1rem;
    line-height: 1.6;
    margin-bottom: 1.25rem;
    text-rendering: optimizeLegibility;
	padding: 3em 2em;*/

}

/*about the team page css*/
.homepage-callout {
    }
.homepage-callout img {
    margin: auto;
    border: 10px solid #1f1f1e;
    margin-bottom: 10px;
}

.homepage-callout:active,
.homepage-callout:hover {
    text-decoration: none;
}

.homepage-callout .name {
    color: #fff;
    vertical-align: middle;
    float: left;
    line-height: 18px;

}
.caption2 {
    position: absolute;
    bottom: 1.5em;
    left: 0.5em;
    right: 0.5em;
    background: rgba(0,0,0,0.6);
    padding: 1em;
    font-size: 14px;
    width: 80%;
    margin: auto;
}
.homepage-callout .subtitle {
    float: right;
    font-style: italic;
    font-size: 10px;
    vertical-align: bottom;
    color: #9dcb3c;
    line-height: 18px;
}

.homepage-callout p {
    text-align: center;
    color: #21362a;
    font-size: 1em;

}

#product #addons-wrapper .row:before {
    display: none;
}
#product #addons-wrapper .row {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
}

#product #addons-wrapper .row .addon {
    width: 100%;
}

form[action="email/subscribe"] {
    z-index: 1;
    position: relative;
}
/*
.homepage-callout .caption {
	float: left;
	width: 100%;
	
	padding: 15px;
	color: #21362a;
	
	font-size: 1.7em;
	line-height: 1em;
	text-align:center;
	border-top:1px dotted #21362a;
	
}*/

/*about the team page css ends*/

@media (min-width: 1200px) {
    .container {
        width: 1200px;
    }

}

@media(min-width: 991px) {
    #product #details {
        margin-top: 0;
    }
}

@media screen and (max-width: 991px) {
    #logo {
        margin: 0 auto;
    }

}

@media screen and (max-width: 767px) {
    #logo {
        font-size: 2.1em;
    }

    #footer2 {
        font-size: 0.65em;
    }
    /*.collection-banner .banner-title::after {
		display: none;
	}*/

    .banner-title {
        font-size: 4vw;
        margin-top: -.8em;
    }
}

@media screen and (min-width: 768px) {
    #website-controls {
        margin-top: 15px;
    }

    .storefront-primary-navigation li:hover {
        }

    #search {
        margin-left: -15px;
        margin-right: -15px;
    }

    .storefront-primary-navigation ul {
        width: auto;
    }
}
@media (min-width: 767px) {
    .combo-text-image {
        display: table;
        width: 100%;
        min-height: 500px;
        overflow: hidden;
        text-align: center;
        background: #ecefe6;

    }

    .combo-text {
        display: table-cell;
        padding: 4em 2em;
        font-family: inherit;
        font-weight: normal;
        font-size: 1em;
        line-height: 1.6;
        margin-bottom: 1.25rem;
        text-rendering: optimizeLegibility;
        vertical-align: middle;
    }

    .combo-image {
        display: table-cell;
        position: relative;
        width: 50%;
        height: 100%;
        overflow: hidden;
    }

    .combo-image img {
        position: absolute;
        top: 0;
        left: 50%;
        max-width: none;
        height: 100%;
        transform: translateX(-50%);
    }

    .combo-text-image-reverse,
    .combo-text-image:nth-of-type(odd) {
        direction: rtl;
    }

    .combo-text-image-reverse .combo-image,
    .combo-text-image-reverse .combo-text,
    .combo-text-image:nth-of-type(odd) .combo-image,
    .combo-text-image:nth-of-type(odd) .combo-text {
        direction: ltr;
    }

}

@media (max-width: 767px) {
    .category .image,
    .product .image {
        height: 100%;
    }

    .category .image img,
    .product .image img {
        height: 100%;
        object-fit: contain;
    }

    a[href^="tel"] {
        color: #000;
    }
    #wedding-nav .lv-2 {
        display: none;

    }
    #wedding-nav::after {
        display: none;
    }

    #logo {
        margin: 0 auto;
    }
    #header {
        }
    #address {
        text-align: center;

        color: #fff;
        padding: 5px;
        margin-top: 0;
        line-height: 1em;
    }
    .phone {
        font-size: 1em;
        text-align: center;
    }

    .street,
    .town {
        display: inline;
    }
    .square-third {
        width: 100%;
    }
    .square-half {
        width: 100%;
    }

}

@media screen and (max-width: 600px) {
    #product #addons-wrapper .row {
        grid-template-columns: repeat(2, 1fr);
    }

    #category {
        padding-left: 1rem;
        padding-right: 1rem;
        margin: 0 auto;
        display: flex;
        flex-wrap: wrap;
    }

    #category .col-sm-4.category,
    #category .col-sm-4.product {
        padding-top: 0.75rem;
        padding-bottom: 6rem;
        width: 50%;
    }

    #category .col-sm-4.category .image-container,
    #category .product.col-sm-4 .image-container {
        height: 0;
        padding-top: 100%;
    }

    #category .col-sm-4.category .image-container img {
        height: 100%;
    }
}

@media screen and (max-width: 424px) {
    #header {
        }
    #logo {
        }
    p {

        font-size: 1em;
    }
}

@media screen and (max-width: 398px) {
    .square-third {
        width: 100%;
    }
    .square-half {
        width: 100%;
    }

    #address {
        position: relative;
        z-index: 100;
    }
    #logo {
        margin: 4px auto;
    }
}

@media screen and (max-width: 390px) {
    #logo {
        margin: 5px auto;
    }
}

@media screen and (max-width: 387px) {
    #logo {
        margin: 5px auto;
    }
}

@media screen and (max-width: 383px) {
    #logo {
        margin: 6px auto;
    }
}

@media screen and (max-width: 367px) {
    #header {
        }
    #logo {
        margin-top: -4px;
    }
}

@media screen and (max-width: 268px) {
    #header {
        }
}

@media (min-width: 767px) {
    .email-subscription-form {
        max-width: none;
    }

    .email-subscription-form br {
        display: none;
    }

    .email-subscription-form h4 {
        float: left;
        width: 180px;
        padding-right: 20px;
    }

    .email-subscription-form input[type="email"] {
        float: left;
        height: 44px;
        width: calc(100% - 360px);
        max-width: 300px;
        border-right: none;
        border-top-right-radius: 0;
        border-bottom-right-radius: 0;
    }

    .email-subscription-form input[type="submit"] {
        height: 44px;
        width: 180px;
        border-left: none;
        border-top-left-radius: 0;
        border-bottom-left-radius: 0;
    }
}

/** Pills **/

.pills {
    display: none;
}

@media(max-width: 767px) {
    .pills {
        display: flex;
        flex-direction: row;
        flex-wrap: nowrap;
        overflow-x: auto;
        scroll-snap-type: x mandatory;
        -webkit-overflow-scrolling: touch;
        /* Needed to work on iOS Safari */
        scroll-snap-type: mandatory;
        -ms-scroll-snap-type: mandatory;
        scroll-snap-points-x: repeat(100%);
        -ms-scroll-snap-points-x: repeat(100%);
        -ms-overflow-style: none;
        scrollbar-width: none;
    }
    .pills .lv-1 ul {
        display: none;
    }

    .pills ul {
        display: flex;
        flex-direction: row;
        flex-wrap: nowrap;
        align-items: center;
        gap: 1rem;
        white-space: nowrap;
        list-style-type: none;
        padding: 1rem;
    }

    .pills ul + ul {
        padding-left: 0;
    }

    .pills ul::-webkit-scrollbar {
        display: none;
    }

    .pills .lv-1 > a {
        display: block;
        padding: 0.5rem 1rem;
        border-radius: 999px;
        font-family: 'Open Sans Condensed', sans-serif;
        background: black;
        text-align: center;
        text-decoration: none;
        color: white;
        white-space: pre;
        scroll-snap-align: center;
    }
}
