@import url('https://fonts.googleapis.com/css2?family=Poetsen+One&display=swap');

@font-face {
    font-family: 'MatterRegular';
    src: url('../../assets/fonts/Matter-Regular.eot');
    src: url('../../assets/fonts/Matter-Regular.eot?#iefix') format('embedded-opentype'),
        url('../../assets/fonts/Matter-Regular.woff2') format('woff2'),
        url('../../assets/fonts/Matter-Regular.woff') format('woff'),
        url('../../assets/fonts/Matter-Regular.ttf') format('truetype'),
        url('../../assets/fonts/Matter-Regular.svg#Matter-Regular') format('svg');
    font-weight: normal;
    font-style: normal;
    font-display: swap;
}
@font-face {
    font-family: 'MatterMedium';
    src: url('../../assets/fonts/Matter-Medium.eot');
    src: url('../../assets/fonts/Matter-Medium.eot?#iefix') format('embedded-opentype'),
        url('../../assets/fonts/Matter-Medium.woff2') format('woff2'),
        url('../../assets/fonts/Matter-Medium.woff') format('woff'),
        url('../../assets/fonts/Matter-Medium.ttf') format('truetype'),
        url('../../assets/fonts/Matter-Medium.svg#Matter-Medium') format('svg');
    font-weight: 500;
    font-style: normal;
    font-display: swap;
}


/*Body*/

:root{
    --primary: #FFAB32;
    --secondary: #FFCA54;
    --white: #fff;
    --blue: #0E2553;
    --matteregular: 'MatterRegular';
    --mattemedium: 'MatterMedium';

    --poetsen: "Poetsen One", sans-serif;
}

body{
    background: url(../../assets/images/body_bg.png)no-repeat;
    background-position: center;
    background-size: cover;
    font-family: var(--matteregular) !important;
    color: #fff;
    overflow-x: hidden;
}
h1,h2,h3,h4,h5,h6{
      font-family: "Poetsen One", sans-serif;
}
h1{}
h2{}
h3{
    font-size: 28px;
    font-weight: 700;
    line-height: 32px;
    color: #fff;
    text-transform: capitalize;
}
h4{
    font-size: 22px;
    font-weight: 400;
    margin: 10px 0;
    line-height: 30px;
}
h5{}

.color-primary{
    color: #FF5B5B;
}
.color-secondary{
    color: #5A32F3;
}
ul{
    list-style: none;
    padding: 0;
    margin: 0;
}
/*Body*/

/*Extra*/
h2,
.sec-heading{
    font-size: 55px;
    font-weight: 700;
    margin: 10px 0;
    color: var(--white);
    line-height: 50px;
    text-transform: uppercase;
}
p,
.sec-para{
    font-size: 18px;
    font-weight: 400;
    line-height: 30px;
    margin: 10px 0;
    color: #7b7373;
}
.btn-business{
    padding: 40px 90px;
    color: #fff;
    font-size: 18px;
    border-radius: 10px;
    transition: all .5s ease;
    text-transform: capitalize;
    text-decoration: none;
    font-family: var(--montserrat);
    font-weight: 700;
    transition: all .5s ease;
    font-size: 0;
}
.btn-business:hover{
    transform: scale(1.1);
}
.btn-simple{
    background: linear-gradient(45deg, var(--primary), var(--secondary));
    padding: 10px 38px !important;
}
.btn-simple:hover{
    background-color: #000;
    color: #fff !important;
}
.container{
    width: 100%;
    max-width: 100%;
    padding: 0 6%;
}
header .container,.banner .container{
    transition: all .5s ease;
}
.dis-flex-start{
    display: flex;
    align-items: center;
    justify-content: flex-start;
}
.dis-flex-center{
    display: flex;
    align-items: center;
    justify-content: flex-start;
}
.dis-flex-end{
    display: flex;
    align-items: flex-end;
    justify-content: center;
}
.inner-banner{}
/*Extra*/

