@import url("https://fonts.googleapis.com/css2?family=Fira+Sans+Condensed:wght@400;600;700&display=swap");

/* ========================================
   DESIGN TOKENS
   ======================================== */
:root {
  --kb2b-font-family: "Fira Sans Condensed", system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  --kb2b-font-size: 1rem;
  --kb2b-line: 1.35;
  --kb2b-radius-sm: .5rem;
  --kb2b-radius-md: .75rem;
  --kb2b-radius-pill: 999rem;
  --kb2b-space-1: .25rem;
  --kb2b-space-2: .5rem;
  --kb2b-space-3: .75rem;
  --kb2b-space-4: 1rem;
  --kb2b-space-5: 1.25rem;
  --kb2b-space-6: 1.5rem;
  --kb2b-space-8: 2rem;
  --kb2b-bg: #f6f7f7;
  --kb2b-surface: #ffffff;
  --kb2b-text: #1d2327;
  --kb2b-muted: #6b7280;
  --kb2b-border: #dcdcde;
  --kb2b-border-soft: #e6e7e8;
  --kb2b-primary: #6E39B0;
  --kb2b-primary-hover: #5a2e91;
  --kb2b-success: #00a32a;
  --kb2b-success-hover: #008a20;
  --kb2b-danger: #d63638;
  --kb2b-danger-hover: #b32d2e;
  --kb2b-warn: #ff5a00;
  --kb2b-warn-hover: #e64f00;
  --kb2b-row-a: #ffffff;
  --kb2b-row-b: #f7f8f9;
  --kb2b-label-size: .75rem;
  --kb2b-label-track: .03em;
  --kb2b-col-qty: 12.25rem;
  --kb2b-col-qty-single: 5rem;
}
@media (max-width: 50rem) {
  :root { --kb2b-font-size: .9rem; --kb2b-label-size: .7rem; }
}

/* ========================================
   BASE & LAYOUT
   ======================================== */
