/* =========================
   PARTY BOX – PAGE
   ========================= */

.kp-partybox{
  padding: 44px 0;
  background: #f7f8f7;
}

.kp-partybox__head{ margin-bottom: 18px; }
.kp-partybox__title{
  margin: 0 0 6px;
  font-size: 34px;
  font-weight: 900;
  color: #111;
}
.kp-partybox__subtitle{
  margin: 0;
  color: rgba(17,17,17,.65);
}

/* GRID */
.kp-partybox__grid{
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 18px;
  margin-top: 18px;
}

@media (max-width: 1200px){
  .kp-partybox__grid{ grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 768px){
  .kp-partybox__grid{ grid-template-columns: 1fr; }
}

/* =========================
   PRODUCT CARD
   ========================= */

.kp-pb-card{
  background: #fff;
  border: 1px solid rgba(0,0,0,.08);
  border-radius: 24px;
  padding: 18px;
  display: flex;
  flex-direction: column;
  transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}

.kp-pb-card:hover{
  transform: translateY(-2px);
  box-shadow: 0 18px 45px rgba(0,0,0,.12);
  border-color: rgba(134,188,64,.45);
}

.kp-pb-card__top{
  display: flex;
  gap: 12px;
  align-items: baseline;
  justify-content: space-between;
}

.kp-pb-card__title{
  margin: 0;
  font-size: 18px;
  font-weight: 900;
  color: #111;
}

.kp-pb-card__price{
  font-size: 13px;
  color: rgba(17,17,17,.7);
}
.kp-pb-card__price b{
  font-size: 16px;
  color: #111;
}

.kp-pb-card__list{
  list-style: none;
  padding: 0;
  margin: 14px 0 18px;
  display: grid;
  gap: 8px;
}

.kp-pb-card__list li{
  position: relative;
  padding-left: 16px;
  font-size: 14px;
  line-height: 1.35;
  color: rgba(17,17,17,.75);
}

.kp-pb-card__list li::before{
  content: "•";
  position: absolute;
  left: 0;
  top: 0;
  font-weight: 900;
  color: rgba(134,188,64,.85);
}

/* =========================
   CARD ACTIONS (FIXED)
   ========================= */

.kp-pb-card__actions{
  margin-top: auto;
  padding-top: 14px;
  border-top: 1px solid rgba(0,0,0,.08);

  display: flex;
  gap: 10px;
  align-items: stretch;
}

/* Poruči – glavno dugme */
.kp-pb-card__actions .kp-btn--primary{
  flex: 1 1 auto;
  min-height: 46px;
}

/* Dodaj – uvek vidljivo */
.kp-pb-card__actions .kp-add-btn-v3{
  flex: 0 0 120px;
  min-height: 46px;

  background: #fff;
  color: #111;
  font-weight: 800;

  border: 1px solid rgba(0,0,0,.14);
  border-radius: 999px;

  cursor: pointer;
  transition: transform .15s ease, box-shadow .15s ease, border-color .15s ease;
}

.kp-pb-card__actions .kp-add-btn-v3:hover{
  border-color: rgba(134,188,64,.55);
  box-shadow: 0 10px 24px rgba(0,0,0,.10);
  transform: translateY(-1px);
}

/* =========================
   CART (V3)
   ========================= */

.kp-cart-v3{
  background: rgba(0,0,0,.03);
  border: 1px solid rgba(0,0,0,.08);
  border-radius: 18px;
  padding: 14px;
  margin: 14px 0;
}

.kp-cart-v3__head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  margin-bottom: 10px;
}

.kp-cart-v3__total{
  font-size: 13px;
  color: rgba(17,17,17,.75);
}
.kp-cart-v3__total b{
  font-size: 16px;
  color:#111;
}

.kp-cart-v3__list{
  display:grid;
  gap: 10px;
}

.kp-cart-row-v3{
  background:#fff;
  border: 1px solid rgba(0,0,0,.08);
  border-radius: 18px;
  padding: 12px 14px;

  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 12px;
}

/* =========================
   QTY CONTROLS (PREMIUM)
   ========================= */

.kp-cart-row-v3__qty{
  display:flex;
  align-items:center;
  gap: 10px;
}

