/*
 * Custom code goes here.
 * A template should always ship with an empty custom.css
 */
 :root{
  --cj-dark: #2B0D0D;
  --cj-text: #2E2424;
  --cj-accent: #D9A7A3;
  --cj-accent-2: #E9C7C4;
  --cj-border: #FFDAD6;

  --color-accent: var(--cj-accent);
  --color-accent-light: var(--cj-accent-2);
  --color-accent-rgb: var(--bs-primary-rgb);

  --bs-primary: var(--cj-accent);
  --bs-primary-rgb: 217, 167, 163;
  --bs-link-color: var(--cj-accent);
  --bs-link-color-rgb: 217, 167, 163;
  --bs-link-hover-color: var(--cj-accent);
  --bs-link-hover-color-rgb: 217, 167, 163;

  --cj-grad: linear-gradient(
    to right,
    rgba(242, 187, 182, 0.5) 0%,
    rgba(242, 187, 182, 0.1) 50%,
    rgba(242, 187, 182, 0.5) 100%
  );
}

/* NSP CMS Sections: keep image/text section within page container width */
.nsp_cms_section.nsp_cms_section--image-text{
  width: 100%;
  margin-left: auto;
  margin-right: auto;
  padding-left: calc(var(--bs-gutter-x, 1.5rem) * .5);
  padding-right: calc(var(--bs-gutter-x, 1.5rem) * .5);
}
.nsp_cms_section.nsp_cms_section--has-bg{
  padding-top: 2rem;
  padding-bottom: 2rem;
  border-radius: 16px;
}
.nsp_cms_section.nsp_cms_section--image-text .nsp_cms_section__media{
  display: flex;
  justify-content: center;
}
.nsp_cms_section.nsp_cms_section--image-text .nsp_cms_section__media img{
  max-width: 800px;
  width: 100%;
  height: auto;
}
@media (min-width: 576px){
  .nsp_cms_section.nsp_cms_section--image-text{ max-width: 540px; }
}
@media (min-width: 768px){
  .nsp_cms_section.nsp_cms_section--image-text{ max-width: 720px; }
}
@media (min-width: 992px){
  .nsp_cms_section.nsp_cms_section--image-text{ max-width: 960px; }
}
@media (min-width: 1200px){
  .nsp_cms_section.nsp_cms_section--image-text{ max-width: 1140px; }
}
@media (min-width: 1400px){
  .nsp_cms_section.nsp_cms_section--image-text{ max-width: 1320px; }
}
/* Carousel */
.carousel .carousel-inner{
  height: 100%;
}

/* Wrapper / fond global */
#wrapper,
#content-wrapper,
main{
  background: var(--cj-grad);
}

/* Header (Hummingbird + fallback selectors Classic) */
#header .header-nav,
.header-nav{
  max-height: 50px;
  color: var(--cj-dark);
  border-bottom: var(--cj-border) 2px solid;
  background: var(--cj-grad);
}

/* Couleur des liens header + menu */
#header a:hover,
.header-top a:hover,
.header-bottom a:hover,
.header-nav a:hover{
  color: var(--cj-accent);
}

#header .top-menu a[data-depth="0"]:hover,
.header-nav .main-menu__tree__link:hover{
  color: var(--cj-accent) !important;
}

/* Liens globaux */



a:hover{
  color: var(--cj-accent);
  font-weight: bold !important;
}

/* Boutons (Bootstrap / PS) */
.btn-primary{
  --bs-btn-bg: var(--cj-accent);
  --bs-btn-border-color: var(--cj-accent);
  --bs-btn-hover-bg: var(--cj-accent);
  --bs-btn-hover-border-color: var(--cj-accent);
  --bs-btn-active-bg: var(--cj-accent);
  --bs-btn-active-border-color: var(--cj-accent);
  --bs-btn-disabled-bg: var(--cj-accent);
  --bs-btn-disabled-border-color: var(--cj-accent);
  background-color: var(--cj-accent) !important;
  border-color: var(--cj-accent) !important;
  color: var(--cj-text) !important;
  font-weight: bold;
}

.btn-outline-primary{
  --bs-btn-color: var(--cj-dark);
  --bs-btn-border-color: var(--cj-accent);
  --bs-btn-hover-bg: var(--cj-accent);
  --bs-btn-hover-border-color: var(--cj-accent);
  --bs-btn-active-bg: var(--cj-accent);
  --bs-btn-active-border-color: var(--cj-accent);

  color: var(--cj-accent) !important;
  border-color: var(--cj-accent) !important;
}

.btn-outline-primary:hover,
.btn-outline-primary:focus,
.btn-outline-primary:active{
  background-color: var(--cj-accent) !important;
  border-color: var(--cj-accent) !important;
  color: var(--cj-text) !important;
}

.btn-primary:hover,
.btn-primary:focus,
.btn-primary:active{
  background-color: var(--cj-accent) !important;
  border-color: var(--cj-accent) !important;
  color: var(--cj-text) !important;
  transform: scale(1.1);
}

.accordion-item{
  border-radius: 6px;
  overflow: hidden;
}

