@charset "UTF-8";
* {
  margin: 0;
  padding: 0;
  outline: none !important;
  -webkit-tap-highlight-color: transparent;
}

*,
::before,
::after {
  box-sizing: border-box;
}

::-moz-selection {
  background: #D4B55C !important;
  color: #ffffff !important;
}

::selection {
  background: #D4B55C !important;
  color: #ffffff !important;
}

html {
  scroll-behavior: smooth;
  height: 100%;
}

body {
  width: 100%;
  margin: 0px !important;
  padding: 0px !important;
  min-height: 100vh;
  overflow-x: hidden;
  overflow-y: auto;
  position: relative !important;
  font-family: "Lato";
  font-size: 14px;
  color: #000000;
  z-index: 9;
  transition: all 1s;
}

::-webkit-scrollbar {
  width: 10px;
}

::-webkit-scrollbar-track {
  background-color: transparent !important;
  border-radius: 10px;
}

::-webkit-scrollbar-thumb {
  border-radius: 10px;
  background: #B4B4B4;
}

a {
  cursor: pointer;
}

@font-face {
  font-display: swap;
  font-family: "Lato";
  font-style: normal;
  font-weight: 400;
  src: url("/font/lato-v25-latin-regular.eot");
  src: url("/font/lato-v25-latin-regular.eot?#iefix") format("embedded-opentype"), url("/font/lato-v25-latin-regular.woff") format("woff"), url("/font/lato-v25-latin-regular.ttf") format("truetype");
}
@font-face {
  font-display: swap;
  font-family: "Lato";
  font-style: normal;
  font-weight: 700;
  src: url("/font/lato-v25-latin-700.eot");
  src: url("/font/lato-v25-latin-700.eot?#iefix") format("embedded-opentype"), url("/font/lato-v25-latin-700.woff") format("woff"), url("/font/lato-v25-latin-700.ttf") format("truetype");
}
@font-face {
  font-display: swap;
  font-family: "Lato";
  font-style: normal;
  font-weight: 900;
  src: url("/font/lato-v25-latin-900.eot");
  src: url("/font/lato-v25-latin-900.eot?#iefix") format("embedded-opentype"), url("/font/lato-v25-latin-900.woff") format("woff"), url("/font/lato-v25-latin-900.ttf") format("truetype");
}
a {
  color: #ffffff;
  text-decoration: none;
  background-color: transparent;
}

a:hover {
  color: #D4B55C;
  text-decoration: none;
}

a:not([href]):not([class]) {
  color: inherit;
  text-decoration: none;
}

a:not([href]):not([class]):hover {
  color: inherit;
  text-decoration: none;
}

select {
  font-family: "Lato" !important;
}

option {
  font-family: "Lato" !important;
}

option:checked {
  box-shadow: 0 0 10px 100px #8A8A8A inset;
}

option:hover {
  background-color: #8A8A8A !important;
  color: #B4B4B4 !important;
}

textarea {
  font-family: "Lato" !important;
  resize: none;
}

input {
  font-family: "Lato" !important;
}

/*---- Responsive Column CSS Here -----*/
.container,
.container-fluid {
  width: 100%;
  margin: 0 auto;
}

@media only screen and (min-width: 300px) and (max-width:692px) {
  .container {
    width: 95%;
    margin: 0 auto;
  }
}
@media only screen and (min-width: 692px) and (max-width:990px) {
  .container {
    max-width: 576px;
  }
}
@media only screen and (min-width: 991px) and (max-width:1200px) {
  .container {
    max-width: 768px;
  }
}
@media only screen and (min-width: 1201px) and (max-width:1366px) {
  .container {
    max-width: 1200px;
  }
}
@media only screen and (min-width: 1367px) and (max-width:1920px) {
  .container {
    max-width: 1300px;
  }
}
@media only screen and (min-width: 1921px) and (max-width:3840px) {
  .container {
    max-width: 1400px;
  }
}

.black_font {
  color: #B4B4B4 !important;
}

.white_font {
  color: #ffffff !important;
}

@media only screen and (min-width: 300px) and (max-width:692px) {
  .text-center-xs {
    text-align: center !important;
  }
}

@media only screen and (min-width: 692px) and (max-width:990px) {
  .text-center-sm {
    text-align: center !important;
  }
}

@media only screen and (min-width: 991px) and (max-width:1200px) {
  .text-center-md {
    text-align: center !important;
  }
}

@media only screen and (min-width: 1201px) and (max-width:1366px) {
  .text-center-lg {
    text-align: center !important;
  }
}

@media only screen and (min-width: 1367px) and (max-width:1920px) {
  .text-center-xl {
    text-align: center !important;
  }
}

@media only screen and (min-width: 1921px) and (max-width:3840px) {
  .text-center-xxl {
    text-align: center !important;
  }
}

@media only screen and (min-width: 300px) and (max-width:692px) {
  .text-left-xs {
    text-align: left !important;
  }
}

@media only screen and (min-width: 692px) and (max-width:990px) {
  .text-left-sm {
    text-align: left !important;
  }
}

@media only screen and (min-width: 991px) and (max-width:1200px) {
  .text-left-md {
    text-align: left !important;
  }
}

@media only screen and (min-width: 1201px) and (max-width:1366px) {
  .text-left-lg {
    text-align: left !important;
  }
}

@media only screen and (min-width: 1367px) and (max-width:1920px) {
  .text-left-xl {
    text-align: left !important;
  }
}

@media only screen and (min-width: 1921px) and (max-width:3840px) {
  .text-left-xxl {
    text-align: left !important;
  }
}

@media only screen and (min-width: 300px) and (max-width:692px) {
  .text-right-xs {
    text-align: right !important;
  }
}

@media only screen and (min-width: 692px) and (max-width:990px) {
  .text-right-sm {
    text-align: right !important;
  }
}

@media only screen and (min-width: 991px) and (max-width:1200px) {
  .text-right-md {
    text-align: right !important;
  }
}

@media only screen and (min-width: 1201px) and (max-width:1366px) {
  .text-right-lg {
    text-align: right !important;
  }
}

@media only screen and (min-width: 1367px) and (max-width:1920px) {
  .text-right-xl {
    text-align: right !important;
  }
}

@media only screen and (min-width: 1921px) and (max-width:3840px) {
  .text-right-xxl {
    text-align: right !important;
  }
}

.text-justify {
  text-align: justify;
}

@media only screen and (min-width: 300px) and (max-width:692px) {
  .text-justify-xs {
    text-align: justify !important;
  }
}

@media only screen and (min-width: 692px) and (max-width:990px) {
  .text-justify-sm {
    text-align: justify !important;
  }
}

@media only screen and (min-width: 991px) and (max-width:1200px) {
  .text-justify-md {
    text-align: justify !important;
  }
}

@media only screen and (min-width: 1201px) and (max-width:1366px) {
  .text-justify-lg {
    text-align: justify !important;
  }
}

@media only screen and (min-width: 1367px) and (max-width:1920px) {
  .text-justify-xl {
    text-align: justify !important;
  }
}

@media only screen and (min-width: 1921px) and (max-width:3840px) {
  .text-justify-xxl {
    text-align: justify !important;
  }
}

.hidden {
  display: none;
}

@media only screen and (min-width: 300px) and (max-width:692px) {
  .hidden-xs {
    display: none !important;
  }
}

@media only screen and (min-width: 692px) and (max-width:990px) {
  .hidden-sm {
    display: none !important;
  }
}

@media only screen and (min-width: 991px) and (max-width:1200px) {
  .hidden-md {
    display: none !important;
  }
}

@media only screen and (min-width: 1201px) and (max-width:1366px) {
  .hidden-lg {
    display: none !important;
  }
}

@media only screen and (min-width: 1367px) and (max-width:1920px) {
  .hidden-xl {
    display: none !important;
  }
}

@media only screen and (min-width: 1921px) and (max-width:3840px) {
  .hidden-xxl {
    display: none !important;
  }
}

.row {
  display: flex;
  flex-wrap: wrap;
}

.col {
  flex-basis: 0;
  flex-grow: 1;
  max-width: 100%;
}

.align_center {
  align-items: center;
}

/*====== Gap css starts ======*/
.gap-1 {
  -ms-gap: 1em;
  gap: 1em;
}

.gap-2 {
  -ms-gap: 2em;
  gap: 2em;
}

.gap-3 {
  -ms-gap: 3em;
  gap: 3em;
}

.gap-4 {
  -ms-gap: 4em;
  gap: 4em;
}

.gap-5 {
  -ms-gap: 5em;
  gap: 5em;
}

.gap-6 {
  -ms-gap: 6em;
  gap: 6em;
}

.gap-7 {
  -ms-gap: 7em;
  gap: 7em;
}

.gap-8 {
  -ms-gap: 8em;
  gap: 8em;
}

.gap-9 {
  -ms-gap: 9em;
  gap: 9em;
}

.gap-10 {
  -ms-gap: 10em;
  gap: 10em;
}

.gap-11 {
  -ms-gap: 11em;
  gap: 11em;
}

.gap-12 {
  -ms-gap: 12em;
  gap: 12em;
}

/*====== Gap css ends ======*/
/*====== Row Gap css starts ======*/
.row-gap-1 {
  -ms-row-gap: 1em;
  row-gap: 1em;
}

.row-gap-2 {
  -ms-row-gap: 2em;
  row-gap: 2em;
}

.row-gap-3 {
  -ms-row-gap: 3em;
  row-gap: 3em;
}

.row-gap-4 {
  -ms-row-gap: 4em;
  row-gap: 4em;
}

.row-gap-5 {
  -ms-row-gap: 5em;
  row-gap: 5em;
}

.row-gap-6 {
  -ms-row-gap: 6em;
  row-gap: 6em;
}

.row-gap-7 {
  -ms-row-gap: 7em;
  row-gap: 7em;
}

.row-gap-8 {
  -ms-row-gap: 8em;
  row-gap: 8em;
}

.row-gap-9 {
  -ms-row-gap: 9em;
  row-gap: 9em;
}

.row-gap-10 {
  -ms-row-gap: 10em;
  row-gap: 10em;
}

.row-gap-11 {
  -ms-row-gap: 11em;
  row-gap: 11em;
}

.row-gap-12 {
  -ms-row-gap: 12em;
  row-gap: 12em;
}

/*====== Column Gap css ends ======*/
/*====== Column Gap css ends ======*/
/*====== Column Common css starts ======*/
.order-1 {
  order: 1;
}

.order-2 {
  order: 2;
}

.order-3 {
  order: 3;
}

.order-4 {
  order: 4;
}

.order-5 {
  order: 5;
}

.order-6 {
  order: 6;
}

.order-7 {
  order: 7;
}

.order-8 {
  order: 8;
}

.order-9 {
  order: 9;
}

.order-10 {
  order: 10;
}

.order-11 {
  order: 11;
}

.order-12 {
  order: 12;
}

/*====== Column Common css ends ======*/
/*====== Column XS css starts ======*/
@media only screen and (min-width: 300px) and (max-width:692px) {
  .col-xs-1 {
    flex: 0 0 8.3333333333% !important;
    max-width: 8.3333333333% !important;
  }
}
@media only screen and (min-width: 300px) and (max-width:692px) {
  .col-xs-2 {
    flex: 0 0 16.6666666667% !important;
    max-width: 16.6666666667% !important;
  }
}
@media only screen and (min-width: 300px) and (max-width:692px) {
  .col-xs-3 {
    flex: 0 0 25% !important;
    max-width: 25% !important;
  }
}
@media only screen and (min-width: 300px) and (max-width:692px) {
  .col-xs-4 {
    flex: 0 0 33.3333333333% !important;
    max-width: 33.3333333333% !important;
  }
}
@media only screen and (min-width: 300px) and (max-width:692px) {
  .col-xs-5 {
    flex: 0 0 41.6666666667% !important;
    max-width: 41.6666666667% !important;
  }
}
@media only screen and (min-width: 300px) and (max-width:692px) {
  .col-xs-6 {
    flex: 0 0 50% !important;
    max-width: 50% !important;
  }
}
@media only screen and (min-width: 300px) and (max-width:692px) {
  .col-xs-7 {
    flex: 0 0 58.3333333333% !important;
    max-width: 58.3333333333% !important;
  }
}
@media only screen and (min-width: 300px) and (max-width:692px) {
  .col-xs-8 {
    flex: 0 0 66.6666666667% !important;
    max-width: 66.6666666667% !important;
  }
}
@media only screen and (min-width: 300px) and (max-width:692px) {
  .col-xs-9 {
    flex: 0 0 75% !important;
    max-width: 75% !important;
  }
}
@media only screen and (min-width: 300px) and (max-width:692px) {
  .col-xs-10 {
    flex: 0 0 83.3333333333% !important;
    max-width: 83.3333333333% !important;
  }
}
@media only screen and (min-width: 300px) and (max-width:692px) {
  .col-xs-11 {
    flex: 0 0 91.6666666667% !important;
    max-width: 91.6666666667% !important;
  }
}
@media only screen and (min-width: 300px) and (max-width:692px) {
  .col-xs-12 {
    flex: 0 0 100% !important;
    max-width: 100% !important;
  }
}
/*====== Column XS css ends ======*/
/*====== Column SM css starts ======*/
@media only screen and (min-width: 692px) and (max-width:990px) {
  .col-sm-1 {
    flex: 0 0 8.3333333333% !important;
    max-width: 8.3333333333% !important;
  }
}
@media only screen and (min-width: 692px) and (max-width:990px) {
  .col-sm-2 {
    flex: 0 0 16.6666666667% !important;
    max-width: 16.6666666667% !important;
  }
}
@media only screen and (min-width: 692px) and (max-width:990px) {
  .col-sm-3 {
    flex: 0 0 25% !important;
    max-width: 25% !important;
  }
}
@media only screen and (min-width: 692px) and (max-width:990px) {
  .col-sm-4 {
    flex: 0 0 33.3333333333% !important;
    max-width: 33.3333333333% !important;
  }
}
@media only screen and (min-width: 692px) and (max-width:990px) {
  .col-sm-5 {
    flex: 0 0 41.6666666667% !important;
    max-width: 41.6666666667% !important;
  }
}
@media only screen and (min-width: 692px) and (max-width:990px) {
  .col-sm-6 {
    flex: 0 0 50% !important;
    max-width: 50% !important;
  }
}
@media only screen and (min-width: 692px) and (max-width:990px) {
  .col-sm-7 {
    flex: 0 0 58.3333333333% !important;
    max-width: 58.3333333333% !important;
  }
}
@media only screen and (min-width: 692px) and (max-width:990px) {
  .col-sm-8 {
    flex: 0 0 66.6666666667% !important;
    max-width: 66.6666666667% !important;
  }
}
@media only screen and (min-width: 692px) and (max-width:990px) {
  .col-sm-9 {
    flex: 0 0 75% !important;
    max-width: 75% !important;
  }
}
@media only screen and (min-width: 692px) and (max-width:990px) {
  .col-sm-10 {
    flex: 0 0 83.3333333333% !important;
    max-width: 83.3333333333% !important;
  }
}
@media only screen and (min-width: 692px) and (max-width:990px) {
  .col-sm-11 {
    flex: 0 0 91.6666666667% !important;
    max-width: 91.6666666667% !important;
  }
}
@media only screen and (min-width: 692px) and (max-width:990px) {
  .col-sm-12 {
    flex: 0 0 100% !important;
    max-width: 100% !important;
  }
}
/*====== Column SM css ends ======*/
/*====== Column MD css starts ======*/
@media only screen and (min-width: 991px) and (max-width:1200px) {
  .col-md-1 {
    flex: 0 0 8.3333333333%;
    max-width: 8.3333333333%;
  }
}
@media only screen and (min-width: 991px) and (max-width:1200px) {
  .col-md-2 {
    flex: 0 0 16.6666666667%;
    max-width: 16.6666666667%;
  }
}
@media only screen and (min-width: 991px) and (max-width:1200px) {
  .col-md-3 {
    flex: 0 0 25%;
    max-width: 25%;
  }
}
@media only screen and (min-width: 991px) and (max-width:1200px) {
  .col-md-4 {
    flex: 0 0 33.3333333333%;
    max-width: 33.3333333333%;
  }
}
@media only screen and (min-width: 991px) and (max-width:1200px) {
  .col-md-5 {
    flex: 0 0 41.6666666667%;
    max-width: 41.6666666667%;
  }
}
@media only screen and (min-width: 991px) and (max-width:1200px) {
  .col-md-6 {
    flex: 0 0 50%;
    max-width: 50%;
  }
}
@media only screen and (min-width: 991px) and (max-width:1200px) {
  .col-md-7 {
    flex: 0 0 58.3333333333%;
    max-width: 58.3333333333%;
  }
}
@media only screen and (min-width: 991px) and (max-width:1200px) {
  .col-md-8 {
    flex: 0 0 66.6666666667%;
    max-width: 66.6666666667%;
  }
}
@media only screen and (min-width: 991px) and (max-width:1200px) {
  .col-md-9 {
    flex: 0 0 75%;
    max-width: 75%;
  }
}
@media only screen and (min-width: 991px) and (max-width:1200px) {
  .col-md-10 {
    flex: 0 0 83.3333333333%;
    max-width: 83.3333333333%;
  }
}
@media only screen and (min-width: 991px) and (max-width:1200px) {
  .col-md-11 {
    flex: 0 0 91.6666666667%;
    max-width: 91.6666666667%;
  }
}
@media only screen and (min-width: 991px) and (max-width:1200px) {
  .col-md-12 {
    flex: 0 0 100%;
    max-width: 100%;
  }
}
/*====== Column MD css ends ======*/
/*====== Column LG css starts ======*/
@media only screen and (min-width: 1201px) and (max-width:1366px) {
  .col-lg-1 {
    flex: 0 0 8.3333333333%;
    max-width: 8.3333333333%;
  }
}
@media only screen and (min-width: 1201px) and (max-width:1366px) {
  .col-lg-2 {
    flex: 0 0 16.6666666667%;
    max-width: 16.6666666667%;
  }
}
@media only screen and (min-width: 1201px) and (max-width:1366px) {
  .col-lg-3 {
    flex: 0 0 25%;
    max-width: 25%;
  }
}
@media only screen and (min-width: 1201px) and (max-width:1366px) {
  .col-lg-4 {
    flex: 0 0 33.3333333333%;
    max-width: 33.3333333333%;
  }
}
@media only screen and (min-width: 1201px) and (max-width:1366px) {
  .col-lg-5 {
    flex: 0 0 41.6666666667%;
    max-width: 41.6666666667%;
  }
}
@media only screen and (min-width: 1201px) and (max-width:1366px) {
  .col-lg-6 {
    flex: 0 0 50%;
    max-width: 50%;
  }
}
@media only screen and (min-width: 1201px) and (max-width:1366px) {
  .col-lg-7 {
    flex: 0 0 58.3333333333%;
    max-width: 58.3333333333%;
  }
}
@media only screen and (min-width: 1201px) and (max-width:1366px) {
  .col-lg-8 {
    flex: 0 0 66.6666666667%;
    max-width: 66.6666666667%;
  }
}
@media only screen and (min-width: 1201px) and (max-width:1366px) {
  .col-lg-9 {
    flex: 0 0 75%;
    max-width: 75%;
  }
}
@media only screen and (min-width: 1201px) and (max-width:1366px) {
  .col-lg-10 {
    flex: 0 0 83.3333333333%;
    max-width: 83.3333333333%;
  }
}
@media only screen and (min-width: 1201px) and (max-width:1366px) {
  .col-lg-11 {
    flex: 0 0 91.6666666667%;
    max-width: 91.6666666667%;
  }
}
@media only screen and (min-width: 1201px) and (max-width:1366px) {
  .col-lg-12 {
    flex: 0 0 100%;
    max-width: 100%;
  }
}
/*====== Column LG css ends ======*/
/*====== Column XL css starts ======*/
@media only screen and (min-width: 1367px) and (max-width:1920px) {
  .col-xl-1 {
    flex: 0 0 8.3333333333%;
    max-width: 8.3333333333%;
  }
}
@media only screen and (min-width: 1367px) and (max-width:1920px) {
  .col-xl-2 {
    flex: 0 0 16.6666666667%;
    max-width: 16.6666666667%;
  }
}
@media only screen and (min-width: 1367px) and (max-width:1920px) {
  .col-xl-3 {
    flex: 0 0 25%;
    max-width: 25%;
  }
}
@media only screen and (min-width: 1367px) and (max-width:1920px) {
  .col-xl-4 {
    flex: 0 0 33.3333333333%;
    max-width: 33.3333333333%;
  }
}
@media only screen and (min-width: 1367px) and (max-width:1920px) {
  .col-xl-5 {
    flex: 0 0 41.6666666667%;
    max-width: 41.6666666667%;
  }
}
@media only screen and (min-width: 1367px) and (max-width:1920px) {
  .col-xl-6 {
    flex: 0 0 50%;
    max-width: 50%;
  }
}
@media only screen and (min-width: 1367px) and (max-width:1920px) {
  .col-xl-7 {
    flex: 0 0 58.3333333333%;
    max-width: 58.3333333333%;
  }
}
@media only screen and (min-width: 1367px) and (max-width:1920px) {
  .col-xl-8 {
    flex: 0 0 66.6666666667%;
    max-width: 66.6666666667%;
  }
}
@media only screen and (min-width: 1367px) and (max-width:1920px) {
  .col-xl-9 {
    flex: 0 0 75%;
    max-width: 75%;
  }
}
@media only screen and (min-width: 1367px) and (max-width:1920px) {
  .col-xl-10 {
    flex: 0 0 83.3333333333%;
    max-width: 83.3333333333%;
  }
}
@media only screen and (min-width: 1367px) and (max-width:1920px) {
  .col-xl-11 {
    flex: 0 0 91.6666666667%;
    max-width: 91.6666666667%;
  }
}
@media only screen and (min-width: 1367px) and (max-width:1920px) {
  .col-xl-12 {
    flex: 0 0 100%;
    max-width: 100%;
  }
}
/*====== Column XL css ends ======*/
/*====== Column XXL css starts ======*/
@media only screen and (min-width: 1921px) and (max-width:3840px) {
  .col-xxl-1 {
    flex: 0 0 8.3333333333%;
    max-width: 8.3333333333%;
  }
}
@media only screen and (min-width: 1921px) and (max-width:3840px) {
  .col-xxl-2 {
    flex: 0 0 16.6666666667%;
    max-width: 16.6666666667%;
  }
}
@media only screen and (min-width: 1921px) and (max-width:3840px) {
  .col-xxl-3 {
    flex: 0 0 25%;
    max-width: 25%;
  }
}
@media only screen and (min-width: 1921px) and (max-width:3840px) {
  .col-xxl-4 {
    flex: 0 0 33.3333333333%;
    max-width: 33.3333333333%;
  }
}
@media only screen and (min-width: 1921px) and (max-width:3840px) {
  .col-xxl-5 {
    flex: 0 0 41.6666666667%;
    max-width: 41.6666666667%;
  }
}
@media only screen and (min-width: 1921px) and (max-width:3840px) {
  .col-xxl-6 {
    flex: 0 0 50%;
    max-width: 50%;
  }
}
@media only screen and (min-width: 1921px) and (max-width:3840px) {
  .col-xxl-7 {
    flex: 0 0 58.3333333333%;
    max-width: 58.3333333333%;
  }
}
@media only screen and (min-width: 1921px) and (max-width:3840px) {
  .col-xxl-8 {
    flex: 0 0 66.6666666667%;
    max-width: 66.6666666667%;
  }
}
@media only screen and (min-width: 1921px) and (max-width:3840px) {
  .col-xxl-9 {
    flex: 0 0 75%;
    max-width: 75%;
  }
}
@media only screen and (min-width: 1921px) and (max-width:3840px) {
  .col-xxl-10 {
    flex: 0 0 83.3333333333%;
    max-width: 83.3333333333%;
  }
}
@media only screen and (min-width: 1921px) and (max-width:3840px) {
  .col-xxl-11 {
    flex: 0 0 91.6666666667%;
    max-width: 91.6666666667%;
  }
}
@media only screen and (min-width: 1921px) and (max-width:3840px) {
  .col-xxl-12 {
    flex: 0 0 100%;
    max-width: 100%;
  }
}
/*====== Column XXL css ends ======*/
.p-0 {
  padding: 0px;
}

.p-5 {
  padding: 5px;
}

.p-10 {
  padding: 10px;
}

.p-15 {
  padding: 15px;
}

.p-20 {
  padding: 20px;
}

.p-25 {
  padding: 25px;
}

.p-30 {
  padding: 30px;
}

.p-35 {
  padding: 35px;
}

.p-40 {
  padding: 40px;
}

.p-45 {
  padding: 45px;
}

.p-50 {
  padding: 50px;
}

/*====== Padding css ends ======*/
/*====== Padding-top css starts ======*/
.p-t-0 {
  padding-top: 0px !important;
}

.p-t-5 {
  padding-top: 5px !important;
}

.p-t-10 {
  padding-top: 10px !important;
}

.p-t-15 {
  padding-top: 15px !important;
}