/*Header*/
header{
    font-family: var(--montserrat);
}
header nav{}
header nav .navbar-brand{}
header nav .navbar-brand img{}
header nav .navbar-nav{}
header nav .navbar-nav li{
    line-height: 30px;
}
header nav .navbar-nav li a{
    color: #000;
    font-size: 24px;
    margin: 0 10px;
    transition: all .5s ease;
    text-decoration: none;
    text-transform: capitalize;
    padding: 10px 38px;
    font-weight: 500;
    border-radius: 10px;
    font-family: 'MatterMedium';
}
header nav .navbar-nav li a.btn:hover{
    color:#fff !important;
}
header nav .navbar-nav li:last-child{}
header nav .navbar-nav li:last-child a{}
header nav .navbar-nav li a:hover,
header nav .navbar-nav li a.active{
    color: var(--primary) !important;
}
/*Header*/

/*Contact*/
section.contact_sec{
    padding: 60px 0 60px;
    /* overflow: hidden; */
    text-align: center;
}
section.contact_sec .box{
    background: url(../../assets/images/form-bg.png)no-repeat;
    padding: 100px 5%;
    border-radius: 20px;
    position: relative;
    z-index: 1;
    background-size: 100% 100%;
}
section.contact_sec .box h3{
    margin: 0 0 20px;
    color: #000;
    font-size: 60px;
}
section.contact_sec .box h4{
    color: #000;
    font-weight: 400;
    font-style: italic;
}
section.contact_sec .box:before{
    position: absolute;
    content: "";

}
section.contact_sec .box:after{
    position: absolute;
    content: "";
    background: url(../../assets/images/sun.png)no-repeat;
    width: 295px;
    height: 300px;
    background-position: center;
    background-size: 100%;
    right: 0;
    top: -140px;
    animation: spin 20s linear infinite;
    z-index: -1;
}
section.contact_sec form{
    font-family: var(--montserrat);
}
section.contact_sec form label{
    width: 100%;
    font-weight: 400;
    padding: 30px 0;
    color: #000;
    text-align: left;
}
section.contact_sec form .form-control{
    background-color: transparent;
    border: 0;
    border: 1px solid #bfbfbf;
    border-radius: 0;
    width: 100%;
    margin: 0 0 25px;
    padding: 20px 20px;
    color: #000;
    font-size: 18px;
    font-weight: 400;
    outline: none;
    box-shadow: none;
    height: 55px;
}
section.contact_sec form .half{/* width: 50%; */}
section.contact_sec form .pads{display: flex;justify-content: center;align-items: center;}
section.contact_sec form h4{
    font-size: 22px;
    font-weight: 600;
    line-height: 32px;
    margin: 10px 0 10px;
}
section.contact_sec form h4 strong{
    margin: 0 0 30px;
    font-weight: 700;
}
/*Contact*/
@keyframes spin{
  0%{
    transform: rotate(0deg);
  }
  100%{
    transform: rotate(360deg);
  }
}
/*Footer*/
footer{
    padding: 60px 0 0;
    background-color: #000;
}
footer .img-box{}
footer .img-box img{}
footer .social_icons{}
footer .social_icons li{
    display: -webkit-inline-box;
    margin: 0 10px;
}
footer .social_icons li a{
    text-decoration: none;
}
footer .social_icons li a i{
    font-size: 18px;
    transition: all .5s ease;
    color: #fff;
}
footer .social_icons li a:hover i{
    background-color: #fff;
    color: #ffb23a;
}
footer .sec-para{
    padding: 0 15%;
    margin: 10px 0 50px;
}
footer .copyright{
    padding: 30px 0 30px;
    border-top: 1px solid #ccccccde;
    margin: 60px 0 0;
}
footer .copyright p{
    padding: 0;
    margin: 0;
}
footer h4{
    font-family: 'MatterMedium';
    font-size: 30px;
    margin: 0 0 30px;
}
footer ul.menu{}
footer ul.menu li{
    line-height: 35px;
}
footer ul.menu li a{
    font-size: 17px;
    color: #fff;
    text-decoration: none;
}
footer .copyright{}
footer .copyright ul{}
footer .copyright ul li{}
footer .copyright ul li a {}
footer .copyright p {
    text-align: right;
}
/*Footer*/