.accordion-button{
  padding: 10px;
}

.accordion-body{
  padding: 10px;
}

.category-tree__item-header {
    display: flex;
    padding: 10px;
}

span[style*="background-color"]{
  background-color: transparent !important;
}

.footer-container a{
  color: #fff !important;
}

/* Sections (images/vidéos) */
._section-block img,
._section-block video{
  height: 400px;
}

/* Flags produits */
li.product-flag.new{
  display: none;
}

/* Social */
.block-social ul li{
  background-color: var(--cj-accent);
}

.block-social ul li:hover{
  background-color: var(--cj-accent-2);
  transform: scale(1.1);
}

/* Prix */
.product-price{
  color: var(--cj-accent);
}

/* Thumbs produit (classique PS, ok sur Hummingbird aussi) */
.product-images > li.thumb-container .thumb.selected,
.product-images > li.thumb-container .thumb:hover{
  color: var(--cj-accent);
  transform: scale(1.1);
  border: var(--cj-accent) 3px solid;
}

/* Panier / cart preview (fallback Classic) */
#header .header-nav .cart-preview.active{
  background-color: var(--cj-text) !important;
}

#header .header-nav .cart-preview.active i:hover{
  color: var(--cj-accent);
  transform: scale(1.1);
}

/* Liens divers (footer, newsletter, compte, catégories...) */
.account-list a:hover,
.block_newsletter form button[type=submit]:hover,
.footer-container li a:hover{
  color: var(--cj-accent) !important;
}

.email_subscription.block_newsletter{
  background: var(--bs-tertiary-bg);
  padding: 1rem 0;
}

.email_subscription.block_newsletter > h4{
  max-width: 1320px;
  margin: 0 auto 0.5rem auto;
  padding: 0 0.75rem;
  font-size: 1.75rem;
  font-weight: 700;
}

.email_subscription.block_newsletter > form{
  max-width: 1320px;
  margin: 0 auto;
  padding: 0 0.75rem;
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  align-items: center;
}

.email_subscription.block_newsletter > form input[type="email"]{
  flex: 1 1 260px;
  min-width: 0;
  height: 38px;
  padding: 0.375rem 0.75rem;
  border-radius: var(--bs-border-radius);
  border: var(--bs-border-width) solid var(--bs-border-color);
}

.email_subscription.block_newsletter > form input[type="submit"]{
  flex: 0 0 auto;
  height: 38px;
  padding: 0.375rem 0.9rem;
  border-radius: var(--bs-border-radius);
  border: 1px solid transparent;
  background: var(--bs-primary);
  color: #fff;
}

.email_subscription.block_newsletter > form p{
  flex: 1 1 100%;
  margin: 0.25rem 0 0 0;
  font-size: 0.875rem;
  color: var(--bs-secondary-color);
}

#subcategories ul li .subcategory-name:hover,
.block-categories .arrows .arrow-down:hover,
.block-categories .arrows .arrow-right:hover,
.block-categories .collapse-icons .add:hover,
.block-categories .collapse-icons .remove:hover,
.cart-grid-body a.label:hover{
  color: var(--cj-accent) !important;
}

/* Tabs */
.tabs .nav-tabs .nav-link.active,
.tabs .nav-tabs .nav-link:hover{
  color: var(--cj-accent) !important;
  border: 0;
  border-bottom: var(--cj-accent) 2px solid;
}

/* Subcategories hover image */
#subcategories ul li:hover .subcategory-image a{
  padding: 5px;
  border: 3px solid var(--cj-accent);
}

/* Header contact info (ton masquage) */
/* Hummingbird n'utilise pas toujours .header-contact-info, donc je garde tes sélecteurs + une version plus large */
.header-contact-info .shop-phone,
.header-contact-info .shop-address{
  display: none;
}

.header-contact-info .shop-email{
  display: none;
}

.header-contact-info .contact-link{
  display: inline-block;
  color: #fff;
  font-weight: bold;
  text-decoration: none;
}

.header-contact-info .contact-link:hover{
  text-decoration: underline;
}

/* Variante Hummingbird: si infos dans header-top */
.header-top .shop-phone,
.header-top .shop-address{
  display: none !important;
}

#_desktop_ps_contactinfo .shop-phone,
#_desktop_ps_contactinfo .shop-email,
#_desktop_ps_contactinfo .shop-address{
  display: none !important;
}

#_desktop_ps_contactinfo .contact-link{
  display: inline-block !important;
}

/* Catégorie: description & bloc catégorie */
#category-description{
  display: none;
}

.block-category .block-category-inner{
  display: none;
}

.block-category{
  min-height: 1rem;
}

#subcategories ul li .subcategory-image{
  display: none;
}

/* Checkout hover (attention: il y avait un espace insécable dans ton CSS) */
body#checkout a:hover{
  color: var(--cj-accent) !important;
}

/* Modale panier */
#blockcart-modal .product-name{
  color: #8a5c59;
}

/* Promos */
ul.js-discount.card-block.promo-discounts{
  display: none;
}

p.block-promo.promo-highlighted{
  display: none;
}

