:root {
    color: #28A5B4;
    color:#292929;
    color: #CBCBCB;
    --items: 5;
    --gap: 0.75rem;

    --border-xl: 20px;
    --border-m: 8px;
    --border-s: 6px;

    --accent-color: hsl(198, 86%, 53%);
    --fill-primary: hsl(204, 3%, 47%);
    --fill-active: hsl(204, 23%, 20%);
    --fill-disabled: hsl(204, 9%, 85%);
}

@font-face {
    src: url("/fonts/solosans-bold.otf");
    font-family: solosan-bold;
}

@font-face {
    src: url("/fonts/solosans-light.otf");
    font-family: solosan-light;
}

@font-face {
    src: url("/fonts/solosans-regular.otf");
    font-family: solosan-regular;
}

body {
    margin: 0;
	padding: 0;
    font-family: solosan-light;
}

html {
    scroll-behavior: smooth;
  }
  

img {
	width: 100%;
	height: auto;
}

h1,h2, h3,h4,h5,h6 {
	margin-top: 0;
    font-family: solosan-bold;
}

h2 {
    border-bottom: 2px solid #000;
    display: inline-block;
    width: auto;
    padding-bottom: 10px;
}

p,
li,
a {
	font-size: 15px;
    font-family: solosan-light;
}

strong {
    font-family: solosan-bold;
}

ul {
	padding-left: 20px;
}

a:hover, a:focus {
	border-bottom: 0;
	text-decoration: none;
    color: inherit;
}

i {
	vertical-align: middle;
}

.logo img {
    width: 60%;
}

header .fixed-top {
    position: fixed;
    top: 0;
    right: 0;
    left: 0;
    z-index: 1030;
    background-color: #fff;
    padding: 10px 0;
    z-index: 999;
    box-shadow: 0px 3px 65px #00000029;
}

.text-dark {
    color: #292929!important;
}

.bg-black {
    background-color: #292929;
}

.btn-primary.focus, .btn-primary:focus {
    box-shadow: none;
}

.bg-dark {
    background-color: rgb(52 58 64 / 33%)!important;
}

.border-bottom-dashed {
    border-bottom: 1px dashed #292929;
    display: inline-block;
}

button:focus {
    outline: none;
}

.btn-primary.inverted {
    padding: 10px 15px!important;
    line-height: 20px;
    background-color: transparent;
    color: #fff;
    vertical-align: middle;
    font-size: 15px;
    border: 2px solid #fff;
    border-radius: 0;
    text-transform: capitalize;
    min-width: 150px;
}

.btn-primary.inverted:hover {
    background-color: #fff;
    color: #000;
    font-size: 15px;
    border: 2px solid #fff;
}

.btn-primary.blue {
    padding: 10px 15px!important;
    line-height: 20px;
    background-color: #28A5B4;
    color: #fff;
    vertical-align: middle;
    font-size: 15px;
    border: 2px solid #28A5B4;
    border-radius: 0;
    text-transform: capitalize;
    min-width: 150px;
}

.btn-primary.blue:hover, .btn-primary:not(:disabled):not(.disabled).active, .btn-primary:not(:disabled):not(.disabled):active, .show>.btn-primary.dropdown-toggle {
    background-color: #fff;
    color: #28A5B4;
    font-size: 15px;
    border: 2px solid #28A5B4;
    box-shadow: none;
}

.btn-primary.inverted-blk {
    padding: 10px 15px!important;
    line-height: 20px;
    background-color: transparent;
    color: #000;
    vertical-align: middle;
    font-size: 15px;
    border: 2px solid #000;
    border-radius: 0;
    text-transform: capitalize;
    min-width: 150px;
    font-family: solosan-regular;
}

.btn-primary.inverted-blk:hover {
    background-color: #000;
    color: #fff;
    font-size: 15px;
    border: 2px solid #000;
}

.navbar-expand-lg .navbar-nav .nav-link {
    padding-right: 20px;
    padding-left: 20px;
}

.navbar-nav .nav-link {
    padding: 0px;
    display: inline-block;
    color: #292929 !important;
    /* font-family: solosan-bold; */
    font-size: 16px;
    border-bottom: 2px solid transparent;
}

.navbar-nav .nav-link i {
    color: #292929;
    font-size: 13px;
}

.nav-item.active .nav-link i {
    color: #28A5B4;
}