.p-t-20 {
  padding-top: 20px !important;
}

.p-t-25 {
  padding-top: 25px !important;
}

.p-t-30 {
  padding-top: 30px !important;
}

.p-t-35 {
  padding-top: 35px !important;
}

.p-t-40 {
  padding-top: 40px !important;
}

.p-t-45 {
  padding-top: 45px !important;
}

.p-t-50 {
  padding-top: 50px !important;
}

.p-t-55 {
  padding-top: 55px !important;
}

.p-t-60 {
  padding-top: 60px !important;
}

.p-t-65 {
  padding-top: 65px !important;
}

.p-t-70 {
  padding-top: 70px !important;
}

.p-t-75 {
  padding-top: 75px !important;
}

.p-t-80 {
  padding-top: 80px !important;
}

.p-t-85 {
  padding-top: 85px !important;
}

.p-t-90 {
  padding-top: 90px !important;
}

/*====== Padding-top css ends ======*/
/*====== Padding-bottom css starts ======*/
.p-b-0 {
  padding-bottom: 0px !important;
}

.p-b-5 {
  padding-bottom: 5px !important;
}

.p-b-10 {
  padding-bottom: 10px !important;
}

.p-b-15 {
  padding-bottom: 15px !important;
}

.p-b-20 {
  padding-bottom: 20px !important;
}

.p-b-25 {
  padding-bottom: 25px !important;
}

.p-b-30 {
  padding-bottom: 30px !important;
}

.p-b-35 {
  padding-bottom: 35px !important;
}

.p-b-40 {
  padding-bottom: 40px !important;
}

.p-b-45 {
  padding-bottom: 45px !important;
}

.p-b-50 {
  padding-bottom: 50px !important;
}

.p-b-55 {
  padding-bottom: 55px !important;
}

.p-b-60 {
  padding-bottom: 60px !important;
}

.p-b-65 {
  padding-bottom: 65px !important;
}

.p-b-70 {
  padding-bottom: 70px !important;
}

.p-b-75 {
  padding-bottom: 75px !important;
}

.p-b-80 {
  padding-bottom: 80px !important;
}

.p-b-85 {
  padding-bottom: 85px !important;
}

.p-b-90 {
  padding-bottom: 90px !important;
}

/*====== Padding-bottom css ends ======*/
/*====== Padding-left css starts ======*/
.p-l-0 {
  padding-left: 0px;
}

.p-l-5 {
  padding-left: 5px;
}

.p-l-10 {
  padding-left: 10px;
}

.p-l-15 {
  padding-left: 15px;
}

.p-l-20 {
  padding-left: 20px;
}

.p-l-25 {
  padding-left: 25px;
}

.p-l-30 {
  padding-left: 30px;
}

.p-l-35 {
  padding-left: 35px;
}

.p-l-40 {
  padding-left: 40px;
}

.p-l-45 {
  padding-left: 45px;
}

.p-l-50 {
  padding-left: 50px;
}

/*====== Padding-left css ends ======*/
/*====== Padding-right css starts ======*/
.p-r-0 {
  padding-right: 0px;
}

.p-r-5 {
  padding-right: 5px;
}

.p-r-10 {
  padding-right: 10px;
}

.p-r-15 {
  padding-right: 15px;
}

.p-r-20 {
  padding-right: 20px;
}

.p-r-25 {
  padding-right: 25px;
}

.p-r-30 {
  padding-right: 30px;
}

.p-r-35 {
  padding-right: 35px;
}

.p-r-40 {
  padding-right: 40px;
}

.p-r-45 {
  padding-right: 45px;
}

.p-r-50 {
  padding-right: 50px;
}

/*====== Padding-right css ends ======*/
/*====== Margin css starts ======*/
.m-0 {
  margin: 0px;
}

.m-5 {
  margin: 5px;
}

.m-10 {
  margin: 10px;
}

.m-15 {
  margin: 15px;
}

.m-20 {
  margin: 20px;
}

.m-25 {
  margin: 25px;
}

.m-30 {
  margin: 30px;
}

.m-35 {
  margin: 35px;
}

.m-40 {
  margin: 40px;
}

.m-45 {
  margin: 45px;
}

.m-50 {
  margin: 50px;
}

/*====== Margin css ends ======*/
/*====== Margin-top css starts ======*/
.m-t-0 {
  margin-top: 0px;
}

.m-t-5 {
  margin-top: 5px;
}

.m-t-10 {
  margin-top: 10px;
}

.m-t-15 {
  margin-top: 15px;
}

.m-t-20 {
  margin-top: 20px;
}

.m-t-25 {
  margin-top: 25px;
}

.m-t-30 {
  margin-top: 30px;
}

.m-t-35 {
  margin-top: 35px;
}

.m-t-40 {
  margin-top: 40px;
}

.m-t-45 {
  margin-top: 45px;
}

.m-t-50 {
  margin-top: 50px;
}

/*====== Margin-top css ends ======*/
/*====== Margin-Bottom css starts ======*/
.m-b-0 {
  margin-bottom: 0px;
}

.m-b-5 {
  margin-bottom: 5px;
}

.m-b-10 {
  margin-bottom: 10px;
}

.m-b-15 {
  margin-bottom: 15px;
}

.m-b-20 {
  margin-bottom: 20px;
}

.m-b-25 {
  margin-bottom: 25px;
}

.m-b-30 {
  margin-bottom: 30px;
}

.m-b-35 {
  margin-bottom: 35px;
}

.m-b-40 {
  margin-bottom: 40px;
}

.m-b-45 {
  margin-bottom: 45px;
}

.m-b-50 {
  margin-bottom: 50px;
}

/*====== Margin-Bottom css ends ======*/
/*====== Margin-left css starts ======*/
.m-l-0 {
  margin-left: 0px;
}

.m-l-5 {
  margin-left: 5px;
}

.m-l-10 {
  margin-left: 10px;
}

.m-l-15 {
  margin-left: 15px;
}

.m-l-20 {
  margin-left: 20px;
}

.m-l-25 {
  margin-left: 25px;
}

.m-l-30 {
  margin-left: 30px;
}

.m-l-35 {
  margin-left: 35px;
}

.m-l-40 {
  margin-left: 40px;
}

.m-l-45 {
  margin-left: 45px;
}

.m-l-50 {
  margin-left: 50px;
}

/*====== Margin-left css ends ======*/
/*====== Margin-right css starts ======*/
.m-r-0 {
  margin-right: 0px;
}

.m-r-5 {
  margin-right: 5px;
}

.m-r-10 {
  margin-right: 10px;
}

.m-r-15 {
  margin-right: 15px;
}

.m-r-20 {
  margin-right: 20px;
}

.m-r-25 {
  margin-right: 25px;
}

.m-r-30 {
  margin-right: 30px;
}

.m-r-35 {
  margin-right: 35px;
}

.m-r-40 {
  margin-right: 40px;
}

.m-r-45 {
  margin-right: 45px;
}

.m-r-50 {
  margin-right: 50px;
}

/*====== Margin-right css ends ======*/
/*====== Border-radius css starts ======*/
.b-radius-0 {
  border-radius: 0px !important;
}

.b-radius-5 {
  border-radius: 5px !important;
}

.b-radius-10 {
  border-radius: 10px !important;
}

/*====== Border-radius css ends ======*/
/*====== Font-size css starts ======*/
.f-12 {
  font-size: 12px;
}

.f-14 {
  font-size: 14px;
}

.f-16 {
  font-size: 16px;
}

.f-18 {
  font-size: 18px;
}

.f-20 {
  font-size: 20px;
}

.f-22 {
  font-size: 22px;
}

.f-24 {
  font-size: 24px;
}

.f-26 {
  font-size: 26px;
}

.f-28 {
  font-size: 28px;
}

.f-30 {
  font-size: 30px;
}

.f-32 {
  font-size: 32px;
}

.f-34 {
  font-size: 34px;
}

.f-36 {
  font-size: 36px;
}

.f-38 {
  font-size: 38px;
}

.f-40 {
  font-size: 40px;
}

.f-42 {
  font-size: 42px;
}

.f-44 {
  font-size: 44px;
}

.f-46 {
  font-size: 46px;
}

.f-48 {
  font-size: 48px;
}

.f-50 {
  font-size: 50px;
}

.f-52 {
  font-size: 52px;
}

.f-54 {
  font-size: 54px;
}

.f-56 {
  font-size: 56px;
}

.f-58 {
  font-size: 58px;
}

.f-60 {
  font-size: 60px;
}

.f-62 {
  font-size: 62px;
}

.f-64 {
  font-size: 64px;
}

.f-66 {
  font-size: 66px;
}

.f-68 {
  font-size: 68px;
}

.f-70 {
  font-size: 70px;
}

.f-72 {
  font-size: 72px;
}

.f-74 {
  font-size: 74px;
}

.f-76 {
  font-size: 76px;
}

.f-78 {
  font-size: 78px;
}

.f-80 {
  font-size: 80px;
}

/*====== Font-size css ends ======*/
/*====== Line-Height css Start ======*/
.line-h-0 {
  line-height: 0px;
}

.line-h-2 {
  line-height: 2px;
}

.line-h-4 {
  line-height: 4px;
}

.line-h-6 {
  line-height: 6px;
}

.line-h-8 {
  line-height: 8px;
}

.line-h-10 {
  line-height: 10px;
}

.line-h-12 {
  line-height: 12px;
}

.line-h-14 {
  line-height: 14px;
}

.line-h-16 {
  line-height: 16px;
}

.line-h-18 {
  line-height: 18px;
}

.line-h-20 {
  line-height: 20px;
}

.line-h-22 {
  line-height: 22px;
}

.line-h-24 {
  line-height: 24px;
}

.line-h-26 {
  line-height: 26px;
}

.line-h-28 {
  line-height: 28px;
}

.line-h-30 {
  line-height: 30px;
}

.line-h-32 {
  line-height: 32px;
}

.line-h-34 {
  line-height: 34px;
}

.line-h-36 {
  line-height: 36px;
}

.line-h-38 {
  line-height: 38px;
}

.line-h-40 {
  line-height: 40px;
}

.line-h-42 {
  line-height: 42px;
}

.line-h-44 {
  line-height: 44px;
}

.line-h-46 {
  line-height: 46px;
}

.line-h-48 {
  line-height: 48px;
}

.line-h-50 {
  line-height: 50px;
}

.line-h-52 {
  line-height: 52px;
}

.line-h-54 {
  line-height: 54px;
}

.line-h-56 {
  line-height: 56px;
}

.line-h-58 {
  line-height: 58px;
}

.line-h-60 {
  line-height: 60px;
}

.line-h-62 {
  line-height: 62px;
}

.line-h-64 {
  line-height: 64px;
}

.line-h-66 {
  line-height: 66px;
}

.line-h-68 {
  line-height: 68px;
}

.line-h-70 {
  line-height: 70px;
}

.line-h-72 {
  line-height: 72px;
}

.line-h-74 {
  line-height: 74px;
}

.line-h-76 {
  line-height: 76px;
}

.line-h-78 {
  line-height: 78px;
}

.line-h-80 {
  line-height: 80px;
}

/*====== Line-Height css ends ======*/
/*====== Justify Content css starts ======*/
.j-c-flex-end {
  justify-content: flex-end;
}

.j-c-flex-start {
  justify-content: flex-start;
}

.j-c-center {
  justify-content: center;
}

.j-c-space-between {
  justify-content: space-between;
}

.j-c-space-around {
  justify-content: space-around;
}

.j-c-space-evenly {
  justify-content: space-evenly;
}

/*====== Justify Content css ends ======*/
/*====== Font-weight css starts ======*/
.f-w-100 {
  font-weight: 100;
}

.f-w-300 {
  font-weight: 300;
}

.f-w-400 {
  font-weight: 400;
}

.f-w-500 {
  font-weight: 500;
}

.f-w-600 {
  font-weight: 600;
}

.f-w-700 {
  font-weight: 700;
}

.f-w-900 {
  font-weight: 900;
}

.f-w-bold {
  font-weight: bold;
}

/*====== Font-weight css ends ======*/
/*====== Font-style css starts ======*/
.f-s-normal {
  font-style: normal;
}

.f-s-italic {
  font-style: italic;
}

.f-s-oblique {
  font-style: oblique;
}

.f-s-initial {
  font-style: initial;
}

.f-s-inherit {
  font-style: inherit;
}

/*====== Font-style css ends ======*/
/*====== Text-align css starts ======*/
.text-center {
  text-align: center;
}

.text-left {
  text-align: left;
}

.text-right {
  text-align: right;
}

/*====== Text-align css ends ======*/
/*====== Text-Transform css starts ======*/
.text-capitalize {
  text-transform: capitalize;
}

.text-uppercase {
  text-transform: uppercase;
}

.text-lowercase {
  text-transform: lowercase;
}

/*====== Text-Transform css ends ======*/
/*====== Text-Decoration css starts ======*/
.text-overline {
  text-decoration: overline;
}

.text-line-through {
  text-decoration: line-through;
}

.text-underline {
  text-decoration: underline;
}

/*====== Text-Decoration css ends ======*/
/*====== Vertical-Align css starts ======*/
.baseline {
  vertical-align: baseline;
}

.sub {
  vertical-align: sub;
}

.super {
  vertical-align: super;
}

.top {
  vertical-align: top;
}

.text-top {
  vertical-align: text-top;
}

.middle {
  vertical-align: middle;
}

.bottom {
  vertical-align: bottom;
}

.text-bottom {
  vertical-align: text-bottom;
}

.initial {
  vertical-align: initial;
}

.inherit {
  vertical-align: inherit;
}

/*====== Vertical-Align css ends ======*/
/*====== Float css starts ======*/
.f-left {
  float: left;
}

.f-right {
  float: right;
}

.f-none {
  float: none;
}

/*====== Float css ends ======*/
/*====== Overflow css starts ======*/
.o-hidden {
  overflow: hidden;
}

.o-visible {
  overflow: visible;
}

.o-auto {
  overflow: auto;
}

/*====== display css starts ======*/
.d-inline-block {
  display: inline-block;
}

.d-block {
  display: block;
}

.d-none {
  display: none;
}

.d-flex {
  display: flex;
}

.d-grid {
  display: grid;
}

.justify-flex-end {
  justify-content: flex-end;
}

.justify-flex-start {
  justify-content: flex-start;
}

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

.justify-space-around {
  justify-content: space-around;
}

.justify-space-between {
  justify-content: space-between;
}

.justify-space-evenly {
  justify-content: space-evenly;
}

.justify-stretch {
  justify-content: stretch;
}

/*====== position css starts ======*/
.p-relative {
  position: relative;
}

.p-absolute {
  position: absolute;
}

.p-fixed {
  position: fixed;
}

.p-static {
  position: static;
}

.p-sticky {
  position: sticky;
}

.red_font {
  color: red;
}

.virticle_align_m {
  align-items: center;
}

/* START TOOLTIP STYLES */
[tooltip] {
  position: relative;
  /* opinion 1 */
}

/* Applies to all tooltips */
[tooltip]::before,
[tooltip]::after {
  text-transform: none;
  /* opinion 2 */
  font-size: 0.9em;
  /* opinion 3 */
  line-height: 1;
  -webkit-user-select: none;
     -moz-user-select: none;
          user-select: none;
  pointer-events: none;
  position: absolute;
  display: none;
  opacity: 0;
}
@media only screen and (min-width: 300px) and (max-width:692px), only screen and (min-width: 692px) and (max-width:990px) {
  [tooltip]::before,
  [tooltip]::after {
    visibility: hidden;
  }
}

[tooltip]::before {
  content: "";
  border: 5px solid transparent;
  /* opinion 4 */
  z-index: 1001;
  /* absurdity 1 */
}

[tooltip]::after {
  content: attr(tooltip);
  /* magic! */
  /* most of the rest of this is opinion */
  /*font-family: Helvetica, sans-serif;*/
  text-align: center;
  /*
      Let the content set the size of the tooltips
      but this will also keep them from being obnoxious
      */
  min-width: 3em;
  max-width: 21em;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  padding: 1ch 1.5ch;
  border-radius: 0.3ch;
  box-shadow: 0 1em 2em -0.5em rgba(0, 0, 0, 0.35);
  background: rgba(255, 255, 255, 0.7);
  background: #ffffff;
  border: 1px solid #D4B55C;
  -webkit-backdrop-filter: blur(10px);
          backdrop-filter: blur(10px);
  color: #D4B55C;
  z-index: 1000;
  /* absurdity 2 */
}

/* Make the tooltips respond to hover */
[tooltip]:hover::before,
[tooltip]:hover::after {
  display: block;
}

/* don't show empty tooltips */
[tooltip=""]::before,
[tooltip=""]::after {
  display: none !important;
}

/* FLOW: UP */
[tooltip]:not([flow])::before,
[tooltip][flow^=up]::before {
  bottom: 100%;
  border-bottom-width: 0;
  border-top-color: #D4B55C;
}

[tooltip]:not([flow])::after,
[tooltip][flow^=up]::after {
  bottom: calc(100% + 5px);
}

[tooltip]:not([flow])::before,
[tooltip]:not([flow])::after,
[tooltip][flow^=up]::before,
[tooltip][flow^=up]::after {
  left: 50%;
  transform: translate(-50%, -0.5em);
}

/* FLOW: DOWN */
[tooltip][flow^=down]::before {
  top: 100%;
  border-top-width: 0;
  border-bottom-color: #D4B55C;
}

[tooltip][flow^=down]::after {
  top: calc(100% + 5px);
}

[tooltip][flow^=down]::before,
[tooltip][flow^=down]::after {
  left: 50%;
  transform: translate(-50%, 0.5em);
}

/* FLOW: LEFT */
[tooltip][flow^=left]::before {
  top: 50%;
  border-right-width: 0;
  border-left-color: #D4B55C;
  left: calc(0em - 5px);
  transform: translate(-0.5em, -50%);
}

[tooltip][flow^=left]::after {
  top: 50%;
  right: calc(100% + 5px);
  transform: translate(-0.5em, -50%);
}

/* FLOW: RIGHT */
[tooltip][flow^=right]::before {
  top: 50%;
  border-left-width: 0;
  border-right-color: #D4B55C;
  right: calc(0em - 5px);
  transform: translate(0.5em, -50%);
}

[tooltip][flow^=right]::after {
  top: 50%;
  left: calc(100% + 5px);
  transform: translate(0.5em, -50%);
}

/* KEYFRAMES */
@keyframes tooltips-vert {
  to {
    opacity: 1;
    transform: translate(-50%, 0);
  }
}
@keyframes tooltips-horz {
  to {
    opacity: 1;
    transform: translate(0, -50%);
  }
}
/* FX All The Things */
[tooltip]:not([flow]):hover::before,
[tooltip]:not([flow]):hover::after,
[tooltip][flow^=up]:hover::before,
[tooltip][flow^=up]:hover::after,
[tooltip][flow^=down]:hover::before,
[tooltip][flow^=down]:hover::after {
  animation: tooltips-vert 300ms ease-out forwards;
}

[tooltip][flow^=left]:hover::before,
[tooltip][flow^=left]:hover::after,
[tooltip][flow^=right]:hover::before,
[tooltip][flow^=right]:hover::after {
  animation: tooltips-horz 300ms ease-out forwards;
}

.img-responsive {
  width: 100%;
  max-width: 100%;
  margin: 0 auto;
  display: block;
}

.go-top-button {
  position: fixed !important;
  cursor: pointer !important;
  outline: none !important;
  bottom: 8% !important;
  right: 0px !important;
  width: 40px !important;
  height: 40px !important;
  line-height: 35px !important;
  text-decoration: none !important;
  color: #fff !important;
  background-color: #D4B55C !important;
  border: none !important;
  border-radius: 3px 0 0 3px !important;
  z-index: 99999;
  top: auto !important;
  /*background-image: url('../../assets/images/arrow_left.18bb86bc1aa09f7c9cf5.svg') !important;*/
  transform: rotate(90deg);
  background-repeat: no-repeat !important;
  background-size: 15px !important;
  text-align: center;
  background-position: 50% !important;
  opacity: initial;
}
@media only screen and (min-width: 300px) and (max-width:692px) {
  .go-top-button {
    right: 0 !important;
    bottom: 14% !important;
  }
}

.contentplace_section {
  padding-top: 160px;
}
@media only screen and (min-width: 1201px) and (max-width:1366px) {
  .contentplace_section {
    padding-top: 130px;
  }
}
@media only screen and (min-width: 991px) and (max-width:1200px) {
  .contentplace_section {
    padding-top: 60px;
  }
}
@media only screen and (min-width: 692px) and (max-width:990px), only screen and (min-width: 300px) and (max-width:692px) {
  .contentplace_section {
    padding-top: 45px;
    padding-bottom: 58px;
  }
}

.align_middle {
  align-items: center;
}

.heading {
  display: flex;
  justify-content: center;
  align-items: center;
}
.heading h1 {
  margin: 0 20px;
  position: relative;
  font-size: 28px;
  padding: 15px 0;
  color: #000000;
  text-align: center;
  text-transform: capitalize;
  font-family: "Lato";
  font-weight: 500;
}
@media only screen and (min-width: 1201px) and (max-width:1366px) {
  .heading h1 {
    font-size: 24px;
    padding: 10px 0;
  }
}
@media only screen and (min-width: 991px) and (max-width:1200px) {
  .heading h1 {
    line-height: 35px;
  }
}
@media only screen and (min-width: 991px) and (max-width:1200px) {
  .heading h1 {
    font-size: 20px;
    padding: 4px 0;
  }
}
@media only screen and (min-width: 692px) and (max-width:990px), only screen and (min-width: 300px) and (max-width:692px) {
  .heading h1 {
    margin: 0 10px;
    font-size: 16px;
    text-transform: uppercase;
    padding: 2px;
    line-height: 26px;
    color: #000000;
    font-weight: 800;
  }
}

.heading-bottom-text {
  text-align: center;
  margin: 6px 6px;
}
@media only screen and (min-width: 692px) and (max-width:990px) {
  .heading-bottom-text {
    margin: 2px 2px;
  }
}
.heading-bottom-text p {
  font-size: 20px;
  line-height: 28px;
  font-family: "Lato";
  color: #929292;
}
@media only screen and (min-width: 991px) and (max-width:1200px) {
  .heading-bottom-text p {
    font-size: 18px;
  }
}
@media only screen and (min-width: 692px) and (max-width:990px) {
  .heading-bottom-text p {
    font-size: 16px;
    line-height: 20px;
  }
}
@media only screen and (min-width: 300px) and (max-width:692px) {
  .heading-bottom-text p {
    font-size: 14px;
    line-height: 18px;
  }
}

.sub_heading h2 {
  font-size: 24px;
  letter-spacing: 1px;
  padding: 30px 0 10px;
  color: #D4B55C;
  font-weight: 400;
}
@media only screen and (min-width: 692px) and (max-width:990px) {
  .sub_heading h2 {
    font-size: 20px;
    padding: 20px 0 10px;
  }
}
@media only screen and (min-width: 300px) and (max-width:692px) {
  .sub_heading h2 {
    font-size: 18px;
    padding: 10px 0 10px;
  }
}

h2 {
  font-size: 26px;
  letter-spacing: 1px;
  padding: 15px 0;
  color: #D4B55C;
  font-weight: 500;
}
@media only screen and (min-width: 692px) and (max-width:990px), only screen and (min-width: 300px) and (max-width:692px) {
  h2 {
    font-size: 22px;
  }
}

h3 {
  font-size: 24px;
  letter-spacing: 1px;
  padding: 15px 0;
  color: #D4B55C;
  font-weight: 500;
}
@media only screen and (min-width: 300px) and (max-width:692px), only screen and (min-width: 692px) and (max-width:990px) {
  h3 {
    font-size: 18px;
  }
}

h4 {
  font-size: 22px;
  letter-spacing: 1px;
  padding: 15px 0;
  color: #D4B55C;
  font-weight: 500;
}
@media only screen and (min-width: 1201px) and (max-width:1366px), only screen and (min-width: 991px) and (max-width:1200px) {
  h4 {
    font-size: 18px;
  }
}
@media only screen and (min-width: 300px) and (max-width:692px), only screen and (min-width: 692px) and (max-width:990px) {
  h4 {
    font-size: 16px;
  }
}

p {
  font-size: 15px;
  line-height: 22px;
}

.txtbox {
  background: #F7F7F3;
  padding: 10px 12px;
  margin-bottom: 15px;
  width: auto;
  border: none;
  transition: all 1s;
}
@media only screen and (min-width: 300px) and (max-width:692px), only screen and (min-width: 692px) and (max-width:990px) {
  .txtbox {
    padding: 8px 10px;
    margin-bottom: 10px;
  }
}
.txtbox:focus {
  box-shadow: none;
  border-bottom: 1px solid #D4B55C;
}