.kp-qty-btn,
.kp-remove-btn{
  width: 40px;
  height: 40px;
  border-radius: 14px;
  border: 1px solid rgba(0,0,0,.14);
  background: #fff;
  font-weight: 900;
  cursor: pointer;
  transition: transform .15s ease, box-shadow .15s ease, border-color .15s ease;
}

.kp-qty-btn:hover{
  border-color: rgba(134,188,64,.55);
  box-shadow: 0 12px 28px rgba(0,0,0,.10);
  transform: translateY(-1px);
}

.kp-qty-input{
  width: 80px;
  height: 40px;
  border-radius: 14px;
  border: 1px solid rgba(0,0,0,.14);
  text-align: center;
  font-weight: 800;
  outline: none;
}

.kp-qty-input:focus{
  border-color: rgba(134,188,64,.7);
  box-shadow: 0 0 0 4px rgba(134,188,64,.18);
}

.kp-remove-btn{
  background: rgba(0,0,0,.04);
}

.kp-remove-btn:hover{
  box-shadow: 0 12px 28px rgba(0,0,0,.10);
}

.kp-cart-v3__empty{
  padding: 10px 2px;
  font-size: 14px;
  color: rgba(17,17,17,.65);
}

/* mobile */
@media (max-width: 640px){
  .kp-cart-row-v3{
    flex-direction: column;
    align-items: stretch;
  }
  .kp-cart-row-v3__qty{
    justify-content: flex-end;
  }
}
/* === HARD FIX: Dodaj dugme mora biti vidljivo (override global ghost) === */
.kp-pb-card__actions .kp-add-btn-v3{
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;

  background: #fff !important;
  color: #111 !important;
  border: 1px solid rgba(0,0,0,.22) !important;

  font-size: 14px !important;
  font-weight: 900 !important;
  line-height: 1 !important;

  padding: 0 16px !important;
  min-height: 46px !important;

  opacity: 1 !important;
  visibility: visible !important;
  text-shadow: none !important;
}

.kp-pb-card__actions .kp-add-btn-v3:hover{
  border-color: rgba(134,188,64,.70) !important;
  box-shadow: 0 10px 24px rgba(0,0,0,.10) !important;
  transform: translateY(-1px);
}
/* ===== Modal širina (opciono) ===== */
.kp-modal__dialog--wide{
  max-width: 920px;
}

/* ===== Picker (Dodaj još) ===== */
.kp-pick-v3{
  margin: 12px 0 10px;
  padding: 14px;
  background: rgba(0,0,0,.02);
  border: 1px solid rgba(0,0,0,.08);
  border-radius: 18px;
}

.kp-pick-v3__head{
  display:flex;
  align-items:baseline;
  justify-content:space-between;
  gap: 12px;
  margin-bottom: 10px;
}

.kp-pick-v3__hint{
  font-size: 13px;
  color: rgba(17,17,17,.65);
}

.kp-pick-v3__grid{
  display:grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}

.kp-pick-v3__item{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 10px;

  padding: 12px 14px;
  border-radius: 16px;
  border: 1px solid rgba(0,0,0,.10);
  background: #fff;

  cursor:pointer;
  transition: transform .15s ease, box-shadow .15s ease, border-color .15s ease;
  text-align:left;
}

.kp-pick-v3__item:hover{
  border-color: rgba(134,188,64,.55);
  box-shadow: 0 14px 34px rgba(0,0,0,.10);
  transform: translateY(-1px);
}

.kp-pick-v3__name{
  font-weight: 900;
  color: #111;
}

.kp-pick-v3__meta{
  font-size: 13px;
  color: rgba(17,17,17,.7);
  white-space: nowrap;
}

.kp-pick-v3__cta{
  font-weight: 900;
  color: #111;
  background: rgba(134,188,64,.18);
  border: 1px solid rgba(134,188,64,.35);
  padding: 8px 10px;
  border-radius: 999px;
  white-space: nowrap;
}

@media (max-width: 720px){
  .kp-pick-v3__grid{ grid-template-columns: 1fr; }
}

/* ===== Toast ===== */
.kp-toast-v3{
  position: sticky;
  top: 10px;
  z-index: 5;

  padding: 10px 12px;
  border-radius: 14px;
  background: rgba(17,17,17,.92);
  color: #fff;
  font-weight: 800;
  font-size: 13px;

  opacity: 0;
  transform: translateY(-6px);
  transition: opacity .16s ease, transform .16s ease;
}