/* Contact: n'afficher que l'email */
.contact-rich .block.email{
  display: flex !important;
}

.contact-rich .block:not(.email){
  display: none !important;
}

/* ==== Crowdfunding (NSP) ==== */
/* Progress bar */
.nsp_cf_progress,
.wk_cf_processbar { background: var(--color-white); border-radius: 20px; overflow: visible; box-shadow: 0 2px 8px rgba(0,0,0,0.08); margin: 1.5rem 0; }
.nsp_cf_progress__bar,
.wk_cf_processbar #container svg path:last-child { height: 24px; background: linear-gradient(90deg, var(--color-accent) 0%, var(--color-accent-light) 100%); border-radius: 20px; transition: width 0.6s ease; position: relative; overflow: hidden; }
.nsp_cf_progress__bar::after { content: ''; position: absolute; top: 0; left: 0; right: 0; bottom: 0; background: linear-gradient(90deg, transparent, rgba(255,255,255,0.3), transparent); animation: shimmer 2s infinite; }
@keyframes shimmer { 0% { transform: translateX(-100%); } 100% { transform: translateX(100%); } }
.nsp_cf_progress__text { font-weight: 600; font-size: 14px; color: var(--color-dark); margin-top: 0.5rem; text-align: center; }
.nsp_cf_progress__meta { display: flex; justify-content: space-between; align-items: center; margin-top: 0.75rem; font-size: 13px; color: var(--color-gray); }
.nsp_cf_progress__meta strong { color: var(--color-dark); font-weight: 600; }

.wk_cf_processbar #container { position: relative; height: 24px; overflow: visible; }
.wk_cf_processbar #container svg { display: block; width: 100%; height: 24px !important; }
.wk_cf_processbar #container svg path:first-child { stroke: rgba(0,0,0,0.08) !important; stroke-width: 2 !important; }
.wk_cf_processbar #container svg path:last-child { stroke: var(--color-accent) !important; stroke-width: 4 !important; }

.wk_cf_processbar #container .progressbar-text { position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%); z-index: 2; pointer-events: none; white-space: nowrap; }
.wk_cf_processbar .progressbar-text { display: inline-block !important; opacity: 1 !important; }

.wk_cf_target_tooltip { font-weight: 600; font-size: 14px; color: var(--color-dark); }
.wk_cf_process_details { font-weight: 600; font-size: 14px; color: var(--color-dark); margin-top: 0.75rem; }
.wk_cf_processbar .progressbar-text { font-weight: 700; }

.wk_cf_target_tooltip { display: none !important; }
.wk_cf_processbar #container .progressbar-text { top: auto; left: auto; bottom: 20px; right: 5px; transform: none; color: var(--color-accent) !important; font-weight: 900 !important; font-size: 18px !important; background: transparent !important; padding: 0 !important; }

/* Story blocks */
.nsp_cf_story_blocks { margin: 2rem 0; }
.nsp_cf_story_block { background: var(--color-white); border-radius: 12px; padding: 1.5rem; margin-bottom: 1.5rem; box-shadow: 0 4px 12px rgba(0,0,0,0.06); transition: transform 0.3s ease, box-shadow 0.3s ease; }
.nsp_cf_story_block:hover { transform: translateY(-4px); box-shadow: 0 8px 24px rgba(0,0,0,0.1); }
.nsp_cf_story_block__header { display: flex; align-items: flex-start; gap: 1rem; margin-bottom: 1rem; }
.nsp_cf_story_block__image { width: 80px; height: 80px; border-radius: 8px; object-fit: cover; flex-shrink: 0; }
.nsp_cf_story_block__inner { display: flex; align-items: center; gap: 1.5rem; }
.nsp_cf_story_block--reverse .nsp_cf_story_block__inner { flex-direction: row-reverse; }
.nsp_cf_story_block__media { flex-shrink: 0; }
.nsp_cf_story_block__media { flex: 0 0 42%; max-width: 42%; }
.nsp_cf_story_block__content { flex: 1 1 auto; }
.nsp_cf_story_block__media img { display: block; width: 100%; height: auto; max-height: 420px; object-fit: contain; border-radius: 12px; background: rgba(0,0,0,0.02); }
.nsp_cf_story_block__title { font-size: 1.25rem; font-weight: 600; color: var(--color-dark); margin: 0 0 0.5rem 0; line-height: 1.3; }
.nsp_cf_story_block__tagline { font-size: 1rem; color: var(--color-accent); font-weight: 500; margin: 0 0 1rem 0; line-height: 1.4; }
.nsp_cf_story_block__content { font-size: 0.95rem; color: var(--color-gray); line-height: 1.6; margin: 0; }
.nsp_cf_story_block__content p:last-child { margin-bottom: 0; }
.nsp_cf_story_block__read-more { display: inline-flex; align-items: center; gap: 0.5rem; margin-top: 1rem; color: var(--color-accent); font-weight: 500; text-decoration: none; transition: color 0.2s ease; cursor: pointer; }
.nsp_cf_story_block__read-more:hover { color: var(--color-accent-light); }
.nsp_cf_story_block__read-more .material-icons { font-size: 18px; }