.button {
  text-align: center;
  margin-top: 30px;
}
@media only screen and (min-width: 991px) and (max-width:1200px) {
  .button {
    margin-top: 20px;
  }
}
@media only screen and (min-width: 692px) and (max-width:990px), only screen and (min-width: 300px) and (max-width:692px) {
  .button {
    margin-top: 20px;
  }
}
.button .btn {
  font-size: 15px;
  font-weight: 500;
  font-family: "Lato";
  background: #D4B55C;
  border: 2px solid #D4B55C !important;
  color: #050606;
  padding: 12px 35px;
  text-align: center;
  transition: all 1s;
  cursor: pointer;
  display: inline-block;
  border-radius: 6px;
}
.button .btn:hover {
  background: #ffffff;
  color: #050606;
}
@media only screen and (min-width: 991px) and (max-width:1200px) {
  .button .btn {
    font-size: 13px;
    padding: 8px 15px;
  }
}
@media only screen and (min-width: 692px) and (max-width:990px), only screen and (min-width: 300px) and (max-width:692px) {
  .button .btn {
    font-size: 12px;
    padding: 6px 10px;
  }
}

.btn1 {
  font-size: 15px;
  font-weight: 500;
  font-family: "Lato";
  background: #ffffff;
  border: 2px solid #D4B55C !important;
  color: #050606;
  padding: 12px 35px;
  text-align: center;
  transition: all 1s;
  cursor: pointer;
  display: inline-block;
  border-radius: 6px;
}
.btn1:hover {
  background: #8A8A8A;
  color: #ffffff;
}

.two_column {
  display: grid;
  grid-template-columns: 1fr 1fr;
}

.vertical_align_m {
  align-items: center;
}

/*------ Back to Top CSS Here --------*/
.go-top {
  position: fixed;
  bottom: 50px;
  right: 37px;
  padding: 20px;
  display: none;
  cursor: pointer;
  -webkit-font-smoothing: antialiased;
  z-index: 9;
}

.go-top:after {
  font-family: FontAwesome;
  content: "\f106";
  padding: 5px 10px;
  color: #ffffff !important;
  position: absolute !important;
  bottom: 35px;
  font-size: 28px;
  background-color: #D4B55C;
  border: 1px solid #ffffff !important;
}

.go-top-text {
  position: absolute !important;
  width: 60px;
  text-align: center;
  font-family: "Questrial";
  line-height: 1.5;
  letter-spacing: 3px;
  font-size: 12px;
  margin: 20px 0 0 -4px;
}
@media only screen and (min-width: 300px) and (max-width:692px), only screen and (min-width: 692px) and (max-width:990px) {
  .go-top-text {
    display: none;
  }
}

.go-top:hover {
  transition: all 0.4s linear;
  transform: scale(1.1);
}

/*----------- Search Pop up css start here -----------*/
.search-popup .btn {
  border: none;
}
.search-popup .jewellery-detail {
  padding: 32px 32px 10px;
  background-color: #ffffff;
}
.search-popup input,
.search-popup textarea {
  background: #ffffff;
  border: 1px solid #D4B55C;
  width: 100%;
  margin-bottom: 25px;
  margin-top: 16px;
  font-size: 16px;
  padding: 8px 14px;
}
.search-popup input :focus,
.search-popup textarea :focus {
  border-bottom: 1px solid #D4B55C;
}
.search-popup ::-moz-placeholder {
  font-weight: normal;
  color: #000 !important;
}
.search-popup ::placeholder {
  font-weight: normal;
  color: #000 !important;
}
.search-popup .search-popup {
  position: fixed;
  left: 0;
  top: 0;
  height: 100%;
  z-index: 1000;
  width: 100%;
  background-color: rgba(0, 0, 0, 0.6);
  opacity: 0;
  visibility: hidden;
  transition: 500ms all;
}
.search-popup .search-popup.is-visible {
  opacity: 1;
  visibility: visible;
  transition: 1s all;
}
.search-popup .search-popup.is-visible .search-popup-container {
  transform: translateY(0);
  transition: 500ms all;
}
.search-popup .search-popup-container {
  transform: translateY(-50%);
  transition: 500ms all;
  position: relative;
  width: 25%;
  margin: 2em auto;
  top: 5%;
  padding: 0.5rem;
  background: #B4B4B4;
  border: 1px solid #ffffff;
  -webkit-backdrop-filter: blur(10px);
          backdrop-filter: blur(10px);
  border-radius: 0.25em 0.25em 0.4em 0.4em;
  text-align: center;
  box-shadow: 0 0 20px rgba(0, 0, 0, 0.2);
  overflow: auto;
}
@media only screen and (min-width: 300px) and (max-width:692px), only screen and (min-width: 692px) and (max-width:990px) {
  .search-popup .search-popup-container {
    width: 100%;
    padding: 0;
    margin: 8em auto;
  }
}
@media only screen and (min-width: 991px) and (max-width:1200px) {
  .search-popup .search-popup-container {
    width: 50%;
    padding: 0;
  }
}
@media only screen and (min-width: 1201px) and (max-width:1366px) {
  .search-popup .search-popup-container {
    width: 30%;
  }
}
.search-popup .search-popup-container .search-popup-close {
  position: absolute;
  top: 8px;
  font-size: 0;
  right: 8px;
  width: 30px;
  height: 30px;
}
.search-popup .search-popup-container .search-popup-close::before, .search-popup .search-popup-container .search-popup-close::after {
  content: "";
  position: absolute;
  top: 12px;
  width: 14px;
  height: 3px;
  background-color: #8A8A8A;
}
.search-popup .search-popup-container .search-popup-close:hover:before, .search-popup .search-popup-container .search-popup-close:hover:after {
  background-color: #D4B55C;
  transition: 300ms all;
}
.search-popup .search-popup-container .search-popup-close::before {
  transform: rotate(45deg);
  left: 8px;
}
.search-popup .search-popup-container .search-popup-close::after {
  transform: rotate(-45deg);
  right: 8px;
}

/*------ Bread Crums --------*/
.breadcrums {
  padding: 20px 0;
}

.animated_checkbox {
  align-items: center;
  display: flex;
  padding: 5px 15px !important;
}
@media only screen and (min-width: 300px) and (max-width:692px) {
  .animated_checkbox {
    padding: 0;
  }
}
.animated_checkbox input[type=checkbox] {
  height: 0;
  width: 0;
  cursor: pointer;
}
.animated_checkbox input[type=checkbox] + label {
  position: relative;
  display: flex;
  /*margin: .6em 0;*/
  align-items: center;
  color: #B4B4B4;
  transition: color 250ms cubic-bezier(0.4, 0, 0.23, 1);
  cursor: pointer;
}
.animated_checkbox input[type=checkbox] + label > ins {
  position: absolute;
  display: block;
  bottom: 0;
  left: 2em;
  height: 0;
  width: 100%;
  overflow: hidden;
  text-decoration: none;
  transition: height 300ms cubic-bezier(0.4, 0, 0.23, 1);
}
.animated_checkbox input[type=checkbox] + label > ins > i {
  position: absolute;
  bottom: 0;
  font-style: normal;
  color: #D4B55C;
}
.animated_checkbox input[type=checkbox] + label > span {
  display: flex;
  justify-content: center;
  align-items: center;
  margin-right: 1em;
  width: 1.5em;
  height: 1.5em;
  background: transparent;
  border: 2px solid #D4B55C;
  border-radius: 2px;
  cursor: pointer;
  transition: all 250ms cubic-bezier(0.4, 0, 0.23, 1);
}
.animated_checkbox input[type=checkbox]:checked + label > ins {
  height: 100%;
}
.animated_checkbox input[type=checkbox]:checked + label > span {
  border: 2px solid #D4B55C;
  animation: shrink-bounce 200ms cubic-bezier(0.4, 0, 0.23, 1);
}
.animated_checkbox input[type=checkbox]:checked + label > span:before {
  content: "";
  position: absolute;
  top: 11px;
  left: 4px;
  border-right: 2px solid transparent;
  border-bottom: 2px solid transparent;
  transform: rotate(45deg);
  transform-origin: 0% 100%;
  animation: checkbox-check 125ms 250ms cubic-bezier(0.4, 0, 0.23, 1) forwards;
  font-size: 24px;
}
.animated_checkbox input[type=checkbox] + label:hover > span,
.animated_checkbox input[type=checkbox]:focus + label > span {
  background: rgba(255, 255, 255, 0.1);
}
@keyframes shrink-bounce {
  0% {
    transform: scale(1);
  }
  33% {
    transform: scale(0.85);
  }
  100% {
    transform: scale(1);
  }
}
@keyframes checkbox-check {
  0% {
    width: 0;
    height: 0;
    border-color: #212121;
    transform: translate3d(0, 0, 0) rotate(45deg);
  }
  33% {
    width: 0.2em;
    height: 0;
    transform: translate3d(0, 0, 0) rotate(45deg);
  }
  100% {
    width: 0.2em;
    height: 0.5em;
    border-color: #212121;
    transform: translate3d(0, -0.5em, 0) rotate(45deg);
  }
}

.animated_radio {
  align-items: center;
  display: flex;
  padding: 5px 0px 5px 5px !important;
}
@media only screen and (min-width: 300px) and (max-width:692px) {
  .animated_radio {
    padding: 0;
  }
}
.animated_radio input[type=radio] {
  height: 0;
  width: 0;
  cursor: pointer;
}
.animated_radio input[type=radio] + label {
  position: relative;
  display: flex;
  /*margin: .6em 0;*/
  align-items: center;
  color: #000000;
  transition: color 250ms cubic-bezier(0.4, 0, 0.23, 1);
  cursor: pointer;
}
.animated_radio input[type=radio] + label > ins {
  position: absolute;
  display: block;
  bottom: 0;
  left: 2em;
  height: 0;
  width: 100%;
  overflow: hidden;
  text-decoration: none;
  transition: height 300ms cubic-bezier(0.4, 0, 0.23, 1);
}
.animated_radio input[type=radio] + label > ins > i {
  position: absolute;
  bottom: 0;
  font-style: normal;
  color: #D4B55C;
}
.animated_radio input[type=radio] + label > span {
  display: flex;
  justify-content: center;
  align-items: center;
  margin-right: 10px;
  width: 1.8em;
  height: 1.8em;
  background: transparent;
  border: 2px solid #D4B55C;
  border-radius: 50%;
  cursor: pointer;
  transition: all 250ms cubic-bezier(0.4, 0, 0.23, 1);
}
.animated_radio input[type=radio]:checked + label > ins {
  height: 100%;
}
.animated_radio input[type=radio]:checked + label > span {
  border: 2px solid #D4B55C;
  animation: shrink-bounce 200ms cubic-bezier(0.4, 0, 0.23, 1);
}
.animated_radio input[type=radio]:checked + label > span:before {
  content: "";
  position: absolute;
  top: 14px;
  left: 6px;
  border-right: 2px solid transparent;
  border-bottom: 2px solid transparent;
  transform: rotate(45deg);
  transform-origin: 0% 100%;
  animation: checkbox-check 125ms 250ms cubic-bezier(0.4, 0, 0.23, 1) forwards;
  font-size: 24px;
}
.animated_radio input[type=radio] + label:hover,
.animated_radio input[type=radio]:focus + label {
  color: #000000;
}
.animated_radio input[type=radio] + label:hover > span,
.animated_radio input[type=radio]:focus + label > span {
  background: rgba(255, 255, 255, 0.1);
}
@keyframes shrink-bounce {
  0% {
    transform: scale(1);
  }
  33% {
    transform: scale(0.85);
  }
  100% {
    transform: scale(1);
  }
}
@keyframes checkbox-check {
  0% {
    width: 0;
    height: 0;
    border-color: #212121;
    transform: translate3d(0, 0, 0) rotate(45deg);
  }
  33% {
    width: 0.2em;
    height: 0;
    transform: translate3d(0, 0, 0) rotate(45deg);
  }
  100% {
    width: 0.2em;
    height: 0.5em;
    border-color: #212121;
    transform: translate3d(0, -0.5em, 0) rotate(45deg);
  }
}

.whitegold {
  height: 20px;
  width: 20px;
  background: #e9e9e9;
  border-radius: 50%;
}

.rosegold {
  height: 20px;
  width: 20px;
  background: #e7ba9a;
  border-radius: 50%;
}

.yellowgold {
  height: 20px;
  width: 20px;
  background: #e5ce83;
  border-radius: 50%;
}

/*----- Rating CSS Here ------*/
.rate-area {
  border-style: none;
  display: flex;
  flex-direction: row-reverse;
  justify-content: flex-end;
  width: 100%;
}

.rate-area:not(:checked) > input {
  position: absolute;
  top: -9999px;
  clip: rect(0, 0, 0, 0);
}

.rate-area:not(:checked) > label {
  float: right;
  width: 1em;
  overflow: hidden;
  white-space: nowrap;
  cursor: pointer;
  font-size: 180%;
  color: lightgrey;
}

.rate-area:not(:checked) > label:before {
  content: "★";
}

.rate-area > input:checked ~ label {
  color: goldenrod;
}

.rate-area:not(:checked) > label:hover,
.rate-area:not(:checked) > label:hover ~ label {
  color: goldenrod;
}

.rate-area > input:checked + label:hover,
.rate-area > input:checked + label:hover ~ label,
.rate-area > input:checked ~ label:hover,
.rate-area > input:checked ~ label:hover ~ label,
.rate-area > label:hover ~ input:checked ~ label {
  color: goldenrod;
}

/* Accordion styles */
.accordian input {
  position: absolute;
  opacity: 0;
  z-index: -1;
  display: none;
}
.accordian .tabs {
  overflow: hidden;
  margin-top: 10px;
}
.accordian .tab {
  width: 100%;
  color: #ffffff;
  overflow: hidden;
  margin-bottom: 10px;
}
.accordian .tab-label {
  display: flex;
  justify-content: space-between;
  padding: 1em;
  background: #B4B4B4;
  font-weight: bold;
  color: #ffffff;
  cursor: pointer;
  /* Icon */
}
.accordian .tab-label::after {
  content: "❯";
  width: 1em;
  height: 1em;
  text-align: center;
  transition: all 0.35s;
}
.accordian .tab-content {
  max-height: 0;
  padding: 0 1em;
  color: #B4B4B4;
  background: #ffffff;
  transition: all 0.35s;
  line-height: 30px;
}
.accordian .tab-close {
  display: flex;
  justify-content: flex-end;
  padding: 1em;
  font-size: 0.75em;
  background: #8A8A8A;
  cursor: pointer;
}
.accordian .tab-close:hover {
  background: rgb(200.1893203883, 162.1165048544, 52.8106796117);
}
.accordian input:checked + .tab-label {
  background: #B4B4B4;
}
.accordian input:checked + .tab-label::after {
  transform: rotate(90deg);
}
.accordian input:checked ~ .tab-content {
  max-height: 100vh;
  padding: 1em;
  border: 1px solid #e6e6e6;
  padding: 15px 0 0 15px !important;
}
.accordian .cart_whishlist_icon {
  display: grid;
  grid-template-columns: 1fr 1fr;
  padding: 10px 0;
}
.accordian .cart_whishlist_icon i {
  color: #999;
}
.accordian .cart_whishlist_icon .active {
  color: #8A8A8A !important;
}

.simple_btn {
  text-decoration: underline;
  font-weight: 600;
  padding: 20px 0;
  color: #B4B4B4;
  transition: all 1s;
  display: inline-block;
}
.simple_btn:hover {
  color: #D4B55C;
}

body:not(.no-js) .image-wrap {
  transition: 1s ease-out;
  transition-delay: 0.2s;
  position: relative;
  width: auto;
  overflow: hidden;
  clip-path: polygon(0 100%, 100% 100%, 100% 100%, 0 100%);
  visibility: hidden;
}

body:not(.no-js) .image-wrap img {
  transform: scale(1.3);
  transition: 2s ease-out;
}

body:not(.no-js) .animating .image-wrap {
  clip-path: polygon(0 0, 100% 0, 100% 100%, 0 100%);
  visibility: visible;
  transform: skewY(0);
}

body:not(.no-js) .animating img {
  transform: scale(1);
  transition: 4s ease-out;
}

body:not(.no-js) .fadeup {
  opacity: 0;
  transition: 0.4s ease-out;
  transform: translateY(40px);
}

body:not(.no-js) .fading-up {
  opacity: 1;
  transition: 1s ease-out;
  transform: translateY(0px);
  transition-delay: 0.7s;
}

.item {
  background-color: #ffffff;
  position: relative;
  display: inline-block;
  overflow: hidden;
  cursor: pointer;
}

.item .overlay {
  color: #8A8A8A;
  width: 100%;
  height: 100%;
  background-color: #ffffff;
  opacity: 0;
  transition: all 0.5s ease;
  position: absolute;
  top: 0;
  bottom: 0;
}

/* effect-clean*/
.clean .overlay span:nth-child(1) {
  position: absolute;
  left: 30%;
  top: 35%;
  font-size: 80px;
  font-weight: bold;
  font-family: coustard;
  transform: translateX(-50%);
}

.clean .overlay span:nth-child(2) {
  position: absolute;
  top: 50%;
  left: 50%;
  font-size: 20px;
  font-weight: 600;
  transform: translateX(-50%);
}

.clean .overlay span:nth-child(3) {
  height: 3px;
  background-color: #000000;
  position: absolute;
  top: 60%;
  left: 0;
}

.clean .overlay:hover {
  opacity: 0.8;
}

.clean .overlay:hover span:nth-child(1) {
  animation: slide 0.4s;
}

.clean .overlay:hover span:nth-child(2) {
  animation: slide 0.7s;
}

.clean .overlay:hover span:nth-child(3) {
  animation: line 0.5s forwards;
}

@keyframes slide {
  0% {
    transform: translateX(-10%);
  }
  100% {
    transform: translateX(-50%);
  }
}
@keyframes line {
  0% {
    width: 0;
  }
  100% {
    width: 50%;
  }
}
/*------- Notification CSS Here ----------*/
.alert {
  background: #D4B55C;
  padding: 20px 40px;
  min-width: 420px;
  position: fixed;
  right: 0;
  top: 10px;
  border-radius: 4px;
  border-left: 8px solid #ffa502;
  overflow: hidden;
  opacity: 0;
  pointer-events: none;
  color: #ffffff;
  z-index: 9999;
}

.alert.showAlert {
  opacity: 1;
  pointer-events: auto;
}

.alert.show {
  animation: show_slide 1s ease forwards;
}

@keyframes show_slide {
  0% {
    transform: translateX(100%);
  }
  40% {
    transform: translateX(-10%);
  }
  80% {
    transform: translateX(0%);
  }
  100% {
    transform: translateX(-10px);
  }
}
.alert.hide {
  animation: hide_slide 1s ease forwards;
}

@keyframes hide_slide {
  0% {
    transform: translateX(-10px);
  }
  40% {
    transform: translateX(0%);
  }
  80% {
    transform: translateX(-10%);
  }
  100% {
    transform: translateX(100%);
  }
}
.alert .fa-exclamation-circle {
  position: absolute;
  left: 20px;
  top: 50%;
  transform: translateY(-50%);
  color: #ffffff;
  font-size: 30px;
}

.alert .msg {
  padding: 0 20px;
  font-size: 18px;
  color: #ffffff;
}

.alert .close-btn {
  position: absolute;
  right: 0px;
  top: 50%;
  transform: translateY(-50%);
  background: #ffa502;
  padding: 20px 18px;
  cursor: pointer;
}

.alert .close-btn:hover {
  background: #ffa502;
}

.success_box {
  border-left: 8px solid green !important;
}

.error_box {
  border-left: 8px solid red !important;
}

.success_alert {
  background: green !important;
}

.error_alert {
  background: red !important;
}

.alert .close-btn .fas {
  color: #ffffff;
  font-size: 22px;
  line-height: 40px;
}

.modal {
  opacity: 0;
  visibility: hidden;
  position: fixed;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  text-align: left;
  background: rgba(0, 0, 0, 0.9);
  transition: opacity 0.25s ease;
  z-index: 999;
}

.modal__bg {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  cursor: pointer;
}

.modal-state {
  display: none;
}

.modal-state:checked + .modal {
  opacity: 1;
  visibility: visible;
}

.modal-state:checked + .modal .modal__inner {
  top: 0;
}

.modal__inner {
  transition: top 0.25s ease;
  position: absolute;
  top: -20%;
  right: 0;
  bottom: 0;
  left: 0;
  width: 50%;
  margin: auto;
  overflow: auto;
  background: #fff;
  border-radius: 5px;
  padding: 1em 2em;
  height: 50%;
}
@media only screen and (min-width: 991px) and (max-width:1200px), only screen and (min-width: 1201px) and (max-width:1366px), only screen and (min-width: 1367px) and (max-width:1920px) {
  .modal__inner {
    width: 70%;
    height: 80%;
  }
}

.modal__close {
  position: absolute;
  right: 1em;
  top: 1em;
  width: 1.1em;
  height: 1.1em;
  cursor: pointer;
}

.modal__close:after,
.modal__close:before {
  content: "";
  position: absolute;
  width: 2px;
  height: 1.5em;
  background: #ccc;
  display: block;
  transform: rotate(45deg);
  left: 50%;
  margin: -3px 0 0 -1px;
  top: 0;
}

.modal__close:hover:after,
.modal__close:hover:before {
  background: #aaa;
}

.modal__close:before {
  transform: rotate(-45deg);
}

@media screen and (max-width: 980px) {
  .modal__inner {
    width: 90%;
    height: 90%;
    box-sizing: border-box;
  }
}
.openpopup {
  opacity: 1;
  visibility: visible;
}

.overflowhidden {
  overflow: hidden !important;
}

@media only screen and (min-width: 991px) and (max-width:1200px), only screen and (min-width: 692px) and (max-width:990px), only screen and (min-width: 300px) and (max-width:692px) {
  .slick-dotted.slick-slider {
    margin-bottom: 30px !important;
  }
}
.slick-dots {
  bottom: -25px !important;
}
@media only screen and (min-width: 991px) and (max-width:1200px), only screen and (min-width: 692px) and (max-width:990px), only screen and (min-width: 300px) and (max-width:692px) {
  .slick-dots {
    bottom: -20px !important;
  }
  .slick-dots .slick-dotted.slick-slider {
    margin-bottom: 30px;
  }
}
@media only screen and (min-width: 991px) and (max-width:1200px), only screen and (min-width: 692px) and (max-width:990px), only screen and (min-width: 300px) and (max-width:692px) {
  .slick-dots li {
    width: 10px !important;
  }
}
.slick-dots li button::before {
  font-size: 12px !important;
}
@media only screen and (min-width: 991px) and (max-width:1200px), only screen and (min-width: 692px) and (max-width:990px), only screen and (min-width: 300px) and (max-width:692px) {
  .slick-dots li button::before {
    font-size: 10px !important;
  }
}

@media only screen and (min-width: 300px) and (max-width:692px) {
  .slick-dotted.slick-slider {
    margin-bottom: 40px;
  }
}
.slick-active button::before {
  color: #D4B55C !important;
}

.pageurl {
  padding: 20px 0;
  font-size: 14px;
}
.pageurl a {
  color: #050606;
}

@media only screen and (min-width: 1921px) and (max-width:3840px), only screen and (min-width: 1367px) and (max-width:1920px), only screen and (min-width: 1201px) and (max-width:1366px) {
  .banner_slider .slick-prev {
    top: 90% !important;
    left: 90% !important;
  }
  .banner_slider .slick-next {
    top: 90% !important;
    right: 4% !important;
  }
  .banner_slider .slick-prev:before,
  .banner_slider .slick-next:before {
    font-size: 32px;
    border: 1px solid #000000;
    background-color: #ffffff;
    border-radius: 0;
    justify-content: center;
    align-items: center;
    display: flex;
    width: 45px;
    height: 45px;
  }
  .banner_slider .slick-prev:before {
    content: url("../images/arrow-left.png");
  }
  .banner_slider .slick-next:before {
    content: url("../images/arrow-right.png");
  }
}
@media only screen and (min-width: 991px) and (max-width:1200px), only screen and (min-width: 692px) and (max-width:990px), only screen and (min-width: 300px) and (max-width:692px) {
  .banner_slider .slick-prev {
    left: 2% !important;
  }
  .banner_slider .slick-next {
    right: 8px !important;
  }
  .banner_slider .slick-prev:before,
  .banner_slider .slick-next:before {
    font-size: 16px;
    padding: 0;
  }
}