body { background: #f6f6f6; }
.kalla-b2b-wrap { font-family: var(--kb2b-font-family); font-size: var(--kb2b-font-size); line-height: var(--kb2b-line); color: var(--kb2b-text); width: 100%; max-width: 75rem; margin: 1.75rem auto; padding: 0 1rem; }
.kalla-b2b-wrap, .kalla-b2b-wrap * { box-sizing: border-box; }
.kalla-b2b-wrap h1, .kalla-b2b-wrap h2, .kalla-b2b-wrap h3, .kalla-b2b-wrap h4, .kalla-b2b-wrap h5, .kalla-b2b-wrap h6 { color: var(--kb2b-primary); }
.kalla-b2b-wrap h2, .kalla-b2b-wrap h3 { margin: var(--kb2b-space-8) 0 var(--kb2b-space-8) 0; letter-spacing: .01em; }
.kalla-b2b-muted { color: var(--kb2b-muted); }
.kalla-b2b-warn { background: #fff3e9; border: 1px solid #ffd7bf; color: #6b2b00; padding: .75rem 1rem; border-radius: var(--kb2b-radius-md); }

/* ========================================
   HEADER
   ======================================== */
.kalla-b2b-header { background: #fff; border-bottom: 2px solid #ddd; box-shadow: 0 0 1rem 0 #ccc; margin-bottom: 2rem; }
.kalla-b2b-header__inner { max-width: 75rem; margin: 0 auto; padding: 1rem; display: flex; align-items: center; justify-content: space-between; gap: 1rem; flex-wrap: wrap; }
.kalla-b2b-header__inner, .kalla-b2b-header__inner * { font-size: .75rem; box-sizing: border-box; }
.kalla-b2b-header__logo { width: 125px; height: 40px; display: block; }
.kalla-b2b-header__logo img { width: 125px; height: 40px; object-fit: contain; display: block; }
@media (max-width: 50rem) {
  .kalla-b2b-header__inner { flex-direction: column; align-items: center; gap: 1rem; }
}

/* ========================================
   TOP NAV
   ======================================== */
.kalla-b2b-top { display: flex; gap: var(--kb2b-space-3); align-items: center; justify-content: space-between; margin-bottom: var(--kb2b-space-4); }
.kalla-b2b-nav { display: flex; gap: var(--kb2b-space-2); flex-wrap: wrap; }
.kalla-b2b-nav a { display: inline-flex; align-items: center; justify-content: center; padding: .55rem .9rem; border: 1px solid var(--kb2b-border); border-radius: var(--kb2b-radius-sm); text-decoration: none; background: var(--kb2b-bg); color: var(--kb2b-text); font-weight: 800; font-size: var(--kb2b-font-size); letter-spacing: .04em; text-transform: uppercase; line-height: 1; transition: background-color .12s ease, border-color .12s ease, color .12s ease, filter .12s ease; }
.kalla-b2b-nav a.active { filter: brightness(.98); }
.kalla-b2b-nav a[href$="/oferta/"] { background: var(--kb2b-success); border-color: var(--kb2b-success); color: #fff; }
.kalla-b2b-nav a[href$="/oferta/"]:hover { background: var(--kb2b-success-hover); border-color: var(--kb2b-success-hover); }
.kalla-b2b-nav a[href$="/zamowienia/"] { background: var(--kb2b-primary); border-color: var(--kb2b-primary); color: #fff; }
.kalla-b2b-nav a[href$="/zamowienia/"]:hover { background: var(--kb2b-primary-hover); border-color: var(--kb2b-primary-hover); }
@media (max-width: 50rem) {
  .kalla-b2b-top { flex-direction: column; align-items: center; justify-content: center; }
}

/* ========================================
   BUTTONS
   ======================================== */
.kalla-b2b-actions { display: flex; gap: var(--kb2b-space-2); justify-content: flex-end; flex-wrap: wrap; margin-top: var(--kb2b-space-8); }
.kalla-b2b-actions--grid2 { margin: var(--kb2b-space-8) 0 0 0; justify-content: center !important; }
.kalla-b2b-actions--cell { justify-content: flex-start; gap: var(--kb2b-space-2); flex-wrap: wrap; margin-top: 0; }
.kalla-b2b-btn { display: inline-flex; align-items: center; justify-content: center; border-radius: var(--kb2b-radius-sm); border: 1px solid transparent; cursor: pointer; font: inherit; font-weight: 800; letter-spacing: .04em; text-transform: uppercase; white-space: nowrap; padding: .55rem .9rem; line-height: 1; text-decoration: none; transition: background-color .12s ease, border-color .12s ease, color .12s ease, filter .12s ease, opacity .12s ease; }
.kalla-b2b-btn--auto { width: auto; }
a.kalla-b2b-btn:hover { text-decoration: none; }
.kalla-b2b-btn.view { background: var(--kb2b-primary); border-color: var(--kb2b-primary); color: #fff; }
.kalla-b2b-btn.view:hover { background: var(--kb2b-primary-hover); border-color: var(--kb2b-primary-hover); }
.kalla-b2b-btn.edit { background: var(--kb2b-warn); border-color: var(--kb2b-warn); color: #fff; }
.kalla-b2b-btn.edit:hover { background: var(--kb2b-warn-hover); border-color: var(--kb2b-warn-hover); }
.kalla-b2b-btn.cancel { background: var(--kb2b-danger); border-color: var(--kb2b-danger); color: #fff; }
.kalla-b2b-btn.cancel:hover { background: var(--kb2b-danger-hover); border-color: var(--kb2b-danger-hover); }
.kalla-b2b-btn--danger { background: var(--kb2b-danger); border-color: var(--kb2b-danger); color: #fff; }
.kalla-b2b-btn--danger:hover { background: var(--kb2b-danger-hover); border-color: var(--kb2b-danger-hover); }
.kalla-b2b-btn.nav-offer { background: var(--kb2b-success); border-color: var(--kb2b-success); color: #fff; }
.kalla-b2b-btn.nav-offer:hover { background: var(--kb2b-success-hover); border-color: var(--kb2b-success-hover); }
.kalla-b2b-btn.nav-orders { background: var(--kb2b-primary); border-color: var(--kb2b-primary); color: #fff; }
.kalla-b2b-btn.nav-orders:hover { background: var(--kb2b-primary-hover); border-color: var(--kb2b-primary-hover); }
.kalla-b2b-btn:active { filter: brightness(.98); }
.kalla-b2b-btn:disabled, .kalla-b2b-btn[disabled] { opacity: .55; cursor: not-allowed; }

/* ========================================
   STATUS BADGES
   ======================================== */
.kalla-b2b-status { display: inline-flex; align-items: center; gap: .4rem; padding: .25rem .6rem; border-radius: var(--kb2b-radius-pill); font-size: .85em; line-height: 1; border: 1px solid var(--kb2b-border); background: var(--kb2b-bg); color: var(--kb2b-text); width: fit-content; }
.kalla-b2b-status .dashicons { font-size: 1em; width: 1em; height: 1em; line-height: 1em; }
.kalla-b2b-status.is-completed { background: #e9f7ef; border-color: #b7e1c4; color: #0f5132; }
.kalla-b2b-status.is-cancelled { background: #fce8e8; border-color: #f3b5b5; color: #8a2424; }
.kalla-b2b-status.is-new { background: #f3ebfa; border-color: #d4bef0; color: #4a2578; }
.kalla-b2b-status.is-processing { background: #fff6e5; border-color: #f0d7a8; color: #6b4e00; }
.kalla-orders-group { margin: var(--kb2b-space-6) 0 var(--kb2b-space-6) 0; }
.kalla-orders-group-title { margin: var(--kb2b-space-6) 0 var(--kb2b-space-6) 0; }
.kalla-group-badge { display: inline-flex; align-items: center; gap: .5rem; padding: .4rem .95rem; border-radius: var(--kb2b-radius-pill); font-weight: 900; border: 1px solid var(--kb2b-border); background: var(--kb2b-bg); color: var(--kb2b-text); }
.kalla-group-badge .dashicons { font-size: 1.1em; width: 1.1em; height: 1.1em; line-height: 1.1em; }
.kalla-group-badge.is-new { background: #f3ebfa; border-color: #d4bef0; color: #4a2578; box-shadow: 0 0 1rem 0 #d4bef0; }
.kalla-group-badge.is-processing { background: #fff6e5; border-color: #f0d7a8; color: #6b4e00; box-shadow: 0 0 1rem 0 #f0d7a8; }
.kalla-group-badge.is-completed { background: #e9f7ef; border-color: #b7e1c4; color: #0f5132; box-shadow: 0 0 1rem 0 #b7e1c4; }
.kalla-group-badge.is-cancelled { background: #fce8e8; border-color: #f3b5b5; color: #8a2424; box-shadow: 0 0 1rem 0 #f3b5b5; }

/* ========================================
   CARD & GRID BASE
   ======================================== */
.kalla-card { background: var(--kb2b-row-b); border: 1px solid var(--kb2b-border); border-radius: var(--kb2b-radius-md); overflow: hidden; box-shadow: 0 0 1rem 0 #d1acff; }
.kalla-grid { width: 100%; background: var(--kb2b-surface); border: 1px solid var(--kb2b-border); border-radius: var(--kb2b-radius-md); overflow: hidden; }
.kalla-grid__row { display: grid; align-items: start; grid-template-columns: var(--kb2b-grid-cols, 1fr); }
.kalla-grid__row:nth-child(odd) { background: var(--kb2b-row-a); }
.kalla-grid__row:nth-child(even) { background: var(--kb2b-row-b); }
.kalla-grid__row + .kalla-grid__row { border-top: 1px solid var(--kb2b-border-soft); }
.kalla-grid__cell { padding: .75rem .75rem; min-width: 0; display: flex; flex-direction: column; justify-content: flex-start; align-items: flex-start; gap: .35rem; }
.kalla-grid__cell + .kalla-grid__cell { border-left: 1px solid var(--kb2b-border-soft); }
.kalla-label { display: block; font-size: var(--kb2b-label-size); letter-spacing: var(--kb2b-label-track); text-transform: uppercase; color: var(--kb2b-muted); line-height: 1.15; }
.kalla-value { display: block; }

/* ========================================
   KV SUMMARY
   ======================================== */
.kalla-kv { --kb2b-grid-cols: minmax(0, 1fr); }
.kalla-kv__row { display: block; padding: .7rem .85rem; }
.kalla-kv__row + .kalla-kv__row { border-top: 1px solid var(--kb2b-border-soft); }
.kalla-kv__label { margin-bottom: .2rem; }
.kalla-kv__value { font-weight: 400; }
.kalla-kv__row--status .kalla-kv__label { display: none; }
.kalla-kv__row--status .kalla-kv__value { font-weight: 400; }
.kalla-kv__row:nth-child(odd) { background: var(--kb2b-row-a); }
.kalla-kv__row:nth-child(even) { background: var(--kb2b-row-b); }
.kalla-screen--order-summary .kalla-kv__row--brutto .kalla-kv__value { font-weight: 900; }
.kalla-kv--order-meta { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: var(--kb2b-space-3); padding: var(--kb2b-space-3); }
.kalla-kv--order-meta .kalla-kv__item { padding: .75rem .9rem; border: 1px solid var(--kb2b-border-soft); border-radius: var(--kb2b-radius-sm); background: var(--kb2b-row-a); display: flex; flex-direction: column; gap: .35rem; min-width: 0; }
.kalla-kv--order-meta .kalla-kv__item--brutto { background: var(--kb2b-surface); border-color: var(--kb2b-primary); border-width: 2px; }
.kalla-kv--order-meta .kalla-kv__item--brutto .kalla-kv__value { font-weight: 900; }
.kalla-kv--order-meta .kalla-kv__item--status .kalla-kv__value { display: inline-flex; align-items: center; }
@media (max-width: 50rem) {
  .kalla-kv--order-meta { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}

/* ========================================
   ORDERS LIST
   ======================================== */
.kalla-grid--orders { --kb2b-grid-cols: max-content minmax(14rem, 1fr) max-content max-content max-content max-content; box-shadow: 0 0 1rem 0 #d1acff; }
.kalla-grid--orders .kalla-grid__row { align-items: stretch; }
.kalla-grid--orders .kalla-grid__cell { white-space: nowrap; }
.kalla-grid--orders .kalla-grid__cell--order-number .kalla-value { white-space: normal; word-break: break-word; }
.kalla-grid--orders .kalla-grid__cell:last-child .kalla-b2b-actions--cell { flex-direction: row; align-items: center; gap: .5rem; margin-top: 0; }
.kalla-grid--orders .kalla-grid__cell:last-child .kalla-b2b-btn { font-size: .68rem; padding: .4rem .6rem; letter-spacing: .04em; }
@media (max-width: 50rem) {
  .kalla-grid--orders .kalla-grid__row { display: grid; grid-template-columns: repeat(6, 1fr); grid-template-rows: auto auto auto; }
  .kalla-grid--orders .kalla-grid__cell { white-space: normal; }
  .kalla-grid--orders .kalla-grid__cell + .kalla-grid__cell { border-left: 0; }
  .kalla-grid--orders .kalla-grid__cell:nth-child(1) { grid-row: 1; grid-column: 1 / 4; border-left: 0; }
  .kalla-grid--orders .kalla-grid__cell:nth-child(2) { grid-row: 1; grid-column: 4 / 7; border-left: 1px solid var(--kb2b-border-soft); }
  .kalla-grid--orders .kalla-grid__cell:nth-child(3) { grid-row: 2; grid-column: 1 / 3; border-top: 1px solid var(--kb2b-border-soft); border-left: 0; }
  .kalla-grid--orders .kalla-grid__cell:nth-child(4) { grid-row: 2; grid-column: 3 / 5; border-top: 1px solid var(--kb2b-border-soft); border-left: 1px solid var(--kb2b-border-soft); }
  .kalla-grid--orders .kalla-grid__cell:nth-child(5) { grid-row: 2; grid-column: 5 / 7; border-top: 1px solid var(--kb2b-border-soft); border-left: 1px solid var(--kb2b-border-soft); }
  .kalla-grid--orders .kalla-grid__cell:nth-child(6) { grid-row: 3; grid-column: 1 / 7; border-top: 1px solid var(--kb2b-border-soft); border-left: 0; }
  .kalla-grid--orders .kalla-grid__cell:last-child .kalla-b2b-actions--cell { flex-direction: row; flex-wrap: wrap; justify-content: flex-start; align-items: center; gap: .5rem; }
}

/* ========================================
   PRODUCT CELL
   ======================================== */
.kalla-product { display: flex; gap: .85rem; align-items: flex-start; min-width: 0; }
.kalla-product__media { flex: 0 0 auto; }
.kalla-product__text { min-width: 0; }
.kalla-product__text a { word-break: break-word; text-decoration: none; color: var(--kb2b-text); }
.kalla-product__text a:hover { text-decoration: underline; }
.kalla-thumb { width: 2.6rem; height: 2.6rem; border-radius: var(--kb2b-radius-sm); border: 1px solid var(--kb2b-border); background: var(--kb2b-surface); object-fit: cover; flex: 0 0 auto; }
.kalla-thumb--placeholder { display: inline-block; background: var(--kb2b-bg); }

/* ========================================
   OFFER (PRODUCTS LIST)
   ======================================== */
.kalla-grid--offer { display: flex; flex-direction: column; gap: 0; box-shadow: 0 0 1rem 0 #d1acff; }
.kalla-offerrow { border-top: 2px solid var(--kb2b-border); }
.kalla-offerrow:nth-child(odd) { background: var(--kb2b-row-a); }
.kalla-offerrow:nth-child(even) { background: var(--kb2b-row-b); }
.kalla-offerrow:first-child { border-top: 0; }
.kalla-offerrow__top { display: grid; grid-template-columns: minmax(0, 1fr) max-content; gap: var(--kb2b-space-6); padding: .9rem .95rem; align-items: start; }
.kalla-offerrow__bottom { display: grid; grid-template-columns: repeat(5, minmax(0, 1fr)); border-top: 1px solid var(--kb2b-border-soft); }
.kalla-offerrow__cell { padding: .75rem .95rem; display: flex; flex-direction: column; justify-content: flex-start; gap: .3rem; }
.kalla-offerrow__cell + .kalla-offerrow__cell { border-left: 1px solid var(--kb2b-border-soft); }
.kalla-offerrow__mutedval { color: var(--kb2b-muted); font-weight: 400; }
.kalla-offerrow__gross { color: var(--kb2b-text); font-weight: 900; }
.kalla-offerrow__qty .kalla-stepper { margin-top: .15rem; }
@media (max-width: 50rem) {
  .kalla-offerrow__top { display: grid; grid-template-columns: 1fr; gap: 0; padding: 0; }
  .kalla-offerrow__top > *:first-child { padding: .9rem .95rem; }
  .kalla-offerrow__top > *:last-child { border-top: 1px solid var(--kb2b-border-soft); padding: .75rem .95rem; }
  .kalla-offerrow__qty { display: flex; flex-direction: column; align-items: flex-start; }
  .kalla-offerrow__qty .kalla-stepper { align-self: center; margin-top: .35rem; }
  .kalla-offerrow__bottom { display: grid; grid-template-columns: repeat(6, 1fr); grid-template-rows: auto auto; }
  .kalla-offerrow__cell + .kalla-offerrow__cell { border-left: 0; }
  .kalla-offerrow__bottom .kalla-offerrow__cell:nth-child(1) { grid-row: 1; grid-column: 1 / 3; border-left: 0; }
  .kalla-offerrow__bottom .kalla-offerrow__cell:nth-child(2) { grid-row: 1; grid-column: 3 / 5; border-left: 1px solid var(--kb2b-border-soft); }
  .kalla-offerrow__bottom .kalla-offerrow__cell:nth-child(3) { grid-row: 1; grid-column: 5 / 7; border-left: 1px solid var(--kb2b-border-soft); }
  .kalla-offerrow__bottom .kalla-offerrow__cell:nth-child(4) { grid-row: 2; grid-column: 1 / 4; border-top: 1px solid var(--kb2b-border-soft); border-left: 0; }
  .kalla-offerrow__bottom .kalla-offerrow__cell:nth-child(5) { grid-row: 2; grid-column: 4 / 7; border-top: 1px solid var(--kb2b-border-soft); border-left: 1px solid var(--kb2b-border-soft); }
}

/* Stepper width/centering fix */
.kalla-stepper { width: auto; }
.kalla-custom-row .kalla-stepper,
.kalla-offerrow__qty .kalla-stepper { justify-self: start; }
@media (max-width:50rem) {
  .kalla-custom-row .kalla-stepper,
  .kalla-offerrow__qty .kalla-stepper { width: auto; max-width: 16rem; justify-self: center; margin-left: auto; margin-right: auto; }
}

/* ========================================
   ORDER LINES
   ======================================== */
.kalla-grid--order-lines2 { display: flex; flex-direction: column; gap: 0; box-shadow: 0 0 1rem 0 #d1acff; }
.kalla-orderrow { border-top: 2px solid var(--kb2b-border); }
.kalla-orderrow:nth-child(odd) { background: var(--kb2b-row-a); }
.kalla-orderrow:nth-child(even) { background: var(--kb2b-row-b); }
.kalla-orderrow:first-child { border-top: 0; }
.kalla-orderrow__top { display: block; padding: .9rem .95rem; }
.kalla-orderrow__bottom { display: grid; grid-template-columns: repeat(5, minmax(0, 1fr)); border-top: 1px solid var(--kb2b-border-soft); }
.kalla-orderrow__bottom--summary { grid-template-columns: repeat(5, minmax(0, 1fr)); }
.kalla-orderrow__cell { padding: .75rem .95rem; display: flex; flex-direction: column; justify-content: flex-start; gap: .3rem; }
.kalla-orderrow__cell + .kalla-orderrow__cell { border-left: 1px solid var(--kb2b-border-soft); }
.kalla-orderrow__bottom .kalla-offerrow__mutedval { color: var(--kb2b-muted); font-weight: 400; }
.kalla-orderrow__bottom .kalla-offerrow__gross { color: var(--kb2b-text); font-weight: 900; }
@media (max-width: 50rem) {
  .kalla-orderrow__bottom, .kalla-orderrow__bottom--summary { display: grid; grid-template-columns: repeat(6, 1fr); grid-template-rows: auto auto; }
  .kalla-orderrow__cell + .kalla-orderrow__cell { border-left: 0; }
  .kalla-orderrow__bottom .kalla-orderrow__cell:nth-child(1) { grid-row: 1; grid-column: 1 / 3; border-left: 0; }
  .kalla-orderrow__bottom .kalla-orderrow__cell:nth-child(2) { grid-row: 1; grid-column: 3 / 5; border-left: 1px solid var(--kb2b-border-soft); }
  .kalla-orderrow__bottom .kalla-orderrow__cell:nth-child(3) { grid-row: 1; grid-column: 5 / 7; border-left: 1px solid var(--kb2b-border-soft); }
  .kalla-orderrow__bottom .kalla-orderrow__cell:nth-child(4) { grid-row: 2; grid-column: 1 / 4; border-top: 1px solid var(--kb2b-border-soft); border-left: 0; }
  .kalla-orderrow__bottom .kalla-orderrow__cell:nth-child(5) { grid-row: 2; grid-column: 4 / 7; border-top: 1px solid var(--kb2b-border-soft); border-left: 1px solid var(--kb2b-border-soft); }
}

/* ========================================
   ORDER TOTAL
   ======================================== */
.kalla-order-total { display: flex; justify-content: flex-end; gap: var(--kb2b-space-6); margin-top: var(--kb2b-space-8); padding: .75rem 1rem; border: 1px solid var(--kb2b-border); border-radius: var(--kb2b-radius-md); background: var(--kb2b-surface); box-shadow: 0 0 1rem 0 #d1acff; }
.kalla-order-total__label { color: var(--kb2b-muted); text-transform: uppercase; letter-spacing: var(--kb2b-label-track); font-size: var(--kb2b-label-size); line-height: 1.15; display: block; }
.kalla-order-total__value { font-size: 1.1em; font-weight: 900; }
@media (max-width: 50rem) {
  .kalla-order-total { justify-content: space-between; flex-direction: column; gap: .75rem; }
}

/* ========================================
   STEPPER / QTY
   ======================================== */
.kalla-stepper { display: inline-flex; align-items: stretch; gap: 0; position: relative; z-index: 1; background: var(--kb2b-surface); border: 2px solid var(--kb2b-border); border-radius: var(--kb2b-radius-md); overflow: hidden; box-shadow: 0 2px 8px rgba(0,0,0,.08); transition: border-color .15s ease, box-shadow .15s ease; }
.kalla-stepper:focus-within { border-color: var(--kb2b-primary); box-shadow: 0 0 0 3px rgba(110,57,176,.15), 0 2px 8px rgba(0,0,0,.08); }
.kalla-stepper.is-disabled { opacity: .55; pointer-events: none; }
.kalla-stepper-btn { appearance: none; -webkit-appearance: none; border: none; background: linear-gradient(to bottom, #f8f9fa, #e9ecef); color: var(--kb2b-text); min-width: 3rem; height: 3rem; padding: 0; display: inline-flex; align-items: center; justify-content: center; font-size: 1.4rem; font-weight: 700; cursor: pointer; user-select: none; -webkit-tap-highlight-color: transparent; touch-action: manipulation; transition: background .12s ease, color .12s ease; }
.kalla-stepper-btn:hover { background: linear-gradient(to bottom, #e9ecef, #dee2e6); }
.kalla-stepper-btn:active { background: #dee2e6; }
.kalla-stepper-btn:disabled { opacity: .4; cursor: not-allowed; }
.kalla-stepper-btn--minus { border-right: 1px solid var(--kb2b-border); color: var(--kb2b-danger); }
.kalla-stepper-btn--minus:hover { background: linear-gradient(to bottom, #fee2e2, #fecaca); color: var(--kb2b-danger-hover); }
.kalla-stepper-btn--plus { border-left: 1px solid var(--kb2b-border); color: var(--kb2b-success); }
.kalla-stepper-btn--plus:hover { background: linear-gradient(to bottom, #dcfce7, #bbf7d0); color: var(--kb2b-success-hover); }
.kalla-qty { width: 4.5rem; height: 3rem; border: none; padding: 0 .5rem; text-align: center; font: inherit; font-size: 1.15rem; font-weight: 700; line-height: 3rem; background: var(--kb2b-surface); color: var(--kb2b-text); -webkit-appearance: none; -moz-appearance: textfield; touch-action: manipulation; -webkit-tap-highlight-color: transparent; }
.kalla-qty:focus { outline: none; background: #f8f4fc; }
.kalla-qty::-webkit-outer-spin-button, .kalla-qty::-webkit-inner-spin-button { -webkit-appearance: none; margin: 0; }

/* ========================================
   PANEL META
   ======================================== */
.kalla-grid--panel-meta { --kb2b-grid-cols: minmax(0, 1fr) minmax(0, 1.2fr); }
@media (max-width: 50rem) {
  .kalla-grid--panel-meta { --kb2b-grid-cols: minmax(0, 1fr); }
}

/* ========================================
   UTILITY
   ======================================== */
.kalla-backlink a { color: var(--kb2b-primary); text-decoration: none; font-weight: 700; }
.kalla-backlink a:hover { text-decoration: underline; }
.kalla-order-single-actions { margin-top: var(--kb2b-space-6); }
.kalla-order-single-actions form { margin: 0; }

/* ========================================
   PRODUCT SINGLE
   ======================================== */
.kalla-product-page { padding: 0; }
.kalla-product-page__header { padding: var(--kb2b-space-6); border-bottom: 1px solid var(--kb2b-border-soft); }
.kalla-product-page__title { margin: 0 !important; }
.kalla-product-page__sku { margin: .25rem 0 0 0; }
.kalla-product-price-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: var(--kb2b-space-3); padding: var(--kb2b-space-6); border-bottom: 1px solid var(--kb2b-border-soft); }
.kalla-product-price-grid__item { padding: .75rem .9rem; border: 1px solid var(--kb2b-border-soft); border-radius: var(--kb2b-radius-sm); background: var(--kb2b-row-a); display: flex; flex-direction: column; gap: .35rem; min-width: 0; }
.kalla-product-price-grid__item--highlight { background: var(--kb2b-surface); border-color: var(--kb2b-primary); border-width: 2px; }
.kalla-product-price-grid__item--highlight .kalla-value { font-weight: 900; }
.kalla-product-page__grid { display: grid; grid-template-columns: minmax(0, 1.05fr) minmax(0, .95fr); gap: var(--kb2b-space-6); padding: var(--kb2b-space-6); }
.kalla-product-page__media img { width: 100%; height: auto; display: block; border-radius: var(--kb2b-radius-md); }
.kalla-product-page__no-media { border: 1px dashed var(--kb2b-border); border-radius: var(--kb2b-radius-md); padding: var(--kb2b-space-6); background: var(--kb2b-bg); }
@media (max-width: 50rem) {
  .kalla-product-page__header { padding: var(--kb2b-space-5); }
  .kalla-product-page__grid { grid-template-columns: minmax(0, 1fr); padding: var(--kb2b-space-5); }
}
@media (max-width: 22rem) {
  .kalla-product-price-grid { grid-template-columns: 1fr; gap: var(--kb2b-space-2); padding: var(--kb2b-space-5); }
}

/* ========================================
   SPLIDE GALLERY
   ======================================== */
.kalla-gallery { display: flex; flex-direction: column; gap: var(--kb2b-space-5); }
.kalla-gallery .splide__arrow { background: var(--kb2b-surface); border: 1px solid var(--kb2b-border); opacity: 1; }
.kalla-gallery .splide__arrow:hover { background: var(--kb2b-bg); }
.kalla-gallery .splide__pagination { display: none; }
#kalla-b2b-main-carousel { margin-bottom: var(--kb2b-space-5); border-radius: var(--kb2b-radius-md); overflow: hidden; background: var(--kb2b-surface); }
#kalla-b2b-main-carousel .splide__slide { display: flex; align-items: center; justify-content: center; background: var(--kb2b-surface); }
#kalla-b2b-main-carousel .splide__track, #kalla-b2b-main-carousel .splide__list { background: var(--kb2b-surface); }
#kalla-b2b-main-carousel .splide__slide a { display: block; line-height: 0; background: transparent; }
#kalla-b2b-thumbnail-carousel { padding: 0 2.5rem; }
#kalla-b2b-thumbnail-carousel .splide__track { overflow: hidden; }
#kalla-b2b-thumbnail-carousel .splide__list { display: flex; align-items: center; }
#kalla-b2b-thumbnail-carousel .splide__slide { opacity: 0.5; transition: opacity .25s ease, transform .25s ease; cursor: pointer; flex-shrink: 0; display: flex; align-items: center; justify-content: center; position: relative; }
#kalla-b2b-thumbnail-carousel .splide__slide:hover { opacity: 0.75; }
#kalla-b2b-thumbnail-carousel .splide__slide img { width: 100%; height: 100%; object-fit: cover; border-radius: var(--kb2b-radius-sm); border: 2px solid var(--kb2b-border-soft); display: block; transition: border-color .25s ease, transform .25s ease; }
#kalla-b2b-thumbnail-carousel .splide__slide.is-active { opacity: 1; border: none !important; }

/* ========================================
   LIGHTBOX
   ======================================== */
.kalla-lightbox { position: fixed; inset: 0; z-index: 99999; }
.kalla-lightbox__backdrop { position: fixed; inset: 0; background: rgba(0,0,0,.9); z-index: 99999; }
.kalla-lightbox__dialog { position: fixed; inset: 0; display: flex; align-items: center; justify-content: center; padding: 3rem 1rem; z-index: 100000; }
.kalla-lightbox__img { max-width: 100%; max-height: 100%; width: auto; height: auto; object-fit: contain; display: block; border-radius: var(--kb2b-radius-sm); box-shadow: 0 20px 60px rgba(0,0,0,.8); }
.kalla-lightbox__close { position: fixed; top: 1rem; right: 1rem; width: 2.75rem; height: 2.75rem; border-radius: var(--kb2b-radius-pill); border: 1px solid rgba(255,255,255,.3); background: rgba(0,0,0,.7); color: #fff; font-size: 1.6rem; line-height: 1; cursor: pointer; z-index: 100001; transition: background .2s ease; }
.kalla-lightbox__close:hover { background: rgba(0,0,0,.9); }
.kalla-lightbox__nav { position: fixed; top: 50%; transform: translateY(-50%); width: 3.25rem; height: 3.25rem; border-radius: var(--kb2b-radius-pill); border: 1px solid rgba(255,255,255,.3); background: rgba(0,0,0,.7); color: #fff; cursor: pointer; display: flex; align-items: center; justify-content: center; z-index: 100001; transition: background .2s ease; }
.kalla-lightbox__nav svg { fill: #fff; }
.kalla-lightbox__nav--prev { left: 1rem; }
.kalla-lightbox__nav--next { right: 1rem; }
.kalla-lightbox__nav:hover { background: rgba(0,0,0,.9); }
@media (max-width: 50rem) {
  .kalla-lightbox__dialog { padding: 1rem; }
  .kalla-lightbox__close { width: 2.5rem; height: 2.5rem; font-size: 1.4rem; }
  .kalla-lightbox__nav { width: 3rem; height: 3rem; }
  .kalla-lightbox__nav svg { width: 30px; height: 30px; }
}

/* ========================================
   CUSTOM WP LOGIN
   ======================================== */
body.login {
  background-color: #f6f7f7;
}
#login h1 a {
  background-image: url('../img/kalla-logo.svg');
  background-size: contain;
  background-position: center;
  background-repeat: no-repeat;
  width: 100%;
  height: 80px;
  margin-bottom: 20px;
}
.login form {
  border-radius: 8px;
}
.login .button-primary {
  background: var(--kb2b-primary);
  border-color: var(--kb2b-primary);
}
.login .button-primary:hover,
.login .button-primary:focus {
  background: var(--kb2b-primary-hover);
  border-color: var(--kb2b-primary-hover);
}
.login .language-switcher {
  display: none !important;
}

/* ========================================
   CUSTOM PRODUCTS
   ======================================== */
.kalla-custom-section { margin-top: var(--kb2b-space-6); border: 1px dashed var(--kb2b-border); border-radius: var(--kb2b-radius-md); background: var(--kb2b-row-b); padding: var(--kb2b-space-4); box-shadow: 0 0 1rem 0 rgba(255,152,0,.5); }
.kalla-custom-header { display: flex; align-items: center; justify-content: space-between; gap: var(--kb2b-space-3); flex-wrap: wrap; }
.kalla-custom-counter { font-weight: 800; color: #ff9800; }
.kalla-custom-list { margin-top: var(--kb2b-space-3); display: flex; flex-direction: column; gap: var(--kb2b-space-3); }
.kalla-custom-row { border: 1px solid #ffd7bf; border-left: 4px solid #ff9800; background: #fff8f0; border-radius: var(--kb2b-radius-md); padding: var(--kb2b-space-3); display: grid; grid-template-columns: minmax(0, 1fr) max-content max-content; gap: var(--kb2b-space-3); align-items: center; }
@media (max-width: 50rem) {
  .kalla-custom-row { grid-template-columns: minmax(0, 1fr); }
}
.kalla-custom-thumb { width: 2.6rem; height: 2.6rem; border-radius: var(--kb2b-radius-sm); border: 1px dashed #ff9800; background: #fff4e6; color: #ff9800; display: inline-flex; align-items: center; justify-content: center; font-weight: 900; }
.kalla-custom-name { width: 100%; padding: .6rem .75rem; border: 1px solid var(--kb2b-border); border-radius: var(--kb2b-radius-sm); font: inherit; }
.kalla-custom-price { font-weight: 700; color: var(--kb2b-muted); }
.kalla-custom-actions { display: inline-flex; align-items: center; gap: var(--kb2b-space-2); }
.kalla-custom-remove { border: none; background: transparent; color: #b32d2e; cursor: pointer; font-weight: 800; padding: .25rem .5rem; }
.kalla-custom-footer { margin-top: var(--kb2b-space-3); display: flex; gap: var(--kb2b-space-2); justify-content: flex-start; }
@media (max-width:50rem) {
  .kalla-custom-footer { justify-content: center; }
}

/* ========================================
   STANDARD ROW HIGHLIGHT
   ======================================== */
.kalla-standard-row { border-left: 4px solid var(--kb2b-success); border-radius: var(--kb2b-radius-md); }
/* ========================================
   REGISTRATION FORM (shortcode)
   ======================================== */
.kalla-b2b-register {
  font-family: var(--kb2b-font-family, "Fira Sans Condensed", Arial, sans-serif);
  font-size: var(--kb2b-font-size, 1rem);
  color: var(--kb2b-text, #1d2327);
  max-width: 40rem;
  margin: 0 auto;
}
.kalla-b2b-register *,
.kalla-b2b-register *::before,
.kalla-b2b-register *::after { box-sizing: border-box; }

/* Notices */
.kalla-b2b-register-notice {
  padding: .875rem 1.125rem;
  border-radius: var(--kb2b-radius-md, .75rem);
  margin-bottom: 1.5rem;
  font-size: .9375rem;
  line-height: 1.5;
}
.kalla-b2b-register-notice--success {
  background: #ecfdf5;
  border: 1px solid #6ee7b7;
  color: #065f46;
}
.kalla-b2b-register-notice--error {
  background: #fef2f2;
  border: 1px solid #fca5a5;
  color: #991b1b;
}
.kalla-b2b-register-notice--error ul {
  margin: .25rem 0 0 1.25rem;
  padding: 0;
}
.kalla-b2b-register-notice--error li { margin-bottom: .25rem; }

/* Form container */
.kalla-b2b-register__form { display: flex; flex-direction: column; gap: 1.5rem; }

/* Section card */
.kalla-b2b-register__section {
  border: 1px solid var(--kb2b-border, #dcdcde);
  border-radius: var(--kb2b-radius-md, .75rem);
  background: var(--kb2b-surface, #fff);
  padding: 1.25rem 1.5rem 1.5rem;
  margin: 0;
  box-shadow: 0 1px 4px rgba(0,0,0,.06);
}
.kalla-b2b-register__section legend {
  font-size: 1rem;
  font-weight: 700;
  color: var(--kb2b-primary, #6E39B0);
  letter-spacing: .015em;
  padding: 0 .5rem;
}

/* Toggle sections */
.kalla-b2b-register__section--toggle { background: var(--kb2b-row-b, #f7f8f9); }

.kalla-b2b-register__checkbox-label {
  display: inline-flex;
  align-items: center;
  gap: .5rem;
  cursor: pointer;
  font-weight: 700;
  font-size: 1rem;
  color: var(--kb2b-primary, #6E39B0);
  user-select: none;
}
.kalla-b2b-register__checkbox-label input[type="checkbox"] {
  width: 1.1em;
  height: 1.1em;
  accent-color: var(--kb2b-primary, #6E39B0);
  cursor: pointer;
  flex-shrink: 0;
}

.kalla-b2b-register__section-desc {
  font-size: .85rem;
  color: var(--kb2b-muted, #6b7280);
  margin: .5rem 0 .875rem;
  line-height: 1.45;
}

.kalla-b2b-register__conditional { display: flex; flex-direction: column; gap: .875rem; margin-top: .25rem; }

/* Field */
.kalla-b2b-register__field {
  display: flex;
  flex-direction: column;
  gap: .3rem;
}
.kalla-b2b-register__field > label,
.kalla-b2b-register__field--inline > div > label {
  font-size: .8125rem;
  font-weight: 600;
  color: var(--kb2b-muted, #6b7280);
  letter-spacing: .02em;
  text-transform: uppercase;
}
.kalla-b2b-register__field > label span[aria-hidden],
.kalla-b2b-register__field--inline > div > label span[aria-hidden] {
  color: var(--kb2b-danger, #d63638);
}
.kalla-b2b-register__field input[type="text"],
.kalla-b2b-register__field input[type="email"],
.kalla-b2b-register__field input[type="tel"],
.kalla-b2b-register__field input[type="password"],
.kalla-b2b-register__conditional input[type="text"],
.kalla-b2b-register__conditional input[type="tel"] {
  width: 100%;
  padding: .55rem .75rem;
  border: 1px solid var(--kb2b-border, #dcdcde);
  border-radius: var(--kb2b-radius-sm, .5rem);
  font: inherit;
  font-size: 1rem;
  background: #fff;
  color: var(--kb2b-text, #1d2327);
  transition: border-color .12s ease, box-shadow .12s ease;
  outline: none;
}
.kalla-b2b-register__field input:focus,
.kalla-b2b-register__conditional input:focus {
  border-color: var(--kb2b-primary, #6E39B0);
  box-shadow: 0 0 0 2px rgba(110,57,176,.15);
}

/* Inline two-column fields */
.kalla-b2b-register__field--inline {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: .75rem;
  align-items: end;
}
.kalla-b2b-register__field--inline > div {
  display: flex;
  flex-direction: column;
  gap: .3rem;
}

/* Submit button */
.kalla-b2b-register__submit {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: .7rem 2rem;
  background: var(--kb2b-primary, #6E39B0);
  color: #fff;
  border: none;
  border-radius: var(--kb2b-radius-sm, .5rem);
  font: inherit;
  font-weight: 700;
  font-size: 1rem;
  letter-spacing: .04em;
  text-transform: uppercase;
  cursor: pointer;
  transition: background .12s ease, filter .12s ease;
  width: 100%;
}
.kalla-b2b-register__submit:hover { background: var(--kb2b-primary-hover, #5a2e91); }

@media (max-width: 34rem) {
  .kalla-b2b-register__section { padding: 1rem; }
  .kalla-b2b-register__field--inline { grid-template-columns: 1fr; }
}

/* Activation pending notice on orders list */
.kalla-b2b-activation-pending {
  background: #fffbeb;
  border: 1px solid #fcd34d;
  color: #78350f;
  padding: .875rem 1.125rem;
  border-radius: var(--kb2b-radius-md, .75rem);
  margin-bottom: 1.5rem;
  font-size: .9375rem;
  line-height: 1.5;
}

/* ========================================
   THANK-YOU PAGE (shortcode)
   ======================================== */
.kalla-b2b-register-thankyou {
  font-family: var(--kb2b-font-family, "Fira Sans Condensed", Arial, sans-serif);
  font-size: var(--kb2b-font-size, 1rem);
  color: var(--kb2b-text, #1d2327);
  max-width: 40rem;
  margin: 0 auto;
  line-height: 1.7;
}
.kalla-b2b-register__btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: .7rem 2rem;
  background: var(--kb2b-primary, #6E39B0);
  color: #fff;
  border: none;
  border-radius: var(--kb2b-radius-sm, .5rem);
  font: inherit;
  font-weight: 700;
  font-size: 1rem;
  letter-spacing: .04em;
  text-transform: uppercase;
  cursor: pointer;
  text-decoration: none;
  transition: background .12s ease, filter .12s ease;
  margin-top: .5rem;
}
.kalla-b2b-register__btn:hover { background: var(--kb2b-primary-hover, #5a2e91); color: #fff; }

/* ========================================
   FILTER BAR
   ======================================== */
.kalla-filter-bar {
  display: flex;
  flex-direction: column;
  gap: var(--kb2b-space-3);
  background: var(--kb2b-surface);
  border: 1px solid var(--kb2b-border);
  border-radius: var(--kb2b-radius-md);
  padding: .75rem 1rem;
  margin-bottom: .75rem;
  box-shadow: 0 0 1rem 0 #d1acff;
}
.kalla-filter-bar__header { margin: 0; }
.kalla-filter-bar__title {
  margin: 0 0 .2rem;
  font-size: 1rem;
  font-weight: 700;
  color: var(--kb2b-primary);
}
.kalla-filter-bar__desc {
  margin: 0;
  font-size: .85rem;
  color: var(--kb2b-muted);
  line-height: 1.5;
}
.kalla-filter-bar__row {
  display: flex;
  gap: var(--kb2b-space-3);
  align-items: center;
  flex-wrap: wrap;
  justify-content: space-between;
}
.kalla-filter-bar__inputs {
  display: flex;
  gap: var(--kb2b-space-3);
  flex-wrap: wrap;
  flex: 1 1 auto;
  min-width: 0;
}
.kalla-filter-input {
  padding: .45rem .75rem;
  border: 1px solid var(--kb2b-border);
  border-radius: var(--kb2b-radius-sm);
  font: inherit;
  font-size: var(--kb2b-font-size);
  background: var(--kb2b-bg);
  color: var(--kb2b-text);
  transition: border-color .12s ease, box-shadow .12s ease;
  outline: none;
  min-width: 0;
}
.kalla-filter-input:focus {
  border-color: var(--kb2b-primary);
  box-shadow: 0 0 0 2px rgba(110,57,176,.15);
}
.kalla-filter-input[type="search"] { flex: 1 1 14rem; }
.kalla-filter-select { flex: 1 1 12rem; cursor: pointer; }
.kalla-filter-noresults {
  padding: .75rem 1rem;
  color: var(--kb2b-muted);
  font-style: italic;
  text-align: center;
}
@media (max-width: 50rem) {
  .kalla-filter-bar__row { flex-direction: column; align-items: stretch; }
  .kalla-filter-bar__row > .kalla-b2b-btn { align-self: flex-start; }
  .kalla-filter-bar__inputs { flex-direction: column; }
  .kalla-filter-input[type="search"],
  .kalla-filter-select { flex: 1 1 auto; width: 100%; }
}

/* ========================================
   PRODUCTS IN ORDER BLOCK
   ======================================== */
.kalla-inorder-section {
  background: var(--kb2b-surface);
  border: 1px solid var(--kb2b-border);
  border-radius: var(--kb2b-radius-md);
  overflow: hidden;
  margin-top: 1.25rem;
  box-shadow: 0 0 1rem 0 #d1acff;
}
.kalla-inorder-title {
  margin: 0;
  padding: .75rem 1rem;
  font-size: 1rem;
  font-weight: 700;
  background: var(--kb2b-row-b);
  border-bottom: 1px solid var(--kb2b-border-soft);
  color: var(--kb2b-primary);
  letter-spacing: .01em;
}
.kalla-inorder-list { display: flex; flex-direction: column; }
.kalla-inorder-item {
  display: grid;
  grid-template-columns: minmax(0, 1fr) max-content max-content;
  gap: var(--kb2b-space-3);
  align-items: center;
  padding: .55rem 1rem;
  border-top: 1px solid var(--kb2b-border-soft);
}
.kalla-inorder-item:first-child { border-top: 0; }
.kalla-inorder-item:nth-child(odd)  { background: var(--kb2b-row-a); }
.kalla-inorder-item:nth-child(even) { background: var(--kb2b-row-b); }
.kalla-inorder-name { font-weight: 600; word-break: break-word; }
.kalla-inorder-qty  { color: var(--kb2b-muted); white-space: nowrap; }
.kalla-inorder-price { font-weight: 900; white-space: nowrap; }
@media (max-width: 50rem) {
  .kalla-inorder-item {
    grid-template-columns: minmax(0,1fr) max-content;
    grid-template-rows: auto auto;
  }
  .kalla-inorder-name  { grid-column: 1 / 3; }
  .kalla-inorder-qty   { grid-row: 2; grid-column: 1; color: var(--kb2b-muted); }
  .kalla-inorder-price { grid-row: 2; grid-column: 2; }
}

/* ========================================
   FILTER NOTICE
   ======================================== */
.kalla-filter-notice {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: .5rem 1rem;
  background: #fff3e9;
  border: 1px solid #ffd7bf;
  color: #6b2b00;
  border-radius: var(--kb2b-radius-md);
  padding: .65rem 1rem;
  margin-top: 1.25rem;
  font-size: .9rem;
  line-height: 1.5;
}
.kalla-filter-notice__link {
  white-space: nowrap;
  color: var(--kb2b-primary);
  font-weight: 700;
  text-decoration: underline;
  background: none;
  border: none;
  padding: 0;
  cursor: pointer;
  font: inherit;
}
.kalla-filter-notice__link:hover { color: var(--kb2b-primary-hover); }