/* News blocks */
.nsp_cf_news_blocks { margin: 2rem 0; display: flex; flex-wrap: wrap; gap: 1.5rem; }
.nsp_cf_news_block { background: var(--color-white); border-radius: 12px; padding: 1.5rem; margin-bottom: 1.5rem; box-shadow: 0 4px 12px rgba(0,0,0,0.06); transition: transform 0.3s ease, box-shadow 0.3s ease; }
.nsp_cf_news_block { flex: 1 1 calc(50% - 1.5rem); margin-bottom: 0; }
.nsp_cf_news_block:hover { transform: translateY(-4px); box-shadow: 0 8px 24px rgba(0,0,0,0.1); }
.nsp_cf_news_block__header { display: flex; align-items: flex-start; gap: 1rem; margin-bottom: 1rem; }
.nsp_cf_news_block__image { width: 80px; height: 80px; border-radius: 8px; object-fit: cover; flex-shrink: 0; }
.nsp_cf_news_block__media img { display: block; width: 100%; height: auto; max-height: 420px; object-fit: contain; border-radius: 12px; background: rgba(0,0,0,0.02); }
.nsp_cf_news_block__title { font-size: 1.25rem; font-weight: 600; color: var(--color-dark); margin: 0 0 0.5rem 0; line-height: 1.3; }
.nsp_cf_news_block__date { font-size: 0.85rem; color: var(--color-gray); margin: 0 0 1rem 0; }
.nsp_cf_news_block__content { font-size: 0.95rem; color: var(--color-gray); line-height: 1.6; margin: 0; }
.nsp_cf_news_block__content p:last-child { margin-bottom: 0; }
.nsp_cf_news_block__read-more { display: inline-flex; align-items: center; gap: 0.5rem; margin-top: 1rem; color: var(--color-accent); font-weight: 500; text-decoration: none; transition: color 0.2s ease; cursor: pointer; }
.nsp_cf_news_block__read-more:hover { color: var(--color-accent-light); }
.nsp_cf_news_block__read-more .material-icons { font-size: 18px; }

/* Rewards zone */
.nsp_cf_rewards_zone { display: grid; grid-template-columns: 1fr 2fr; gap: 2rem; margin: 2rem 0; }
.nsp_cf_reward_empty { background: var(--color-white); border: 2px dashed var(--color-gray); border-radius: 12px; padding: 3rem; text-align: center; color: var(--color-gray); }
.nsp_cf_reward_empty .material-icons { font-size: 48px; margin-bottom: 1rem; opacity: 0.4; }
.nsp_cf_reward_empty p { margin: 0; font-size: 1.1rem; }