.custom-field {
  position: relative;
  font-size: 14px;
  margin-top: 24px;
  display: inline-block;
  width: 100%;
}
.custom-field input,
.custom-field select {
  border: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
  background: #f2f2f2;
  padding: 12px;
  border-radius: 3px;
  width: 100%;
  outline: none;
  font-size: 14px;
}
.custom-field input:not(:-moz-placeholder) + .placeholder, .custom-field select:not(:-moz-placeholder) + .placeholder {
  top: -10px;
  font-size: 12px;
  color: #222;
}
.custom-field input.dirty + .placeholder, .custom-field input:focus + .placeholder, .custom-field input:not(:placeholder-shown) + .placeholder,
.custom-field select.dirty + .placeholder,
.custom-field select:focus + .placeholder,
.custom-field select:not(:placeholder-shown) + .placeholder {
  top: -10px;
  font-size: 12px;
  color: #222;
}
.custom-field .placeholder {
  position: absolute;
  left: 12px;
  overflow: hidden;
  white-space: nowrap;
  top: 22px;
  line-height: 100%;
  transform: translateY(-50%);
  color: #aaa;
  transition: top 0.3s ease, color 0.3s ease, font-size 0.3s ease;
}
.custom-field.box_line input,
.custom-field.box_line select {
  border-radius: 0;
  border-top-left-radius: 3px;
  border-top-right-radius: 3px;
  background: linear-gradient(90deg, #222, #222) center bottom/0 0.15em no-repeat, linear-gradient(90deg, #ccc, #ccc) left bottom/100% 0.15em no-repeat, linear-gradient(90deg, #fafafa, #fafafa) left bottom/100% no-repeat;
  transition: background-size 0.3s ease;
}
.custom-field.box_line input:not(:-moz-placeholder), .custom-field.box_line select:not(:-moz-placeholder) {
  background-size: 100% 0.15em, 100% 0.1em, 100%;
}
.custom-field.box_line input.dirty, .custom-field.box_line input:not(:placeholder-shown), .custom-field.box_line input:focus,
.custom-field.box_line select.dirty,
.custom-field.box_line select:not(:placeholder-shown),
.custom-field.box_line select:focus {
  background-size: 100% 0.15em, 100% 0.1em, 100%;
}

.login-screen {
  position: relative;
  top: 0;
  left: 0;
  width: 100%;
  padding: 100px 0 100px;
  background-color: #D4B55C;
  background-size: 400% 400%;
  animation: loginGradient 20s ease infinite;
  z-index: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
}
.login-screen::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  overflow: hidden;
  background: radial-gradient(circle at 20% 80%, rgba(225, 225, 225, 0.3) 0%, transparent 50%), radial-gradient(circle at 80% 20%, rgba(225, 225, 225, 0.1) 0%, transparent 50%), radial-gradient(circle at 40% 40%, rgba(225, 225, 225, 0.2) 0%, transparent 50%);
  animation: particleMove 20s ease-in-out infinite;
}

@keyframes loginGradient {
  0% {
    background-position: 0% 50%;
  }
  50% {
    background-position: 100% 50%;
  }
  100% {
    background-position: 0% 50%;
  }
}
@keyframes particleMove {
  0%, 100% {
    transform: translate(0, 0) rotate(0deg);
  }
  33% {
    transform: translate(30px, -30px) rotate(120deg);
  }
  66% {
    transform: translate(-20px, 20px) rotate(240deg);
  }
}
.login-form-container {
  background: rgba(255, 255, 255, 0.1);
  -webkit-backdrop-filter: blur(20px);
          backdrop-filter: blur(20px);
  border: 1px solid rgba(255, 255, 255, 0.2);
  border-radius: 24px;
  padding: 3rem 2.5rem;
  width: 100%;
  max-width: 620px;
  margin: 0 1rem;
  box-shadow: 0 32px 64px rgba(5, 6, 6, 0.2), inset 0 1px 0 rgba(255, 255, 255, 0.3);
  transform: translateY(-100vh);
  opacity: 0;
  animation: slideDownForm 0.8s ease-out 0.5s forwards;
  position: relative;
  overflow: hidden;
}
.login-form-container.slide-out {
  animation: slideUpForm 0.6s ease-in forwards;
}

@keyframes slideDownForm {
  to {
    transform: translateY(0);
    opacity: 1;
  }
}
@keyframes slideUpForm {
  to {
    transform: translateY(100vh);
    opacity: 0;
  }
}
.floating-element {
  position: absolute;
  background: rgba(5, 6, 6, 0.1);
  border-radius: 20%;
  pointer-events: none;
  animation: float 6s ease-in-out infinite;
}
.floating-element:nth-child(1) {
  width: 80px;
  height: 80px;
  top: 10%;
  left: 10%;
  animation-delay: 0s;
}
.floating-element:nth-child(2) {
  width: 120px;
  height: 120px;
  top: 70%;
  right: 10%;
  animation-delay: 2s;
}
.floating-element:nth-child(3) {
  width: 60px;
  height: 60px;
  bottom: 20%;
  left: 70%;
  animation-delay: 4s;
}

@keyframes float {
  0%, 100% {
    transform: translateY(0) rotate(0deg);
  }
  50% {
    transform: translateY(-20px) rotate(180deg);
  }
}
.login-title {
  color: #050606 !important;
}

.error_text {
  color: red;
  margin-top: 5px;
  margin-bottom: 5px;
}

#show-forgot-pwd {
  float: inline-end;
  color: #050606;
  margin-top: 5px;
  margin-bottom: 5px;
}

.a_color a:hover {
  color: #050606 !important;
  text-decoration: underline;
}

.columns2 {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1em;
}
@media only screen and (min-width: 991px) and (max-width:1200px), only screen and (min-width: 300px) and (max-width:692px), only screen and (min-width: 692px) and (max-width:990px) {
  .columns2 {
    grid-template-columns: 1fr;
  }
}

.columns48 {
  display: grid;
  grid-template-columns: 4fr 8fr;
  gap: 1em;
}
@media only screen and (min-width: 991px) and (max-width:1200px), only screen and (min-width: 300px) and (max-width:692px), only screen and (min-width: 692px) and (max-width:990px) {
  .columns48 {
    grid-template-columns: 1fr;
  }
}

.hedding_text {
  background-color: #D4B55C;
  padding: 28px 15px 28px 58px;
}
@media only screen and (min-width: 991px) and (max-width:1200px), only screen and (min-width: 692px) and (max-width:990px) {
  .hedding_text {
    padding: 28px 15px 28px 20px;
  }
}
@media only screen and (min-width: 300px) and (max-width:692px) {
  .hedding_text {
    padding: 15px 12px;
  }
}
.hedding_text h2 {
  text-transform: uppercase;
  color: #ffffff;
  padding-top: 0;
}
@media only screen and (min-width: 300px) and (max-width:692px) {
  .hedding_text h2 {
    font-size: 20px;
    padding-bottom: 5px;
  }
}
.hedding_text h2 span {
  font-size: 20px;
  color: #ffffff;
  text-transform: capitalize;
}
.hedding_text .pageurl {
  font-size: 14px;
  font-family: "Lato";
  list-style: none;
  display: flex;
  align-items: center;
  text-transform: uppercase;
}
@media only screen and (min-width: 300px) and (max-width:692px) {
  .hedding_text .pageurl {
    font-size: 12px;
  }
}
.hedding_text .pageurl .mainpage a {
  color: #ffffff;
  font-weight: 400;
}
.hedding_text .pageurl .mainpage a span {
  font-size: 16px;
}
.hedding_text .pageurl .activepage {
  color: #ffffff;
}

.gc-display-area-container {
  height: 100% !important;
  width: 100% !important;
}

.customsize {
  width: 100% !important;
  height: auto !important;
}

.item_img {
  position: relative;
}
.item_img .zoom_img .glass-case .gc-display-area {
  margin-bottom: 8px;
}
.item_img .zoom_img .glass-case .gc-display-area .gc-display-area-container {
  border: 1px solid #ECECEC !important;
}
.item_img #zoom1 li {
  border: 1px solid #ECECEC !important;
  margin-right: 10px;
}
.item_img #zoom1 .gc-active {
  border: 1px solid #D4B55C !important;
}

.section-header {
  padding-top: 45px;
  padding-bottom: 15px;
}
@media only screen and (min-width: 1201px) and (max-width:1366px), only screen and (min-width: 991px) and (max-width:1200px) {
  .section-header {
    padding-top: 25px;
    padding-bottom: 10px;
  }
}
@media only screen and (min-width: 300px) and (max-width:692px), only screen and (min-width: 692px) and (max-width:990px) {
  .section-header {
    padding-top: 15px;
    padding-bottom: 5px;
  }
}

.input:-internal-autofill-selected {
  background-color: transparent !important;
  -webkit-text-fill-color: transparent !important;
}

input:-webkit-autofill,
input:-webkit-autofill:hover,
input:-webkit-autofill:focus,
input:-webkit-autofill:active {
  -webkit-transition: background-color 5000s ease-in-out 0s;
  transition: background-color 5000s ease-in-out 0s;
  -webkit-text-fill-color: transparent !important;
  -webkit-text-fill-color: black !important;
}

input,
textarea,
button,
select,
a,
body,
* {
  -webkit-tap-highlight-color: transparent;
}

.commen_page {
  margin-bottom: 50px;
}
@media only screen and (min-width: 692px) and (max-width:990px) {
  .commen_page {
    margin-bottom: 30px;
  }
}
@media only screen and (min-width: 300px) and (max-width:692px) {
  .commen_page {
    margin-bottom: 20px;
  }
}
.commen_page li::marker {
  font-size: 22px;
  letter-spacing: 1px;
  padding: 15px 0;
  color: #D4B55C;
  font-weight: 500;
}
@media only screen and (min-width: 1201px) and (max-width:1366px), only screen and (min-width: 991px) and (max-width:1200px) {
  .commen_page li::marker {
    font-size: 18px;
  }
}
@media only screen and (min-width: 300px) and (max-width:692px), only screen and (min-width: 692px) and (max-width:990px) {
  .commen_page li::marker {
    font-size: 16px;
  }
}
.commen_page .commen_ol {
  margin-left: 24px;
  margin-bottom: 26px;
}
.commen_page p {
  font-size: 18px;
  font-family: "Lato";
  font-weight: 400;
  line-height: 26px;
  margin-bottom: 12px;
}
@media only screen and (min-width: 692px) and (max-width:990px) {
  .commen_page p {
    font-size: 16px;
    line-height: 26px;
  }
}
@media only screen and (min-width: 300px) and (max-width:692px) {
  .commen_page p {
    font-size: 14px;
    line-height: 24px;
  }
}
.commen_page .commen_ul {
  padding-left: 20px;
}
.commen_page .commen_ul li {
  font-size: 18px;
  font-family: "Lato";
  font-weight: 400;
  line-height: 28px;
  margin-bottom: 10px;
}
@media only screen and (min-width: 692px) and (max-width:990px) {
  .commen_page .commen_ul li {
    font-size: 16px;
    line-height: 26px;
    margin: 13px 0;
  }
}
@media only screen and (min-width: 300px) and (max-width:692px) {
  .commen_page .commen_ul li {
    font-size: 14px;
    line-height: 24px;
    margin: 10px 0;
  }
}

.Custom_radio-button input[type=checkbox],
.Custom_radio-button input[type=radio] {
  display: none;
  opacity: 0;
}
.Custom_radio-button input[type=radio] + span {
  background-color: #B4B4B4;
  border-radius: 100%;
  box-shadow: inset 0 1px 2px rgba(0, 0, 0, 0.15);
  display: inline-block;
  margin-right: 10px;
  padding: 10px;
  position: relative;
}
.Custom_radio-button input[type=radio]:checked + span {
  background-color: #D4B55C;
  border-color: #D4B55C;
  color: #ffffff;
}
.Custom_radio-button input[type=radio]:checked + span:after {
  color: #ffffff;
  content: "✔";
  font-size: 13px;
  left: 4px;
  position: absolute;
  top: 1px;
}

.form_close_icon {
  width: 20px;
  height: 20px;
  position: absolute;
  top: 0;
  right: 0;
  cursor: pointer;
}
.form_close_icon:before, .form_close_icon:after {
  content: "";
  position: absolute;
  height: 3px;
  width: 20px;
  background-color: #8A8A8A;
  left: 50%;
  top: 50%;
  transition: ease-out 0.3s all;
}
.form_close_icon:before {
  transform: translate(-50%, -50%) rotate(-45deg);
}
.form_close_icon:after {
  transform: translate(-50%, -50%) rotate(45deg);
}
.form_close_icon:hover:before, .form_close_icon:focus:before {
  transform: translate(-50%, -50%) rotate(135deg);
}
.form_close_icon:hover:after, .form_close_icon:focus:after {
  transform: translate(-50%, -50%) rotate(225deg);
}

.ngx-pagination .current {
  background: #D4B55C !important;
}

::-webkit-datetime-edit-year-field:not([aria-valuenow]),
::-webkit-datetime-edit-month-field:not([aria-valuenow]),
::-webkit-datetime-edit-day-field:not([aria-valuenow]) {
  color: transparent;
}

.checkbox__checkmark {
  position: absolute;
  top: 2px;
  left: 0;
  height: 20px;
  width: 20px;
  border: 1px solid #D4B55C;
  transition: background-color 0.25s ease;
  border-radius: 4px;
}
.checkbox__checkmark:after {
  content: "";
  position: absolute;
  left: 7px;
  top: 3.5px;
  width: 5px;
  height: 10px;
  border: solid #D4B55C;
  border-width: 0 2px 2px 0;
  transform: rotate(45deg);
  opacity: 0;
  transition: opacity 0.25s ease;
}

.menucheckbox {
  display: inline-block;
  position: relative;
  padding-left: 30px;
  cursor: pointer;
  -webkit-user-select: none;
  -moz-user-select: none;
  user-select: none;
}
.menucheckbox input {
  margin-right: 10px;
  position: absolute;
  opacity: 0;
  cursor: pointer;
  height: 0;
  width: 0;
}
.menucheckbox input:checked ~ .checkbox__checkmark:after {
  opacity: 1;
}
.menucheckbox:hover input:checked ~ .checkbox__checkmark {
  background-color: #ffffff;
}
.menucheckbox .filterText {
  font-size: 16px;
  font-family: "Lato";
  font-family: 700;
}
@media only screen and (min-width: 692px) and (max-width:990px), only screen and (min-width: 300px) and (max-width:692px) {
  .menucheckbox .filterText {
    font-size: 14px;
  }
}
.menucheckbox .filterText span {
  padding-left: 5px;
  color: #D4B55C;
}

.action_btn {
  line-height: normal !important;
}

.section-margintop {
  margin-top: 50px;
}
@media only screen and (min-width: 1201px) and (max-width:1366px) {
  .section-margintop {
    margin-top: 40px;
  }
}
@media only screen and (min-width: 991px) and (max-width:1200px), only screen and (min-width: 692px) and (max-width:990px) {
  .section-margintop {
    margin-top: 30px;
  }
}
@media only screen and (min-width: 300px) and (max-width:692px) {
  .section-margintop {
    margin-top: 20px;
  }
}

.ngx-slider {
  margin: 35px 0 25px !important;
}
.ngx-slider .ngx-slider-pointer {
  background-color: #D4B55C !important;
}
.ngx-slider .ngx-slider-pointer.ngx-slider-active:after {
  background-color: #8A8A8A !important;
}
.ngx-slider .ngx-slider-selection {
  background: #D4B55C !important;
}
.ngx-slider .ngx-slider-bubble {
  bottom: 20px !important;
}

.margin-top-containt {
  margin: 20px 0px;
}
@media only screen and (min-width: 692px) and (max-width:990px) {
  .margin-top-containt {
    margin: 16px 0px;
  }
}
@media only screen and (min-width: 300px) and (max-width:692px) {
  .margin-top-containt {
    margin: 10px 0px;
  }
}

::-webkit-input-placeholder {
  color: rgb(200, 200, 200) !important;
}

::-moz-placeholder {
  color: rgb(200, 200, 200) !important;
}

:-ms-input-placeholder {
  color: rgb(200, 200, 200) !important;
}

:-moz-placeholder {
  color: rgb(200, 200, 200) !important;
}

/* Sticky header: fixed at top with frosted glass (blurred semi-transparent) */
header {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  z-index: 999;
  /* background-color: rgba(255, 255, 255, 0.75); */
  /* -webkit-backdrop-filter: blur(12px); */
  /*backdrop-filter: blur(12px);*/
  background-image: linear-gradient(to bottom, rgba(0, 0, 0, 1), transparent);
  color:#ffffff;
  /* box-shadow: 0 2px 12px rgba(0, 0, 0, 0.08); */
}

/*header.is-sticky {
  box-shadow: 0 5px 20px rgba(0, 0, 0, 0.12);
  background-color: rgba(255, 255, 255, 0.85);
  -webkit-backdrop-filter: blur(14px);
  backdrop-filter: blur(14px);
}*/

header .search_bar {
  display: flex;
  align-items: center;
  padding: 16px;
  margin: 0;
  min-height: 75px;
}
header .search_bar .search {
  flex: 1;
  min-width: 0;
}
header .search_bar .search input {
  width: 100%;
  border: 2px solid #DADADA;
  border-radius: 100px;
  height: 35px;
  padding: 10px 14px;
  font-size: 16px;
  background: transparent;
  box-sizing: border-box;
  color: #FFFFFF;
}
/* White clear (X) icon for global search */
header .search_bar .search input[type="search"]::-webkit-search-cancel-button {
  -webkit-appearance: none;
  appearance: none;
  width: 16px;
  height: 16px;
  background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23ffffff' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cline x1='18' y1='6' x2='6' y2='18'/%3E%3Cline x1='6' y1='6' x2='18' y2='18'/%3E%3C/svg%3E") center/contain no-repeat;
  cursor: pointer;
}
header .search_bar .search input[type="search"]::-moz-search-cancel-button {
  -moz-appearance: none;
  appearance: none;
  width: 16px;
  height: 16px;
  background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23ffffff' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cline x1='18' y1='6' x2='6' y2='18'/%3E%3Cline x1='6' y1='6' x2='18' y2='18'/%3E%3C/svg%3E") center/contain no-repeat;
  cursor: pointer;
}
header .search_bar .header_notifications_wrap {
  flex-shrink: 0;
}
header .search_bar .header_notifications_trigger {
  display: flex;
  align-items: center;
  justify-content: center;
  padding-left: 6px;
  border: none;
  background: transparent;
  cursor: pointer;
  position: relative;
}
header .search_bar .notification_icon {
  width: 30px;
  height: 35px;
  display: block;
}
header .search_bar .count {
  position: absolute;
  right: -2px;
  top: -2px;
  min-width: 18px;
  height: 18px;
  padding: 0 5px;
  background: #000000;
  border-radius: 50px;
  color: #fff;
  text-align: center;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 11px;
  font-weight: 600;
}

/* Real-time header search dropdown */
.header_search_wrap {
  position: relative;
}
.header_search_wrap .header_search_form {
  margin: 0;
}
.header_search_results {
  position: absolute;
  left: 0;
  right: 0;
  top: 100%;
  margin-top: 6px;
  background: #fff;
  border-radius: 8px;
  box-shadow: 0 6px 20px rgba(0,0,0,0.12);
  max-height: 320px;
  overflow-y: auto;
  z-index: 1000;
}
.header_search_list {
  list-style: none;
  margin: 0;
  padding: 8px 0;
}
.header_search_item {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 10px 14px;
  color: #000;
  text-decoration: none;
  border-bottom: 1px solid #f0f0f0;
}
.header_search_item:last-child {
  border-bottom: none;
}
.header_search_item:hover {
  background: #f8f8f8;
}
.header_search_item img {
  width: 48px;
  height: 48px;
  object-fit: cover;
  border-radius: 6px;
  flex-shrink: 0;
}
.header_search_item > div {
  display: flex;
  flex-direction: column;
  gap: 2px;
  min-width: 0;
}
.header_search_name {
  font-size: 14px;
  font-weight: 500;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.header_search_price {
  font-size: 13px;
  font-weight: 600;
  color: #333;
}
.header_search_footer {
  padding: 10px 14px;
  border-top: 1px solid #eee;
  background: #fafafa;
  border-radius: 0 0 8px 8px;
}
.header_search_footer a {
  font-size: 13px;
  font-weight: 600;
  color: #000;
  text-decoration: none;
}
.header_search_footer a:hover {
  text-decoration: underline;
}

/* Header notifications dropdown */
.header_notifications_wrap {
  position: relative;
}
.header_notifications_dropdown {
  display: inline-block;
}
.header_notifications_trigger {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  list-style: none;
  padding: 0;
  position: relative;
}
.header_notifications_trigger::-webkit-details-marker {
  display: none;
}
.header_notifications_trigger img {
  display: block;
}
.header_notifications_panel {
  position: absolute;
  right: 0;
  top: 100%;
  margin-top: 8px;
  min-width: 280px;
  max-width: 340px;
  background: #fff;
  border-radius: 8px;
  box-shadow: 0 6px 20px rgba(0,0,0,0.12);
  max-height: 360px;
  overflow: hidden;
  z-index: 1000;
}
.header_notifications_header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 12px 14px;
  border-bottom: 1px solid #eee;
  background: #fafafa;
}
.header_notifications_header span {
  font-size: 14px;
  font-weight: 600;
}
.header_notifications_clear_form button {
  font-size: 12px;
  color: #666;
  background: none;
  border: none;
  cursor: pointer;
  padding: 0;
  text-decoration: underline;
}
.header_notifications_clear_form button:hover {
  color: #000;
}
.header_notifications_list {
  list-style: none;
  margin: 0;
  padding: 0;
  max-height: 280px;
  overflow-y: auto;
}
.header_notification_item {
  display: block;
  padding: 12px 14px;
  color: #333;
  text-decoration: none;
  font-size: 13px;
  border-bottom: 1px solid #f0f0f0;
}
.header_notification_item:hover {
  background: #f8f8f8;
}
.header_notification_message {
  display: block;
}
.header_notification_empty {
  padding: 24px 14px;
  text-align: center;
  color: #999;
  font-size: 13px;
}

/* Marquee – .marquee--inner has two spans; each span as wide as its content to avoid overlap */
.section2 .marquee {
  height: 35px;
  width: 100%;
  /* border: 2px solid #000; */
  border-left: 0;
  border-right: 0;
  overflow: hidden;
  box-sizing: border-box;
  position: relative;
  margin: 0 auto;
  font-size: 14px;
}
.section2 .marquee span,
.section2 .marquee span div {
  font-size: 14px !important;
}
.section2 .marquee--inner {
  display: flex;
  width: max-content;
  margin: 0;
  padding: 6px;
  position: absolute;
  left: 0;
  animation: marquee 20s linear infinite;
  font-size: 14px !important;
  background: #000;
  color: #fff;
}
.section2 .marquee--inner:hover {
  animation-play-state: paused;
}
.section2 .marquee span {
  flex-shrink: 0;
  white-space: nowrap;
}
.section2 .marquee span div {
  white-space: nowrap;
  display: inline;
}
.section2 .marquee img {
  vertical-align: middle;
  margin: 0 2px;
}
.section2 .marquee .marquee-sep {
  margin: 0 1.5em;
  opacity: 0.8;
  pointer-events: none;
  white-space: nowrap;
}
@keyframes marquee {
  0% { transform: translateX(0); }
  100% { transform: translateX(-50%); }
}

.section1 .banner_slider {
  position: relative;
  overflow: hidden;
  height: 584px;
}
.section1 .banner_slider.swiper .swiper-wrapper {
  align-items: stretch;
  transition-timing-function: ease-in-out;
}
.section1 .banner_slider .swiper-slide {
  height: 584px;
  width: 100%;
  min-width: 0;
  max-width: 100%;
  box-sizing: border-box;
}
.section1 .banner_slider .swiper-slide .banner_slide__inner {
  height: 584px;
}
/* Slide inner: flex center, overflow hidden, transition (ref-style) */
.section1 .banner_slide__inner {
  position: relative;
  isolation: isolate;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  overflow: hidden;
  transition: opacity ease-in-out 0.2s;
  height: 100%;
  width: 100%;
  max-width: 100%;
  cursor: pointer;
}
.section1 .banner_slide__link {
  display: block;
  height: 100%;
  width: 100%;
}
/* Gradient overlays – top and bottom (ref: from-transparent-35) */
.section1 .banner_slide__gradient {
  position: absolute;
  left: 0;
  right: 0;
  width: 100%;
  height: 200px;
  pointer-events: none;
  z-index: 1;
}
.section1 .banner_slide__gradient--top {
  top: 0;
  background: linear-gradient(to bottom, rgba(0, 0, 0, 0.35), transparent);
}
.section1 .banner_slide__gradient--bottom {
  bottom: 0;
  background: linear-gradient(to top, rgba(0, 0, 0, 0.35), transparent);
}
.section1 .banner_slide__img-wrap {
  position: relative;
  flex: 1 1 0%;
  min-height: 0;
  width: 100%;
}
.section1 .banner_slide__img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  color: transparent;
}
.section1 .banner_slide a {
  display: block;
}

/* Slider wrapper for arrows + dots */
.section1 .banner_slider_wrap {
  position: relative;
}

/* Prev/Next arrows – circular semi-transparent dark, white chevron */
.section1 .banner_slider_arrow {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  z-index: 10;
  width: 44px;
  height: 44px;
  border-radius: 50%;
  border: none;
  background: rgba(0, 0, 0, 0.4);
  color: #fff;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background 0.2s ease;
}
.section1 .banner_slider_arrow:hover {
  background: rgba(0, 0, 0, 0.6);
}
.section1 .banner_slider_arrow--prev {
  left: 12px;
}
.section1 .banner_slider_arrow--next {
  right: 12px;
}