.nav-item.active .nav-link {
    color:#28A5B4!important;
    border-bottom: 2px solid #28A5B4;
    padding: 0px;
    font-family: solosan-light;
    font-weight: 100;
}

.navbar-nav {
    display: -ms-flexbox;
    display: flex;
    -ms-flex-direction: column;
    flex-direction: column;
    padding-left: 0;
    margin-bottom: 0;
    list-style: none;
    display: -webkit-inline-box;
}

.nav-item {
    padding: 0 20px;
}

.bg-light {
    background-color: #fff;
}

.cart-extra-cards .bg-light {
    background: #ECEFF2!important;
    background-color: #ECEFF2!important;
}

.cart-table tr>td {
    vertical-align: middle;
    align-items: center;
}

.card {
    border-radius: 0;
}

.card a {
    color: #292929;
}

.products {
    padding-top: 5%;
}

.products .card {
    height: 100%;
}

/* .products .card-body {
    min-height: 205px;
} */

.carousel__slider {
    display: flex;
    overflow-x: auto;
    scroll-behavior: smooth;
    list-style: none;
    padding: 0;
    margin: 0;
}

.carousel__slide {
    flex: 0 0 auto; /* Prevent shrinking */
    margin-right: 10px; /* Add spacing between thumbnails */
}

.carousel__slider::-webkit-scrollbar {
    display: none; /* Hide scrollbar for a cleaner look */
}

.our-products .card {
    border: 1px solid #ECEFF2;
    height: 100%;
}

.products .card-footer, .our-products .card-footer {
    padding: .75rem 1.25rem;
    background-color: transparent;
    border-top: 0;
}

.price {
    color: #28A5B4;
    font-family: solosan-bold;
    font-size: 20px;
}

.card-title {
    font-family: solosan-regular;
    text-transform: uppercase;
}
/* Modals */

.close {
    float: right;
    font-size: 40px;
    font-weight: 700;
    line-height: 1;
    color: #000;
    text-shadow: 0 1px 0 #fff;
    opacity: 1;
    position: absolute;
    top: 15px;
    right: 25px;
    height: 60px;
}

.modal-title {
    margin-bottom: 0;
    line-height: 40px;
    vertical-align: middle;
}

.modal-body {
    position: relative;
    -ms-flex: 1 1 auto;
    flex: 1 1 auto;
    padding: 2rem;
}

.modal-body .card-img {
    width: 60%;
}

/* New carousel with thumbnail gallery */
.image-thumbnail-carousel {
    padding: 1rem;
    width: auto;
    display: flex;
    flex-flow: column;
    gap: 1rem;
    position: relative;
}

.image-display {
    border-radius: var(--border-xl);
    overflow: hidden;
    min-height: 30vmin;
    /* aspect-ratio: 16 / 9;
    box-shadow: 0 0.375em 0.67em #0003, 0 0.5em 1.3em #0002; */
}