/*Wizard*/
.wizard form {
    min-height: 350px;
}

.step {
  display: none;
}

.step.active {
  display: block;
  animation: fadeIn 0.5s ease-in-out;
}

@keyframes fadeIn {
  from {
    opacity: 0;
    transform: translateY(20px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}
/* Hide default radio input */
.form-check-input {
  display: none;
}

/* Style the label as a radio button */
.form-check-label {
  position: relative;
  padding-left: 30px;
  cursor: pointer;
  font-weight: normal;
}

/* Create a custom radio button */
.form-check-label:before {
  content: '';
  position: absolute;
  left: 0;
  top: 15px;
  margin: auto;
  width: 30px;
  height: 30px;
  border: 1px solid transparent; /* Border color for unchecked */
  border-radius: 50%;
  transition: border-color 0.3s, background-color 0.3s;
  right: 0;
}

/* Change the radio button color when checked */
/*.form-check-input:checked + .form-check-label:before {*/
/*  border-color: #ff8800;*/
/*  background: linear-gradient(45deg, #fbdd91, #d7abe1);*/
/*}*/
.form-check-input:checked + .form-check-label strong{
    padding: 0 0 0 50px;
    padding: 0;
    z-index: 999;
}
/* Add animation to the checked label */
/*.form-check-input:checked + .form-check-label:before {*/
/*  animation: pulse .8s infinite; !* Add your preferred animation *!*/
/*}*/

@keyframes pulse {
  0%, 100% {
    transform: scale(1);
  }
  50% {
    transform: scale(1.2);
  }
}
.custom_radios .form-check{
    /* height: 50px; */
    margin: 0 10px 15px;
    padding: 0;
    width: 20%;
    float: left;
    display: flex;
    align-items: center;
    justify-content: center;
}
.custom_radios input{}
.custom_radios label {
    display: flex;
    align-items: center;
    /* background-color: #2e1e3e26; */
    justify-content: center;
    padding: 30px 20px;
    color: #000;
    flex-direction: column;
}
.custom_radios label span{
    /*position: absolute;*/
    left: 24px;
    top: 13px;
    font-weight: 700;
    /* display: none; */
}
.custom_radios label strong{
    padding: 0 0 0 40px;
    transition: all .5s ease;
}
/*Wizard*/
/* Style for the file input */
.custom-file-input {
  cursor: pointer;
  position: relative;
  width: 100%;
  height: calc(1.5em + 0.75rem + 2px);
  opacity: 0;
}

.custom-file-input::before {
  content: 'Choose File';
  display: inline-block;
  cursor: pointer;
  background-color: #007bff;
  color: #fff;
  border-radius: 0.25rem;
  padding: 0.375rem 0.75rem;
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  line-height: 1.5;
  text-align: center;
}

/* Animation effect on hover */
.custom-file-input:hover::before {
  background-color: #0056b3;
}

/*File upload*/
    .dropzone {
      border: 2px dashed #ccc;
      border-radius: 5px;
      padding: 20px;
      text-align: center;
      padding: 20px 20px;
      margin: 10px 0 30px;
      cursor: pointer;
      background: transparent !important;
      border: 2px dashed #fff !important;
    }

    .dropzone.hover {
      border-color: #007bff;
    }

    .progress {
      display: none;
      margin-top: 10px;
    }
    .file-list {
      margin: 0px 0 20px 0;
      width: 100%;
    }
    .file-list span{
        font-weight: 700;
    }
    .file-list #uploadedFilesList{}
    .file-list #uploadedFilesList li{
    position: relative;
    border-bottom: 1px solid #444168;
    padding: 0 0 2px;
    margin: 0 0 5px;
}
    .file-list #uploadedFilesList li:before{
        position: absolute;
        content: "\f022";
        font-family: 'Font Awesome 5 Free';
        right: 0;
        top: 0;
        bottom: 0;
        margin: auto;
        font-size: 18px;
        color: #28a745;
        transition: all .5s ease;
    }