/* Dots below slider – active = wide white pill, inactive = small dark circle */
.section1 .banner_slider_dots {
  position: absolute;
  bottom: 16px;
  left: 50%;
  transform: translateX(-50%);
  z-index: 10;
  display: flex;
  align-items: center;
  gap: 8px;
}
.section1 .banner_slider_dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  border: none;
  padding: 0;
  background: rgba(0, 0, 0, 0.5);
  cursor: pointer;
  transition: width 0.25s ease, background 0.2s ease;
}
.section1 .banner_slider_dot:hover {
  background: rgba(0, 0, 0, 0.7);
}
.section1 .banner_slider_dot.is-active {
  width: 24px;
  border-radius: 4px;
  background: #fff;
}

/* Main categories carousel – Slick smooth scroll */
.section3 .main-categories-carousel {
  position: relative;
  margin: 20px 0 10px;
  padding: 0;
}
.section3 .main-categories-carousel_track {
  overflow: hidden;
}
.section3 .home-main-categories.slick-initialized .slick-list {
  overflow: hidden;
}
.section3 .home-main-categories .slick-slide {
  padding: 0 12px;
}
.section3 .home-main-category {
  text-align: center;
  padding: 8px 0;
}
.section3 .home-main-category img {
  width: 90px;
  height: 90px;
  border-radius: 50%;
  object-fit: cover;
  display: block;
  margin: 0 auto;
}
.section3 .home-main-category-name {
  font-size: 12px;
  font-weight: 500;
  margin-top: 16px;
  text-transform: uppercase;
}
.section3 .main-categories-carousel_arrow {
  display: none !important;
}

.section4 {
  margin-top: 20px;
}
.section4 .Category {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
  margin: 12px 0 0;
}
.section4 .Category .Category_block {
  position: relative;
  display: block;
  width: 100%;
  aspect-ratio: 4 / 5;
  overflow: hidden;
  background-color: #f3f3f3;
}
.section4 .Category .Category_block img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.section4 .Category .Category_block .Category_type {
    position: absolute;
    font-size: 14px;
    font-weight: 600;
    bottom: 20px;
    padding: 5px 0;
    background-color: rgba(255, 255, 255, 0.5);
    color: #000000;
    border: 1px solid #DBDBDB;
    -webkit-backdrop-filter: blur(10px);
    backdrop-filter: blur(10px);
    text-align: center;
    width: 100%;
    text-transform: uppercase;
}

.section5 {
  margin-top: 20px;
}
.section5 .search_by_brand {
  margin: 12px 0 0;
}
.section5 .brand_marquee {
  overflow: hidden;
}
.section5 .brand_marquee-track {
  display: flex;
  align-items: center;
  gap: 12px;
  width: max-content;
  animation: brand-marquee 18s linear infinite;
}
.section5 .brand_marquee-item {
  flex: 0 0 auto;
  width: 120px;
}
.section5 .brand_marquee-item img {
  width: 100%;
  height: auto;
  display: block;
}
@keyframes brand-marquee {
  0% { transform: translateX(0); }
  100% { transform: translateX(-50%); }
}

.section6 {
  margin: 35px 0;
  min-height: 120px;
}
.section6__banner-link {
  display: block;
  width: 100%;
}
.section6__banner-img {
  width: 100%;
  height: auto;
  min-height: 120px;
  display: block;
  object-fit: cover;
}

.section-arrival {
  margin: 20px 0;
}
.section-arrival .just_launch {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 24px 12px;
}
.section-arrival .just_launch_block--link {
  display: block;
  text-decoration: none;
  color: inherit;
}
.section-arrival .just_launch_block--link:hover {
  color: inherit;
}
.section-arrival .just_launch_block--link .just_launch_text .title:hover,
.section-arrival .just_launch_block--link .just_launch_text .descriptions:hover {
  color: #D4B55C;
}
.section-arrival .just_launch .just_launch_block .just_launch_img {
  position: relative;
  aspect-ratio: 4/5;
  overflow: hidden;
  background: #f3f3f3;
}
.section-arrival .just_launch .just_launch_block .just_launch_img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.section-arrival .just_launch .just_launch_block .just_launch_text .title {
  font-size: 14px;
  font-weight: 600;
  color: #000000;
}
.section-arrival .just_launch .just_launch_block .just_launch_text .descriptions {
  font-size: 12px;
  font-weight: 400;
  color: #000000;
}

.section7 {
  margin: 20px 0 30px;
}

/* Snitch-style filter bar: clean bar, full width, scrolls with content (no overlap) */
.filter_sec {
  padding: 14px 16px;
  background: #fff;
  border-bottom: 1px solid #eee;
}
.filter_sec .filter {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 10px;
  text-align: center;
  align-items: center;
  max-width: 1200px;
  margin: 0 auto;
}
.filter_sec .filter .filter_block img {
  margin-right: 8px;
  width: 18px;
  height: 18px;
  opacity: 0.9;
}
.filter_sec .filter .filter_block:first-child {
  text-align: left;
}
.filter_sec .filter .filter_block:last-child {
  text-align: right;
}
.filter_sec .filter_trigger {
  font-size: 14px;
  font-weight: 500;
  color: #1a1a1a;
}
.filter_sec .filter .filter_block a {
  color: #1a1a1a;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
}
.filter_sec .filter .filter_block a .count {
  position: absolute;
  left: 12px;
  top: -6px;
  width: 20px;
  height: 20px;
  background: #1a1a1a;
  border-radius: 50px;
  color: #fff;
  text-align: center;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 5px;
  font-size: 11px;
  font-weight: 600;
}
/* .section7 .filter_sec {
  display: block;
  margin: 16px 0;
  padding: 0 16px;
}
.section7 .filter_sec .filter {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}
.section7 .filter_sec .filter_block {
  display: flex;
  align-items: center;
  gap: 8px;
}
.section7 .filter_sec .filter_block a {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  color: #000000;
  font-size: 14px;
  font-weight: 600;
}
.section7 .filter_sec .filter_block a:hover {
  color: #D4B55C;
}
.section7 .filter_sec .filter_block img {
  width: 20px;
  height: 20px;
  object-fit: contain;
}
.section7 .filter_sec .filter_block .p-relative {
  position: relative;
}
.section7 .filter_sec .filter_block .count {
  position: absolute;
  top: -6px;
  right: -6px;
  min-width: 18px;
  height: 18px;
  padding: 0 4px;
  font-size: 11px;
  font-weight: 700;
  color: #fff;
  background: #D4B55C;
  border-radius: 9px;
  display: flex;
  align-items: center;
  justify-content: center;
} */

/* Dynamic filter: trigger button, sort dropdown, filter panel */
.filter_sec .filter_trigger {
  background: none;
  border: none;
  padding: 0;
  cursor: pointer;
  font: inherit;
  color: inherit;
  display: inline-flex;
  align-items: center;
}
.filter_sec .filter_block--sort {
  position: relative;
}
.filter_sec .filter_sort_dropdown {
  position: relative;
}
.filter_sec .filter_sort_menu {
  position: absolute;
  top: 100%;
  left: 0;
  margin-top: 4px;
  min-width: 180px;
  background: #fff;
  border: 1px solid #e0e0e0;
  border-radius: 8px;
  box-shadow: 0 4px 12px rgba(0,0,0,0.12);
  z-index: 20;
  padding: 6px 0;
}
.filter_sec .filter_sort_menu[aria-hidden="true"] {
  display: none;
}
.filter_sec .filter_sort_option {
  display: block;
  padding: 10px 14px;
  color: #333;
  text-decoration: none;
  font-size: 14px;
}
.filter_sec .filter_sort_option:hover,
.filter_sec .filter_sort_option.active {
  background: #f5f5f5;
  color: #D4B55C;
}
/* Snitch-style filter panel: left drawer on desktop, bottom sheet on mobile */
.filter_sec .filter_panel {
  position: fixed;
  inset: 0;
  z-index: 1000;
  display: none;
  align-items: flex-end;
  justify-content: center;
  pointer-events: none;
}
.filter_sec .filter_panel[hidden] {
  display: none !important;
}
.filter_sec .filter_panel:not([hidden]) {
  display: flex;
  pointer-events: auto;
}
.filter_sec .filter_panel:not([hidden]) .filter_panel_backdrop {
  opacity: 1;
}
.filter_sec .filter_panel:not([hidden]) .filter_panel_content {
  transform: translateY(0);
}
@media (min-width: 768px) {
  .filter_sec .filter_panel {
    align-items: stretch;
    justify-content: flex-start;
  }
  .filter_sec .filter_panel:not([hidden]) .filter_panel_content {
    transform: translateX(0);
  }
  .filter_sec .filter_panel_content {
    max-width: 360px;
    width: 100%;
    max-height: none;
    height: 100%;
    border-radius: 0;
    transform: translateX(-100%);
    transition: transform 0.3s cubic-bezier(0.32, 0.72, 0, 1);
    box-shadow: 4px 0 24px rgba(0, 0, 0, 0.12);
  }
  .filter_sec .filter_panel_handle {
    display: none;
  }
}
.filter_sec .filter_panel_backdrop {
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.4);
  opacity: 0;
  transition: opacity 0.25s ease;
}
.filter_sec .filter_panel_content {
  position: relative;
  width: 100%;
  max-width: 100%;
  max-height: 85vh;
  background: #fff;
  border-radius: 20px 20px 0 0;
  /* padding: 0 0 calc(24px + env(safe-area-inset-bottom, 0)); */
  padding-bottom: 70px;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  box-shadow: 0 -8px 32px rgba(0, 0, 0, 0.2);
  transform: translateY(100%);
  transition: transform 0.3s cubic-bezier(0.32, 0.72, 0, 1);
}
.filter_sec .filter_panel_handle {
  width: 40px;
  height: 4px;
  background: #ddd;
  border-radius: 2px;
  margin: 10px auto 0;
  flex-shrink: 0;
}
.filter_sec .filter_panel_header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 16px 20px;
  border-bottom: 1px solid #eee;
  flex-shrink: 0;
}
.filter_sec .filter_panel_title {
  margin: 0;
  font-size: 18px;
  font-weight: 600;
  color: #1a1a1a;
  letter-spacing: 0.02em;
}
.filter_sec .filter_panel_close {
  width: 36px;
  height: 36px;
  background: transparent;
  border: none;
  border-radius: 50%;
  color: #666;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0;
  transition: background 0.2s ease, color 0.2s ease;
}
.filter_sec .filter_panel_close:hover {
  background: #f0f0f0;
  color: #1a1a1a;
}
.filter_sec .filter_panel_form {
  flex: 1;
  display: flex;
  flex-direction: column;
  min-height: 0;
}
.filter_sec .filter_panel_sections {
  flex: 1;
  overflow-y: auto;
  padding: 8px 20px 16px;
}
/* Snitch-style collapsible sections */
.filter_sec .filter_panel_section {
  border-bottom: 1px solid #eee;
  padding: 12px 0;
}
.filter_sec .filter_panel_section:last-child {
  border-bottom: none;
}
.filter_sec .filter_panel_section_title {
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: #666;
  list-style: none;
  cursor: pointer;
  padding: 4px 0;
  display: flex;
  align-items: center;
}
.filter_sec .filter_panel_section_title::-webkit-details-marker {
  display: none;
}
.filter_sec .filter_panel_section_title::after {
  content: "";
  margin-left: auto;
  width: 0;
  height: 0;
  border-left: 4px solid transparent;
  border-right: 4px solid transparent;
  border-top: 5px solid #999;
  transition: transform 0.2s ease;
}
.filter_sec .filter_panel_section[open] .filter_panel_section_title::after {
  transform: rotate(180deg);
}
.filter_sec .filter_panel_section_body {
  padding-top: 12px;
}
.filter_sec .filter_panel_field {
  margin-bottom: 14px;
}
.filter_sec .filter_panel_field:last-child {
  margin-bottom: 0;
}
.filter_sec .filter_panel_field label {
  display: block;
  font-size: 13px;
  font-weight: 500;
  margin-bottom: 6px;
  color: #333;
}
.filter_sec .visually-hidden {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  white-space: nowrap;
  border: 0;
}
.filter_sec .filter_panel_select,
.filter_sec .filter_panel_input {
  width: 100%;
  padding: 10px 12px;
  border: 1px solid #e0e0e0;
  border-radius: 6px;
  font-size: 14px;
  background: #fff;
  transition: border-color 0.2s ease;
}
.filter_sec .filter_panel_select:focus,
.filter_sec .filter_panel_input:focus {
  outline: none;
  border-color: #1a1a1a;
}
.filter_sec .filter_panel_row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
}
/* Snitch-style footer: Clear all + Apply */
.filter_sec .filter_panel_footer {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 16px 20px;
  border-top: 1px solid #eee;
  background: #fff;
  flex-shrink: 0;
}
.filter_sec .filter_panel_clear {
  font-size: 14px;
  font-weight: 500;
  color: #666;
  text-decoration: underline;
  padding: 12px 0;
  transition: color 0.2s ease;
}
.filter_sec .filter_panel_clear:hover {
  color: #1a1a1a;
}
.filter_sec .filter_panel_apply {
  flex: 1;
  margin: 0;
  padding: 14px 20px;
  background: #1a1a1a;
  color: #fff;
  border: none;
  border-radius: 6px;
  font-size: 14px;
  font-weight: 600;
  cursor: pointer;
  transition: background 0.2s ease;
}
.filter_sec .filter_panel_apply:hover {
  background: #333;
}

.section7 .just_launch {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 24px 12px;
  margin: 12px 0 0;
}
.section7 .just_launch_block--link {
  display: block;
  text-decoration: none;
  color: inherit;
}
.section7 .just_launch_block--link:hover {
  color: inherit;
}
.section7 .just_launch_block--link .just_launch_text .title:hover,
.section7 .just_launch_block--link .just_launch_text .descriptions:hover {
  color: #D4B55C;
}
.section7 .just_launch .just_launch_block .just_launch_img {
  position: relative;
}
.section7 .just_launch .just_launch_block .just_launch_img .product_wishlist_btn {
  position: absolute;
  top: 8px;
  right: 8px;
  z-index: 5;
  width: 36px;
  height: 36px;
  padding: 0;
  border: none;
  background: transparent;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: transform 0.2s ease;
}
.section7 .just_launch .just_launch_block .just_launch_img .product_wishlist_btn:hover {
  transform: scale(1.1);
}
.section7 .just_launch .just_launch_block .just_launch_img .product_wishlist_btn .product_wishlist_icon {
  width: 24px;
  height: 24px;
  color: #333;
  transition: fill 0.2s ease, color 0.2s ease;
}
.section7 .just_launch .just_launch_block .just_launch_img .product_wishlist_btn.active .product_wishlist_icon {
  fill: #e11d48;
  color: #e11d48;
}
.section7 .just_launch .just_launch_block .just_launch_img .product_list_colors {
  position: absolute;
  bottom: 36px;
  left: 0;
  right: 0;
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  padding: 6px 8px;
  justify-content: center;
  align-items: center;
  pointer-events: none;
}
.section7 .just_launch .just_launch_block .just_launch_img .product_list_colors .product_list_color_swatch {
  pointer-events: auto;
  width: 18px;
  height: 18px;
  border-radius: 50%;
  border: 2px solid rgba(255, 255, 255, 0.9);
  padding: 0;
  cursor: pointer;
  box-shadow: 0 0 0 1px rgba(0, 0, 0, 0.1);
  flex-shrink: 0;
}
.section7 .just_launch .just_launch_block .just_launch_img .product_list_color_swatch:hover,
.section7 .just_launch .just_launch_block .just_launch_img .product_list_color_swatch.active {
  border-color: #000;
  box-shadow: 0 0 0 2px #000;
}
.section7 .just_launch .just_launch_block .just_launch_img .rating {
  position: absolute;
  bottom: 10px;
  left: 10px;
  font-size: 14px;
  padding: 6px 10px;
  background-color: rgba(255, 255, 255, 0.75);
  color: #000000;
  border-radius: 5px;
  border: 1px solid #DBDBDB;
  -webkit-backdrop-filter: blur(10px);
  backdrop-filter: blur(10px);
  text-align: center;
  display: flex;
  align-items: center;
}
.section7 .just_launch .just_launch_block .just_launch_text .title {
  font-size: 14px;
  font-weight: 600;
  color: #000000;
  margin: 10px 0 5px;
  text-transform: uppercase;
}
.section7 .just_launch .just_launch_block .just_launch_text .descriptions {
  font-size: 12px;
  font-weight: 400;
  color: #000000;
  margin: 5px 0;
}
.section7 .just_launch .just_launch_block .just_launch_text .price {
  font-size: 14px;
  font-weight: bold;
}
.section7 .just_launch .just_launch_block .just_launch_text .price del {
  font-weight: 400;
  color: #525252;
  margin: 0 6px;
}