.screen {
    block-size: 100%;
    display: flex;
    background-image: linear-gradient(12deg, #aaa, #eee);
    position: relative;
    user-select: none;
}

.thumbnail-carousel {
    display: flex;
    gap: var(--gap);
    block-size: 100%;
    overflow: hidden;
    position: relative;
    width: 110%;
    padding-left: 30px;
    padding-right: 40px;
}
.image-thumbnail-carousel .carousel {
    position: relative;
    padding-left: 30px;
    padding-right: 15px;
}

.carousel__btn.prev {
    left: -3px;
}

.carousel__btn {
    flex: 1 0 max(2.75rem, 5.834%);
    background: #0000;
    border: 1px solid #0000;
    cursor: pointer;
    display: flex;
    align-items: center;
    position: absolute;
    top: 35%;
}

.next {
    right: -10px;
}

.arrow-icon {
    margin-inline: auto;
    outline: none;
    border: 0;
    scale: 1.5;
    display: inline grid;
    width: max(70%, 1.3rem);
    height: max(70%, 1.3rem);
    fill: var(--fill-primary);
}

.carousel__btn:hover .arrow-icon {
    fill: var(--fill-active);
}

.carousel__btn:disabled {
    opacity: 0.5;
    pointer-events: none;
}

.carousel__slider {
    user-select: none;
    flex-grow: 999;
    list-style: none;
    display: inline-flex;
    gap: 11px;
    padding: 0.5rem;
    width: 100%;
    /* overflow-x: auto; */
    padding-right: 30px;
}

.carousel__slider::-webkit-scrollbar {
    display: none;
}

.carousel__slide {
    cursor: pointer;
    border-radius: var(--border-m);
    overflow: hidden;
    /* scroll-snap-align: center;
    flex: 1 0 calc((100% / var(--items)) - 10px); */
    width: 120px;
    border: 1px solid transparent;
    padding: 5px;
}

.carousel__slide.active {
    border: 1px solid #aaa;
    padding: 5px;
}

/* .active.carousel__slide {
    outline: 0.125em solid var(--accent-color);
    outline-offset: -0.37em;
} */

.thumbnail {
    width: min-content;
    min-width: 110px;
}

/* End of Carousel with thumbnails */
.product-page {
    height: auto;
}
.product-page .carousel-item {
    padding: 20px;
}

/* Home */
/* .home-header {
    background-image: url('https://via.placeholder.com/1920x500');
    background-position: center;
    background-size: cover;
    min-height: 500px;
    padding: 5% 0;
} */

.home-header .card {
    background-color: #fff;
    min-height: 240px;
    height: auto;
    width: 25rem!important;
    margin-top: 15%;
}

.page-header {
    background-color: #28A5B4;
    padding: 3% 0;
}

.home-about {
    background-color: #ECEFF2;
}

.original-price {
    text-decoration: line-through;
    color: #666666;
    font-size: 16px;
    margin-left: 10px;
    font-family: solosan-regular;
}

/* FAQs */
.accordion .card {
    border:0;
}
.accordion .card-header {
    padding: .75rem 1.25rem;
    margin-bottom: 0;
    background-color: transparent;
    border-bottom: 0;
}

.accordion .card-header p {
    font-size: 20px!important;
}

.accordion .card-header.active p {
    color: #28A5B4!important;
    font-size: 20px!important;
}

.accordion .card-body {
    -ms-flex: 1 1 auto;
    flex: 1 1 auto;
    min-height: 1px;
    padding: .75rem 2rem;
}

/* Terms and conditions */
.terms {
    padding: 5% 0;
}

/* Form */
.contact a {
    color: #28A5B4;
    font-family: solosan-bold;
}

.contact p>span {
    margin-left: 10px;
}

.form-control {
    display: block;
    width: 100%;
    height: auto;
    padding: 10px;
    font-size: 15px;
    font-weight: 300;
    line-height: 1.5;
    color: #323234;
    background-color: #fff;
    background-clip: padding-box;
    border: 1px solid #D1D1D1;
    border-radius: 0;
    transition: border-color .15s ease-in-out,box-shadow .15s ease-in-out;
}

.form-control:focus {
    color: #131010;
    background-color: #fff;
    border-color: #404627;
    outline: 0;
    box-shadow: none;
}

.custom-select {
    display: inline-block;
    width: 100%;
    height: auto;
    padding: 10px;
    font-size: 15px;
    font-weight: 400;
    line-height: 1.5;
    vertical-align: middle;
    background: url('https://files.crtgroupstorage.com/sulenetaylor/angle-down-light.png') no-repeat right 0.70rem center/12px 7px;
    color: #0F3559;
    background-color: #fff;
    background-clip: padding-box;
    border: 1px solid #A2A2A2;
    border-radius: 0px;
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
}

.custom-select:focus {
    border-color: #A2A2A2;
    outline: 0;
    box-shadow:none;
}

.dropdown {
    position: relative;
    color: #323234;
    background-color: #fff;
    background-clip: padding-box;
    border:0;
    border-radius: 0;
    transition: border-color .15s ease-in-out, box-shadow .15s ease-in-out;
}

.form-range {
    float: right;
    vertical-align: middle;
    height: 25px;
    -webkit-appearance: none;
    appearance: none;
    background: transparent;
    cursor: pointer;
    width: 280px;
}

input[type="range"] {
    -webkit-appearance: none; /* For Chrome, Safari, and Opera */
    -moz-appearance: none;    /* For Firefox */
    appearance: none;         /* Standard property */
    background: transparent;  /* Make the default background transparent */
    cursor: pointer;          /* Change the cursor to a pointer */
    width: 280px;              /* Adjust width as needed */
    outline: none;            /* Remove outline on focus */
}

input[type="range"]::-webkit-slider-runnable-track {
    height: 8px; /* Set the height of the track */
    background: #28a6b47c; /* Background color of the track */
    border-radius: 4px; /* Rounded corners for the track */
    box-shadow: inset 0 0 4px rgba(0, 0, 0, 0.1); /* Optional inner shadow */
}

input[type="range"]::-moz-range-track {
    height: 8px;
    background: #28a6b47c;
    border-radius: 4px;
    box-shadow: inset 0 0 4px rgba(0, 0, 0, 0.1);
}

input[type="range"]::-webkit-slider-thumb {
    -webkit-appearance: none;
    height: 20px; /* Set the height of the thumb */
    width: 20px;  /* Set the width of the thumb */
    background: #28A5B4; /* Background color of the thumb */
    border-radius: 50%; /* Make the thumb circular */
    margin-top: -6px; /* Adjust to center the thumb vertically on the track */
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.2); /* Optional shadow */
}