/*File upload*/

.step .img-box{
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
}
.step .img-box img{
}
.step_form {
/*    min-height: 500px;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: flex-start;*/
}

button#prevButton {
    background: url(../../assets/images/previous.png)no-repeat;
}
button#nextButton {
    background: url(../../assets/images/next.png)no-repeat;
}


.color_select .custom_radios .form-check,
.crate_part .form-check,
.cat_treats .form-check {
    width: unset;
}


.color_select .form-check-label:before {
    width: 100px;
    height: 100px;
    top: 0;
    left: 0;
    right: 0;
}

.color_select .form-check-label {
    height: 100px;
    width: 100px;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 0;
    text-align: center;
}

.color_select .form-check-label strong {
    padding: 0;
    z-index: 9;
    color: #fff;
}

.color_select .form-check-label.black:before {background-color: #000;}
.color_select .form-check-label.red:before {background-color: red;}
.color_select .form-check-label.blue:before {background-color: blue;}
.color_select .form-check-label.purple:before {background-color: purple;}
.color_select .form-check-label.pink:before {background-color: pink;}
.color_select .form-check-label.silver:before {background-color: silver;}



.crate_part .custom_radios label {
    flex-direction: column;
}
.crate_part label strong,
.cat_treats label strong {
    padding: 0;
}
.custom_radios label .qty {
    width: 50%;
}

.form_part label {
    width: 35% !important;
    padding: 0 0 !important;
    margin: 0 0 !IMPORTANT;
    font-size: 26px;
    font-weight: 500 !important;
}
.form_part .lasty{
    position: relative;
}
.form_part .lasty label {
    width: 100% !important;
}
.content.form_part {margin: 40px 0 20px;}

.form_part .lasty input {
    position: relative;
    margin: 0 !important;
}

.form_part .lasty button {
    position: absolute;
    bottom: 0;
    right: 0;
    z-index: 999;
    height: 55px;
    border: 0;
    background-color: #52AE77;
    color: #fff;
    padding: 10px 60px;
    font-size: 20px;
    font-weight: 500;
    line-height: 0;
}
button.add_to_cart {
    background: url(../../assets/images/addtocart.png)no-repeat !important;
}
.cat_dog img {
    height: 300px;
    width: 100%;
    object-fit: scale-down;
    padding: 20px 0 0;
    object-position: bottom;
}
.hidden {
    display: none !important;
}
.img-height img {
    height: 100px;
    width: 100px;
    object-fit: contain;
}
span.image-choices-choice-text {
    border: 1px solid #0000006b;
    /*height: 160px;*/
    padding: 10px;
    display: flex;
    justify-content: center;
    align-items: end;
    font-size: 14px;
    cursor: pointer;
    width: 161px;
}
.sizing.form-check img {
            width: 120px;
        height: 120px;
        object-fit: contain;

}
a.link-arrow-cc {
    color: gray;
}
.sec-padding-center {
    padding-top: 80px;
}

a.button-style {
    color: gray;
    background: #d6d6d6;
    border-radius: 3px;
    height: 30px;
    width: 40%;
    text-align: center;
    margin-top: 7px;
    color: #615c5c;
    font-size: 13px;
    padding-top: 4px;
    text-decoration: none;
    font-weight: 600;
}
a.button-style:hover {
    color: var(--bs-btn-hover-color);
    background-color: #bfbfbf;
    border-color: #bfbfbf;
    color: #5c5c5c;
}

.form-check-input:checked + .form-check-label {
    border: 1px solid #ff8800;
    /*padding: 2px;*/
    /*animation:pulse .8s infinite;*/
}
div#treat_products_step .col-12.half.pads.custom_radios div#treat_products .form-check.sizing {
    HEIGHT: 280PX !IMPORTANT;
}
.bordering label .form-check-label {
    padding: 5px !important;
}