/* Product detail page */
.section7--detail {
  padding: 0 16px 80px;
}
.product_detail_top {
  margin-bottom: 16px;
}
.product_detail_top .back_link {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  color: #000000;
  font-size: 14px;
  font-weight: 600;
  text-decoration: none;
}
.product_detail_top .back_link:hover {
  color: #D4B55C;
}
.product_detail_main {
  display: grid;
  gap: 20px;
  margin-bottom: 32px;
}
.product_detail_img {
  width: 100%;
  border-radius: 8px;
  overflow: hidden;
  background: #f5f5f5;
}
.product_detail_img .img-responsive {
  width: 100%;
  height: auto;
  display: block;
}
.product_detail_info {
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.product_detail_title {
  font-size: 20px;
  font-weight: 700;
  color: #000000;
  margin: 0;
  line-height: 1.3;
}
.product_detail_category {
  font-size: 14px;
  color: #666;
}
.product_detail_rating {
  font-size: 14px;
  padding: 6px 10px;
  background-color: rgba(255, 255, 255, 0.75);
  color: #000000;
  border-radius: 5px;
  border: 1px solid #DBDBDB;
  display: inline-flex;
  align-items: center;
  width: fit-content;
}
.product_detail_price {
  font-size: 18px;
  font-weight: 700;
  color: #000000;
}
.product_detail_price del {
  font-weight: 400;
  color: #525252;
  margin: 0 6px;
}
.product_detail_price .off_badge {
  color: #0a0;
  font-size: 14px;
  font-weight: 600;
}
.product_detail_desc {
  font-size: 14px;
  color: #333;
  line-height: 1.5;
}
.product_detail_actions {
  margin-top: 8px;
}
.btn_add_cart {
  display: inline-block;
  padding: 12px 24px;
  background: #D4B55C;
  color: #ffffff;
  font-size: 16px;
  font-weight: 700;
  text-decoration: none;
  border-radius: 8px;
  text-align: center;
  border: none;
  cursor: pointer;
}
.btn_add_cart:hover {
  background: #c4a54c;
  color: #ffffff;
}
.product_detail_related {
  margin-top: 32px;
  padding-top: 24px;
  border-top: 1px solid #eee;
}
.product_detail_related .heading--small {
  font-size: 18px;
  margin-bottom: 16px;
}
.product_detail_empty {
  text-align: center;
  padding: 40px 20px;
}
.product_detail_empty a {
  color: #D4B55C;
  font-weight: 600;
}

/* Product detail page - from reference ProductDetail (product_Details_page, colors, size, accordion, bottom button) */
.product_Details_page {
  margin-left: 10px;
  margin-right: 10px;
  margin-bottom: 50px;
}
.product_Details_page .product_Details .product_img {
  position: relative;
}
.product_Details_page .product_Details .product_img.product_img_gallery .product_gallery_main {
  position: relative;
  margin-bottom: 8px;
}
.product_Details_page .product_Details .product_img.product_img_gallery .product_gallery_main_link {
  display: block;
  line-height: 0;
}
.product_Details_page .product_Details .product_img.product_img_gallery .product_gallery_main_link img {
  width: 100%;
  height: auto;
  display: block;
}
.product_Details_page .product_Details .product_img.product_img_gallery .product-gallery-swiper {
  overflow: hidden;
}
.product_Details_page .product_Details .product_img.product_img_gallery .product-gallery-swiper .swiper-wrapper {
  align-items: flex-start;
}
.product_Details_page .product_Details .product_img.product_img_gallery .product-gallery-swiper .swiper-slide {
  height: auto;
}
.product_Details_page .product_Details .product_img.product_img_gallery .product-gallery-swiper .swiper-slide .product_gallery_main_link {
  display: block;
  line-height: 0;
}
.product_Details_page .product_Details .product_img.product_img_gallery .product-gallery-swiper .swiper-slide .product_gallery_main_link img {
  width: 100%;
  height: auto;
  display: block;
}
.product_Details_page .product_Details .product_img.product_img_gallery .product-gallery-swiper .product-gallery-pagination {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  height: 44px;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
}
.product_Details_page .product_Details .product_img.product_img_gallery .product-gallery-swiper .product-gallery-pagination .swiper-pagination-bullet {
  width: 6px;
  height: 6px;
  background: rgba(255, 255, 255, 0.979);
  opacity: 1;
  transition: width 0.2s ease, background 0.2s ease;
}
.product_Details_page .product_Details .product_img.product_img_gallery .product-gallery-swiper .product-gallery-pagination .swiper-pagination-bullet-active {
  width: 20px;
  border-radius: 3px;
  background: rgba(219, 218, 218, 0.75);
}
.product_Details_page .product_Details .product_img .product_gallery_thumbnails {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 8px;
}
.product_Details_page .product_Details .product_img .product_gallery_thumb {
  padding: 0;
  border: 2px solid transparent;
  border-radius: 6px;
  overflow: hidden;
  cursor: pointer;
  background: none;
  width: 56px;
  height: 56px;
  flex-shrink: 0;
}
.product_Details_page .product_Details .product_img .product_gallery_thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.product_Details_page .product_Details .product_img .product_gallery_thumb.active,
.product_Details_page .product_Details .product_img .product_gallery_thumb:hover {
  border-color: #000;
}
.product_Details_page .product_Details .product_img .rating {
  position: absolute;
  bottom: 10px;
  left: 10px;
  font-size: 12px;
  padding: 6px 10px;
  background-color: rgba(255, 255, 255, 0.75);
  color: #000000;
  border-radius: 5px;
  border: 1px solid #DBDBDB;
  -webkit-backdrop-filter: blur(10px);
  backdrop-filter: blur(10px);
  text-align: center;
  display: flex;
  align-items: center;
}
.product_Details_page .product_Details .product_text .title {
  font-size: 15px;
  font-weight: 600;
  color: #000000;
  margin: 10px 0 8px;
}
.product_Details_page .product_Details .product_text .descriptions {
  font-size: 12px;
  font-weight: 400;
  color: #000000;
  margin: 8px 0;
}
.product_Details_page .product_Details .product_text .price {
  font-size: 15px;
  font-weight: bold;
}
.product_Details_page .product_Details .product_text .price del {
  font-weight: 400;
  color: #525252;
  margin: 0 6px;
}
/* .product_Details_page .product_color {
  margin-top: 20px;
} */
.product_Details_page .product_color h1 {
  font-size: 15px;
  font-weight: 600;
  color: #000000;
  margin: 10px 0 10px;
}
.product_Details_page .product_color .product_color_block {
  align-items: center;
  display: flex;
  gap: 6px;
}
.product_Details_page .product_color .product_color_block input[type=radio] {
  display: none;
}
.product_Details_page .product_color .product_color_block label {
  position: relative;
  display: flex;
  align-items: center;
  margin-right: 10px;
  width: 50px;
  height: 85px;
  transition: all 250ms cubic-bezier(0.4, 0, 0.23, 1);
}
.product_Details_page .product_color .product_color_block label::after {
  position: absolute;
  width: 50px;
  height: 50px;
  background-color: transparent;
  border: 2px solid #000000;
  border-radius: 50%;
  top: 50%;
  left: -16px;
  transform: translateY(-50%) scale(0);
  transition: transform 400ms ease;
}
.product_Details_page .product_color .product_color_block input[type=radio]:checked + label::after {
  transform: translateY(-50%) scale(0.55);
}

/* COLORS section: square thumbnails, centered (match reference image) */
/* .product_Details_page .product_color--snitch {
  margin-top: 24px;
  margin-bottom: 24px;
} */
.product_Details_page .product_color--snitch .product_color_title {
  font-size: 18px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.02em;
  text-align: center;
  /* margin: 0 0 16px; */
  color: #000;
  font-family: inherit;
}
.product_Details_page .product_color--snitch .product_color_block--images {
  display: flex;
  flex-wrap: wrap;
  gap: 5px;
  justify-content: center;
  align-items: center;
}
/* When more than 5 color images: horizontal smooth scroll */
.product_Details_page .product_color--snitch .product_color_block--images.product_color_block--scroll {
  flex-wrap: nowrap;
  justify-content: flex-start;
  overflow-x: auto;
  overflow-y: hidden;
  scroll-behavior: smooth;
  -webkit-overflow-scrolling: touch;
  padding-bottom: 4px;
}
.product_Details_page .product_color--snitch .product_color_block--scroll .color_option_image_wrap {
  flex-shrink: 0;
}
.product_Details_page .product_color--snitch .color_option_image_wrap {
  flex: 0 0 auto;
}
.product_Details_page .product_color--snitch .color_option_input {
  position: absolute;
  opacity: 0;
  pointer-events: none;
  width: 0;
  height: 0;
}
.product_Details_page .product_color--snitch .color_option_image_label {
  display: block;
  cursor: pointer;
  border: 2px solid transparent;
  border-radius: 4px;
  overflow: hidden;
  transition: border-color 0.2s ease, box-shadow 0.2s ease;
  background: #f5f5f5;
}
.product_Details_page .product_color--snitch .color_option_image_label:hover {
  border-color: #ccc;
}
.product_Details_page .product_color--snitch .color_option_input:checked + .color_option_image_label {
  box-shadow: 0 0 0 1px #000;
}
/* Square-cropped thumbnails, equal size and spacing */
.product_Details_page .product_color--snitch .color_option_image {
  display: block;
  width: 72px;
  height: 72px;
  object-fit: cover;
  vertical-align: top;
}
@media (min-width: 480px) {
  .product_Details_page .product_color--snitch .color_option_image {
    width: 88px;
    height: 88px;
  }
}
@media (min-width: 768px) {
  .product_Details_page .product_color--snitch .color_option_image {
    width: 100px;
    height: 100px;
  }
}

.product_Details_page .product_size {
  margin-top: 20px;
}
.product_Details_page .product_size .SIZE_CHART {
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.product_Details_page .product_size .SIZE_CHART h1 {
  font-size: 15px;
  font-weight: 600;
  color: #000000;
  margin: 10px 0 10px;
}
.product_Details_page .product_size .SIZE_CHART div a,
.product_Details_page .product_size .SIZE_CHART .size_chart_link {
  font-size: 14px;
  color: #000000;
  font-weight: 500;
  text-decoration: underline;
  background: none;
  border: none;
  padding: 0;
  cursor: pointer;
}
.product_Details_page .product_size .product_size_block {
  display: flex;
  align-items: center;
  gap: 16px;
}
.product_Details_page .product_size .product_size_block input[type=radio] {
  display: none;
}
.product_Details_page .product_size .product_size_block .size_radio label {
  font-size: 12px;
  border: 1px solid black;
  width: 30px;
  height: 30px;
  text-align: center;
  align-items: center;
  justify-content: center;
  display: flex;
}
.product_Details_page .product_size .product_size_block .size_radio input[type=radio]:checked + label {
  background-color: #000000;
  color: #ffffff;
}

/* Size Chart popup: simple view, minimal CSS, no inner scrollbar */
.size_chart_modal {
  position: fixed;
  inset: 0;
  z-index: 9999;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 12px;
  overflow: auto;
}
.size_chart_modal[hidden] {
  display: none;
}
.size_chart_modal_backdrop {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.4);
  cursor: pointer;
}
.size_chart_modal_content {
  position: relative;
  background: #fff;
  border: 1px solid #e0e0e0;
  max-width: 480px;
  width: 100%;
  padding: 16px 20px;
  margin: auto;
}
.size_chart_modal_close {
  position: absolute;
  top: 8px;
  right: 8px;
  width: 28px;
  height: 28px;
  border: none;
  background: transparent;
  font-size: 22px;
  line-height: 1;
  color: #333;
  cursor: pointer;
  padding: 0;
}
.size_chart_modal_close:hover {
  color: #000;
}
.size_chart_modal_content .size_chart_inline_header {
  margin-top: 0;
  margin-bottom: 10px;
  padding-right: 28px;
}
.size_chart_inline_header {
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.size_chart_inline_title {
  font-size: 14px;
  font-weight: 700;
  text-transform: uppercase;
  color: #000;
  margin: 0;
}
.size_chart_inline_title--right {
  text-align: right;
  font-size: 14px;
}
.size_chart_table_wrap {
  margin-bottom: 8px;
}
.size_chart_image_wrap {
  margin-bottom: 12px;
  text-align: center;
}
.size_chart_image_wrap .size_chart_image {
  max-width: 100%;
  height: auto;
  display: block;
  margin: 0 auto;
}
.size_chart_table--inline,
.size_chart_table {
  width: 100%;
  border-collapse: collapse;
  font-size: 13px;
  background: #fff;
}
.size_chart_table th,
.size_chart_table td {
  border: 1px solid #e0e0e0;
  padding: 6px 8px;
  text-align: center;
  color: #000;
}
.size_chart_table th {
  font-weight: 700;
  text-transform: uppercase;
}
.size_chart_table th:first-child {
  background: #fff;
}
.size_chart_note {
  font-size: 11px;
  color: #555;
  margin: 0;
}
.size_chart_how_content {
  font-size: 13px;
  line-height: 1.5;
  color: #333;
  margin: 0;
}
.size_chart_empty {
  color: #666;
  font-size: 13px;
  margin: 0;
}

.product_Details_Offers {
  margin-bottom: 20px;
}
.product_Details_Offers .accordion {
  display: flex;
  flex-direction: column;
  margin: 10px auto;
}
.product_Details_Offers .accordion .accordion-item {
  margin-top: 16px;
  border-radius: 6px;
  background: #ffffff;
}
.product_Details_Offers .accordion .accordion-item label {
  position: relative;
  margin: 0;
  display: flex;
  width: 100%;
  font-size: 15px;
  cursor: pointer;
  justify-content: space-between;
  flex-direction: row-reverse;
  box-sizing: border-box;
  align-items: center;
}
.product_Details_Offers .accordion .accordion-item label .icon {
  border: 1px solid;
  border-radius: 100%;
  width: 22px;
  height: 22px;
  line-height: 14px;
  text-align: center;
  align-items: center;
  display: flex;
  justify-content: center;
  margin-left: 14px;
}
.product_Details_Offers .accordion .accordion-item .accordion-item-desc {
  display: none;
  font-size: 12px;
  line-height: 22px;
  font-weight: 300;
  color: #525252;
  padding: 10px 0 0;
  box-sizing: border-box;
}
.product_Details_Offers .accordion .accordion-item input[type=checkbox] {
  position: absolute;
  height: 0;
  width: 0;
  opacity: 0;
}
.product_Details_Offers .accordion .accordion-item input[type=checkbox]:checked ~ .accordion-item-desc {
  display: block;
}
.product_Details_Offers .accordion .accordion-item input[type=checkbox]:checked ~ label .icon:after {
  content: "-";
  font-size: 20px;
  margin-bottom: 3px;
}
.product_Details_Offers .accordion .accordion-item input[type=checkbox] ~ label .icon:after {
  content: "+";
  font-size: 20px;
}
.product_Details_Offers .accordion .accordion-item input[type=checkbox]:first-child {
  margin-top: 0;
}
.bottom_button {
  background-color: #000000;
  width: 100%;
  display: flex;
  justify-content: center;
  padding: 14px;
  position: fixed;
  bottom: 48px;
  left: 0;
  right: 0;
  box-sizing: border-box;
  text-decoration: none;
  color: #ffffff;
  padding-bottom: 35px;
  /* z-index: 10; */
}

button.bottom_button {
  border: none;
  cursor: pointer;
  font-family: inherit;
  z-index: 2;
}
.bottom_button span {
  font-size: 14px;
  line-height: 17px;
  font-weight: 500;
}
.cart_add_form {
  margin: 0;
}
.cart_add_message {
  padding: 8px 0;
  font-size: 14px;
  color: #000000;
  text-align: center;
}
.you_may_also_like {
  display: grid;
  gap: 22px;
  margin: 12px 0 0;
}
.you_may_also_like.grid_columns_2 {
  grid-template-columns: 1fr 1fr;
}
.you_may_also_like .product_block .product_img {
  position: relative;
}
.you_may_also_like .product_block .product_img .rating {
  position: absolute;
  bottom: 10px;
  left: 10px;
  font-size: 12px;
  padding: 6px 10px;
  background-color: rgba(255, 255, 255, 0.75);
  color: #000000;
  border-radius: 5px;
  border: 1px solid #DBDBDB;
  -webkit-backdrop-filter: blur(10px);
  backdrop-filter: blur(10px);
  text-align: center;
  display: flex;
  align-items: center;
}
.you_may_also_like .product_block .product_text .title {
  font-size: 12px;
  font-weight: 600;
  color: #000000;
  margin: 10px 0 5px;
}
.you_may_also_like .product_block .product_text .descriptions {
  font-size: 10px;
  font-weight: 400;
  color: #000000;
  margin: 5px 0;
}
.you_may_also_like .product_block .product_text .price {
  font-size: 12px;
  font-weight: bold;
}
.you_may_also_like .product_block .product_text .price del {
  font-weight: 400;
  color: #525252;
  margin: 0 6px;
}

/* Cart page - from reference Cart.html / master.css */
.CartPage {
  margin-top: 16px;
  margin-bottom: 50px;
}
.CartPage .selection_card {
  display: grid;
  grid-template-columns: 3fr 9fr;
  gap: 10px;
  margin-top: 16px;
  margin-bottom: 20px;
  padding-bottom: 20px;
  border-bottom: 1px solid #e0e0e0;
}
.CartPage .selection_card .product_text .title {
  font-size: 15px;
  line-height: 17px;
  font-weight: 600;
  color: #000000;
  margin-bottom: 8px;
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.CartPage .selection_card .product_text .descriptions {
  font-size: 13px;
  font-weight: 400;
  color: #000000;
  margin: 8px 0;
}
.CartPage .selection_card .product_text .price {
  font-size: 15px;
  font-weight: bold;
  margin: 8px 0;
}
.CartPage .selection_card .product_text .price del {
  font-weight: 400;
  color: #525252;
  margin: 0 8px;
}
.CartPage .selection_card .product_text .size_delete {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin: 8px 0 0;
}
.CartPage .selection_card .product_text .size_delete .d-flex {
  display: flex;
  align-items: center;
  gap: 6px;
}
.CartPage .selection_card .product_text .color_radio {
  position: relative;
  display: inline-block;
  width: 18px;
  height: 18px;
  border-radius: 50%;
  flex-shrink: 0;
}
.CartPage .Apply_CouponCode {
  margin-bottom: 20px;
}
.CartPage .Apply_CouponCode .accordion .accordion-item {
  border-top: 1px solid #000000;
  border-bottom: 1px solid #000000;
  padding: 12px 0;
  border-radius: 0;
}
.CartPage .Apply_CouponCode .accordion .accordion-item label {
  position: relative;
  margin: 0;
  display: flex;
  width: 100%;
  font-size: 15px;
  cursor: pointer;
  justify-content: space-between;
  flex-direction: row-reverse;
  box-sizing: border-box;
  align-items: center;
}
.CartPage .Apply_CouponCode .accordion .accordion-item label .icon {
  border: 1px solid;
  border-radius: 100%;
  width: 22px;
  height: 22px;
  line-height: 14px;
  text-align: center;
  align-items: center;
  display: flex;
  justify-content: center;
  margin-left: 14px;
}
.CartPage .Apply_CouponCode .accordion .accordion-item .accordion-item-desc {
  display: none;
  font-size: 12px;
  line-height: 22px;
  font-weight: 300;
  color: #525252;
  padding: 10px 0 0;
  box-sizing: border-box;
}
.CartPage .Apply_CouponCode .accordion .accordion-item input[type=checkbox] {
  position: absolute;
  height: 0;
  width: 0;
  opacity: 0;
}
.CartPage .Apply_CouponCode .accordion .accordion-item input[type=checkbox]:checked ~ .accordion-item-desc {
  display: block;
}
.CartPage .Apply_CouponCode .accordion .accordion-item input[type=checkbox]:checked ~ label .icon:after {
  content: "-";
  font-size: 20px;
  margin-bottom: 3px;
}
.CartPage .Apply_CouponCode .accordion .accordion-item input[type=checkbox] ~ label .icon:after {
  content: "+";
  font-size: 20px;
}

.CartPage .cart_delivering_to {
  margin-bottom: 20px;
  padding: 14px 0;
  border-top: 1px solid #E4E4E4;
  border-bottom: 1px solid #E4E4E4;
}
.CartPage .cart_delivering_to_header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 8px;
}
.CartPage .cart_delivering_to_title {
  font-size: 14px;
  font-weight: 600;
  color: #000;
}
.CartPage .cart_delivering_to_change {
  font-size: 14px;
  font-weight: 600;
  color: #000;
  text-decoration: underline;
}
.CartPage .cart_delivering_to_change:hover {
  color: #333;
}
.CartPage .cart_delivering_to_address {
  font-size: 13px;
  color: #444;
  margin: 0;
  line-height: 1.4;
}
.CartPage .cart_delivering_to_address--empty {
  color: #888;
}
.CartPage .heading h1 {
  font-size: 15px;
  font-weight: 600;
  color: #000000;
  margin: 16px 0 10px;
}
.CartPage .product_filter_button {
  display: flex;
  gap: 12px;
  overflow-x: auto;
  margin: 10px 0;
}
.CartPage .product_filter_button .btn {
  margin: 20px 0;
}
.CartPage .product_filter_button .btn a {
  font-size: 14px;
  padding: 10px 20px;
  border: 1px solid #000000;
  color: #000000;
  cursor: pointer;
  white-space: nowrap;
  text-decoration: none;
}
.CartPage .product_filter_button .btn a:hover {
  background: #000;
  color: #fff;
}
.CartPage .looks_scrol {
  overflow-x: scroll;
  margin: 20px 0 30px;
}
.CartPage .looks_scrol .looks_completewith {
  display: inline-flex;
  gap: 12px;
}
.CartPage .looks_scrol .looks_completewith .looks_block {
  position: relative;
  width: 200px;
  min-width: 200px;
  display: grid;
  gap: 12px;
}
.CartPage .looks_scrol .looks_completewith .looks_block .looks_img {
  position: relative;
}
.CartPage .looks_scrol .looks_completewith .looks_block .looks_plus {
  position: absolute;
  top: 6px;
  right: 6px;
}
.CartPage .looks_scrol .looks_completewith .looks_block .looks_plus img {
  width: 24px;
  height: 24px;
}
.CartPage .looks_scrol .looks_completewith .looks_text .title {
  font-size: 15px;
  line-height: 17px;
  font-weight: 600;
  color: #000000;
  margin-bottom: 8px;
}
.CartPage .looks_scrol .looks_completewith .looks_text .descriptions {
  font-size: 13px;
  font-weight: 400;
  color: #000000;
  margin: 8px 0;
}
.CartPage .looks_scrol .looks_completewith .looks_text .price {
  font-size: 15px;
  font-weight: bold;
  margin: 8px 0;
}
.CartPage .looks_scrol .looks_completewith .looks_text .price del {
  font-weight: 400;
  color: #525252;
  margin: 0 8px;
}

/* Wishlist page - from HeyMe Wishlist.html / master.css */
.Wishlist {
  margin-top: 10px;
}
.Wishlist .Wishlist_sec {
  margin-top: 20px;
}
.Wishlist .Wishlist_sec .selection_card {
  display: grid;
  grid-template-columns: 3fr 9fr;
  gap: 10px;
  margin-top: 16px;
  margin-bottom: 20px;
  padding-bottom: 20px;
  border-bottom: 1px solid;
}
.Wishlist .Wishlist_sec .selection_card .product_text .title {
  font-size: 15px;
  line-height: 20px;
  font-weight: 600;
  color: #000000;
  margin-bottom: 8px;
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.Wishlist .Wishlist_sec .selection_card .product_text .descriptions {
  font-size: 13px;
  line-height: 22px;
  font-weight: 400;
  color: #000000;
  margin: 8px 0;
}
.Wishlist .Wishlist_sec .selection_card .product_text .price {
  font-size: 15px;
  line-height: 23px;
  font-weight: bold;
  margin: 8px 0;
}
.Wishlist .Wishlist_sec .selection_card .product_text .price del {
  font-weight: 400;
  color: #525252;
  margin: 0 8px;
}
.Wishlist .Wishlist_sec .selection_card .product_text .size_delete {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin: 8px 0 0;
}
.Wishlist .Wishlist_sec .selection_card .product_text .size_delete a {
  color: #000000;
  text-decoration: underline;
}
.Wishlist .Wishlist_sec .selection_card .product_text .size_delete .link_btn {
  color: #000000;
  text-decoration: underline;
  background: none;
  border: none;
  padding: 0;
  cursor: pointer;
  font-size: 13px;
  font-family: inherit;
}
.Wishlist .Wishlist_sec .selection_card .product_text .size_delete .btn_trash {
  padding: 0;
  background: none;
  border: none;
  cursor: pointer;
  text-decoration: none;
}
.Wishlist .Wishlist_sec .selection_card .product_text .size_delete .btn_trash img {
  display: block;
}
/* My Orders page - from HeyMe Orders.html / master.css */
.myorders {
  margin-top: 10px;
}
.myorders .orders_sec {
  margin-top: 20px;
}
.myorders .orders_sec .selection_card {
  display: grid;
  grid-template-columns: 8fr 3fr;
  gap: 10px;
  align-items: end;
  padding-bottom: 20px;
  border-bottom: 1px solid #000000;
  margin-bottom: 20px;
}
.myorders .orders_sec .selection_card .product_text {
  display: grid;
  grid-template-columns: 5fr 0.5fr 6fr;
  gap: 4px 10px;
}
.myorders .orders_sec .selection_card .product_text .text_heding,
.myorders .orders_sec .selection_card .product_text .text_dot,
.myorders .orders_sec .selection_card .product_text .text_number {
  font-size: 14px;
  line-height: 25px;
  color: #000000;
  font-weight: 600;
}
.myorders .orders_sec .selection_card .product_text .text_number {
  font-weight: 400;
}
.myorders .orders_sec .selection_card .button {
  text-align: center;
  margin-top: 10px;
}
.myorders .orders_sec .selection_card .button .btn {
  font-size: 15px;
  font-weight: 500;
  background: #000000;
  border: 2px solid #000000;
  color: #ffffff;
  padding: 12px 35px;
  text-align: center;
  text-decoration: none;
  display: inline-block;
  cursor: pointer;
  border-radius: 6px;
}
.myorders .orders_sec .selection_card .button .btn:hover {
  background: #ffffff;
  color: #000000;
}

/* Order card - clean layout with product image + confirmation */
.order_card {
  padding-bottom: 24px;
  margin-bottom: 24px;
  border-bottom: 1px solid #e0e0e0;
}
.order_card:last-child {
  border-bottom: none;
}
.order_card_header {
  margin-bottom: 16px;
}
.order_card_row {
  display: block;
  font-size: 14px;
  line-height: 22px;
  color: #000;
}
.order_card_row .order_label {
  font-weight: 600;
}
.order_card_row .order_value {
  font-weight: 400;
}
.order_card_body {
  display: flex;
  gap: 16px;
  align-items: flex-start;
  margin-bottom: 16px;
}
.order_card_product_img {
  flex-shrink: 0;
  width: 100px;
  height: 130px;
  border-radius: 6px;
  overflow: hidden;
  background: #f5f5f5;
}
.order_card_product_img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.order_card_confirm {
  flex: 1;
}
.order_card_confirm_title {
  font-size: 15px;
  font-weight: 600;
  color: #000;
  margin: 0 0 6px 0;
}
.order_card_confirm_msg {
  font-size: 13px;
  color: #525252;
  line-height: 20px;
  margin: 0;
}
.order_card_footer {
  text-align: center;
}
.order_card_btn {
  display: inline-block;
  font-size: 14px;
  font-weight: 500;
  background: #000;
  border: 2px solid #000;
  color: #fff;
  padding: 10px 28px;
  text-decoration: none;
  border-radius: 6px;
  cursor: pointer;
}
.order_card_btn:hover {
  background: #fff;
  color: #000;
}
.orders_empty {
  text-align: center;
  padding: 40px 20px;
  color: #666;
}
.orders_empty p {
  margin: 0 0 12px 0;
  font-size: 15px;
}
.orders_empty_link {
  color: #D4B55C;
  font-weight: 600;
  text-decoration: none;
}

/* Profile page - from HeyMe Profile.html / master.css */
.Profile {
  margin-top: 10px;
}
.Profile .avatar-upload {
  position: relative;
  justify-content: center;
  display: flex;
  margin-top: 20px;
  margin-bottom: 30px;
}
.Profile .avatar-upload .avatar-edit {
  position: absolute;
  z-index: 1;
  top: 80px;
  right: 150px;
}
@media only screen and (min-width: 300px) and (max-width:692px) {
  .Profile .avatar-upload .avatar-edit {
    right: calc(50% - 55px - 20px);
  }
}
@media only screen and (min-width: 692px) and (max-width:990px) {
  .Profile .avatar-upload .avatar-edit {
    right: calc(50% - 55px - 30px);
  }
}
.Profile .avatar-upload .avatar-edit input {
  display: none;
}
.Profile .avatar-upload .avatar-edit input + label {
  width: 37px;
  height: 37px;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  margin-bottom: 0;
  border-radius: 100%;
  background: #FFFFFF;
  border: 1px solid #000000;
  box-shadow: 0px 2px 4px 0px rgba(0, 0, 0, 0.12);
  cursor: pointer;
  font-weight: normal;
  transition: all 0.2s ease-in-out;
}
.Profile .avatar-upload .avatar-preview {
  width: 110px;
  height: 110px;
  position: relative;
  border-radius: 100%;
  border: 1px solid #F8F8F8;
  box-shadow: 0px 2px 4px 0px rgba(0, 0, 0, 0.1);
}
.Profile .avatar-upload .avatar-preview > div {
  width: 100%;
  height: 100%;
  border-radius: 100%;
  background-size: cover;
  background-repeat: no-repeat;
  background-position: center;
}
.Profile .parsnel_details {
  font-size: 15px;
  line-height: 34px;
  font-weight: 600;
  margin-bottom: 30px;
}
.Profile .Preference .Custom_radio-button {
  list-style: none;
  margin-top: 16px;
}
.Profile .Preference .Custom_radio-button .mobile-submenu-item {
  margin-bottom: 10px;
}
.Profile .Preference .Custom_radio-button .mobile-submenu-item label {
  display: flex;
}
/* Profile Preference radios - master uses black for checked */
.Profile .Preference .Custom_radio-button input[type=radio] + span {
  background-color: #e6e6e6;
}
.Profile .Preference .Custom_radio-button input[type=radio]:checked + span {
  background-color: #000000;
  border-color: #000000;
}
.Profile .CheckoutStep .form label {
  font-size: 14px;
  font-weight: 500;
  color: #000000;
  margin-bottom: 8px;
  display: block;
}
.Profile .CheckoutStep .form > div {
  margin-bottom: 20px;
}

/* Checkout step 1 - from reference CheckoutStep1.html / master.css */
.CheckoutStep {
  margin: 10px 0 30px;
}
.CheckoutStep ::-webkit-input-placeholder {
  color: rgb(0, 0, 0) !important;
}
.CheckoutStep ::-moz-placeholder {
  color: rgb(0, 0, 0) !important;
}
.CheckoutStep :-ms-input-placeholder {
  color: rgb(0, 0, 0) !important;
}
.CheckoutStep :-moz-placeholder {
  color: rgb(0, 0, 0) !important;
}
.CheckoutStep #progress-bar {
  display: table;
  width: 100%;
  margin: 0;
  padding: 15px 0 0;
  table-layout: fixed;
  counter-reset: step;
}
.CheckoutStep #progress-bar li {
  list-style-type: none;
  display: table-cell;
  width: 33.33%;
  float: left;
  font-size: 12px;
  position: relative;
  text-align: center;
}
.CheckoutStep #progress-bar li:before {
  content: counter(step);
  width: 28px;
  height: 28px;
  color: #212121;
  counter-increment: step;
  line-height: 24px;
  font-size: 14px;
  border: 1px solid #D9D9D9;
  background-color: #fff;
  display: block;
  text-align: center;
  margin: 0 auto 14px auto;
  border-radius: 50%;
}
.CheckoutStep #progress-bar li:after {
  content: "";
  width: 100%;
  height: 2px;
  position: absolute;
  background-color: #D9D9D9;
  top: 14px;
  left: -50%;
  z-index: -1;
}
.CheckoutStep #progress-bar li:first-child:after {
  content: none;
}
.CheckoutStep #progress-bar li.done {
  color: #000000;
}
.CheckoutStep #progress-bar li.done:before {
  border-color: #000000;
  background-color: #000000;
  color: #fff;
}
.CheckoutStep #progress-bar li.done + li:after {
  background-color: #000000;
}
.CheckoutStep #progress-bar li.active {
  color: #000000;
}
.CheckoutStep #progress-bar li.active:before {
  border-color: #000000;
  color: #000000;
  font-weight: 700;
}
.CheckoutStep .form {
  margin: 30px 20px;
}
.CheckoutStep .form input {
  width: 100%;
  padding: 10px;
  margin-bottom: 20px;
  border-radius: 5px;
  color: #000000;
  border: 1.5px solid #E4E4E4;
  font-size: 14px;
  letter-spacing: 1px;
  outline: none;
  box-sizing: border-box;
}
.CheckoutStep .form input::-moz-placeholder {
  color: #000;
}
.CheckoutStep .form input::placeholder {
  color: #000;
}
.CheckoutStep .form input:focus {
  border-color: #000;
}
.CheckoutStep .form .menucheckbox {
  margin-top: 10px;
  margin-bottom: 20px;
  display: block;
}