.nsp_cf_rewards_zone { background: #fff; border-radius: 16px; padding: 1.5rem; box-shadow: 0 4px 12px rgba(0,0,0,0.06); }
.nsp_cf_rewards_zone__header { margin-bottom: 1rem; grid-column: 1 / -1; }
.nsp_cf_rewards_zone__title { font-size: 1.25rem; font-weight: 700; color: var(--color-dark); }
.nsp_cf_rewards_zone__subtitle { margin-top: 0.25rem; font-size: 0.95rem; color: var(--color-gray); }
.nsp_cf_rewards_zone__layout { display: grid; grid-template-columns: minmax(280px, 38%) 1fr; gap: 1.5rem; align-items: start; grid-column: 1 / -1; }

.nsp_cf_rewards_empty { border: 2px dashed rgba(0,0,0,0.18); border-radius: 12px; padding: 1.25rem; background: rgba(0,0,0,0.02); }
.nsp_cf_rewards_empty__media img { width: 100%; height: auto; max-height: 220px; object-fit: contain; border-radius: 10px; display: block; background: rgba(0,0,0,0.02); }
.nsp_cf_rewards_empty__title { margin-top: 0.75rem; font-size: 1.05rem; font-weight: 700; color: var(--color-dark); }
.nsp_cf_rewards_empty__text { margin-top: 0.5rem; color: var(--color-gray); }

.nsp_cf_reward_carousel { position: relative; }
.nsp_cf_reward_carousel__viewport { overflow: auto; padding-right: 0.25rem; scroll-behavior: smooth; }
.nsp_cf_reward_carousel__btn { width: 40px; height: 40px; border-radius: 50%; background: var(--color-accent); color: var(--color-white); border: none; cursor: pointer; box-shadow: 0 4px 12px rgba(var(--color-accent-rgb), 0.3); }
.nsp_cf_reward_carousel__btn:hover { background: var(--color-accent-light); }

.nsp_cf_reward_carousel__btn { position: sticky; top: 0; z-index: 3; }
.nsp_cf_reward_carousel__btn--down { top: auto; bottom: 0; }

.nsp_cf_reward_carousel__btn { font-size: 0; line-height: 0; }
.nsp_cf_reward_carousel__btn::before { content: ''; display: block; width: 18px; height: 18px; margin: 0 auto; background-repeat: no-repeat; background-position: center; background-size: 18px 18px; }
.nsp_cf_reward_carousel__btn--up::before { background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='%23FFFFFF' d='M7.41 14.59 12 10l4.59 4.59L18 13.17l-6-6-6 6z'/%3E%3C/svg%3E"); }
.nsp_cf_reward_carousel__btn--down::before { background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='%23FFFFFF' d='m7.41 8.41 4.59 4.59 4.59-4.59L18 9.83l-6 6-6-6z'/%3E%3C/svg%3E"); }

.nsp_cf_reward_tiers { display: block; }
.nsp_cf_reward_tier { height: auto; }
.nsp_cf_reward_tier.is-unlocked { opacity: 1; border-color: rgba(var(--color-accent-rgb), 0.35); box-shadow: 0 6px 18px rgba(var(--color-accent-rgb), 0.12); }
.nsp_cf_reward_tier.is-unlocked .nsp_cf_reward_tier__threshold { background: var(--color-accent); }
.nsp_cf_reward_tier.is-locked { background: rgba(0,0,0,0.01); }

.nsp_cf_reward_tier { background: var(--color-white); border: 1px solid rgba(0,0,0,0.08); border-radius: 12px; padding: 1rem; margin: 1rem; transition: transform 0.2s ease, box-shadow 0.2s ease; }
.nsp_cf_reward_tier { display: flex; align-items: flex-start; gap: 1rem; }
.nsp_cf_reward_tier:hover { transform: translateY(-2px); box-shadow: 0 8px 24px rgba(0,0,0,0.10); }
.nsp_cf_reward_tier { position: relative; }
.nsp_cf_reward_tier.is-locked { opacity: 0.65; }
.nsp_cf_reward_tier.is-locked::after { content: ''; position: absolute; top: 10px; right: 10px; width: 34px; height: 34px; border-radius: 999px; background: rgba(0,0,0,0.06); background-repeat: no-repeat; background-position: center; background-size: 18px 18px; background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='%23393939' d='M12 1a5 5 0 0 0-5 5v3H6a2 2 0 0 0-2 2v9a2 2 0 0 0 2 2h12a2 2 0 0 0 2-2v-9a2 2 0 0 0-2-2h-1V6a5 5 0 0 0-5-5Zm-3 8V6a3 3 0 1 1 6 0v3H9Z'/%3E%3C/svg%3E"); }
.nsp_cf_reward_tier__media { flex: 0 0 88px; max-width: 88px; }
.nsp_cf_reward_tier__media img { width: 88px; height: 88px; border-radius: 10px; display: block; object-fit: contain; background: rgba(0,0,0,0.02); }
.nsp_cf_reward_tier__body { flex: 1 1 auto; min-width: 0; }
.nsp_cf_reward_tier__threshold { display: inline-flex; align-items: center; background: var(--color-accent); color: var(--color-white); padding: 0.25rem 0.75rem; border-radius: 20px; font-size: 0.85rem; font-weight: 700; margin-bottom: 0.5rem; }
.nsp_cf_reward_tier__title { font-size: 1.05rem; font-weight: 700; color: var(--color-dark); margin-bottom: 0.25rem; }
.nsp_cf_reward_tier__tagline { font-size: 0.95rem; color: var(--color-accent); font-weight: 600; }
.nsp_cf_reward_tiers { position: relative; }
.nsp_cf_reward_tiers__container { max-height: 600px; overflow-y: auto; padding-right: 0.5rem; }
.nsp_cf_reward_tiers__container::-webkit-scrollbar { width: 8px; }
.nsp_cf_reward_tiers__container::-webkit-scrollbar-track { background: var(--color-white); border-radius: 4px; }
.nsp_cf_reward_tiers__container::-webkit-scrollbar-thumb { background: var(--color-accent); border-radius: 4px; }
.nsp_cf_reward_tiers__container::-webkit-scrollbar-thumb:hover { background: var(--color-accent-light); }
.nsp_cf_reward_tier { background: var(--color-white); border: 1px solid rgba(0,0,0,0.08); border-radius: 12px; padding: 1.5rem; margin-bottom: 1rem; transition: transform 0.3s ease, box-shadow 0.3s ease; cursor: pointer; }
.nsp_cf_reward_tier:hover { transform: translateY(-2px); box-shadow: 0 6px 16px rgba(0,0,0,0.1); }
.nsp_cf_reward_tier__header { display: flex; align-items: flex-start; gap: 1rem; margin-bottom: 1rem; }
.nsp_cf_reward_tier__image { width: 60px; height: 60px; border-radius: 8px; object-fit: cover; flex-shrink: 0; }
.nsp_cf_reward_tier__title { font-size: 1.1rem; font-weight: 600; color: var(--color-dark); margin: 0 0 0.5rem 0; line-height: 1.3; }
.nsp_cf_reward_tier__tagline { font-size: 0.9rem; color: var(--color-accent); font-weight: 500; margin: 0; line-height: 1.4; }
.nsp_cf_reward_tier__threshold { display: inline-flex; align-items: center; gap: 0.5rem; background: var(--color-accent); color: var(--color-white); padding: 0.25rem 0.75rem; border-radius: 20px; font-size: 0.85rem; font-weight: 600; margin-bottom: 1rem; }
.nsp_cf_reward_tier__threshold .material-icons { font-size: 16px; }
.nsp_cf_reward_tier__content { font-size: 0.9rem; color: var(--color-gray); line-height: 1.5; margin: 0; }
.nsp_cf_reward_tier__content p:last-child { margin-bottom: 0; }

/* Carousel navigation */
.nsp_cf_reward_tiers__nav { position: absolute; top: 50%; transform: translateY(-50%); width: 100%; display: flex; justify-content: space-between; pointer-events: none; padding: 0 0.5rem; }
.nsp_cf_reward_tiers__nav button { width: 40px; height: 40px; border-radius: 50%; background: var(--color-accent); color: var(--color-white); border: none; cursor: pointer; display: flex; align-items: center; justify-content: center; box-shadow: 0 4px 12px rgba(var(--color-accent-rgb), 0.3); transition: all 0.3s ease; pointer-events: all; }
.nsp_cf_reward_tiers__nav button:hover { background: var(--color-accent-light); transform: scale(1.1); }
.nsp_cf_reward_tiers__nav button:active { transform: scale(0.95); }
.nsp_cf_reward_tiers__nav button .material-icons { font-size: 20px; }

/* Responsive */
@media (max-width: 768px) {
  .nsp_cf_rewards_zone { grid-template-columns: 1fr; gap: 1.5rem; }
  .nsp_cf_reward_empty { padding: 2rem; }
  .nsp_cf_reward_tier { padding: 1rem; }
  .nsp_cf_reward_tier__image { width: 50px; height: 50px; }
  .nsp_cf_reward_tier__title { font-size: 1rem; }
  .nsp_cf_reward_tier__tagline { font-size: 0.85rem; }
  .nsp_cf_reward_tier__content { font-size: 0.85rem; }
}

@media (max-width: 768px) {
  .nsp_cf_story_block__inner { flex-direction: column; align-items: stretch; }
  .nsp_cf_story_block__media { flex: 0 0 auto; max-width: 100%; }
  .nsp_cf_news_block { flex-basis: 100%; }
}

@media (min-width: 992px) {
  .nsp_cf_news_block { flex-basis: calc(33.333% - 1.5rem); }
}

@media (min-width: 1400px) {
  .nsp_cf_news_block { flex-basis: calc(25% - 1.5rem); }
}

@media (max-width: 768px) {
  .nsp_cf_rewards_zone__layout { grid-template-columns: 1fr; }
}

.wk_cf_stats_inline { display: flex; align-items: center; justify-content: center; gap: 1rem; margin-top: 1rem; font-size: 14px; color: var(--color-gray); background: transparent; border: 0; border-radius: 0; padding: 0; }
.wk_cf_stats_inline__item { display: inline-flex; align-items: baseline; gap: 0.5rem; }
.wk_cf_stats_inline__item strong { color: var(--color-dark); font-weight: 900; font-size: 20px; line-height: 1; }
.wk_cf_stats_inline__item span { color: var(--color-accent); font-weight: 700; }
.wk_cf_stats_inline__sep { opacity: 0.6; font-weight: 900; color: rgba(var(--color-accent-rgb), 0.55); }

@media (max-width: 576px) {
  .wk_cf_stats_inline { justify-content: flex-start; flex-wrap: wrap; }
}

.wk_donation_notice { display: flex; align-items: flex-start; gap: 0.75rem; padding: 0.75rem 1rem; border-radius: 12px; background: rgba(var(--color-accent-rgb), .10); color: var(--color-dark); margin-top: 1rem; }
.wk_donation_notice__icon { color: var(--color-accent); }

.product__tax-label { display: inline-flex; align-items: center; justify-content: center; padding: 0.15rem 0.6rem; border-radius: 999px; background: rgba(var(--color-accent-rgb), 0.12); color: var(--color-accent); font-weight: 800; font-size: 12px; line-height: 1.2; }

.product__prices-inline .product__tax-infos { display: inline-flex; align-items: center; gap: 0.5rem; margin: 0; }
.product__prices-inline .product__tax-infos .product__tax-label { margin: 0; }

.wk_cf_processbar #container { position: relative; }
.modal.quickview .wk_cf_processbar #container .progressbar-text,
.wk_cf_processbar #container .progressbar-text { color: var(--color-accent) !important; font-weight: 900 !important; font-size: 18px !important; background: transparent !important; padding: 0 !important; border-radius: 0 !important; bottom: 20px; right: 5px; top: auto; left: auto; transform: none; }

.wk_cf_detail_container a { color: inherit; text-decoration: none; }
.wk_cf_detail_container a:hover { text-decoration: none; }
.wk_cf_detail_container .wk-thumbnail-container.row { margin-left: 0; margin-right: 0; display: flex; align-items: center; gap: 1rem; flex-wrap: nowrap; }
.wk_cf_detail_container .wk-thumbnail-container.row > [class*='col-'] { padding-left: 0; padding-right: 0; float: none; }
.wk_cf_detail_container .wk_camp_image { flex: 0 0 110px; max-width: 110px; }
.wk_cf_detail_container .wk_camp_image img { width: 110px; height: 110px; border-radius: 12px; object-fit: contain; background: rgba(0,0,0,0.02); display: block; }
.wk_cf_detail_container .wk_camp_desc { flex: 1 1 auto; min-width: 0; }
.wk_cf_detail_container .wk_camp_desc .product-title { margin: 0 0 0.5rem 0; }
.wk_cf_detail_container .wk_camp_desc .product-price-and-shipping > .price { display: none !important; }
.wk_cf_target_tooltip { display: none !important; }

body.nsp_cf_campaign_page .wk_cf_product_footer .product-price-and-shipping { display: none !important; }
body.nsp_cf_campaign_page .product__prices-block { display: none !important; }

.product-variant__label { display: flex; flex-wrap: wrap; align-items: baseline; gap: 0.25rem 0.5rem; }
.product-variant__selected { white-space: normal; overflow: visible; text-overflow: clip; }

@media (max-width: 576px) {
  .wk_cf_detail_container .wk-thumbnail-container.row { align-items: flex-start; flex-wrap: wrap; }
  .wk_cf_detail_container .wk_camp_image { flex: 0 0 88px; max-width: 88px; }
  .wk_cf_detail_container .wk_camp_image img { width: 88px; height: 88px; }
}

.wk_cf_product_footer #cf_description .product-description img { display: block; max-width: 100%; height: auto; object-fit: contain; background: rgba(0,0,0,0.02); border-radius: 12px; }

body.nsp_cf_campaign_page #product_details { display: none !important; }

@media (min-width: 992px) {
  .wk_cf_product_footer .wk_cf_project_side:not(.wk_cf_project_side--stack) .products {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  body.nsp_cf_campaign_page #cf_counterparts_tab .products {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

.wk_cf_product_footer .wk_cf_project_side.wk_cf_project_side--stack .products {
  grid-template-columns: repeat(1, minmax(0, 1fr));
}

@media (min-width: 992px) {
  .ps-categoryproducts .products {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }
}

.wk_bakeit_input_box { display: flex; flex-wrap: wrap; gap: 0.75rem; align-items: stretch; }
.wk_bakeit_input_box > * { flex: 1 1 260px; min-width: 260px; }
.wk_bakeit_input_box .input-wrapper { float: none !important; }
.wk_bakeit_input_box .row { align-items: center; justify-content: center; display: flex; flex-wrap: wrap; gap: 0.75rem; }
.wk_bakeit_input_box .row > [class*='col-'] { flex: 1 1 260px; max-width: none; display: flex; align-items: stretch; }
.wk_bakeit_input_box .input-group { width: 100%; align-items: stretch; position: relative; }
.wk_bakeit_input_box .input-group-text,
.wk_bakeit_input_box .input-group-addon {
  position: absolute;
  left: 12px;
  top: 50%;
  transform: translateY(-50%);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  white-space: nowrap;
  background: transparent;
  border: 0;
  padding: 0;
  color: var(--color-gray);
  font-weight: 700;
  pointer-events: none;
  z-index: 2;
}
.wk_bakeit_input_box .input-group .form-control,
.wk_bakeit_input_box .input-group input.form-control {
  padding-left: 2.25rem;
}
#wk_crowdfunding_pay { width: 100% !important; display: inline-flex; align-items: center; justify-content: center; }

@media (min-width: 768px) {
  .wk_bakeit_input_box { flex-wrap: nowrap; }
  .wk_bakeit_input_box > * { min-width: 0; }
  .wk_bakeit_input_box .row { flex-wrap: nowrap; }
  .wk_bakeit_input_box .row > [class*='col-'] { flex: 1 1 0; }
}

@media (max-width: 768px) {
  .wk_bakeit_input_box { flex-direction: column; }
  .wk_bakeit_input_box > * { min-width: 0; }
}

.wk_cf_product_footer { margin-top: 2rem; }
.wk_cf_product_footer .nav-tabs { border-bottom: 1px solid rgba(0,0,0,0.08); }
.wk_cf_product_footer .nav-tabs .nav-link { color: var(--color-gray); font-weight: 600; border: 0; border-bottom: 2px solid transparent; padding: 0.75rem 1rem; }
.wk_cf_product_footer .nav-tabs .nav-link:hover { color: var(--color-accent); border-bottom-color: rgba(var(--color-accent-rgb), 0.35); }
.wk_cf_product_footer .nav-tabs .nav-link.active,
.wk_cf_product_footer .nav-tabs .nav-item.show .nav-link { color: var(--color-accent); border-bottom-color: var(--color-accent); background: transparent; }
.wk_cf_product_footer .wk_cf_nav_icon img { width: 18px; height: 18px; object-fit: contain; opacity: 0.85; }
.wk_cf_product_footer .tab-content { padding-top: 1rem; }
.wk_cf_product_footer .tab-pane { background: transparent; }

.wk_cf_news.wk_user_comment { background: var(--color-white); border: 1px solid rgba(0,0,0,0.08); border-radius: 12px; padding: 1rem 1.25rem; box-shadow: 0 4px 12px rgba(0,0,0,0.06); }
.wk_cf_news.wk_user_comment + .wk_cf_news.wk_user_comment { margin-top: 1rem; }

@media (max-width: 1024px) {
  .wk_cf_product_footer .wk_cf_project_side { display: none !important; }
}
.wk_cf_news.wk_user_comment p:last-child { margin-bottom: 0; }

.wk_cf_comment .comment-section { background: var(--color-white); border: 1px solid rgba(0,0,0,0.08); border-radius: 12px; padding: 1rem 1.25rem; box-shadow: 0 4px 12px rgba(0,0,0,0.06); }
.wk_cf_comment .comment-section + .comment-section { margin-top: 1rem; }
.wk_cf_comment .wk_first_letter { width: 42px; height: 42px; border-radius: 50%; background: rgba(var(--color-accent-rgb), 0.12); color: var(--color-accent); display: inline-flex; align-items: center; justify-content: center; font-weight: 800; }
.wk_cf_comment .wk_full_name strong { color: var(--color-dark); }
.wk_cf_comment .wk_cf_date { color: var(--color-gray); }
.wk_cf_comment .wk_user_comment p { color: var(--color-gray); }

.wk_cf_write_comment textarea.form-control { border-radius: 12px; }
.wk_cf_write_comment #wk_crowdfunding_write_comment { border-radius: 999px; padding-left: 1.25rem; padding-right: 1.25rem; }

#bakers .table-responsive { background: var(--color-white); border: 1px solid rgba(0,0,0,0.08); border-radius: 12px; box-shadow: 0 4px 12px rgba(0,0,0,0.06); }
#bakers table { margin-bottom: 0; }
#bakers thead th { font-weight: 700; color: var(--color-dark); }
#bakers tbody td { color: var(--color-gray); }

/* ==== Quickview ==== */
.modal.quickview .modal-body { padding: 2rem; overflow-x: hidden; }
.modal.quickview .product-cover-thumbnails { margin-bottom: 2rem; }
.modal.quickview .product-additional-info { margin-top: 1.5rem; padding-top: 1.5rem; border-top: 1px solid rgba(0,0,0,0.08); }
.modal.quickview .product-additional-info--start { flex-wrap: wrap; gap: 0.75rem; }
.modal.quickview .product-additional-info--start > * { max-width: 100%; }
.modal.quickview .product-additional-info a { flex: 0 1 auto; white-space: normal; }
.modal.quickview .product-additional-info a .material-icons { display: inline-flex; align-items: center; justify-content: center; width: 1em; height: 1em; font-size: 20px; line-height: 1; vertical-align: middle; opacity: 0.85; }
.modal.quickview .material-icons { font-family: 'Material Icons' !important; font-feature-settings: 'liga'; -webkit-font-feature-settings: 'liga'; }

.modal.quickview .wk_cf_detail_container { background: var(--color-white); border-radius: 16px; box-shadow: 0 4px 12px rgba(0,0,0,0.06); padding: 1.25rem 1.5rem; }
.modal.quickview .wk_cf_detail_container hr { opacity: 0.12; }

.modal.quickview .wk_cf_processbar #container { padding-bottom: 0; }
.modal.quickview .wk_cf_processbar #container .progressbar-text {
  position: relative !important;
  inset: auto !important;
  transform: none !important;
  margin-top: 0.35rem;
  display: flex !important;
  justify-content: flex-end;
  white-space: nowrap;
}

.nsp-zigzag { display: grid; grid-template-columns: minmax(0, 1fr) minmax(0, 1fr); gap: 2rem; align-items: center; margin: 2.5rem 0; }
.nsp-zigzag--reverse .nsp-zigzag__media { order: 2; }
.nsp-zigzag--reverse .nsp-zigzag__content { order: 1; }
.nsp-zigzag__media { width: 100%; }
.nsp-zigzag__media img { width: 100%; height: auto; display: block; border-radius: 16px; object-fit: cover; background: rgba(0,0,0,0.02); }
.nsp-zigzag__content { min-width: 0; }
.nsp-zigzag__kicker { font-weight: 800; letter-spacing: 0.02em; text-transform: uppercase; font-size: 12px; color: var(--color-accent); margin: 0 0 0.5rem 0; }
.nsp-zigzag__title { font-weight: 900; font-size: clamp(22px, 2.2vw, 34px); line-height: 1.15; color: var(--color-dark); margin: 0 0 0.75rem 0; }
.nsp-zigzag__text { color: var(--color-gray); font-size: 16px; line-height: 1.6; margin: 0; }
.nsp-zigzag__actions { margin-top: 1.25rem; display: flex; gap: 0.75rem; flex-wrap: wrap; }

@media (max-width: 768px) {
  .nsp-zigzag { grid-template-columns: 1fr; gap: 1.25rem; margin: 2rem 0; }
  .nsp-zigzag--reverse .nsp-zigzag__media,
  .nsp-zigzag--reverse .nsp-zigzag__content { order: initial; }
}