@import url('https://fonts.googleapis.com/css2?family=Roboto+Flex:opsz,wdth,wght@8..144,25..151,100..1000&display=swap');

body { font-family: "Roboto Flex", sans-serif; font-weight: 400; font-style: normal; font-size: 1.3rem; }
body strong { font-weight: 500; }
h1, h2, h3, h4, h5, h6 { font-weight: 600; }
.card { font-variation-settings: "wdth" 75; }
.card h5 { font-weight: 500; font-variation-settings: "wdth" 75; font-size: 1.5rem; }
.card i { font-size: 0.8rem; }
.card-body { padding: 15px; }
.sentiment-card .card-body.card-body-border { border-top: 1px solid rgba(0, 0, 0, 0.176); }
.sp-filter-badge { background: #726e6c; }

.tagify__dropdown { border: 1px solid rgba(0, 0, 0, 0.176); border-radius: 0 0 6px 6px; }
.tagify__dropdown__wrapper { border: 0px; }

.search-box ul.list-group { top: 36px; border-radius: 0 0 6px 6px; left: 89px; box-shadow: none !important; border-top: none;  border-bottom-left-radius: 6px !important; } 

#loading-overlay {
  position: fixed;
  inset: 0;
  z-index: 9999;
  background: white;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: opacity 0.3s ease;
}

.sp-icon-text { display: none; }
#loading-overlay.fade-out {
  opacity: 0;
  pointer-events: none;
}

@keyframes spin {
  to {
    transform: rotate(360deg);
  }
}
/* Override Choices.js input container */
.choices__inner {
  background-color: white !important;
  border-radius: 6px !important;
}

/* Style selected pill/tag items inside the field */
.choices__list--multiple .choices__item.choices__item--selectable {
  background-color: #666 !important; 
  color: #FFF !important;
  border-radius: 6px !important;
  border: none !important;
  padding: 3px 8px !important;
  font-weight: 500;
}
/* Remove blue outline on focus */
.choices__inner:focus,
.choices__inner:focus-visible {
  outline: none !important;
  box-shadow: none !important;
}
.choices__input {
  background-color: transparent !important;
}

/* Dropdown menu container */

.choices__list--dropdown {
  background-color: #fff !important; 
  border-radius: 6px !important;
  border: 1px solid rgb(183, 183, 183) !important;
  margin: 6px 0 !important;
}

/* Dropdown items */
.choices__list--dropdown .choices__item {
  color: #212529;
  padding: 6px 10px;
}


/* Highlighted (hovered or selected) item */
.choices__list--dropdown .choices__item--selectable.is-highlighted {
  background-color: #e9ecef !important; /* Bootstrap hover gray */
  color: #212529 !important;
}
.list-group-suggestions {}

ul.list-group.position-absolute.list-group-suggestions > li:first-child { border-top:0px; }