input[type="range"]::-moz-range-thumb {
    height: 20px;
    width: 20px;
    background: #28A5B4;
    border-radius: 50%;
    box-shadow: 0 2px 5px rgba(0, 0, 0, 0.2);
}

.form-select {
    width: 100%;
    height: auto;
    padding: 10px;
    font-size: 15px;
    font-weight: 300;
    line-height: 1.5;
    color: #323234;
    background-color: #fff;
    background-clip: padding-box;
    transition: border-color .15s ease-in-out,box-shadow .15s ease-in-out;
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    background:url('https://files.crtgroupstorage.com/angle-down-light.png') 96% / 15px 8px no-repeat;
    background-color: #fff;
    border-radius: 0!important;
    border: 1px solid #D1D1D1!important;
}

.form-control:focus, select.form-select:focus {
    color: #323234;
    background-color: #fff;
    border-color: #323234;
    outline: 0;
    box-shadow: none;
}

.form-select:focus {
    color: #131010;
    background-color: #fff;
    border-color: #404627;
    outline: 0;
    box-shadow: none;
}

input[type=number]::-webkit-outer-spin-button,
input[type=number]::-webkit-inner-spin-button {
    -webkit-appearance: none;
    margin: 0;
}

.dropdown-toggle::after {
    display: none;
}

textarea.form-control {
    height: 130px;
}

label {
    margin-bottom: 10px;
    color: #202536;
    font-weight: 300;
}

.input-group-text {
    display: flex;
    align-items: center;
    padding: 0 .75rem;
    font-size: 1rem;
    font-weight: 400;
    line-height: 1.5;
    color: var(--bs-body-color);
    text-align: center;
    white-space: nowrap;
    background-color: transparent;
    border: 0;
    border-radius: 0;
}

.flatpickr-input {
    padding: 8px 10px;
   border-radius: 0;
}

.input-group-text i {
    display: block!important;
}

.input-group>.form-control, .input-group>.form-floating, .input-group>.form-select {
    width: auto!important;
}

.checkbox {
    margin: 0;
    display: -webkit-box;
    overflow: hidden;
    position: relative;
}
.checkbox input[type=checkbox]{
    margin: 0;
    visibility: hidden;
    left: 7px;
    top: 7px;
}
.checkbox label{
	width: 15px;
    height: 15px;
    padding: 0;
    margin: auto 15px auto 0;
    border-radius: 0;
    border: 1px solid #666;
    cursor: pointer;
    display: block;
    position: relative;
    transition: all 0.3s ease 0s;
	margin-left: -11px;
}
.checkbox label:hover { 
	border-width: 2px; 
}
.checkbox input[type=checkbox]:checked+label{
    background-color: #28A5B4;
    border: 7px solid #28A5B4;
    box-shadow: none;
}
.checkbox label:before,
.checkbox label:after{
    content: "";
    background: #fff;
    width: 2px;
    height: 10px;
    opacity: 0;
    transform: translateX(-50%) rotate(55deg);
    position: absolute;
    left: 160%;
    top: -10px;
    transition: all 0.2s ease 0s;
}
.checkbox label:after{
	height: 7px;
    transform: translateX(-50%) rotate(-33deg);
    left: -35%;
    top: -6px;
}
.checkbox input[type=checkbox]:checked+label:before{
    opacity: 0;
    transform: translateX(-50%) rotate(55deg);
    left: 75%;
    top: 0px;
}
.checkbox input[type=checkbox]:checked+label:after{
    opacity: 0;
    transform: translateX(-50%) rotate(-33deg);
    left: 1%;
    top: 2px;
}

