/* =========================================
   BOOKING WIDGET — top CTA
   ========================================= */
/* Override overflow:hidden on parents to allow sticky */
.container-main,.container-main>.content{overflow:visible !important}
.container-main>.content::after{content:'';display:table;clear:both}

.book-widget{background:linear-gradient(135deg,#fdf5f8 0%,#e8f4f8 100%);border:1px solid #f0d6e0;border-radius:14px;padding:22px 26px;margin:0 0 24px;display:flex;align-items:center;gap:24px;flex-wrap:wrap;position:sticky;top:0;z-index:90;transition:box-shadow .2s,border-radius .2s}
@media(min-width:769px){.book-widget{top:48px}}
.book-widget.is-stuck{box-shadow:0 4px 20px rgba(0,0,0,.1);border-radius:0 0 14px 14px;border-top-color:transparent}

/* Mobile: no sticky widget, use fixed floating button instead */
@media(max-width:768px){
  .book-widget{position:static !important}
  .book-widget.is-stuck{box-shadow:none;border-radius:14px;border-top-color:#f0d6e0}
  .bk-float-btn{display:none;position:fixed;top:10px;left:50%;transform:translateX(-50%);z-index:95;background:#d2527f;color:#fff;border:none;border-radius:20px;padding:10px 28px;font-size:.88rem;font-weight:700;cursor:pointer;box-shadow:0 3px 14px rgba(210,82,127,.4);font-family:inherit;transition:opacity .2s;text-decoration:none}
  .bk-float-btn.visible{display:block}
}
.book-widget__info{flex:1;min-width:240px}
.book-widget__title{font-size:1.15rem;font-weight:700;color:#2a1a20;margin:0 0 6px;line-height:1.3}
.book-widget__meta{display:flex;gap:18px;flex-wrap:wrap;font-size:.9rem;color:#4c4c4c}
.book-widget__meta strong{color:#d2527f}
.book-widget__btn{flex:0 0 auto;background:#d2527f;color:#fff !important;border:none;border-radius:10px;padding:14px 32px;font-size:1rem;font-weight:700;cursor:pointer;text-decoration:none !important;transition:background .15s,transform .1s,box-shadow .2s;box-shadow:0 4px 14px rgba(210,82,127,.28);font-family:inherit;position:relative;overflow:hidden}
.book-widget__btn:hover{background:#b03060;transform:translateY(-1px);box-shadow:0 6px 20px rgba(210,82,127,.4)}
.book-widget__btn:active{transform:translateY(0)}
.book-widget__btn::after{content:'';position:absolute;inset:0;background:radial-gradient(circle,rgba(255,255,255,.3) 0%,transparent 70%);opacity:0;transition:opacity .3s}
.book-widget__btn:hover::after{opacity:1}
@media(max-width:640px){.book-widget{padding:18px 20px;gap:16px}.book-widget__btn{width:100%;padding:13px 20px}}

/* =========================================
   MODAL SHELL
   ========================================= */
.bk-overlay{position:fixed;inset:0;background:rgba(30,15,25,.6);z-index:10000;display:none;align-items:flex-start;justify-content:center;overflow-y:auto;padding:20px 12px;backdrop-filter:blur(3px);-webkit-backdrop-filter:blur(3px)}
.bk-overlay.bk-open{display:flex;animation:bkFade .25s ease-out}
@keyframes bkFade{from{opacity:0}to{opacity:1}}
.bk-modal{background:#fff;border-radius:16px;width:100%;max-width:580px;box-shadow:0 20px 80px rgba(0,0,0,.3);position:relative;margin:auto;overflow:hidden;animation:bkPop .3s cubic-bezier(.34,1.56,.64,1)}
@keyframes bkPop{from{transform:translateY(30px) scale(.96);opacity:0}to{transform:translateY(0) scale(1);opacity:1}}
.bk-head{padding:22px 56px 16px 26px;border-bottom:1px solid #f0f0f0;background:linear-gradient(135deg,#fdf5f8,#fff)}
.bk-head h2{margin:0 0 4px;font-size:1.2rem;color:#2a1a20;font-weight:700}
.bk-head .bk-sub{margin:0;color:#808080;font-size:.88rem}
.bk-close{position:absolute;top:16px;right:16px;width:34px;height:34px;border:none;background:#fff;border-radius:50%;cursor:pointer;font-size:1.6rem;color:#808080;line-height:1;display:flex;align-items:center;justify-content:center;transition:all .15s;box-shadow:0 2px 6px rgba(0,0,0,.08)}
.bk-close:hover{background:#d2527f;color:#fff;transform:rotate(90deg)}
.bk-body{padding:0;position:relative}

/* =========================================
   PROGRESS BAR
   ========================================= */
.bk-progress{padding:12px 26px 0;display:flex;align-items:center;gap:6px}
.bk-progress-dot{flex:1;height:4px;border-radius:3px;background:#eee;transition:background .4s ease}
.bk-progress-dot.on{background:linear-gradient(90deg,#d2527f,#e8749a)}
.bk-progress-dot.done{background:#d2527f}
.bk-progress-label{font-size:.72rem;color:#999;text-transform:uppercase;letter-spacing:.06em;margin-left:8px;font-weight:700;white-space:nowrap}

/* =========================================
   STEP CONTAINER + TRANSITIONS
   ========================================= */
.bk-steps{position:relative;overflow:hidden;min-height:260px}
.bk-step{padding:18px 26px 20px;opacity:0;transform:translateX(40px);transition:all .32s cubic-bezier(.4,0,.2,1);pointer-events:none;position:absolute;top:0;left:0;right:0;width:100%;box-sizing:border-box}
.bk-step.bk-active{opacity:1;transform:translateX(0);pointer-events:auto;position:relative}
.bk-step.bk-prev{transform:translateX(-40px);opacity:0;pointer-events:none}

.bk-step-title{font-size:1.05rem;font-weight:700;color:#2a1a20;margin:0 0 4px;display:flex;align-items:center;gap:8px}
.bk-step-title::before{content:"";display:inline-block;width:6px;height:6px;border-radius:50%;background:#d2527f;box-shadow:0 0 0 3px rgba(210,82,127,.18)}
.bk-step-hint{font-size:.82rem;color:#999;margin:0 0 16px}

/* =========================================
   FIELDS
   ========================================= */
.bk-field{margin-bottom:14px}
.bk-field label{display:block;font-size:.78rem;color:#4c4c4c;margin-bottom:5px;font-weight:600}
.bk-field label .req{color:#d2527f;margin-left:2px}
.bk-input-wrap{position:relative}
.bk-field input,.bk-field textarea{width:100%;padding:12px 42px 12px 14px;border:1.5px solid #e8e8e8;border-radius:10px;font-size:.95rem;font-family:inherit;color:#4c4c4c;background:#fff;transition:border-color .15s,box-shadow .15s;box-sizing:border-box}
.bk-field input:focus,.bk-field textarea:focus{outline:none;border-color:#d2527f;box-shadow:0 0 0 4px rgba(210,82,127,.12)}
.bk-field textarea{min-height:90px;resize:vertical;padding-right:14px}
.bk-field.bk-invalid input,.bk-field.bk-invalid textarea{border-color:#e57390;background:#fff9fa;box-shadow:0 0 0 3px rgba(229,115,144,.12);animation:bkShake .28s ease-in-out}
.bk-err-hint{display:block;color:#c53045;font-size:.76rem;margin-top:5px;line-height:1.35;padding-left:2px;animation:bkSlideIn .2s ease-out}
.bk-err-hint::before{content:"⚠ ";font-size:.85rem}
@keyframes bkShake{0%,100%{transform:translateX(0)}20%{transform:translateX(-5px)}40%{transform:translateX(5px)}60%{transform:translateX(-3px)}80%{transform:translateX(3px)}}

/* Clear (×) button — positioned relative to input wrapper, centered on input */
.bk-clear{position:absolute;right:8px;top:50%;transform:translateY(-50%);background:#f0f0f0;border:none;width:26px;height:26px;border-radius:50%;color:#808080;font-size:1rem;cursor:pointer;display:none;align-items:center;justify-content:center;line-height:1;transition:all .15s;padding:0;z-index:2}
.bk-input-wrap.has-value .bk-clear{display:flex}
.bk-clear:hover{background:#d2527f;color:#fff;transform:translateY(-50%) scale(1.08)}
/* For textarea, pin to top-right corner */
.bk-input-wrap--area .bk-clear{top:10px;transform:none}
.bk-input-wrap--area .bk-clear:hover{transform:scale(1.08)}

/* Number input: hide spinner, custom ± controls */
.bk-number{position:relative}
.bk-number input{text-align:center;padding:12px 46px;-moz-appearance:textfield;font-weight:600;font-size:1.05rem}
.bk-number input::-webkit-outer-spin-button,.bk-number input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}
.bk-num-btn{position:absolute;top:50%;transform:translateY(-50%);width:34px;height:34px;border-radius:50%;background:#fdf5f8;border:1.5px solid #f0d6e0;color:#d2527f;font-size:1.1rem;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s;padding:0}
.bk-num-btn:hover{background:#d2527f;color:#fff;border-color:#d2527f}
.bk-num-btn:active{transform:translateY(-50%) scale(.92)}
.bk-num-btn--minus{left:8px}
.bk-num-btn--plus{right:8px}

/* =========================================
   DROPZONE + FILES
   ========================================= */
.bk-dropzone{border:2px dashed #e0c3cf;border-radius:12px;padding:24px 18px;text-align:center;background:linear-gradient(135deg,#fff 0%,#fdf5f8 100%);cursor:pointer;transition:all .2s;position:relative}
.bk-dropzone:hover{border-color:#d2527f;background:linear-gradient(135deg,#fdf5f8 0%,#fff 100%)}
.bk-dropzone.bk-dragover{border-color:#d2527f;background:#fce8ee;transform:scale(1.01);box-shadow:0 0 0 4px rgba(210,82,127,.12)}
.bk-dropzone input[type=file]{position:absolute;inset:0;opacity:0;cursor:pointer;width:100%;height:100%}
.bk-dropzone__icon{font-size:2rem;margin-bottom:6px;line-height:1;animation:bkFloat 3s ease-in-out infinite}
@keyframes bkFloat{0%,100%{transform:translateY(0)}50%{transform:translateY(-4px)}}
.bk-dropzone__title{font-size:.95rem;font-weight:700;color:#4c4c4c;margin-bottom:4px}
.bk-dropzone__hint{font-size:.78rem;color:#999;line-height:1.4}
.bk-dropzone__hint strong{color:#d2527f}

.bk-files{margin-top:10px;display:flex;flex-direction:column;gap:7px}
.bk-file{display:flex;align-items:center;gap:10px;padding:8px 10px;background:#fff;border:1px solid #e8e8e8;border-radius:9px;animation:bkSlideIn .28s ease-out}
@keyframes bkSlideIn{from{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}
.bk-file__icon{flex:0 0 auto;width:32px;height:32px;border-radius:7px;display:flex;align-items:center;justify-content:center;font-size:.88rem;font-weight:700;color:#fff;letter-spacing:.02em}
.bk-file__icon.t-pdf{background:linear-gradient(135deg,#e53e3e,#c53030)}
.bk-file__icon.t-doc{background:linear-gradient(135deg,#3182ce,#2c5282)}
.bk-file__icon.t-img{background:linear-gradient(135deg,#38a169,#2f855a)}
.bk-file__icon.t-err{background:linear-gradient(135deg,#a0a0a0,#707070)}
.bk-file__info{flex:1;min-width:0}
.bk-file__name{font-size:.86rem;color:#4c4c4c;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.bk-file__meta{font-size:.72rem;color:#999;margin-top:1px}
.bk-file__progress{flex:0 0 70px;height:5px;background:#f0f0f0;border-radius:3px;overflow:hidden;display:none}
.bk-file__progress-bar{height:100%;background:linear-gradient(90deg,#d2527f,#e8749a);transition:width .2s;width:0}
.bk-file.loading .bk-file__progress{display:block}
.bk-file__remove{flex:0 0 auto;background:none;border:none;width:28px;height:28px;border-radius:50%;color:#999;font-size:1rem;cursor:pointer;transition:all .15s;padding:0;display:flex;align-items:center;justify-content:center}
.bk-file__remove:hover{background:#fde1e6;color:#c53045}

/* =========================================
   CALENDAR + SLOTS (step 4)
   ========================================= */
.bk-calendar{border:1.5px solid #e8e8e8;border-radius:12px;padding:12px;background:#fff}
.bk-cal-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}
.bk-cal-head button{background:#fdf5f8;border:1px solid #f0d6e0;width:32px;height:32px;border-radius:7px;cursor:pointer;font-size:1rem;color:#d2527f;font-weight:700;transition:all .15s}
.bk-cal-head button:hover:not(:disabled){background:#d2527f;color:#fff;transform:scale(1.05)}
.bk-cal-head button:disabled{opacity:.3;cursor:not-allowed}
.bk-cal-title{font-weight:700;color:#2a1a20;font-size:.95rem}
.bk-cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:3px}
.bk-cal-dow{text-align:center;font-size:.68rem;color:#999;padding:4px 0;font-weight:700;text-transform:uppercase;letter-spacing:.04em}
.bk-cal-day{text-align:center;padding:10px 0;border-radius:7px;cursor:pointer;font-size:.88rem;background:#fafafa;border:1px solid transparent;transition:all .12s;user-select:none}
.bk-cal-day:hover:not(.bk-cal-day--off):not(.bk-cal-day--past):not(.bk-cal-day--weekend):not(.bk-cal-day--blocked){background:#fdf5f8;border-color:#f0d6e0;color:#d2527f;transform:scale(1.05)}
.bk-cal-day--past,.bk-cal-day--weekend{color:#ccc;cursor:not-allowed;background:#fff}
.bk-cal-day--past{text-decoration:line-through}
.bk-cal-day--blocked{color:#ccc;background:repeating-linear-gradient(45deg,#fff,#fff 3px,#f5f5f5 3px,#f5f5f5 6px);cursor:not-allowed}
.bk-cal-day--sel{background:#d2527f !important;color:#fff !important;border-color:#d2527f !important;font-weight:700;box-shadow:0 3px 10px rgba(210,82,127,.4)}
.bk-cal-day--empty{visibility:hidden}

.bk-legend{margin-top:10px;display:flex;flex-wrap:wrap;gap:12px 14px;font-size:.72rem;color:#808080;padding:8px 4px;border-top:1px dashed #f0d6e0}
.bk-legend__item{display:inline-flex;align-items:center;gap:5px;white-space:nowrap}
.bk-legend__sw{display:inline-block;width:14px;height:14px;border-radius:4px;border:1px solid transparent;flex:0 0 auto}
.bk-legend__sw--free{background:#fafafa;border-color:#e8e8e8}
.bk-legend__sw--sel{background:#d2527f;border-color:#d2527f}
.bk-legend__sw--past{background:#fff;border-color:#e8e8e8;position:relative}
.bk-legend__sw--past::after{content:"";position:absolute;top:50%;left:10%;right:10%;height:1.5px;background:#ccc}
.bk-legend__sw--weekend{background:#fff;border-color:#e8e8e8;color:#aaa}
.bk-legend__sw--blocked{background:repeating-linear-gradient(45deg,#fff,#fff 2px,#e0e0e0 2px,#e0e0e0 4px);border-color:#e0e0e0}

.bk-slots{margin-top:10px;display:grid;grid-template-columns:repeat(auto-fill,minmax(72px,1fr));gap:6px;max-height:136px;overflow-y:auto;padding:2px}
.bk-slot{padding:9px 6px;border:1.5px solid #e8e8e8;border-radius:8px;background:#fff;cursor:pointer;text-align:center;font-size:.88rem;font-weight:600;color:#4c4c4c;transition:all .12s;animation:bkSlideIn .25s ease-out}
.bk-slot:hover{background:#fff;border-color:#d2527f;color:#d2527f;transform:translateY(-2px)}
.bk-slot--sel{background:#d2527f;color:#fff;border-color:#d2527f;box-shadow:0 4px 10px rgba(210,82,127,.35)}
.bk-slot--sel:hover{background:#fff;color:#d2527f;border-color:#d2527f;transform:translateY(-2px)}
.bk-slots-empty{grid-column:1/-1;color:#999;font-size:.85rem;text-align:center;padding:22px 8px}

/* =========================================
   WIDGET BADGES + VARIANT PICKER
   ========================================= */
.book-widget__badge{display:inline-block;margin-left:8px;font-size:.7rem;padding:2px 8px;border-radius:4px;font-weight:700;letter-spacing:.02em;vertical-align:middle}
.book-widget__badge--program{background:#d2527f;color:#fff}
.book-widget__badge--variants{background:#fff;color:#d2527f;border:1.5px solid #d2527f}

.bk-variants{display:flex;flex-direction:column;gap:10px}
.bk-variant{display:flex;align-items:center;gap:14px;padding:14px 18px;border:1.5px solid #e8e8e8;border-radius:10px;cursor:pointer;background:#fff;transition:all .15s}
.bk-variant:hover{border-color:#d2527f;background:#fdf5f8}
.bk-variant--sel{border-color:#d2527f;background:#fdf5f8;box-shadow:0 4px 14px rgba(210,82,127,.15)}
.bk-variant input[type=radio]{flex:0 0 auto;width:18px;height:18px;accent-color:#d2527f;cursor:pointer}
.bk-variant__body{flex:1;min-width:0}
.bk-variant__name{font-size:.95rem;font-weight:700;color:#2a1a20;line-height:1.3}
.bk-variant__meta{font-size:.78rem;color:#808080;margin-top:3px}
.bk-variant__price{flex:0 0 auto;font-size:1.05rem;font-weight:800;color:#d2527f;white-space:nowrap}

/* =========================================
   PROGRAM CONFIGURATOR
   ========================================= */
.bk-cfg{max-height:320px;overflow-y:auto;border:1.5px solid #e8e8e8;border-radius:10px;padding:4px;background:#fff}
.bk-cfg-loading{padding:24px;text-align:center;color:#999;font-size:.88rem}
.bk-cfg-group{margin:4px 0}
.bk-cfg-cat{font-size:.72rem;color:#d2527f;text-transform:uppercase;letter-spacing:.06em;font-weight:700;padding:10px 10px 6px;background:linear-gradient(90deg,#fdf5f8,#fff);border-radius:6px;margin:2px 0}
.bk-cfg-item{display:grid;grid-template-columns:1fr auto 62px;align-items:center;gap:10px;padding:8px 10px;border-radius:8px;transition:background .12s,border-color .15s;border:1.5px solid transparent;margin-bottom:2px;background:#fff}
.bk-cfg-item:hover{background:#fdf5f8}
.bk-cfg-item.on{background:#fdf5f8;border-color:#f0d6e0}
.bk-cfg-name{min-width:0;line-height:1.3}
.bk-cfg-title{font-size:.88rem;font-weight:600;color:#2a1a20}
.bk-cfg-meta{font-size:.74rem;color:#999;margin-top:2px}
.bk-cfg-qty{display:flex;align-items:center;gap:0;flex:0 0 auto}
.bk-cfg-qty button{width:28px;height:28px;background:#fff;border:1.5px solid #f0d6e0;color:#d2527f;font-weight:700;font-size:1rem;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;transition:all .12s;font-family:inherit}
.bk-cfg-qty button:first-child{border-radius:6px 0 0 6px}
.bk-cfg-qty button:last-child{border-radius:0 6px 6px 0}
.bk-cfg-qty button:hover{background:#d2527f;color:#fff;border-color:#d2527f;z-index:1}
.bk-cfg-qty-input{width:42px;height:28px;text-align:center;border:1.5px solid #f0d6e0;border-left:none;border-right:none;background:#fff;font-weight:700;font-size:.88rem;color:#2a1a20;font-family:inherit;padding:0;-moz-appearance:textfield}
.bk-cfg-qty-input::-webkit-outer-spin-button,.bk-cfg-qty-input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}
.bk-cfg-qty-input:focus{outline:none;border-color:#d2527f;background:#fff;z-index:2;position:relative}
.bk-cfg-item.on .bk-cfg-qty-input{background:#fff;color:#d2527f}
.bk-cfg-line-total{text-align:right;font-size:.82rem;font-weight:700;color:#d2527f;white-space:nowrap;min-height:1em}
@media(max-width:520px){.bk-cfg-item{grid-template-columns:1fr auto;grid-template-rows:auto auto;gap:6px 10px}.bk-cfg-name{grid-column:1/-1}.bk-cfg-line-total{text-align:right;grid-column:2}}
.bk-cfg-total{position:sticky;bottom:0;margin-top:10px;padding:12px 14px;background:linear-gradient(90deg,#fdf5f8,#fce8ee);border:1.5px solid #f0d6e0;border-radius:10px;display:flex;justify-content:space-between;align-items:center;font-size:.88rem;color:#4c4c4c;font-weight:600}
.bk-cfg-total .bk-cfg-sum{font-size:1.05rem;font-weight:800;color:#d2527f;letter-spacing:.02em}

/* =========================================
   CAPTCHA + CONSENT
   ========================================= */
.bk-captcha{display:flex;align-items:center;gap:10px;margin-top:4px}
.bk-captcha__q{background:linear-gradient(135deg,#fdf5f8,#fce8ee);border:1.5px solid #f0d6e0;padding:11px 16px;border-radius:9px;font-weight:700;color:#2a1a20;font-size:1.05rem;min-width:90px;text-align:center;letter-spacing:.04em;font-family:'Courier New',monospace}
.bk-captcha input{flex:1;max-width:120px;text-align:center;font-weight:700;font-size:1rem}
.bk-captcha__reload{background:#fff;border:1.5px solid #e8e8e8;width:40px;height:40px;border-radius:9px;cursor:pointer;font-size:1.1rem;color:#808080;transition:all .2s;padding:0;display:flex;align-items:center;justify-content:center}
.bk-captcha__reload:hover{border-color:#d2527f;color:#d2527f;transform:rotate(180deg)}

.bk-consent{margin:16px 0 10px;display:flex;align-items:flex-start;gap:10px;font-size:.82rem;color:#4c4c4c;line-height:1.5;cursor:pointer;padding:12px;background:#fdf5f8;border-radius:9px;transition:background .15s}
.bk-consent:hover{background:#fce8ee}
.bk-consent input[type=checkbox]{flex:0 0 auto;margin-top:2px;width:17px;height:17px;accent-color:#d2527f;cursor:pointer}
.bk-consent a{color:#d2527f;text-decoration:underline;font-weight:600}
.bk-birth{display:grid;grid-template-columns:1fr 1.4fr 1fr;gap:8px}
.bk-birth__sel{width:100%;padding:10px 12px;border:1.5px solid #ede4e9;border-radius:8px;font:inherit;font-size:.92rem;color:#2b2b2b;background:#fff;outline:none;transition:border-color .15s}
.bk-birth__sel:focus{border-color:#d2527f}
.bk-birth__sel--wide{min-width:0}
.bk-field.bk-invalid .bk-birth__sel{border-color:#d0021b;background:#fff5f5}
.bk-birth-age{margin-top:6px;font-size:.82rem;font-weight:600;min-height:1em}
.bk-consent-details{margin:0 0 14px;background:#fafafa;border:1px solid #ececec;border-radius:8px;font-size:.78rem}
.bk-consent-details summary{padding:9px 14px;cursor:pointer;color:#d2527f;font-weight:600;list-style:none;user-select:none;outline:none;display:flex;align-items:center;gap:6px}
.bk-consent-details summary::-webkit-details-marker{display:none}
.bk-consent-details summary::before{content:'▸';display:inline-block;font-size:.72rem;transition:transform .2s;color:#d2527f}
.bk-consent-details[open] summary::before{transform:rotate(90deg)}
.bk-consent-details summary:hover{color:#b03a67;background:#f5f5f5;border-radius:8px 8px 0 0}
.bk-consent-full{padding:0 16px 14px;color:#555;line-height:1.55;max-height:280px;overflow-y:auto;scrollbar-width:thin;scrollbar-color:#d2527f #f5f5f5}
.bk-consent-full::-webkit-scrollbar{width:6px}
.bk-consent-full::-webkit-scrollbar-track{background:#f5f5f5}
.bk-consent-full::-webkit-scrollbar-thumb{background:#d2527f;border-radius:3px}
.bk-consent-full p{margin:8px 0}
.bk-consent-full p:first-child{margin-top:6px}
.bk-consent-full strong{color:#2b2b2b}
.bk-consent-full a{color:#d2527f;text-decoration:underline}

/* =========================================
   NAV BUTTONS
   ========================================= */
.bk-nav{padding:16px 26px 22px;display:flex;gap:10px;justify-content:space-between;border-top:1px solid #f0f0f0;background:#fafafa}
.bk-btn{padding:12px 22px;border:none;border-radius:10px;font-size:.95rem;font-weight:700;cursor:pointer;transition:all .15s;font-family:inherit;display:inline-flex;align-items:center;gap:6px}
.bk-btn--back{background:#fff;color:#4c4c4c;border:1.5px solid #e8e8e8}
.bk-btn--back:hover{border-color:#d2527f;color:#d2527f}
.bk-btn--next,.bk-btn--submit{background:#d2527f;color:#fff;box-shadow:0 4px 12px rgba(210,82,127,.3);margin-left:auto}
.bk-btn--next:hover:not(:disabled),.bk-btn--submit:hover:not(:disabled){background:#b03060;transform:translateY(-1px);box-shadow:0 6px 16px rgba(210,82,127,.4)}
.bk-btn--next:disabled,.bk-btn--submit:disabled{background:#d0d0d0;cursor:not-allowed;box-shadow:none}
.bk-btn--back:disabled{opacity:.4;cursor:not-allowed}

.bk-error{margin:0 26px 6px;background:#fdecef;color:#a01a3a;padding:10px 14px;border-radius:9px;font-size:.85rem;border-left:3px solid #d2527f;display:none;animation:bkShake .3s}
.bk-error.on{display:block}
.bk-success{margin:20px 26px 26px;background:linear-gradient(135deg,#e8f7ee,#d5f2df);color:#1b6b2e;padding:26px 20px;border-radius:12px;text-align:center;display:none}
.bk-success.on{display:block;animation:bkPop .4s cubic-bezier(.34,1.56,.64,1)}
.bk-success h3{margin:0 0 6px;color:#1b6b2e;font-size:1.15rem}
.bk-success__icon{font-size:2.4rem;margin-bottom:8px;animation:bkCheck .6s cubic-bezier(.34,1.56,.64,1)}
@keyframes bkCheck{0%{transform:scale(0) rotate(-30deg)}100%{transform:scale(1) rotate(0)}}
.bk-loading{opacity:.5;pointer-events:none}

.bk-honeypot{position:absolute;left:-9999px;width:1px;height:1px;opacity:0;pointer-events:none}

/* Summary on last step */
.bk-summary{background:#fdf5f8;border-radius:10px;padding:14px 16px;margin-bottom:14px;font-size:.85rem;color:#4c4c4c;border-left:3px solid #d2527f}
.bk-summary__row{display:flex;justify-content:space-between;margin-bottom:4px;gap:14px}
.bk-summary__row:last-child{margin-bottom:0}
.bk-summary__label{color:#999;font-size:.78rem;flex:0 0 auto}
.bk-summary__val{font-weight:600;color:#2a1a20;text-align:right;word-break:break-word}
.bk-summary__row--total{margin-top:10px;padding-top:10px;border-top:2px solid #f0d6e0;align-items:center}
.bk-summary__row--total .bk-summary__label{font-weight:700;color:#2b2b2b;font-size:.95rem}

/* =========================================
   RESPONSIVE
   ========================================= */
@media(max-width:560px){
  .bk-modal{max-width:100%;margin:0;border-radius:0;min-height:100vh}
  .bk-head{padding:18px 52px 14px 18px}
  .bk-progress{padding:10px 18px 0}
  .bk-step{padding:16px 18px}
  .bk-nav{padding:14px 18px 20px}
  .bk-error{margin:0 18px 6px}
  .bk-success{margin:16px 18px 20px}
  .bk-captcha{flex-wrap:wrap}
  .bk-captcha input{max-width:none;width:100%}
}

/* === Fullscreen modal === */
.bk-overlay{padding:0 !important;background:rgba(20,10,18,.85) !important}
.bk-modal{
  max-width:none !important;width:100% !important;height:100vh !important;
  max-height:100vh !important;border-radius:0 !important;margin:0 !important;
  display:flex;flex-direction:column;overflow:hidden
}
.bk-modal .bk-head{flex-shrink:0}
.bk-modal .bk-form{flex:1;overflow-y:auto;padding:24px 32px}
.bk-modal .bk-nav{flex-shrink:0;border-top:1px solid #eee;background:#fafafa}
@media(min-width:900px){
  .bk-modal .bk-form{padding:32px 60px;max-width:none}
}


/* (old stacked block removed — see unified block below) */

/* Форма: убрать огромный padding */
.bk-modal .bk-form{padding:0 !important}
.bk-modal.bk-stacked .bk-nav{padding:14px 24px;background:#fff;border-top:1px solid #f0e4eb}

/* === Flatpickr input visibility === */
.bk-modal.bk-stacked .flatpickr-input,
.bk-modal.bk-stacked input.flatpickr-alt-input{
  width:100% !important;display:block !important;cursor:pointer;
  padding:12px 14px !important;border:1.5px solid #e8e8e8 !important;
  border-radius:10px !important;font-size:.95rem !important;background:#fff !important;
  box-sizing:border-box;font-family:inherit
}
.bk-modal.bk-stacked input.flatpickr-input[readonly]{background:#fff !important}

/* === Программа: компактный конфигуратор внутри карточки === */
.bk-modal.bk-stacked .bk-cfg{
  background:#fdf6fa;border-radius:10px;padding:14px 16px;margin-top:10px
}
.bk-modal.bk-stacked .bk-cfg-cat{
  font-size:.78rem;font-weight:700;color:#8a7d84;text-transform:uppercase;
  letter-spacing:.05em;margin:14px 0 8px
}
.bk-modal.bk-stacked .bk-cfg-cat:first-child{margin-top:0}
.bk-modal.bk-stacked .bk-cfg-item{
  background:#fff;border:1px solid #f0e4eb;border-radius:8px;
  padding:10px 14px;margin-bottom:8px
}
.bk-modal.bk-stacked .bk-cfg-total{
  background:#d2527f;color:#fff;padding:14px 18px;border-radius:10px;
  margin-top:14px;display:flex;justify-content:space-between;align-items:center;
  font-size:.95rem;font-weight:600
}
.bk-modal.bk-stacked .bk-cfg-total strong{color:#fff}
.bk-modal.bk-stacked .bk-cfg-sum{font-size:1.05rem}

/* === Stacked: убрать внутренний скролл программы и плохую обёртку === */
.bk-modal.bk-stacked .bk-cfg{
  max-height:none !important;overflow:visible !important;
  border:none !important;background:transparent !important;
  padding:0 !important;margin-top:8px
}
/* Карточка-шаг с программой не должна сжиматься через flex */
.bk-modal.bk-stacked .bk-step:has(.bk-cfg){padding:22px !important}

/* Итого: внутри карточки, не торчит */
.bk-modal.bk-stacked .bk-cfg-total{
  position:static !important;
  border-radius:10px;margin:14px 0 0 !important;
  padding:14px 18px;width:auto
}



/* ============================================================
   STACKED MODAL — bootstrap-like row/col grid
   ============================================================ */

/* Контейнер: единая сетка, фиксированные равные колонки */
.bk-modal.bk-stacked .bk-steps{
  overflow:visible !important;min-height:0 !important;position:static !important;
  display:grid !important;
  grid-template-columns:repeat(12, minmax(0, 1fr));
  gap:16px;
  background:#f8f3f6;padding:16px
}
@media(min-width:768px){
  .bk-modal.bk-stacked .bk-steps{padding:20px;gap:18px}
}
@media(min-width:1100px){
  .bk-modal.bk-stacked .bk-steps{padding:24px;gap:20px}
}

/* Каждый шаг — карточка одной ширины */
.bk-modal.bk-stacked .bk-step{
  position:static !important;display:flex !important;flex-direction:column;
  opacity:1 !important;transform:none !important;pointer-events:auto !important;
  width:auto !important;left:auto !important;right:auto !important;top:auto !important;
  margin:0 !important;
  background:#fff;border-radius:14px;
  padding:20px 22px !important;
  box-shadow:0 2px 8px rgba(0,0,0,.05);
  border:1px solid #efe6eb;
  transition:none !important;min-width:0;

  /* Bootstrap-like col sizing */
  grid-column:span 12;          /* Mobile: 12/12 = full width */
}
@media(min-width:680px){
  .bk-modal.bk-stacked .bk-step{grid-column:span 6}    /* tablet: 6/12 = 2 cols */
}
@media(min-width:1100px){
  .bk-modal.bk-stacked .bk-step{grid-column:span 4}    /* desktop: 4/12 = 3 cols */
}
@media(min-width:1500px){
  .bk-modal.bk-stacked .bk-step{grid-column:span 3}    /* xl: 3/12 = 4 cols */
}

/* Прогресс / wizard-навигация — спрятать */
.bk-modal.bk-stacked .bk-progress{display:none !important}
.bk-modal.bk-stacked .bk-btn--back,
.bk-modal.bk-stacked .bk-btn--next{display:none !important}
.bk-modal.bk-stacked .bk-btn--submit{display:block !important;width:100%}

/* Заголовки */
.bk-modal.bk-stacked .bk-step-title{
  margin:0 0 4px;font-size:1rem;font-weight:700;color:#2b2b2b;
  display:flex;align-items:center;gap:8px
}
.bk-modal.bk-stacked .bk-step-title::before{
  content:"";width:6px;height:6px;border-radius:50%;background:#d2527f;flex-shrink:0
}
.bk-modal.bk-stacked .bk-step-hint{font-size:.78rem;color:#999;margin:0 0 14px;line-height:1.4}

/* Поля */
.bk-modal.bk-stacked .bk-step .bk-field{margin-bottom:12px}
.bk-modal.bk-stacked .bk-step .bk-field:last-child{margin-bottom:0}
.bk-modal.bk-stacked .bk-step .bk-field label{
  font-size:.78rem;font-weight:600;color:#666;margin-bottom:4px;display:block
}
.bk-modal.bk-stacked .bk-step .bk-field input,
.bk-modal.bk-stacked .bk-step .bk-field textarea,
.bk-modal.bk-stacked .bk-step .bk-field select{
  width:100%;padding:10px 12px;border:1.5px solid #e8e8e8;border-radius:8px;
  font-size:.9rem;background:#fff;box-sizing:border-box;font-family:inherit
}
.bk-modal.bk-stacked .bk-step .bk-field input:focus,
.bk-modal.bk-stacked .bk-step .bk-field textarea:focus{outline:none;border-color:#d2527f}

/* Number ± */
.bk-modal.bk-stacked .bk-number{
  display:grid;grid-template-columns:38px 1fr 38px;
  border:1.5px solid #e8e8e8;border-radius:8px;overflow:hidden;background:#fff
}
.bk-modal.bk-stacked .bk-num-btn{
  background:#fdf6fa;border:0;cursor:pointer;color:#d2527f;font-weight:700;font-size:1rem;
  padding:0;transition:background .12s
}
.bk-modal.bk-stacked .bk-num-btn:hover{background:#f5e0ec}
.bk-modal.bk-stacked .bk-number input{border:0 !important;border-radius:0 !important;text-align:center;font-weight:600}

/* Программа конфигуратор */
.bk-modal.bk-stacked .bk-cfg{
  max-height:none !important;overflow:visible !important;
  border:none !important;background:transparent !important;
  padding:0 !important;margin:8px 0 0
}
.bk-modal.bk-stacked .bk-cfg-cat{
  font-size:.7rem;font-weight:700;color:#8a7d84;text-transform:uppercase;
  letter-spacing:.05em;margin:14px 0 6px
}
.bk-modal.bk-stacked .bk-cfg-cat:first-child{margin-top:0}
.bk-modal.bk-stacked .bk-cfg-item{
  background:#fdf6fa;border:1px solid #f0e4eb;border-radius:8px;
  padding:10px 12px;margin-bottom:6px;
  display:flex;align-items:center;gap:10px;flex-wrap:wrap
}
.bk-modal.bk-stacked .bk-cfg-item.on{background:#fff;border-color:#d2527f}
.bk-modal.bk-stacked .bk-cfg-info{flex:1;min-width:0}
.bk-modal.bk-stacked .bk-cfg-name{font-size:.84rem;font-weight:600;color:#2b2b2b;line-height:1.3}
.bk-modal.bk-stacked .bk-cfg-meta{font-size:.72rem;color:#999;margin-top:2px}
.bk-modal.bk-stacked .bk-cfg-line-total{font-size:.78rem;color:#d2527f;font-weight:700}
.bk-modal.bk-stacked .bk-cfg-qty{
  display:grid;grid-template-columns:30px 50px 30px;border:1px solid #e8e8e8;
  border-radius:6px;overflow:hidden;background:#fff;flex-shrink:0
}
.bk-modal.bk-stacked .bk-cfg-qty button{background:#fdf6fa;border:0;color:#d2527f;cursor:pointer;font-weight:700;font-size:.9rem}
.bk-modal.bk-stacked .bk-cfg-qty input{border:0 !important;text-align:center;font-weight:600;font-size:.85rem;padding:6px 0;border-radius:0 !important}
.bk-modal.bk-stacked .bk-cfg-total{
  background:linear-gradient(135deg,#d2527f 0%,#b03a67 100%);
  color:#fff;padding:12px 16px;border-radius:8px;
  margin-top:12px;display:flex;justify-content:space-between;align-items:center;
  font-size:.88rem;font-weight:600
}
.bk-modal.bk-stacked .bk-cfg-total strong{color:#fff;font-weight:700}
.bk-modal.bk-stacked .bk-cfg-sum{font-size:.95rem}

/* Варианты услуг */
.bk-modal.bk-stacked .bk-variants{display:flex;flex-direction:column;gap:6px;margin-top:6px}
.bk-modal.bk-stacked .bk-variant{
  display:flex;align-items:center;gap:10px;padding:10px 12px;
  border:1.5px solid #e8e8e8;border-radius:8px;cursor:pointer;background:#fff;
  transition:border-color .12s,background .12s
}
.bk-modal.bk-stacked .bk-variant:hover{border-color:#d2527f;background:#fdf6fa}
.bk-modal.bk-stacked .bk-variant--sel{border-color:#d2527f;background:#fdf6fa}
.bk-modal.bk-stacked .bk-variant input{margin:0;flex-shrink:0}
.bk-modal.bk-stacked .bk-variant__body{flex:1;min-width:0}
.bk-modal.bk-stacked .bk-variant__name{font-size:.85rem;font-weight:600;color:#2b2b2b}
.bk-modal.bk-stacked .bk-variant__meta{font-size:.72rem;color:#999;margin-top:2px}
.bk-modal.bk-stacked .bk-variant__price{font-size:.85rem;font-weight:700;color:#d2527f}

/* Drop-zone */
.bk-modal.bk-stacked .bk-dropzone{
  border:2px dashed #e8d4dc;border-radius:10px;padding:18px 14px;text-align:center;
  background:#fafafa;cursor:pointer;transition:border-color .15s,background .15s
}
.bk-modal.bk-stacked .bk-dropzone:hover{border-color:#d2527f;background:#fdf6fa}
.bk-modal.bk-stacked .bk-dropzone__icon{font-size:1.4rem;margin-bottom:4px}
.bk-modal.bk-stacked .bk-dropzone__title{font-size:.85rem;font-weight:600;color:#3a3a3a;margin:0}
.bk-modal.bk-stacked .bk-dropzone__hint{font-size:.7rem;color:#999;margin-top:4px;line-height:1.3}
.bk-modal.bk-stacked .bk-files{margin-top:8px}
.bk-modal.bk-stacked .bk-file{
  display:flex;align-items:center;gap:8px;padding:6px 10px;background:#fdf6fa;
  border-radius:6px;margin-bottom:4px;font-size:.8rem
}

/* Summary */
.bk-modal.bk-stacked .bk-summary{background:#fdf6fa;border-radius:8px;padding:12px 14px;font-size:.82rem}
.bk-modal.bk-stacked .bk-summary table{width:100%;border-collapse:collapse}
.bk-modal.bk-stacked .bk-summary td{padding:4px 0;vertical-align:top}
.bk-modal.bk-stacked .bk-summary td:first-child{color:#999;font-weight:500;padding-right:10px;white-space:nowrap}
.bk-modal.bk-stacked .bk-summary td:last-child{color:#2b2b2b;font-weight:500}

/* Captcha + consent */
.bk-modal.bk-stacked .bk-captcha{
  display:grid;grid-template-columns:1fr auto auto;gap:8px;align-items:center;margin-top:6px
}
.bk-modal.bk-stacked .bk-captcha__q{
  font-weight:600;font-size:.9rem;color:#2b2b2b;
  background:#fdf6fa;padding:10px 12px;border-radius:8px
}
.bk-modal.bk-stacked .bk-captcha input{width:80px !important;text-align:center;font-weight:600}
.bk-modal.bk-stacked .bk-captcha__reload{
  background:#fdf6fa;border:1.5px solid #e8e8e8;color:#d2527f;
  width:38px;height:38px;border-radius:8px;cursor:pointer;font-size:1rem
}
.bk-modal.bk-stacked .bk-captcha__reload:hover{background:#f5e0ec}
.bk-modal.bk-stacked .bk-consent{
  display:flex;gap:10px;align-items:flex-start;font-size:.8rem;color:#666;
  line-height:1.4;margin-top:10px
}
.bk-modal.bk-stacked .bk-consent input{margin-top:2px;flex-shrink:0;accent-color:#d2527f}
.bk-modal.bk-stacked .bk-consent a{color:#d2527f;text-decoration:underline}

/* Form padding reset */
.bk-modal .bk-form{padding:0 !important}
.bk-modal.bk-stacked .bk-nav{padding:14px 24px;background:#fff;border-top:1px solid #f0e4eb}

/* Header модалки */
.bk-modal .bk-head{padding:18px 24px;background:#fff;border-bottom:1px solid #f0e4eb}
.bk-modal .bk-head h2{font-size:1.25rem !important;margin:0 0 2px}
.bk-modal .bk-sub{font-size:.82rem;color:#999}
.bk-modal .bk-close{position:absolute;top:14px;right:14px}

/* Errors */
.bk-modal.bk-stacked .bk-step.bk-invalid{border-color:#f56565}
.bk-modal.bk-stacked .bk-err-hint{color:#e53e3e;font-size:.74rem;margin-top:4px}

/* === Flatpickr theme === */
.flatpickr-calendar{
  background:#fff !important;border-radius:14px !important;
  box-shadow:0 12px 40px rgba(210,82,127,.18), 0 2px 8px rgba(0,0,0,.06) !important;
  border:1px solid #f0e4eb !important;font-family:inherit !important;
  width:320px !important;padding:6px;z-index:10100 !important
}
.flatpickr-months .flatpickr-month{background:transparent !important;color:#2b2b2b !important;height:38px;border-radius:8px}
.flatpickr-current-month{font-size:1rem !important;font-weight:700 !important;padding:6px 0 !important;color:#2b2b2b}
.flatpickr-prev-month,.flatpickr-next-month{
  fill:#d2527f !important;color:#d2527f !important;padding:8px !important;
  border-radius:8px !important;transition:background .15s
}
.flatpickr-prev-month:hover,.flatpickr-next-month:hover{background:#fdf6fa !important;fill:#b03a67 !important}
.flatpickr-weekday{background:transparent !important;color:#999 !important;font-size:.74rem !important;font-weight:600 !important;text-transform:uppercase}
.flatpickr-day{
  border-radius:8px !important;color:#3a3a3a !important;font-weight:500;border:none !important;
  max-width:40px;height:36px;line-height:36px;margin:1px;transition:background .12s,color .12s
}
.flatpickr-day:hover{background:#fdf6fa !important;color:#d2527f !important}
.flatpickr-day.today{background:transparent !important;color:#d2527f !important;font-weight:700;border:1.5px solid #f0c0d3 !important}
.flatpickr-day.selected,.flatpickr-day.selected:hover{
  background:#d2527f !important;color:#fff !important;border:none !important;
  font-weight:700;box-shadow:0 4px 12px rgba(210,82,127,.3)
}
.flatpickr-day.flatpickr-disabled,.flatpickr-day.flatpickr-disabled:hover,
.flatpickr-day.prevMonthDay,.flatpickr-day.nextMonthDay{color:#ccc !important;background:transparent !important}
input.flatpickr-input{display:none !important}
input.flatpickr-alt-input{display:block !important;cursor:pointer}

/* === Cards: auto height, no overflow clipping === */
.bk-modal.bk-stacked .bk-steps{align-items:start}
.bk-modal.bk-stacked .bk-step{
  height:auto;max-height:none;
  overflow:visible;display:flex !important;flex-direction:column
}
/* Контент с возможным скроллом */
.bk-modal.bk-stacked .bk-step .bk-cfg{
  flex:1;min-height:0;
  max-height:none !important;
  overflow-y:auto !important;
  padding-right:6px !important;
  scrollbar-width:thin;scrollbar-color:#d2527f #f5e8ef
}
.bk-modal.bk-stacked .bk-step .bk-cfg::-webkit-scrollbar{width:6px}
.bk-modal.bk-stacked .bk-step .bk-cfg::-webkit-scrollbar-thumb{background:#d2527f;border-radius:3px}
.bk-modal.bk-stacked .bk-step .bk-cfg::-webkit-scrollbar-track{background:#f5e8ef}

/* Итого внизу остаётся прижатым */
.bk-modal.bk-stacked .bk-step .bk-cfg-total{flex-shrink:0;margin-top:auto}
/* Подсказка/заголовок не скроллятся */
.bk-modal.bk-stacked .bk-step .bk-step-title,
.bk-modal.bk-stacked .bk-step .bk-step-hint{flex-shrink:0}

/* Drop-zone files: тоже скроллятся внутри карточки */
.bk-modal.bk-stacked .bk-step .bk-files{max-height:120px;overflow-y:auto}
.bk-modal.bk-stacked .bk-step .bk-variants{max-height:200px;overflow-y:auto}

/* Снять любые grid-column переопределения для full-width */
.bk-modal.bk-stacked .bk-step:has(.bk-cfg),
.bk-modal.bk-stacked .bk-step:has(.bk-dropzone),
.bk-modal.bk-stacked .bk-step:has(.bk-summary),
.bk-modal.bk-stacked .bk-step:has(.bk-variants),
.bk-modal.bk-stacked .bk-step:has(.bk-captcha){
  grid-column:span 12 !important
}
@media(min-width:680px){
  .bk-modal.bk-stacked .bk-step:has(.bk-cfg),
  .bk-modal.bk-stacked .bk-step:has(.bk-dropzone),
  .bk-modal.bk-stacked .bk-step:has(.bk-summary),
  .bk-modal.bk-stacked .bk-step:has(.bk-variants),
  .bk-modal.bk-stacked .bk-step:has(.bk-captcha){grid-column:span 6 !important}
}
@media(min-width:1100px){
  .bk-modal.bk-stacked .bk-step:has(.bk-cfg),
  .bk-modal.bk-stacked .bk-step:has(.bk-dropzone),
  .bk-modal.bk-stacked .bk-step:has(.bk-summary),
  .bk-modal.bk-stacked .bk-step:has(.bk-variants),
  .bk-modal.bk-stacked .bk-step:has(.bk-captcha){grid-column:span 4 !important}
}
@media(min-width:1500px){
  .bk-modal.bk-stacked .bk-step:has(.bk-cfg),
  .bk-modal.bk-stacked .bk-step:has(.bk-dropzone),
  .bk-modal.bk-stacked .bk-step:has(.bk-summary),
  .bk-modal.bk-stacked .bk-step:has(.bk-variants),
  .bk-modal.bk-stacked .bk-step:has(.bk-captcha){grid-column:span 3 !important}
}

/* Итого: белый текст для суммы, не прозрачный */
.bk-modal.bk-stacked .bk-cfg-sum,
.bk-cfg-total .bk-cfg-sum{color:#fff !important;opacity:1 !important;font-weight:700}
.bk-cfg-total{color:#fff !important}
.bk-cfg-total *{color:#fff !important;opacity:1 !important}

/* === ALL cards equal width — override any has() rules === */
.bk-modal.bk-stacked .bk-step,
.bk-modal.bk-stacked .bk-step:has(*){
  grid-column:span 12 !important
}
@media(min-width:680px){
  .bk-modal.bk-stacked .bk-step,
  .bk-modal.bk-stacked .bk-step:has(*){grid-column:span 6 !important}
}
@media(min-width:1100px){
  .bk-modal.bk-stacked .bk-step,
  .bk-modal.bk-stacked .bk-step:has(*){grid-column:span 4 !important}
}
@media(min-width:1500px){
  .bk-modal.bk-stacked .bk-step,
  .bk-modal.bk-stacked .bk-step:has(*){grid-column:span 3 !important}
}

/* === Программа: единая раскладка строк (без скачков) === */
.bk-modal.bk-stacked .bk-cfg-item{
  display:grid !important;
  grid-template-columns:1fr 110px;
  align-items:center;
  gap:8px 12px !important;
  flex-wrap:nowrap !important;
  padding:10px 12px !important;
  min-height:62px
}
.bk-modal.bk-stacked .bk-cfg-item .bk-cfg-info{
  grid-column:1;min-width:0
}
.bk-modal.bk-stacked .bk-cfg-item .bk-cfg-qty{
  grid-column:2;justify-self:end;
  grid-template-columns:28px 44px 28px;
  height:32px
}
.bk-modal.bk-stacked .bk-cfg-item .bk-cfg-qty button{height:32px;line-height:32px;padding:0}
.bk-modal.bk-stacked .bk-cfg-item .bk-cfg-qty input{height:32px;line-height:32px;padding:0;font-size:.85rem}
.bk-modal.bk-stacked .bk-cfg-item .bk-cfg-line-total{
  grid-column:1 / -1;text-align:right;font-size:.74rem;margin-top:0
}
/* Если cfg-line-total пустой — не должно расширять */
.bk-modal.bk-stacked .bk-cfg-item .bk-cfg-line-total:empty{display:none}

/* Категория-разделитель не выглядит карточкой */
.bk-modal.bk-stacked .bk-cfg-cat{
  background:transparent;padding:0;margin:14px 0 6px;
  border:0;font-size:.7rem
}
.bk-modal.bk-stacked .bk-cfg-cat:first-child{margin-top:0}

/* === Equal height row: align stretch === */
.bk-modal.bk-stacked .bk-steps{align-items:stretch !important}
.bk-modal.bk-stacked .bk-step{
  height:100% !important;max-height:none !important;
  align-self:stretch !important
}
/* Программа: скролл внутри пока не превысит высоту ряда */
.bk-modal.bk-stacked .bk-step .bk-cfg{
  flex:1 1 auto !important;min-height:0 !important;
  max-height:none !important;overflow-y:auto !important
}

/* Cancel stretch: рядки выравниваем по верху, карточки по контенту */
.bk-modal.bk-stacked .bk-steps{align-items:start !important}
.bk-modal.bk-stacked .bk-step{
  height:auto !important;align-self:start !important;
  max-height:none !important
}
/* Программа: фиксированная высота со скроллом (только десктоп) */
.bk-modal.bk-stacked .bk-step:has(.bk-cfg){
  overflow:hidden;display:flex !important;flex-direction:column
}
@media(min-width:680px){
  .bk-modal.bk-stacked .bk-step:has(.bk-cfg){
    height:560px !important;max-height:560px !important
  }
}
.bk-modal.bk-stacked .bk-step:has(.bk-cfg) .bk-cfg{
  flex:1 1 auto !important;min-height:0 !important;
  max-height:none !important;overflow-y:auto !important;
  padding-right:6px !important;
  scrollbar-width:thin;scrollbar-color:#d2527f #f5e8ef
}
.bk-modal.bk-stacked .bk-step:has(.bk-cfg) .bk-cfg::-webkit-scrollbar{width:6px}
.bk-modal.bk-stacked .bk-step:has(.bk-cfg) .bk-cfg::-webkit-scrollbar-thumb{background:#d2527f;border-radius:3px}
.bk-modal.bk-stacked .bk-step:has(.bk-cfg) .bk-cfg-total{flex-shrink:0;margin-top:12px !important}

/* (masonry removed — using grid from above) */
/* Программа: ограничить высоту, скролл внутри */
.bk-modal.bk-stacked .bk-step:has(.bk-cfg){
  max-height:560px !important;overflow:hidden;
  display:flex !important;flex-direction:column
}
.bk-modal.bk-stacked .bk-step:has(.bk-cfg) .bk-cfg{
  flex:1 1 auto !important;min-height:0 !important;
  overflow-y:auto !important;padding-right:6px !important
}
.bk-modal.bk-stacked .bk-step:has(.bk-cfg) .bk-cfg-total{flex-shrink:0;margin-top:12px !important}

/* Гарантия что кнопки кликабельны */
.bk-modal.bk-stacked .bk-num-btn{pointer-events:auto !important;cursor:pointer !important;z-index:2}
.bk-modal.bk-stacked .bk-number{position:relative}

/* Reset absolute positioning on number buttons in stacked mode */
.bk-modal.bk-stacked .bk-num-btn{
  position:static !important;transform:none !important;
  width:100% !important;height:100% !important;
  border-radius:0 !important;border:0 !important
}
.bk-modal.bk-stacked .bk-number{position:relative !important;height:42px}

/* Submit footer — внизу формы, не sticky */
.bk-modal.bk-stacked .bk-nav{
  position:static !important;
  z-index:10;background:#fff;border-top:1px solid #f0e4eb;
  padding:14px 24px;
  box-shadow:0 -4px 12px rgba(0,0,0,.06)
}
.bk-modal.bk-stacked .bk-btn--submit{
  margin:0 !important;font-size:1rem;padding:14px 24px;
  background:#d2527f;color:#fff;border:0;border-radius:10px;
  cursor:pointer;font-weight:700;width:100%
}
.bk-modal.bk-stacked .bk-btn--submit:hover{background:#b03a67}

/* Модалка: header fixed, form scrolls, nav в потоке контента */
.bk-modal.bk-stacked{display:flex !important;flex-direction:column;height:100vh;max-height:100vh}
.bk-modal.bk-stacked .bk-head{flex-shrink:0}
.bk-modal.bk-stacked .bk-form{flex:1 1 auto;min-height:0;overflow-y:auto;display:block !important}
.bk-modal.bk-stacked .bk-steps{flex:none}
.bk-modal.bk-stacked .bk-nav{
  position:static !important;
  background:#fff;border-top:1px solid #f0e4eb;
  padding:14px 24px;box-shadow:0 -4px 12px rgba(0,0,0,.06)
}

/* Подсветка невалидной карточки и полей */
.bk-modal.bk-stacked .bk-step.bk-invalid{
  border-color:#f56565 !important;
  box-shadow:0 0 0 3px rgba(245,101,101,.18), 0 1px 4px rgba(0,0,0,.05) !important;
  animation:bkShake .35s ease
}
@keyframes bkShake{
  0%,100%{transform:translateX(0)}
  20%,60%{transform:translateX(-4px)}
  40%,80%{transform:translateX(4px)}
}
.bk-modal.bk-stacked .bk-field.bk-invalid input,
.bk-modal.bk-stacked .bk-field.bk-invalid textarea,
.bk-modal.bk-stacked .bk-field.bk-invalid .bk-number,
.bk-modal.bk-stacked .bk-field.bk-invalid .bk-input-wrap textarea,
.bk-modal.bk-stacked .bk-field.bk-invalid .flatpickr-alt-input{
  border-color:#f56565 !important;background:#fff5f5 !important
}
.bk-modal.bk-stacked .bk-err-hint{
  display:block;color:#e53e3e;font-size:.78rem;font-weight:600;
  margin-top:6px;padding:4px 8px;background:#fff5f5;border-radius:6px;
  border-left:3px solid #f56565
}

/* Сводка ошибок над submit */
.bk-modal.bk-stacked .bk-error{
  display:none;background:#fff5f5;border:1.5px solid #f56565;
  color:#c53030;border-radius:10px;padding:12px 16px;margin:0 16px 12px;
  font-size:.88rem;line-height:1.4
}
.bk-modal.bk-stacked .bk-error.on{display:block}
.bk-modal.bk-stacked .bk-error ul{margin:6px 0 0;padding-left:20px}
.bk-modal.bk-stacked .bk-error li{margin-bottom:2px}

/* Итого по количеству для простой услуги */
.bk-modal.bk-stacked .bk-qty-total{
  margin-top:12px;padding:12px 16px;border-radius:10px;
  background:linear-gradient(135deg,#d2527f 0%,#b03a67 100%);
  color:#fff;font-size:.92rem;font-weight:600;
  display:flex;justify-content:space-between;align-items:center
}
.bk-modal.bk-stacked .bk-qty-total strong{color:#fff;font-size:1rem}

/* Home button in modal header */
.bk-home-btn{display:inline-block;padding:8px 16px;background:#d2527f;color:#fff !important;border-radius:8px;font-size:.82rem;font-weight:600;text-decoration:none !important;transition:background .2s;white-space:nowrap;margin-top:6px}
.bk-home-btn:hover{background:#b03a67}
@media(max-width:600px){
  .bk-home-btn{padding:7px 14px;font-size:.78rem}
}