.payment-flow { max-width: 700px; text-align: center; border: 1px solid #e8e3e2; border-radius: 6px; padding: 30px; margin: 30px auto 30px auto; background-color: #fff !important; }
.payment-flow-summary { max-width: 400px; margin: 0 auto; text-align: left; }
.payment-flow img.logo { max-width: 400px; margin: 0 auto; }
.payment-flow table { font-size: 1rem; }
.payment-flow-discount { max-width: 200px; margin: 0 auto; }
.payment-flow-buttons { max-width: 500px; margin: 0 auto; }
@media (max-width: 767px) {
    .payment-flow {  margin: 15px !important; padding: 0px; }
    .payment-flow .container { padding: 20px 15px 0 15px !important; }
    .payment-flow { margin: 30px; }
    .payment-flow img.logo { width: 80%; }
}
footer { font-size: 0.8rem; font-weight: 200; }
footer a { color: #666;}

.sp-nav a { font-size: 1rem; font-variation-settings: "wdth" 75;  }

.search-box .input-group { padding: 0 15px; }
body.search-results { background-color: #8b8583; }
.sp-filter-header { position: sticky; top: 0; background: #716165; z-index: 99999999; }
.sp-btn-filter-close { color: #E7E6E6; font-size: 2rem; padding: 0px 10px 0 5px; border: none; height: 20px; margin-top: -30px; }
.sp-card-info { font-size: 1rem; font-weight: 300; }
.sp-card-info i { font-size: 1rem; color: rgb(131, 130, 130); }
.sp-block-size { font-variation-settings: "wdth" 150; border: 1px solid rgb(108, 117, 125); width: 1.5rem; }
.sp-card-toggles i { font-size: 1em; }
.sp-set-name, .sp-sku { border: 1px solid rgb(108, 117, 125); color: rgb(33, 37, 41); font-size: 1rem; margin-bottom: 5px; width: auto; font-weight: 500; padding: 2px 7px 0px 7px; font-variation-settings: "wdth" 25; }
.sp-card-header { font-size: 1rem; font-variation-settings: "wdth" 25; color: rgb(33, 37, 41, 0.5); padding: 10px 15px 6px 15px !important; line-height: 0.8rem; }
.sp-card-header a { text-decoration: none; color: rgb(33, 37, 41, 0.5); }
.sp-card-header a:hover {color: rgb(184, 92, 90); }
.sp-sku-header { font-size: 0.8rem;}

.sp-filter-bar-inner-2 { background: #bbb4b1; }

.form-check { padding-left: 1.5rem !important; }
.form-switch { padding-left: 0px !important; }
.form-switch  .form-check-input { margin-left: 0rem !important; }
.form-switch .form-check-label { margin-left: 3rem; }
.sp-email-login { color: #716165; }
input.choices__input { border: 0px !important; margin-bottom: 0px; }
input[type="text"], textarea { background: #fff !important; border: 1px solid rgb(221, 221, 221) !important; }
.input-group-text, .sp-search-btn { border: 1px solid rgb(221, 221, 221); }
.sp-search-btn { background: rgb(131, 130, 130); color:rgb(221, 221, 221); }

/* Make modal fill viewport minus 30px margin */
.modal.custom-scaled-modal .modal-dialog {
  margin: 30px auto;
  max-width: 1600px;
  width: calc(100vw - 60px);
  height: calc(100vh - 60px);
}

/* Expand modal content to full size */
.modal.custom-scaled-modal .modal-content {
  height: 100%;
  display: flex;
  flex-direction: column;
}

/* Make body center and fit the image */
.modal.custom-scaled-modal .modal-body {
  flex: 1;
  display: flex;
  justify-content: center;
  align-items: center;
  overflow: hidden;
  padding: 0;
}

/* Image scales to fit modal box */
.modal.custom-scaled-modal .modal-body img {
  max-width: 100%;
  max-height: 100%;
  width: auto;
  height: auto;
  object-fit: contain;
  display: block;
}

input[type="checkbox"]:checked, input[type="radio"]:checked { background-color:rgb(131, 130, 130); border-color:rgb(131, 130, 130); }

/* Sticky filter bar (all screen sizes) */
.sp-filter-bar {
  position: sticky;
  top: 0;
  z-index: 100;
  background: transparent;
  padding: 0px;
}
.sp-scope-right { display: none; padding: 10px; }
.sp-scope-left { display: block; }
.sp-scope-right .btn { width: 100%; }
.sp-scope-right .dropdown-menu.show { width: 100%; background:rgb(231, 230, 230); margin-top: -7px !important; border-color: rgb(231, 230, 230); }
.sp-scope-right .dropdown-menu .dropdown-item { text-align: center; }

.sp-filter-bar-inner-1 { background: #ac615c; }
.sp-filter-bar-inner-1 .nav-item a { padding: 5px 10px 3px 10px !important; }
.sp-filter-bar-inner-2 button { background: #fff; }
.sp-tab-active { background: #bbb4b1; border-radius: 6px 6px 0 0; }
.sp-scope-left ul.nav { font-variation-settings: "wdth" 100; font-weight: 700; text-transform: uppercase; letter-spacing: 1px; }
.sp-scope-left ul li a { color: #fcfbfb; }
.sp-scope-left ul li a:hover { color: #bbb4b1; }
.sp-filter-bar-inner-2 { padding: 7px; }
.sp-scope-left a.nav-link { padding: 0px 15px 5px 15px !important; margin-top: 8px; }
.sp-scope-left ul li a.sp-tab-active { color:  #fcfbfb; padding: 5px 15px 0px 15px !important; }
.sp-filter-bar-search .dropdown-toggle, .sp-filter-bar-inner-2 .dropdown-toggle { background: #dddad8; border: 1px solid #8b8583; color: #8b8583; padding: 6px 24px; }
.sp-filter-bar-search button, .sp-filter-bar-inner-2 button { font-weight: 600; }
.sp-filter-bar-search-filters .btn-outline-dark, .sp-filter-bar-inner-2 .btn-outline-dark { background-color: #8b8583; color:#dddad8; border-color: #8b8583; }
.sp-filter-bar-search .dropdown-toggle:focus, .sp-filter-bar-inner-2 .dropdown-toggle:focus, .sp-filter-bar-inner-2 .btn-outline-dark:focus { box-shadow: none; }
.sp-filter-bar-search .dropdown-menu { width: 100% !important; }
.sp-filter-bar-search .dropdown-menu, .sp-filter-bar-inner-2 .dropdown-menu { background-color:#dddad8; color: #8b8583; border: 1px solid #8b8583; }
.sp-filter-bar-search .dropdown-menu .form-check-input, .sp-filter-bar-inner-2 .dropdown-menu .form-check-input { border-color: #8b8583; }
.sp-filter-bar-search-heading {font-size: 1rem; font-variation-settings: "wdth" 70 !important; }
.sp-filter-bar-search-heading strong {font-variation-settings: "wdth" 90 !important; font-weight: 900; }
.sp-filter-bar-search-filters .dropdown-menu:first-of-type { min-width: 200px; max-width: 100%; }
.sp-filter-bar-search { padding: 8px 8px !important; }
@media (max-width: 997.98px) {
    .sp-filter-bar-search-heading { margin-bottom: 0px !important; }
    .sp-filter-bar-search-scope.dropdown button { width: 100% !important; }
    .sp-filter-bar-search-heading { justify-content: center; margin-bottom:10px; }
}
@media (max-width: 929.98px) {
    .sp-filter-bar-search-scope .dropdown-toggle, .sp-filter-bar-search-filters .dropdown-toggle { padding: 6px 12px !important; }
}
@media (max-width: 841.98px) {
    .sp-filter-bar-search-heading { width: 100%; 
    text-align: center; margin-bottom: 6px !important; }
    .sp-filter-bar-search-scope .dropdown-toggle, .sp-filter-bar-search-filters .dropdown-toggle { padding: 6px 24px !important; }
}
@media (max-width: 699.98px) {
      .sp-filter-bar-search-heading { width: 100%; 
    text-align: center; margin-bottom: 3px; }
  .sp-scope-left ul.nav li { font-variation-settings: "wdth" 60 !important; font-weight: 600; text-transform: uppercase;  }
    .sp-filter-bar-search .sp-filter-bar-search-scope {
    width: 100%;
    text-align: center;
        display: block; }
    .sp-filter-bar-search-scope { margin-right: 0px !important; margin-bottom: 6px; }
    .sp-filter-bar-search-filters { width: 100%; }
.sp-filter-bar-search-filters .btn-outline-dark {
  margin-left: auto;
}
}
@media (max-width: 616.98px) {
    .nav-link span { display: none; }
}
@media (max-width: 530px) {
    .sp-filter-bar-search {
    flex-direction: column;
  }
    .sp-filter-bar-search .filter-row {
    flex-direction: column;
  }
}
@media (max-width: 509.98px) {
    .sp-scope-left ul.nav { font-size: 1.1rem; font-weight: 600; text-transform: uppercase; }
  .sp-filter-bar-search button span, .sp-filter-bar button span { display: none; }
}
@media (max-width: 460px) {
    .sp-scope-left ul.nav { font-size: 0.9rem; font-weight: 600; text-transform: uppercase; }
.sp-filter-bar-search-filters .dropdown-toggle { padding: 6px 12px !important; }
.sp-filter-bar-inner-2 .dropdown-toggle { padding: 6px 12px !important; }
}
@media (max-width: 427.98px) {

}
@media (max-width: 415px) {
.sp-filter-bar-inner-2 .dropdown-toggle { font-variation-settings: "wdth" 50 !important; }
.sp-scope-left ul.nav li.nav-item a.nav-link { padding: 6px 10px !important; }
}
@media (max-width: 377px) {
.sp-filter-bar-inner-2 .dropdown-toggle { padding: 6px 10px !important; font-weight: 300; }
.sp-scope-left ul.nav { font-variation-settings: "wdth" 50 !important; font-weight: 300; font-size: 0.9rem; }
    .sp-filter-bar-search-filters .dropdown-toggle { padding: 6px 10px !important; font-variation-settings: "wdth" 40 !important; }
}

body.admin-page input[type="text"], body.admin-page select, body.admin-page textarea, body.admin-page .choices { font-family: monospace; font-size: 22px !important; color: #333; }

.sentiment-col {
  padding: 0.5rem;
}
#sentiment-grid {
  margin-left: -0.5rem;
  margin-right: -0.5rem;
}

img.sp-logo { width: 100%; height: auto; }

.pagination .page-item.disabled a, .pagination .page-item.disabled span { border: 1px solid #e3e0e1 !important; }
.pagination .page-item.active { font-weight: 800; }

a.sp-full-text.open-fulltext-modal { 
  color: rgb(131, 130, 130) !important; 
}
.sp-z-helper { 
  z-index: 2000 !important; 
}
.sp-filter-bar-search { 
  padding: 8px !important; 
}
button.sp-search-set { 
  border: 1px solid #8b8583 !important; 
  color: #8b8583 !important; 
  background-color: #c5c2c1 !important; 
}
ul.dropdown-menu.sp-search-set-menu { 
  border: 1px solid #8b8583 !important; 
  color: #8b8583 !important; 
}
.accordion-button:active, button.accordion-button:not(.collapsed) { 
  background-color: rgba(131,130,130,0.03); 
  color: rgb(106, 104, 105); 
}
button.accordion-button:focus { 
  box-shadow: 0 0 0.25rem rgba(131,130,130,0.25) !important; 
  border-color: rgba(131,130,130,0.25); 
}
.sp-matching-sets-grid a { 
  font-size: 1rem; 
  text-decoration: none; 
  color: rgb(131, 130, 130); 
}
.sp-matching-sets-grid a:hover { 
  text-decoration: underline; 
}
.sp-matching-sets-grid {
  columns: 2;
  column-gap: 2rem;
  max-height: 25vh;
  overflow-y: auto;
}
.accordion-item { 
  border-radius: 3px; 
}

@media (min-width: 768px) {
  .sp-matching-sets-grid {
    columns: 3;
  }
}
@media (min-width: 1200px) {
  .sp-matching-sets-grid {
    columns: 4;
  }
}
.sp-filter-bar-search-scope button.dropdown-toggle, .sp-filter-bar-search-scope ul.dropdown-menu.show { background-color: #fff; }

.sp-filter-bar-search {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
}
.sp-filter-bar-search .filter-row {
  display: flex;
  justify-content: center;
  align-items: center;
  flex-wrap: wrap;
}
.btn.btn-outline-primary.sp-cta-btn.btn-sm { padding: 0.2rem 1rem; border: 2px solid #c15b57; color: #c15b57; font-weight: 700; margin-left: 5px; }
.btn.btn-outline-primary.sp-cta-btn.btn-sm:hover { color: #fcfafa; } 
span.sp-cta-count { background-color:#c15b57!important; }
span.sp-cta-count:hover { background-color:#71403d!important; }
.sp-cart h2 { font-variation-settings: "wdth" 105 !important; font-weight: 800; }
.sp-cart .alert-dark strong { font-variation-settings: "wdth" 105 !important; font-weight: 800; text-transform: uppercase; }

.sp-cart p strong { font-variation-settings: "wdth" 105 !important; font-weight: 800; color: #ab343b; text-transform: uppercase; }

.sp-payment img { width: 12%; border: 1px solid #bdb4b1; border-radius: 6px; margin: 1px; }

.sp-home img { max-width: 95%; filter: drop-shadow(0 0 6px rgba(0,0,0,0.1)); background: none; }
.sp-home img.sp-logo { filter: none !important; max-width: 400px; }
.sp-home .sp-image-end, .sp-home .sp-image-start { min-height: 500px; }
.sp-home img.sp-home-img-scale { width: 66% !important; }
.sp-home h1 { font-size: 4rem; }
.sp-home h2 { font-size: 2rem; font-variation-settings: "wdth" 100; font-weight: 300; }
.sp-home h3 { font-weight: 800; }
.sp-home-cta { margin-top: 60px; }
.sp-home-cta h3 { font-size: 3rem; }
.sp-home-cta p span { font-weight: 800; }
.sp-home-cta p.lh-sm { font-size: 1rem; font-weight: 100; padding: 0 30px; }
.sp-checkout-alert { font-size: 0.8em; color: #919191; }
.sp-checkout-alert strong { font-weight: 800; }
.sp-pricing h2 { font-size: 4rem; line-height: 100%; font-weight: 700; }
.sp-pricing h3 { font-weight: 700; }
.sp-pricing h4 { font-size: 4.25rem; color: #b85c5a; font-weight: 700; font-variation-settings: "wdth" 105; }
.sp-pricing h4 span.sp-dollar { font-size: 3rem; padding-right: 3px; }
.sp-pricing h4 span.sp-unit { font-size: 0.9rem; color: #9b9999; font-weight: 500; }
.sp-pricing p.sp-small { font-size: 0.9rem; padding: 0 30px; line-height: 1rem; }
h2.sp-cart-sub { font-size: 3.3rem; font-weight: 700; line-height: 100%; }
.sp-app-login img.sp-logo { width: 90%; max-width: 400px; }
.sp-app-login .sp-app-login-btn { padding: 1rem 4rem; }
@media (max-width: 767px) {
    .sp-home img.sp-logo { width: 95%; max-width: 400px !important; }
    .sp-home img { margin-bottom: 30px; }
    .sp-home .col-md-6 h3, .sp-home .col-md-6 p { text-align: center !important; }
    .sp-home .sp-image-end, .sp-home .sp-image-start { min-height: 10px; border-bottom: 1px solid #ccc; padding-bottom: 30px; }
    .sp-home-cta h3 { font-size: 2.5rem; }
    .sp-home .col-md-6 { text-align: center !important; }
    .sp-home { padding: 0 30px; }
    .sp-pricing h2 { font-size: 3rem; }
    .sp-pricing h4 { font-size: 3.5rem; }
}
@media (max-width: 627.98px) {
    .sp-home h1 { font-size: 3rem; line-height: 98%; }
    .sp-home h2 { font-size: 1.9rem; }
    .sp-app-login .sp-app-login-btn { padding: 0.6rem 1.5rem; }
}
.sp-app-login-muted { width: 90%; max-width: 400px; margin: 0 auto; }
.sp-app-login-muted p { font-size: 0.8rem; color: #d2cecc; line-height: 1rem; }
.sp-app-login-muted a { color: #d2cecc; }
.sp-footer-text p { line-height: 120%; }
.sp-page-view img.sp-logo { width: 85%; max-width: 300px; }
.sp-page-view h1 { font-weight: 900; line-height: 100%; font-size: 3rem; }
.sp-page-view h1 span { display: block; width: 100%; font-size: 1.2rem; font-weight: 300; }
@keyframes pulse-glow {
  0% {
    box-shadow: 0 0 0.3rem 0.3rem rgba(184, 91, 90, 0.5);
  }
  50% {
    box-shadow: 0 0 0.6rem 0.6rem rgba(184, 91, 90, 0.85);
  }
  100% {
    box-shadow: 0 0 0.3rem 0.3rem rgba(184, 91, 90, 0.5);
  }
}

.glow-highlight {
  animation: pulse-glow 1.5s ease-in-out infinite;
  border: 2px solid #b85b5a !important;
  border-radius: 0.5rem;
}

.glow-highlight {
  box-shadow: 0 0 0.3rem 0.3rem rgba(184, 91, 90, 0.5) !important;
  transition: box-shadow 2s ease;
}