.checkbox span {
	font-size: 16px;
    font-weight: 500;
}

.error {
	margin-top: 15px;
	padding: 10px;
	background-color: #C0352C;
	color: #fff;
	display: none;
}

.output {
	margin-top: 15px;
	padding: 10px;
	background-color: #3ba15d;
	color: #fff;
	display: none;
}

#email2 {
	display: none;
}

textarea.form-control {
    height: 150px;
    border-radius: 0;
}

/* Qty */
.qty-up {
    position: absolute;
    top: -2px;
    left: auto;
    right: 11px;
    bottom: 0;
    color: #000000;
    vertical-align: middle;
}

.qty-up i {
    vertical-align: middle;
    font-size: 20px;
    line-height: 25px;
}

.qty-down {
    position: absolute;
    top: -2px;
    left: 10px;
    color: #000000;
    bottom: 0;
    vertical-align: middle;
    right: auto;
    z-index: 999;
}

.qty-down i {
    vertical-align: middle;
    font-size: 20px;
    line-height: 25px;
}

.qty-final {
    border: 1px solid #C9C9C9;
    font-size: 20px;
    border-radius: 26px;
    padding: 4px 5px;
    background-color: #fff;
    min-height: 30px;
    width: 115px;
    vertical-align: middle;
    display: inline-block;
    text-align: center;
    position: relative;
}

.qty {
    padding: 0;
}

table tr {
    vertical-align: middle;
}

/* Cart */
.cart-page, .checkout {
    padding: 5% 0;
}

.remove-item i {
    font-size: 20px;
}


/* Footer */
.footer-top {
    background-color: #292929;
    padding: 5% 0;
}

footer p, footer a {
    color: #292929;
    margin-bottom: 0;
    line-height: 30px;
    vertical-align: middle;
}

.footer-contact-details a {
    color:#28A5B4;
    font-family: solosan-bold;
    padding: 0 5px;
    vertical-align: middle;
}

.footer-contact-details{
    font-family: solosan-bold;
}

.links {
    vertical-align: middle;
    text-align: right;
}

.links span {
    font-size: 17px;
    line-height: 15px;
    vertical-align: middle;
}

div:where(.swal2-container) h2:where(.swal2-title) {
    border-bottom: 0;
    padding: 0;
}

div:where(.swal2-icon).swal2-success .swal2-success-ring {
    position: absolute;
    z-index: 2;
    top: -0.25em;
    left: -0.25em;
    box-sizing: content-box;
    width: 100%;
    height: 100%;
    border: .25em solid rgba(165, 220, 134, .3);
    border-radius: 50%;
}

div:where(.swal2-icon).swal2-success .swal2-success-fix {
    position: absolute;
    z-index: 1;
    top: 0;
    left: 5.625em;
    width: 20px;
    height: 20px;
    transform: rotate(-45deg);
}

div:where(.swal2-icon).swal2-success [class^=swal2-success-circular-line] {
    position: absolute;
    width: 20px;
    height: 20px;
    transform: rotate(45deg);
    border-radius: 50%;
}

div:where(.swal2-icon).swal2-success [class^=swal2-success-circular-line][class$=right] {
    top: -0.6875em;
    left: 0.875em;
    transform: rotate(-45deg);
    transform-origin: 0 3.75em;
    border-radius: 0 7.5em 7.5em 0;
}

div:where(.swal2-container) button:where(.swal2-styled).swal2-confirm {
    border: 0;
    border-radius: 0;
    background: initial;
    background-color: #7066e0;
    color: #fff;
    font-size: 15px;
}

div:where(.swal2-container) button:where(.swal2-styled).swal2-cancel {
    border: 0;
    border-radius: 0;
    background: initial;
    background-color: #6e7881;
    color: #fff;
    font-size: 15px;
}

div:where(.swal2-container) button:where(.swal2-styled).swal2-default-outline:focus {
    box-shadow: none;
}

div:where(.swal2-container) button:where(.swal2-styled).swal2-default-outline:focus {
    box-shadow: none;
}

div:where(.swal2-icon).swal2-error [class^=swal2-x-mark-line] {
    position: absolute;
    width: 50px;
    height: 3px;
    transform: rotate(45deg);
    border-radius: 0%;
    background-color: #f27474;
}