/* Checkout step 3 - pay header and order summary */
.CheckoutStep .pay_header_row {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  margin-bottom: 12px;
  background: #fff;
}
.CheckoutStep .pay_back_btn {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  width: 48px;
  height: 48px;
  margin: -12px 0 0 -12px;
  color: #000;
  text-decoration: none;
}
.CheckoutStep .pay_back_btn:hover {
  color: #333;
}
.CheckoutStep .pay_back_icon {
  display: block;
  width: 24px;
  height: 24px;
  background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M19 12H5M12 19l-7-7 7-7'/%3E%3C/svg%3E") center/contain no-repeat;
}
.CheckoutStep .pay_header_content {
  flex: 1;
  min-width: 0;
}
.CheckoutStep .pay_title {
  font-size: 16px;
  font-weight: 600;
  color: #000;
  margin: 0 0 6px 0;
  line-height: 1.3;
}
.CheckoutStep .order_summary_list {
  margin: 0;
  padding: 0;
  list-style: none;
  font-size: 14px;
  color: #333;
  line-height: 1.5;
}
.CheckoutStep .order_summary_list li {
  position: relative;
  padding-left: 14px;
  margin-bottom: 2px;
}
.CheckoutStep .order_summary_list li::before {
  content: "•";
  position: absolute;
  left: 0;
  color: #000;
}
.CheckoutStep .pay_delivery_icon {
  flex-shrink: 0;
  width: 28px;
  height: 28px;
  margin-top: 2px;
  background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M5 18H3a2 2 0 01-2-2v-5a2 2 0 012-2h2m0 10h10a2 2 0 002-2v-5a2 2 0 00-2-2H5m0 10l3-3m-3 3l-3-3m3-3l3-3'/%3E%3C/svg%3E") center/contain no-repeat;
  color: #000;
}

/* Checkout step 3 - payment options */
.CheckoutStep .payment_options {
  margin: 30px 20px 20px;
}
.CheckoutStep .payment_option_row .payment_option_plus {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 24px;
  height: 24px;
  flex-shrink: 0;
  font-size: 18px;
  font-weight: 300;
  color: #000;
  line-height: 1;
}
.CheckoutStep .payment_option_row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  padding: 14px 16px;
  margin-bottom: 12px;
  border: 1.5px solid #E4E4E4;
  border-radius: 5px;
  background: #fff;
  font-size: 14px;
  font-weight: 600;
  color: #000000;
  letter-spacing: 0.5px;
  box-sizing: border-box;
}
.CheckoutStep .payment_option_row:last-child {
  margin-bottom: 0;
}