.kp-toast-v3.is-show{
  opacity: 1;
  transform: translateY(0);
}
/* ===== Modal: bolji mobile UX ===== */
.kp-modal__dialog{
  max-height: 88vh;
  overflow: auto;
  -webkit-overflow-scrolling: touch;
}

/* malo više prostora dole da sticky bar ne prekrije sadržaj */
#kpOrderModalV3 .kp-form{
  padding-bottom: 92px;
}

/* ===== Sticky CTA bar (mobile-first) ===== */
.kp-sticky-cta-v3{
  position: sticky;
  bottom: 0;
  margin-top: 12px;

  display: none; /* desktop: sakriveno */
  align-items: center;
  justify-content: space-between;
  gap: 12px;

  background: rgba(255,255,255,.92);
  backdrop-filter: blur(10px);

  border-top: 1px solid rgba(0,0,0,.10);
  padding: 10px 12px;
  border-bottom-left-radius: 18px;
  border-bottom-right-radius: 18px;
}

.kp-sticky-cta-v3__sum{
  display: grid;
  gap: 2px;
  color: rgba(17,17,17,.7);
  font-size: 12px;
}
.kp-sticky-cta-v3__sum b{
  color: #111;
  font-size: 16px;
  font-weight: 900;
}

.kp-sticky-cta-v3__btn{
  white-space: nowrap;
  min-height: 44px;
  padding: 0 16px;
}

/* mobile: prikazi sticky */
@media (max-width: 820px){
  .kp-sticky-cta-v3{ display: flex; }
}

/* desktop: forma dugmad ostaju, sticky sakriven */
@media (min-width: 821px){
  .kp-sticky-cta-v3{ display: none; }
}
.kp-sticky-cta-v3__sum{
  display: grid;
  gap: 2px;
  min-width: 92px;
}

.kp-sticky-cta-v3__label{
  font-size: 12px;
  color: rgba(17,17,17,.65);
  line-height: 1.1;
}

.kp-sticky-cta-v3__amount{
  display: inline-flex;
  align-items: baseline;
  gap: 0;
  white-space: nowrap;
}

.kp-sticky-cta-v3__amount b{
  font-size: 18px;
  font-weight: 900;
  color: #111;
}

.kp-sticky-cta-v3__cur{
  font-size: 14px;
  font-weight: 900;
  color: #111;
  opacity: .9;
}
/* =========================
   PARTY BOX – ACF EXTENSIONS
   (SAFE PATCH)
   ========================= */

/* Top info iznad naslova */
.kp-partybox__top{
  margin-bottom: 18px;
  padding: 14px 16px;
  background: rgba(255,255,255,.75);
  border: 1px solid rgba(0,0,0,.08);
  border-radius: 18px;
}

.kp-partybox__kicker{
  margin: 0 0 8px;
  font-size: 13px;
  font-weight: 900;
  color: rgba(17,17,17,.85);
}

.kp-partybox__points{
  list-style: none;
  padding: 0;
  margin: 0;
  display: grid;
  gap: 6px;
}

.kp-partybox__points li{
  position: relative;
  padding-left: 16px;
  font-size: 13px;
  color: rgba(17,17,17,.7);
}

.kp-partybox__points li::before{
  content: "✓";
  position: absolute;
  left: 0;
  top: 0;
  font-weight: 900;
  color: rgba(134,188,64,.85);
}

/* Napomena unutar kartice (između liste i dugmeta) */
.kp-pb-card__note{
  margin: 10px 0 12px;
  padding: 10px 12px;
  background: rgba(134,188,64,.08);
  border: 1px dashed rgba(134,188,64,.35);
  border-radius: 14px;

  font-size: 13px;
  font-weight: 700;
  color: rgba(17,17,17,.8);
}


/* =========================
   Party Box – Card Overline
   (SAFE ADDITION)
   ========================= */

.kp-pb-card__top{
  flex-wrap: wrap; /* dozvoljava red iznad naslova */
}

.kp-pb-card__overline{
  width: 100%;
  margin-bottom: 6px;

  font-size: 12px;
  font-weight: 700;
  letter-spacing: .02em;
  text-transform: uppercase;

  color: #c5d12d;
}