/* Expandable payment option (e.g. PAY VIA UPI) */
.CheckoutStep .payment_option_expandable {
  flex-direction: column;
  align-items: stretch;
  padding: 0;
  overflow: hidden;
}
.CheckoutStep .payment_option_expandable .payment_option_row_clickable {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  padding: 14px 16px;
  cursor: pointer;
  box-sizing: border-box;
}
.CheckoutStep .payment_option_expandable .payment_option_toggle {
  flex-shrink: 0;
  width: 24px;
  height: 24px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 20px;
  font-weight: 300;
  line-height: 1;
}
.CheckoutStep .payment_option_expandable .payment_option_toggle_minus {
  cursor: pointer;
}
.CheckoutStep .payment_option_expand_content {
  display: none;
  border-top: 1px solid #E4E4E4;
  padding: 0 16px 12px;
}
.CheckoutStep .payment_option_expandable.is_expanded .payment_option_expand_content {
  display: block;
}
.CheckoutStep .payment_option_expandable .payment_option_toggle_minus_top {
  display: none;
}
.CheckoutStep .payment_option_expandable.is_expanded .payment_option_toggle_plus {
  display: none;
}
.CheckoutStep .payment_option_expandable.is_expanded .payment_option_toggle_minus_top {
  display: flex;
}
.CheckoutStep .payment_option_expand_header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 12px 0 8px;
  font-size: 14px;
  font-weight: 600;
  color: #000;
  letter-spacing: 0.5px;
}
.CheckoutStep .payment_method_list {
  list-style: none;
  margin: 0;
  padding: 0;
  border-top: 1px solid #E4E4E4;
}
.CheckoutStep .payment_method_item {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 12px 0;
  font-size: 14px;
  font-weight: 500;
  color: #000;
  border-bottom: 1px solid #E4E4E4;
  cursor: pointer;
}
.CheckoutStep .payment_method_item:last-child {
  border-bottom: none;
}
.CheckoutStep .payment_method_logo {
  flex-shrink: 0;
  width: 36px;
  height: 36px;
  border-radius: 8px;
  background-size: contain;
  background-position: center;
  background-repeat: no-repeat;
}
.CheckoutStep .payment_method_logo_gpay {
  background-color: #fff;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='%234285F4' d='M12 2C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10S17.52 2 12 2zm-1 17.93c-3.95-.49-7-3.85-7-7.93 0-.62.08-1.21.21-1.79L9 15v1c0 1.1.9 2 2 2v1.93zm6.9-2.54c-.26-.81-1-1.39-1.9-1.39h-1v-3c0-.55-.45-1-1-1H8v-2h2c.55 0 1-.45 1-1V7h2c1.1 0 2-.9 2-2v-.41c2.93 1.19 5 4.06 5 7.41 0 2.08-.8 3.97-2.1 5.39z'/%3E%3C/svg%3E");
}
.CheckoutStep .payment_method_logo_phonepe {
  background-color: #5F259F;
  border-radius: 8px;
}
.CheckoutStep .payment_method_logo_paytm {
  background-color: #00BAF2;
  border-radius: 8px;
}
.CheckoutStep .payment_method_logo_upi {
  background: linear-gradient(135deg, #00A651 0%, #E4E4E4 100%);
  border-radius: 8px;
}

/* Credit / Debit card form inside expand */
.CheckoutStep .payment_card_form {
  padding: 12px 0 0;
  border-top: 1px solid #E4E4E4;
  background: #f5f5f5;
  margin: 0 -16px 0;
  padding: 16px 16px 20px;
}
.CheckoutStep .payment_card_form .payment_form_group {
  margin-bottom: 14px;
}
.CheckoutStep .payment_card_form .payment_form_group:last-of-type {
  margin-bottom: 0;
}
.CheckoutStep .payment_card_form label {
  display: block;
  font-size: 13px;
  font-weight: 500;
  color: #333;
  margin-bottom: 6px;
}
.CheckoutStep .payment_card_form input[type="text"] {
  width: 100%;
  padding: 12px 14px;
  border: 1px solid #E4E4E4;
  border-radius: 5px;
  background: #fff;
  font-size: 14px;
  color: #000;
  box-sizing: border-box;
}
.CheckoutStep .payment_card_form input[type="text"]::placeholder {
  color: #999;
}
.CheckoutStep .payment_card_form .payment_form_row {
  display: flex;
  gap: 12px;
  margin-bottom: 14px;
}
.CheckoutStep .payment_card_form .payment_form_row .payment_form_group {
  flex: 1;
  margin-bottom: 0;
}
.CheckoutStep .payment_form_checkbox {
  display: flex;
  align-items: center;
  gap: 10px;
  margin: 16px 0 20px;
  font-size: 14px;
  font-weight: 500;
  color: #000;
  cursor: pointer;
}
.CheckoutStep .payment_form_checkbox input[type="checkbox"] {
  width: 18px;
  height: 18px;
  accent-color: #000;
  cursor: pointer;
  flex-shrink: 0;
}
.CheckoutStep .payment_card_pay_btn {
  width: 100%;
  padding: 14px 20px;
  background: #000;
  color: #fff;
  border: none;
  border-radius: 5px;
  font-size: 16px;
  font-weight: 600;
  letter-spacing: 0.5px;
  cursor: pointer;
}
.CheckoutStep .payment_card_pay_btn:hover {
  background: #333;
}

/* Cash on Delivery expand content */
.CheckoutStep .payment_cod_message {
  margin: 12px 0 16px;
  font-size: 14px;
  font-weight: 500;
  color: #000;
  padding: 0;
  border-top: 1px solid #E4E4E4;
  padding-top: 12px;
}
.CheckoutStep .payment_cod_pay_btn {
  width: 100%;
  padding: 14px 20px;
  background: #b0b0b0;
  color: #fff;
  border: none;
  border-radius: 5px;
  font-size: 16px;
  font-weight: 600;
  letter-spacing: 0.5px;
  cursor: not-allowed;
}
.CheckoutStep .payment_cod_pay_btn:not(:disabled):hover {
  background: #333;
  cursor: pointer;
}

/* EMI expand content */
.CheckoutStep .payment_emi_option {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  padding: 12px 0 0;
  border-top: 1px solid #E4E4E4;
}
.CheckoutStep .payment_emi_logo {
  flex-shrink: 0;
  width: 48px;
  height: 48px;
  border: 1px solid #8dd0c4;
  border-radius: 6px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 11px;
  font-weight: 600;
  color: #2a9d8a;
  text-transform: lowercase;
}
.CheckoutStep .payment_emi_detail {
  flex: 1;
  min-width: 0;
}
.CheckoutStep .payment_emi_title {
  display: block;
  font-size: 14px;
  font-weight: 700;
  color: #000;
  margin: 0 0 4px 0;
}
.CheckoutStep .payment_emi_desc {
  font-size: 13px;
  font-weight: 400;
  color: #000;
  margin: 0;
  line-height: 1.4;
}

/* Netbanking expand content */
.CheckoutStep .payment_bank_logos {
  display: -webkit-inline-box;
  padding: 12px 0 0;
  border-top: 1px solid #E4E4E4;
}
.CheckoutStep .payment_bank_item {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 6px;
  cursor: pointer;
  min-width: 56px;
}
.CheckoutStep .payment_bank_logo {
  width: 48px;
  height: 48px;
  border-radius: 8px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 10px;
  font-weight: 700;
  color: #fff;
}
.CheckoutStep .payment_bank_hdfc { background: #c41e2a; }
.CheckoutStep .payment_bank_icici { background: #c41e2a; }
.CheckoutStep .payment_bank_sbi { background: #22419a; }
.CheckoutStep .payment_bank_axis { background: #c41e2a; }
.CheckoutStep .payment_bank_kotak { background: #22419a; }
.CheckoutStep .payment_bank_name {
  font-size: 11px;
  font-weight: 500;
  color: #555;
}
.CheckoutStep .payment_bank_or {
  margin: 16px 0;
  text-align: center;
  font-size: 12px;
  font-weight: 600;
  color: #888;
  position: relative;
}
.CheckoutStep .payment_bank_or::before,
.CheckoutStep .payment_bank_or::after {
  content: "";
  position: absolute;
  top: 50%;
  width: 40%;
  height: 1px;
  background: #E4E4E4;
}
.CheckoutStep .payment_bank_or::before { left: 0; }
.CheckoutStep .payment_bank_or::after { right: 0; }
.CheckoutStep .payment_bank_search_wrap {
  position: relative;
}
.CheckoutStep .payment_bank_search {
  width: 100%;
  padding: 12px 40px 12px 14px;
  border: 1px solid #E4E4E4;
  border-radius: 5px;
  background: #fff;
  font-size: 14px;
  color: #000;
  box-sizing: border-box;
}
.CheckoutStep .payment_bank_search::placeholder {
  color: #999;
}
.CheckoutStep .payment_bank_search_icon {
  position: absolute;
  right: 12px;
  top: 50%;
  transform: translateY(-50%);
  width: 18px;
  height: 18px;
  background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23999' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Ccircle cx='11' cy='11' r='8'/%3E%3Cpath d='m21 21-4.35-4.35'/%3E%3C/svg%3E") center/contain no-repeat;
  pointer-events: none;
}

.CheckoutStep .payment_option_icon {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 28px;
  height: 28px;
  flex-shrink: 0;
}
.CheckoutStep .payment_option_icon img {
  width: 24px;
  height: 24px;
}

/* Thank you page - from reference ThankYou.html / master.css */
.CheckoutStep .thankyou_block .thankyou_img {
  text-align: center;
}
.CheckoutStep .thankyou_block .thankyou_img.text-center {
  text-align: center;
}
.CheckoutStep .thankyou_block .thankyou_img img {
  margin: 30px 0 40px;
  max-width: 100%;
  height: auto;
}
.CheckoutStep .thankyou_block .thankyou_img h1 {
  font-size: 20px;
  color: #000000;
  font-weight: 400;
  text-align: center;
}
.CheckoutStep .thankyou_block .thankyou_sms {
  margin: 50px 0 40px;
}
.CheckoutStep .thankyou_block .thankyou_sms h1 {
  font-size: 20px;
  color: #000000;
  font-weight: 400;
  text-align: center;
}
.CheckoutStep .thankyou_block .thankyou_sms .sms {
  margin-top: 30px;
}
.CheckoutStep .thankyou_block .thankyou_sms .sms p {
  font-size: 14px;
  color: #898989;
  line-height: 24px;
  font-weight: 400;
  text-align: center;
  margin: 4px 0;
}

/* Order Confirmed page - modern confirmation UI */
.thank-you-body .order_confirmed_block,
.order-confirm-body .order_confirmed_block {
  padding: 24px 0 40px;
  text-align: center;
}
.thank-you-body .order_confirmed_title,
.order-confirm-body .order_confirmed_title {
  font-size: 18px;
  font-weight: 700;
  color: #000;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  margin: 0 0 20px;
  font-family: "Lato", sans-serif;
}
.thank-you-body .order_confirmed_check,
.order-confirm-body .order_confirmed_check {
  width: 72px;
  height: 72px;
  margin: 0 auto 24px;
  border-radius: 50%;
  background: #22c55e;
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
}
.thank-you-body .order_confirmed_check svg,
.order-confirm-body .order_confirmed_check svg {
  width: 36px;
  height: 36px;
}
.thank-you-body .order_confirmed_card,
.order-confirm-body .order_confirmed_card {
  background: #fff;
  border-radius: 12px;
  padding: 20px;
  margin-bottom: 16px;
  text-align: left;
  box-shadow: 0 1px 4px rgba(0, 0, 0, 0.08);
  border: 1px solid #eee;
}
.thank-you-body .order_confirmed_status,
.order-confirm-body .order_confirmed_status {
  margin: 0 0 8px;
  font-size: 15px;
  color: #000;
}
.thank-you-body .order_confirmed_highlight,
.order-confirm-body .order_confirmed_highlight {
  color: #e65100;
  font-weight: 600;
}
.thank-you-body .order_confirmed_delivery,
.order-confirm-body .order_confirmed_delivery {
  margin: 0 0 8px;
  font-size: 15px;
  color: #000;
}
.thank-you-body .order_confirmed_date,
.order-confirm-body .order_confirmed_date {
  color: #22c55e;
  font-weight: 600;
}
.thank-you-body .order_confirmed_items,
.order-confirm-body .order_confirmed_items {
  margin: 0 0 12px;
  font-size: 15px;
  color: #000;
}
.thank-you-body .order_confirmed_thumbnail,
.order-confirm-body .order_confirmed_thumbnail {
  margin-top: 12px;
  width: 80px;
  height: 80px;
  border-radius: 8px;
  overflow: hidden;
  background: #f5f5f5;
}
.thank-you-body .order_confirmed_thumbnail img,
.order-confirm-body .order_confirmed_thumbnail img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.thank-you-body .order_confirmed_recommend,
.order-confirm-body .order_confirmed_recommend {
  text-align: center;
}
.thank-you-body .order_confirmed_recommend_q,
.order-confirm-body .order_confirmed_recommend_q {
  margin: 0 0 16px;
  font-size: 14px;
  color: #333;
  line-height: 1.4;
}
.thank-you-body .order_confirmed_stars,
.order-confirm-body .order_confirmed_stars {
  display: flex;
  justify-content: center;
  gap: 8px;
  flex-wrap: wrap;
}
.thank-you-body .order_confirmed_star,
.order-confirm-body .order_confirmed_star {
  padding: 4px;
  background: none;
  border: none;
  cursor: pointer;
  color: #d1d5db;
  transition: color 0.2s;
}
.thank-you-body .order_confirmed_star:hover,
.order-confirm-body .order_confirmed_star:hover,
.thank-you-body .order_confirmed_star.rated,
.order-confirm-body .order_confirmed_star.rated {
  color: #fbbf24;
}

/* Page back header - back circle + centered title (matches design reference) */
.page_back_header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  position: relative;
  padding: 12px 0 16px;
  margin-bottom: 8px;
  min-height: 52px;
}
.page_back_btn {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  flex-shrink: 0;
  color: #525252;  /* theme minor dark */
}
.page_back_spacer {
  width: 40px;
  height: 40px;
  flex-shrink: 0;
}
.page_back_btn:hover {
  color: #292D32;  /* darker on hover */
}
.page_back_icon {
  width: 28px;
  height: 28px;
  display: block;
  color: inherit;
}
.page_back_title {
  margin: 0;
  flex: 1;
  font-size: 16px;
  font-weight: 500;
  color: #000000;
  text-align: center;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  font-family: "Lato", sans-serif;
}

/* Dashboard - from HeyMe master.css */
.dashbord {
  margin-top: 10px;
}
.dashbord .dashbord_sec {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 20px 20px;
  margin-top: 20px;
}
.dashbord .dashbord_sec .box {
  min-height: 120px;
  padding: 24px 16px 16px;
  background-color: #EAEAEA;
  color: #000000;
  text-align: center;
}
.dashbord .dashbord_sec a.box {
  text-decoration: none;
  display: block;
}
.dashbord .dashbord_sec .box .icon {
  background-color: rgba(255, 255, 255, 0.6);
  width: 40px;
  height: 40px;
  border-radius: 100%;
  justify-content: center;
  align-items: center;
  display: flex;
  margin: 0px auto 16px;
}
.dashbord .dashbord_sec .box .icon.big {
  width: 40px;
  height: 40px;
  overflow: hidden;
}
.dashbord .dashbord_sec .box .icon.big .dashboard-profile-img {
  width: 100%;
  height: 100%;
  border-radius: 50%;
  object-fit: cover;
  display: block;
}
.dashbord .dashbord_sec .box.save_list {
  grid-row: span 2;
}
.dashbord .dashbord_sec .box.myprofile {
  grid-column: span 2;
}

/* Rider dashboard sidebar menu */
.rider_dash_menu {
  background: #f5f5f5;
  border-radius: 8px;
  padding: 20px 0;
  margin-top: 16px;
}
.rider_dash_menu_title {
  font-size: 16px;
  font-weight: 700;
  color: #1a1a1a;
  margin: 0 20px 12px;
  letter-spacing: 0.02em;
}
.rider_dash_menu_line {
  border: none;
  border-top: 2px solid #333;
  margin: 0 20px 16px;
}
.rider_dash_menu_list {
  list-style: none;
  margin: 0;
  padding: 0;
}
.rider_dash_menu_list li {
  margin: 0;
  border-bottom: 1px solid #e0e0e0;
}
.rider_dash_menu_list li:last-child {
  border-bottom: none;
}
.rider_dash_menu_item {
  display: block;
  padding: 14px 20px;
  color: #1a1a1a;
  text-decoration: none;
  font-size: 15px;
  font-weight: 500;
  transition: background 0.15s;
}
.rider_dash_menu_item:hover {
  background: #ebebeb;
}
.rider_dash_menu_item.active {
  background: #e0e0e0;
  font-weight: 600;
}
.rider_dash_menu_logout_form {
  margin: 0;
}
.rider_dash_menu_logout_btn {
  width: 100%;
  text-align: left;
  background: none;
  border: none;
  cursor: pointer;
  font: inherit;
  font-size: 15px;
  font-weight: 500;
  padding: 14px 20px;
  color: #1a1a1a;
}
.rider_dash_menu_logout_btn:hover {
  background: #ebebeb;
}
.rider_dash_status {
  padding: 12px 16px;
  margin-top: 12px;
  background: #e8f5e9;
  color: #2e7d32;
  border-radius: 6px;
  font-size: 14px;
}
.rider_dash_summary {
  margin-top: 20px;
  padding: 16px;
  background: #fafafa;
  border-radius: 8px;
  font-size: 14px;
  color: #333;
}
.rider_dash_summary a {
  color: #1565c0;
  text-decoration: none;
}
.rider_dash_summary a:hover {
  text-decoration: underline;
}

/* Rider reset password - card form (same app style) */
.rider_reset_page .rider_reset_card {
  background: #fff;
  border-radius: 8px;
  box-shadow: 0 2px 12px rgba(0, 0, 0, 0.08);
  margin-top: 16px;
  padding: 24px 20px 32px;
}
.rider_reset_page .rider_reset_card .form label {
  font-size: 14px;
  font-weight: 500;
  color: #000;
  margin-bottom: 8px;
  display: block;
}
.rider_reset_page .rider_reset_card .form > div {
  margin-bottom: 20px;
}
.rider_reset_page .rider_reset_card .form input {
  width: 100%;
  padding: 10px 12px;
  margin-bottom: 0;
  border-radius: 5px;
  color: #000;
  border: 1.5px solid #e4e4e4;
  font-size: 14px;
  box-sizing: border-box;
}
.rider_reset_page .rider_reset_card .form input:focus {
  border-color: #000;
  outline: none;
}
.rider_reset_page .rider_reset_card .form_error {
  color: #c62828;
  font-size: 12px;
  display: block;
  margin-top: 6px;
}
.rider_reset_page .rider_form_errors {
  list-style: none;
  margin: 0 0 16px;
  padding: 12px;
  background: #ffebee;
  color: #c62828;
  border-radius: 6px;
  font-size: 13px;
}
.rider_reset_page .rider_reset_btn {
  position: relative;
  bottom: auto;
  left: auto;
  right: auto;
  margin-top: 24px;
  border-radius: 5px;
}

/* Dashboard settings dropdown (Edit Address, etc.) */
.dashboard_settings_wrap {
  position: relative;
}
.dashboard_settings_details {
  display: block;
}
.dashboard_settings_details summary {
  list-style: none;
  cursor: pointer;
}
.dashboard_settings_details summary::-webkit-details-marker {
  display: none;
}
.dashboard_settings_dropdown {
  list-style: none;
  margin: 0;
  padding: 8px 0;
  background: #fff;
  border-radius: 8px;
  box-shadow: 0 4px 12px rgba(0, 0, 0, 0.12);
  border: 1px solid #eee;
  min-width: 180px;
  position: absolute;
  left: 0;
  top: 100%;
  margin-top: 4px;
  z-index: 10;
}
.dashboard_settings_dropdown li {
  margin: 0;
}
.dashboard_settings_dropdown a {
  display: block;
  padding: 12px 16px;
  color: #000;
  text-decoration: none;
  font-size: 14px;
  font-weight: 500;
}
.dashboard_settings_dropdown a:hover {
  background: #f5f5f5;
}

/* Settings page - address list with edit icon on right */
.settings_page .settings_sec {
  margin-top: 20px;
}
.settings_section_title {
  font-size: 15px;
  font-weight: 600;
  color: #000;
  margin: 0 0 16px;
}
.settings_address_card {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding: 16px;
  background: #fff;
  border: 1px solid #eee;
  border-radius: 10px;
  margin-bottom: 12px;
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.06);
}
.settings_address_text {
  flex: 1;
  min-width: 0;
}
.settings_address_line {
  margin: 0 0 4px 0;
  font-size: 14px;
  color: #333;
  line-height: 1.4;
}
.settings_address_line:last-of-type {
  margin-bottom: 0;
}
.settings_address_default {
  display: inline-block;
  margin-top: 6px;
  font-size: 12px;
  font-weight: 600;
  color: #22c55e;
}
.settings_address_edit {
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 44px;
  height: 44px;
  border-radius: 8px;
  color: #525252;
  transition: background 0.2s, color 0.2s;
}
.settings_address_edit:hover {
  background: #f0f0f0;
  color: #000;
}
.settings_empty {
  text-align: center;
  padding: 40px 20px;
  color: #666;
}
.settings_empty p {
  margin: 0 0 16px 0;
  font-size: 15px;
}
.settings_add_btn {
  display: inline-block;
  padding: 12px 24px;
  background: #000;
  color: #fff;
  font-size: 14px;
  font-weight: 600;
  text-decoration: none;
  border-radius: 8px;
}
.settings_add_btn:hover {
  background: #333;
  color: #fff;
}

/* Logout form - button styled like .box */
.dashbord_logout_form {
  display: contents;
}
.dashbord_logout_form .box.logout {
  width: 100%;
  min-height: 120px;
  padding: 24px 16px 16px;
  background-color: #EAEAEA;
  color: #000000;
  text-align: center;
  border: none;
  cursor: pointer;
  font-family: inherit;
  font-size: inherit;
}

.main {
  /* padding-top: 62px; space for fixed header (greeting + search bar height) */
  padding-bottom: 80px;
}
.main--checkout {
  padding-top: 12px;
}

.footer {
  position: fixed;
  bottom: 0;
  width: 100%;
  z-index: 999;
}
.footer .footer_nev {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr 1fr 1fr;
  text-align: center;
  align-items: center;
  background-color: rgba(255, 255, 255, 0.75);
  -webkit-backdrop-filter: blur(10px);
  backdrop-filter: blur(10px);
  padding: 11px 0;
}
.footer .footer_nev .footer_navbar a {
  display: block;
  opacity: 1;
}
.footer .footer_nev .footer_navbar a.active {
  display: block;
  opacity: 1;
}
.footer .footer_nev .footer_navbar .footer-profile-img {
  width: 24px;
  height: 24px;
  border-radius: 50%;
  object-fit: cover;
  margin: 0 auto;
  display: block;
}
.footer .footer_nev .footer_navbar.bird {
  margin-top: -22px;
}
.footer .footer_navbar_cart {
  position: relative;
}
.footer .footer_navbar_cart .count {
  position: absolute;
  left: calc(50% + 14px);
  top: -6px;
  transform: translateX(-50%);
  min-width: 18px;
  height: 18px;
  line-height: 18px;
  padding: 0 4px;
  font-size: 11px;
  font-weight: 600;
  background: #000;
  color: #fff;
  border-radius: 50%;
  text-align: center;
}

/* Footer categories listing */
.footer_navbar_categories {
  position: relative;
}
.footer_categories_dropdown {
  display: inline-block;
}
.footer_categories_trigger {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  list-style: none;
  padding: 0;
}
.footer_categories_trigger::-webkit-details-marker {
  display: none;
}
.footer_categories_trigger img {
  display: block;
}
.footer_categories_list {
  position: absolute;
  bottom: 100%;
  left: 50%;
  transform: translateX(-50%);
  margin: 0 0 8px 0;
  padding: 8px 0;
  min-width: 140px;
  max-height: 200px;
  overflow-y: auto;
  background: #fff;
  border-radius: 8px;
  box-shadow: 0 4px 12px rgba(0,0,0,0.15);
  list-style: none;
  z-index: 10;
}
.footer_categories_list li {
  margin: 0;
}
.footer_categories_list a {
  display: block;
  padding: 8px 16px;
  font-size: 13px;
  color: #000;
  text-decoration: none;
  white-space: nowrap;
}
.footer_categories_list a:hover {
  background: #f5f5f5;
}
.footer_categories_dropdown[open] .footer_categories_trigger img {
  opacity: 1;
}

/* Signup page - full-page UI (light blue, hummingbird logo, hero, frosted panel) */
.Signup_page {
  background-color: #7CC3D9;
  position: relative;
}
.Signup_page .Signup {
  position: relative;
  height: 100vh;
  overflow: hidden;
  display: flex;
  justify-content: center;
  align-items: center;
}
.Signup_page .logo {
  position: absolute;
  top: 30px;
}
.Signup_page .people {
  position: absolute;
  top: 15%;
  width: 100%;
  text-align: center;
  z-index: 1;
}
.Signup_page .card {
  position: relative;
  top: 15%;
  z-index: 2;
  width: 320px;
  padding: 30px;
  border-radius: 12px;
  background: rgba(255, 255, 255, 0.5);
  border: 1px solid #DBDBDB;
  -webkit-backdrop-filter: blur(10px);
          backdrop-filter: blur(10px);
  box-shadow: 0 10px 30px rgba(0, 0, 0, 0.15);
}
.Signup_page .card h2 {
  font-size: 15px;
  font-weight: bold;
  color: #000000;
  text-align: center;
  margin-bottom: 20px;
}
.Signup_page .card label {
  font-size: 12px;
  margin-top: 12px;
  display: block;
}
.Signup_page .card input {
  width: 100%;
  padding: 10px;
  margin-top: 6px;
  border-radius: 6px;
  border: none;
  outline: none;
}
.Signup_page .card button {
  width: 100%;
  margin-top: 20px;
  padding: 12px;
  background: #000000;
  color: #ffffff;
  border: none;
  border-radius: 8px;
  cursor: pointer;
}
.Signup_page .card button:hover {
  opacity: 0.9;
}
.Signup_page .skip {
  position: absolute;
  bottom: 30px;
  text-decoration: underline;
  color: #000000;
  font-weight: 500;
  z-index: 2;
}

/* ----- Page skeleton loader (smooth loader on every page load) ----- */
.page-skeleton-loader {
  position: fixed;
  inset: 0;
  z-index: 9999;
  background: #f5f5f5;
  display: flex;
  align-items: stretch;
  justify-content: center;
  opacity: 1;
  visibility: visible;
  transition: opacity 0.35s ease-out, visibility 0.35s ease-out;
  pointer-events: none;
}

.page-skeleton-loader.page-skeleton-loader--hidden {
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
}

.page-skeleton-loader__inner {
  width: 100%;
  max-width: 1200px;
  padding: 16px;
  padding-top: 80px;
}

.page-skeleton-loader__bar {
  height: 24px;
  width: 60%;
  max-width: 280px;
  margin-bottom: 24px;
  border-radius: 8px;
  background: linear-gradient(
    90deg,
    #e8e8e8 0%,
    #e8e8e8 40%,
    #f0f0f0 50%,
    #e8e8e8 60%,
    #e8e8e8 100%
  );
  background-size: 200% 100%;
  animation: page-skeleton-shimmer 1.4s ease-in-out infinite;
}

.page-skeleton-loader__content {
  margin-top: 8px;
}

.page-skeleton-loader__block {
  height: 120px;
  border-radius: 12px;
  margin-bottom: 20px;
  background: linear-gradient(
    90deg,
    #e8e8e8 0%,
    #e8e8e8 40%,
    #f0f0f0 50%,
    #e8e8e8 60%,
    #e8e8e8 100%
  );
  background-size: 200% 100%;
  animation: page-skeleton-shimmer 1.4s ease-in-out infinite;
}

.page-skeleton-loader__block--wide {
  width: 100%;
}

.page-skeleton-loader__grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 16px;
}

@media (min-width: 692px) {
  .page-skeleton-loader__grid {
    grid-template-columns: repeat(3, 1fr);
  }
}

.page-skeleton-loader__card {
  border-radius: 12px;
  overflow: hidden;
}

.page-skeleton-loader__card-img {
  width: 100%;
  aspect-ratio: 3 / 4;
  background: linear-gradient(
    90deg,
    #e8e8e8 0%,
    #e8e8e8 40%,
    #f0f0f0 50%,
    #e8e8e8 60%,
    #e8e8e8 100%
  );
  background-size: 200% 100%;
  animation: page-skeleton-shimmer 1.4s ease-in-out infinite;
  animation-delay: 0.1s;
}

.page-skeleton-loader__card-line {
  height: 12px;
  margin-top: 10px;
  margin-left: 4px;
  border-radius: 6px;
  background: linear-gradient(
    90deg,
    #e8e8e8 0%,
    #e8e8e8 40%,
    #f0f0f0 50%,
    #e8e8e8 60%,
    #e8e8e8 100%
  );
  background-size: 200% 100%;
  animation: page-skeleton-shimmer 1.4s ease-in-out infinite;
  animation-delay: 0.2s;
}

.page-skeleton-loader__card-line--short {
  width: 50%;
  margin-top: 6px;
}

/* Page-specific skeleton variants */
.page-skeleton-loader__block--banner {
  height: 180px;
  margin-bottom: 16px;
  border-radius: 12px;
  background: linear-gradient(90deg, #e8e8e8 0%, #e8e8e8 40%, #f0f0f0 50%, #e8e8e8 60%, #e8e8e8 100%);
  background-size: 200% 100%;
  animation: page-skeleton-shimmer 1.4s ease-in-out infinite;
}

.page-skeleton-loader__bar--back {
  width: 40%;
  max-width: 160px;
  height: 20px;
  margin-bottom: 12px;
}

.page-skeleton-loader__bar--filter {
  width: 100%;
  height: 36px;
  margin-bottom: 16px;
  border-radius: 8px;
  background: linear-gradient(90deg, #e8e8e8 0%, #e8e8e8 40%, #f0f0f0 50%, #e8e8e8 60%, #e8e8e8 100%);
  background-size: 200% 100%;
  animation: page-skeleton-shimmer 1.4s ease-in-out infinite;
  animation-delay: 0.05s;
}

.page-skeleton-loader__detail {
  display: flex;
  flex-direction: column;
  gap: 16px;
  margin-top: 8px;
}

.page-skeleton-loader__detail-img {
  width: 100%;
  aspect-ratio: 3 / 4;
  border-radius: 12px;
  background: linear-gradient(90deg, #e8e8e8 0%, #e8e8e8 40%, #f0f0f0 50%, #e8e8e8 60%, #e8e8e8 100%);
  background-size: 200% 100%;
  animation: page-skeleton-shimmer 1.4s ease-in-out infinite;
}

.page-skeleton-loader__detail-info {
  margin-left: 4px;
}

.page-skeleton-loader__detail-info .page-skeleton-loader__card-line--title {
  width: 90%;
  height: 18px;
}

.page-skeleton-loader__detail-info .page-skeleton-loader__card-line--price {
  width: 40%;
  height: 16px;
  margin-top: 10px;
}

.page-skeleton-loader__row {
  display: flex;
  gap: 12px;
  margin-bottom: 16px;
  align-items: flex-start;
}

.page-skeleton-loader__row-img {
  width: 80px;
  min-width: 80px;
  height: 100px;
  border-radius: 8px;
  background: linear-gradient(90deg, #e8e8e8 0%, #e8e8e8 40%, #f0f0f0 50%, #e8e8e8 60%, #e8e8e8 100%);
  background-size: 200% 100%;
  animation: page-skeleton-shimmer 1.4s ease-in-out infinite;
}

.page-skeleton-loader__row-text {
  flex: 1;
  min-width: 0;
}

.page-skeleton-loader__row-text .page-skeleton-loader__card-line {
  margin-left: 0;
}

.page-skeleton-loader__avatar {
  width: 80px;
  height: 80px;
  border-radius: 50%;
  margin: 0 auto 20px;
  background: linear-gradient(90deg, #e8e8e8 0%, #e8e8e8 40%, #f0f0f0 50%, #e8e8e8 60%, #e8e8e8 100%);
  background-size: 200% 100%;
  animation: page-skeleton-shimmer 1.4s ease-in-out infinite;
}

.page-skeleton-loader__form .page-skeleton-loader__card-line {
  margin-left: 0;
  margin-bottom: 12px;
}

.page-skeleton-loader__form .page-skeleton-loader__card-line:last-child {
  width: 60%;
}

@keyframes page-skeleton-shimmer {
  0% {
    background-position: 200% 0;
  }
  100% {
    background-position: -200% 0;
  }
}

/* ----- Address / Save Address page (checkout step 2) - map same as reference image ----- */
.AddressPage {
  margin-top: 8px;
  margin-bottom: 100px;
  font-family: "Lato", sans-serif;
}

/* Map at top - always visible */
.address_map_container {
  position: relative;
  width: 100%;
  margin-bottom: 12px;
  border-radius: 8px;
  overflow: hidden;
  border: 2px solid #DADADA;
}
/* Header row: back arrow + Search for Delivery Area (same as reference UI) */
.address_header_row {
  display: flex;
  align-items: center;
  gap: 0;
  margin-bottom: 12px;
  background: #fff;
  border: 1px solid #000;
  border-radius: 8px;
  overflow: hidden;
  min-height: 48px;
}
.address_back_btn {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  width: 48px;
  height: 48px;
  color: #000;
  text-decoration: none;
  border-right: 1px solid #000;
}
.address_back_btn:hover {
  background: #f5f5f5;
  color: #000;
}
.address_back_icon {
  display: block;
  width: 24px;
  height: 24px;
  background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M19 12H5M12 19l-7-7 7-7'/%3E%3C/svg%3E") center/contain no-repeat;
}
.address_search_bar {
  display: flex;
  align-items: center;
  gap: 10px;
  flex: 1;
  min-width: 0;
  padding: 0 14px;
  background: #fff;
}
.address_search_icon {
  flex-shrink: 0;
  width: 20px;
  height: 20px;
  background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23525252' stroke-width='2'%3E%3Ccircle cx='11' cy='11' r='8'/%3E%3Cpath d='m21 21-4.35-4.35'/%3E%3C/svg%3E") center/contain no-repeat;
}
.address_search_input {
  flex: 1;
  min-width: 0;
  padding: 12px 0;
  font-size: 15px;
  font-family: "Lato", sans-serif;
  border: none;
  background: transparent;
  color: #000;
}
.address_search_input::placeholder {
  color: #757575;
}
.address_search_input:focus {
  outline: none;
}
.address_map {
  width: 100%;
  height: 220px;
  min-height: 220px;
  background: #e8e8e8;
}
.address_current_location_btn {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  width: 100%;
  padding: 12px 14px;
  margin-bottom: 16px;
  background: #fff;
  border: 2px solid #000;
  border-radius: 8px;
  font-size: 15px;
  font-weight: 500;
  font-family: "Lato", sans-serif;
  color: #000;
  cursor: pointer;
  transition: background 0.2s, color 0.2s;
}
.address_current_location_btn:hover {
  background: #000;
  color: #fff;
}
.address_current_location_btn:hover .address_current_location_icon {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='%23fff'%3E%3Cpath d='M12 2C8.13 2 5 5.13 5 9c0 5.25 7 13 7 13s7-7.75 7-13c0-3.87-3.13-7-7-7zm0 9.5c-1.38 0-2.5-1.12-2.5-2.5s1.12-2.5 2.5-2.5 2.5 1.12 2.5 2.5-1.12 2.5-2.5 2.5z'/%3E%3C/svg%3E");
}
.address_current_location_icon {
  flex-shrink: 0;
  width: 20px;
  height: 20px;
  background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='%23E65100'%3E%3Cpath d='M12 2C8.13 2 5 5.13 5 9c0 5.25 7 13 7 13s7-7.75 7-13c0-3.87-3.13-7-7-7zm0 9.5c-1.38 0-2.5-1.12-2.5-2.5s1.12-2.5 2.5-2.5 2.5 1.12 2.5 2.5-1.12 2.5-2.5 2.5z'/%3E%3C/svg%3E") center/contain no-repeat;
}
#address-map.leaflet-container {
  font-family: "Lato", sans-serif;
}

/* Resolved address line below map */
.address_resolved_block {
  display: none;
  margin-bottom: 10px;
  padding: 0 2px;
}
.address_resolved_text {
  display: flex;
  align-items: center;
  gap: 8px;
  margin: 0 0 6px;
  font-size: 14px;
  color: #000;
  font-family: "Lato", sans-serif;
}
.address_resolved_pin {
  flex-shrink: 0;
  width: 16px;
  height: 16px;
  background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='%23E65100'%3E%3Cpath d='M12 2C8.13 2 5 5.13 5 9c0 5.25 7 13 7 13s7-7.75 7-13c0-3.87-3.13-7-7-7zm0 9.5c-1.38 0-2.5-1.12-2.5-2.5s1.12-2.5 2.5-2.5 2.5 1.12 2.5 2.5-1.12 2.5-2.5 2.5z'/%3E%3C/svg%3E") center/contain no-repeat;
}
/* Prompt when location not yet set */
.address_location_prompt {
  margin-bottom: 16px;
  text-align: center;
}
.address_location_hint {
  margin: 0;
  font-size: 13px;
  color: #525252;
  font-family: "Lato", sans-serif;
}
.address_search_message {
  margin: 8px 0 16px;
  font-size: 13px;
  color: #525252;
  font-family: "Lato", sans-serif;
}
.address_search_message--error {
  color: #c62828;
}

/* Leaflet custom marker: orange teardrop (delivery) */
.address_map_icon_delivery {
  background: none !important;
  border: none !important;
}
.address_map_orange_pin {
  display: block;
  width: 36px;
  height: 44px;
  background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 36 44'%3E%3Cpath fill='%23FF9800' stroke='%23E65100' stroke-width='1' d='M18 0C8.06 0 0 8.06 0 18c0 9.94 18 26 18 26s18-16.06 18-26C36 8.06 27.94 0 18 0z'/%3E%3Ccircle cx='18' cy='18' r='6' fill='%23fff'/%3E%3C/svg%3E") center/contain no-repeat;
  filter: drop-shadow(0 2px 4px rgba(0,0,0,0.25));
}
.leaflet-draggable .address_map_orange_pin {
  cursor: move;
}

.address_form .address_label {
  display: block;
  font-size: 14px;
  font-weight: 600;
  color: #000;
  margin-top: 16px;
  margin-bottom: 8px;
}
.address_form .address_input {
  width: 100%;
  padding: 12px 14px;
  border: 2px solid #DADADA;
  border-radius: 8px;
  font-size: 15px;
  font-family: "Lato", sans-serif;
  box-sizing: border-box;
  background: #fff;
}
.address_form .address_input::placeholder {
  color: #999;
}
.address_form .address_input:focus {
  outline: none;
  border-color: #000;
}
.address_field_wrap {
  position: relative;
}
.address_field_wrap--count .address_input {
  padding-right: 56px;
}
.address_char_count {
  position: absolute;
  right: 14px;
  top: 50%;
  transform: translateY(-50%);
  font-size: 12px;
  color: #525252;
}
.address_phone_wrap {
  display: flex;
  align-items: stretch;
  border: 2px solid #DADADA;
  border-radius: 8px;
  overflow: hidden;
  background: #fff;
}
.address_phone_prefix {
  padding: 12px 14px;
  background: #f5f5f5;
  color: #000;
  font-size: 15px;
  font-weight: 500;
  border-right: 1px solid #DADADA;
}
.address_phone_wrap .address_input--phone {
  flex: 1;
  border: none;
  border-radius: 0;
  margin: 0;
  min-width: 0;
  box-shadow: none;
}
.address_phone_wrap .address_input--phone:focus {
  border-color: transparent;
  box-shadow: none;
}
.address_default_wrap {
  display: flex;
  align-items: center;
  margin-top: 18px;
  cursor: pointer;
}
.address_checkbox {
  width: 18px;
  height: 18px;
  margin: 0 10px 0 0;
  accent-color: #000;
}
.address_default_label {
  font-size: 14px;
  color: #000;
}
.address_save_btn {
  margin-top: 28px;
}
.address_error {
  display: block;
  font-size: 13px;
  color: #c62828;
  margin-top: 4px;
}
.address_error_toast {
  position: fixed;
  bottom: 100px;
  left: 50%;
  transform: translateX(-50%);
  padding: 12px 20px;
  background: #c62828;
  color: #fff;
  border-radius: 8px;
  font-size: 14px;
  z-index: 1000;
  max-width: 90%;
}

.order_detail_section { margin-bottom: 24px; }
.order_detail_heading { font-size: 14px; font-weight: 700; text-align: center; margin-bottom: 12px; letter-spacing: 0.02em; }
.order_detail_status_red { color: #c62828; font-weight: 700; }
.order_detail_card { background: #fff; border-radius: 8px; box-shadow: 0 1px 4px rgba(0,0,0,0.08); padding: 16px; margin-bottom: 16px; }
.order_detail_product_row { display: flex; gap: 16px; margin-bottom: 16px; }
.order_detail_product_img { width: 80px; height: 80px; flex-shrink: 0; border-radius: 6px; overflow: hidden; background: #f0f0f0; }
.order_detail_product_img img { width: 100%; height: 100%; object-fit: cover; }
.order_detail_product_info { flex: 1; min-width: 0; }
.order_detail_product_name { font-weight: 600; font-size: 14px; margin-bottom: 4px; }
.order_detail_product_meta { font-size: 13px; color: #555; margin-bottom: 2px; }
.order_detail_product_price { font-size: 14px; font-weight: 600; }
.order_detail_track_list { list-style: none; margin: 0; padding: 0; }
.order_detail_track_item { display: flex; align-items: flex-start; gap: 12px; margin-bottom: 16px; }
.order_detail_track_item:last-child { margin-bottom: 0; }
.order_detail_track_circle { width: 28px; height: 28px; border-radius: 50%; background: #000; color: #fff; font-size: 12px; font-weight: 700; display: flex; align-items: center; justify-content: center; flex-shrink: 0; }
.order_detail_track_circle.pending { background: #e0e0e0; color: #666; }
.order_detail_track_body { flex: 1; }
.order_detail_track_title { font-weight: 600; font-size: 14px; }
.order_detail_track_date { font-size: 12px; color: #666; margin-top: 2px; }
.order_detail_track_badge { font-size: 11px; color: #2e7d32; font-weight: 500; margin-top: 2px; }
.order_detail_price_row { display: flex; justify-content: space-between; padding: 8px 0; font-size: 14px; }
.order_detail_price_row.grand { font-weight: 700; font-size: 15px; padding-top: 12px; border-top: 1px solid #eee; }
.order_detail_address_block { font-size: 14px; line-height: 1.5; }
.order_detail_address_block .name { font-weight: 600; margin-bottom: 4px; }
.order_detail_actions { margin-top: 24px; }
.order_detail_actions .bottom_button { position: relative; bottom: auto; left: auto; right: auto; margin: 0; border-radius: 6px; }

/* ========== Product review section ========== */
.review_section_title { font-size: 18px; font-weight: 700; color: #000; letter-spacing: 0.02em; }
.review_form_group { margin-bottom: 20px; }
.review_form_label { display: block; font-weight: 700; font-size: 14px; color: #000; margin-bottom: 8px; }
.review_form_required { color: #c62828; }
.review_stars_wrap { text-align: center; margin-bottom: 20px; }
.review_stars { display: inline-flex; flex-direction: row-reverse; justify-content: center; gap: 6px; margin-bottom: 4px; align-items: center; }
.review_star_input { position: absolute; opacity: 0; pointer-events: none; }
.review_star_label { cursor: pointer; transition: color 0.15s ease; user-select: none; display: inline-block; color: #9e9e9e; }
.review_star_svg { width: 20px; height: 20px; display: block; }
.review_star_path { fill: none; stroke: currentColor; stroke-width: 1.5; stroke-linejoin: round; transition: fill 0.15s ease, stroke 0.15s ease; }
.review_star_label:hover { color: #000; }
.review_star_label:hover .review_star_path { fill: #000; stroke: #000; }
.review_star_input:checked ~ .review_star_label { color: #000; }
.review_star_input:checked ~ .review_star_label .review_star_path { fill: #000; stroke: #000; }
.review_stars:has(.review_star_input:checked) .review_star_label { color: #9e9e9e; }
.review_stars:has(.review_star_input:checked) .review_star_label .review_star_path { fill: none; stroke: #9e9e9e; }
.review_stars .review_star_input:checked ~ .review_star_label,
.review_stars .review_star_label:hover,
.review_stars .review_star_label:hover ~ .review_star_label { color: #000; }
.review_stars .review_star_input:checked ~ .review_star_label .review_star_path,
.review_stars .review_star_label:hover .review_star_path,
.review_stars .review_star_label:hover ~ .review_star_label .review_star_path { fill: #000; stroke: #000; }
.review_textarea { width: 100%; padding: 12px 14px; border: 1px solid #ddd; border-radius: 10px; font-size: 14px; font-family: inherit; resize: vertical; min-height: 100px; box-sizing: border-box; transition: border-color 0.2s; }
.review_textarea:focus { outline: none; border-color: #000; }
.review_char_count { display: block; font-size: 12px; color: #888; margin-top: 4px; text-align: right; }
.review_upload_zone { position: relative; border: 2px dashed #ccc; border-radius: 12px; padding: 24px; text-align: center; background: #fafafa; cursor: pointer; transition: border-color 0.2s, background 0.2s; }
.review_upload_zone:hover { border-color: #000; background: #f5f5f5; }
.review_upload_zone.review_upload_zone--has-files { border-color: #000; background: #f5f5f5; }
.review_file_input { position: absolute; inset: 0; width: 100%; height: 100%; opacity: 0; cursor: pointer; }
.review_upload_icon { display: block; font-size: 32px; margin-bottom: 8px; }
.review_upload_text { display: block; font-weight: 600; color: #333; font-size: 14px; }
.review_upload_hint { display: block; font-size: 12px; color: #888; margin-top: 4px; }
.review_preview_list { display: flex; flex-wrap: wrap; gap: 10px; margin-top: 12px; }
.review_preview_item { position: relative; width: 72px; height: 72px; border-radius: 10px; overflow: hidden; border: 1px solid #eee; }
.review_preview_item img { width: 100%; height: 100%; object-fit: cover; }
.review_preview_remove { position: absolute; top: 4px; right: 4px; width: 22px; height: 22px; border-radius: 50%; background: rgba(0,0,0,0.6); color: #fff; border: none; cursor: pointer; font-size: 14px; line-height: 1; padding: 0; display: flex; align-items: center; justify-content: center; }
.review_preview_remove:hover { background: #c62828; }
.review_submit_btn { padding: 12px 28px; background: #000; color: #fff; font-weight: 700; border: none; border-radius: 10px; cursor: pointer; font-size: 15px; letter-spacing: 0.02em; transition: opacity 0.2s, transform 0.1s; }
.review_submit_btn:hover { opacity: 0.9; color: #fff; }
.review_submit_btn:active { transform: scale(0.98); }