/* ── IMAGE ZOOM ── */
.img-zoom-bg{position:fixed;inset:0;background:rgba(0,0,0,.93);z-index:600;display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .3s;cursor:zoom-out}
.img-zoom-bg.open{opacity:1;pointer-events:all}
.img-zoom-bg img{max-width:95vw;max-height:95vh;object-fit:contain;border-radius:12px;transform:scale(.88);transition:transform .35s var(--spring)}
.img-zoom-bg.open img{transform:scale(1)}
.m-img img{cursor:zoom-in}

/* ── PRODUCT MODAL ── */
.modal-bg{position:fixed;inset:0;background:rgba(10,4,8,.72);z-index:500;display:flex;align-items:center;justify-content:center;padding:28px;opacity:0;pointer-events:none;transition:opacity .4s;backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px)}
.modal-bg.open{opacity:1;pointer-events:all}
.modal-box{background:#fff;border-radius:30px;overflow:hidden;width:100%;max-width:860px;display:grid;grid-template-columns:1fr 1fr;transform:scale(.92) translateY(20px);transition:transform .5s var(--spring);max-height:90vh;position:relative}
.modal-bg.open .modal-box{transform:scale(1) translateY(0)}
.m-img{overflow:hidden;background:var(--bg);position:relative}
.m-img img{width:100%;height:100%;object-fit:cover;object-position:center center;display:block}
.m-content{padding:44px 40px;overflow-y:auto;display:flex;flex-direction:column;gap:16px}
.m-cat{font-size:10px;font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:var(--mauve)}
.m-name{font-family:'Playfair Display',serif;font-size:30px;font-weight:400;color:var(--plum);line-height:1.1}
.m-price{font-family:'Playfair Display',serif;font-size:36px;font-weight:400;color:var(--plum)}
.m-price small{font-family:'DM Sans';font-size:13px;font-weight:300;color:var(--muted)}
.m-desc{font-size:14px;font-weight:300;color:var(--muted);line-height:1.85}
.m-inc{background:var(--bg);border-radius:14px;padding:18px 20px}
.m-inc h5{font-size:10px;font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:var(--plum);margin-bottom:12px}
.inc-list{list-style:none;display:flex;flex-direction:column;gap:8px}
.inc-list li{font-size:13px;font-weight:300;color:var(--text);display:flex;align-items:center;gap:9px}
.inc-list li::before{content:'';width:5px;height:5px;border-radius:50%;background:var(--dpink);flex-shrink:0}
.m-btns{display:flex;flex-direction:column;gap:9px;margin-top:4px}
.mbtn{padding:14px;border-radius:100px;border:none;font-family:'DM Sans',sans-serif;font-size:14px;font-weight:500;cursor:pointer;transition:all .22s var(--spring);letter-spacing:.04em;text-align:center;text-decoration:none;display:block}
.mbtn-p{background:var(--plum);color:#fff}.mbtn-p:hover{background:var(--mauve);transform:translateY(-1px)}
.mbtn-wa{background:var(--green);color:#fff;display:flex;align-items:center;justify-content:center;gap:9px}.mbtn-wa:hover{background:#1fb059;transform:translateY(-1px)}
.m-close{position:absolute;top:14px;right:14px;width:36px;height:36px;border-radius:50%;background:#fff;border:1px solid var(--border);font-size:14px;cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:10;transition:background .2s,transform .25s var(--spring);box-shadow:0 2px 10px rgba(0,0,0,.12)}
.m-close:hover{background:var(--bg);transform:rotate(90deg)}

/* ── CHECKOUT MODAL ── */
.checkout-bg{position:fixed;inset:0;background:rgba(10,4,8,.75);z-index:600;display:flex;align-items:center;justify-content:center;padding:24px;opacity:0;pointer-events:none;transition:opacity .4s;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px)}
.checkout-bg.open{opacity:1;pointer-events:all}
.checkout-box{background:#fff;border-radius:28px;width:100%;max-width:580px;max-height:92vh;overflow-y:auto;transform:scale(.93) translateY(18px);transition:transform .5s var(--spring);position:relative}
.checkout-bg.open .checkout-box{transform:scale(1) translateY(0)}
.checkout-hd{padding:24px 32px 0;border-bottom:1px solid var(--border);padding-bottom:26px;position:sticky;top:0;background:#fff;z-index:2;border-radius:28px 28px 0 0}
.checkout-hd h3{font-family:'Playfair Display',serif;font-size:22px;font-weight:400;color:var(--plum);margin-bottom:4px}
.checkout-hd p{font-size:12px;font-weight:300;color:var(--muted);margin-bottom:0}
.steps-bar{display:flex;gap:0;margin-top:32px}
.step-dot{flex:1;height:3px;background:var(--border);transition:background .4s;position:relative}
.step-dot::before{content:attr(data-n);position:absolute;top:-22px;left:50%;transform:translateX(-50%);font-size:10px;font-weight:500;color:var(--muted);letter-spacing:.06em}
.step-dot.done{background:var(--mauve)}.step-dot.active{background:var(--dpink)}
.checkout-body{padding:28px 32px}
.ck-step{display:none}.ck-step.active{display:block}
.ck-product-preview{display:flex;gap:14px;align-items:center;background:var(--bg);border-radius:14px;padding:14px;margin-bottom:22px}
.ck-prod-img{width:60px;height:60px;border-radius:10px;overflow:hidden;flex-shrink:0}
.ck-prod-img img{width:100%;height:100%;object-fit:cover;object-position:center center}
.ck-prod-name{font-family:'Playfair Display',serif;font-size:16px;font-weight:400;color:var(--plum)}
.ck-prod-cat{font-size:11px;font-weight:300;color:var(--muted)}
.ck-prod-price{font-size:14px;font-weight:500;color:var(--mauve);margin-top:2px}
.ck-section-title{font-size:11px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--plum);margin-bottom:14px;padding-bottom:8px;border-bottom:1px solid var(--border)}
.ck-field{margin-bottom:14px}
.ck-field label{display:block;font-size:12px;font-weight:500;color:var(--muted);margin-bottom:5px}
.ck-field label span{color:var(--dpink)}
.ck-field input,.ck-field textarea,.ck-field select{width:100%;padding:11px 14px;border:1px solid var(--border);border-radius:10px;font-family:'DM Sans',sans-serif;font-size:14px;font-weight:300;color:var(--text);background:#fff;outline:none;transition:border-color .2s,box-shadow .2s}
.ck-field input:focus,.ck-field textarea:focus,.ck-field select:focus{border-color:var(--mauve);box-shadow:0 0 0 3px rgba(139,74,110,.08)}
.ck-field textarea{height:80px;resize:vertical}
.ck-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.date-note{display:flex;align-items:center;gap:8px;font-size:12px;font-weight:300;color:var(--muted);background:#fff8ec;border:1px solid #fde8a0;border-radius:10px;padding:10px 14px;margin-bottom:16px}
.date-note::before{content:'📅';font-size:16px;flex-shrink:0}
.promo-row{display:flex;gap:10px;margin-bottom:8px}
.promo-row input{flex:1;padding:11px 14px;border:1px solid var(--border);border-radius:10px;font-family:'DM Sans',sans-serif;font-size:14px;font-weight:300;color:var(--text);outline:none;transition:border-color .2s}
.promo-row input:focus{border-color:var(--mauve)}
.promo-apply{padding:11px 20px;border-radius:10px;background:var(--plum);color:#fff;border:none;font-family:'DM Sans',sans-serif;font-size:13px;font-weight:500;cursor:pointer;transition:background .2s,transform .2s var(--spring);white-space:nowrap}
.promo-apply:hover{background:var(--mauve);transform:translateY(-1px)}
.promo-msg{font-size:12px;font-weight:400;padding:0;margin-bottom:14px}
.promo-msg.ok{color:#1a7a3d}.promo-msg.err{color:#c0392b}
.ck-summary{background:var(--bg);border-radius:14px;padding:16px 18px;margin-bottom:18px}
.summary-row{display:flex;justify-content:space-between;align-items:center;font-size:13px;font-weight:300;color:var(--text);padding:5px 0}
.summary-row.discount{color:#1a7a3d;font-weight:400}
.summary-row.total{font-family:'Playfair Display',serif;font-size:20px;font-weight:400;color:var(--plum);border-top:1px solid var(--border);margin-top:8px;padding-top:12px}
.payment-methods{display:flex;flex-direction:column;gap:10px;margin-bottom:18px}
.pay-opt{display:flex;align-items:center;gap:12px;padding:14px 16px;border:1.5px solid var(--border);border-radius:12px;cursor:pointer;transition:border-color .2s,background .2s}
.pay-opt:hover{border-color:var(--pink);background:#fdf5f8}
.pay-opt.selected{border-color:var(--mauve);background:#fdf5f8}
.pay-opt input[type=radio]{accent-color:var(--mauve);width:16px;height:16px;flex-shrink:0}
.pay-icon{width:36px;height:36px;border-radius:9px;display:flex;align-items:center;justify-content:center;font-size:18px;flex-shrink:0}
.pay-info strong{display:block;font-size:13px;font-weight:500;color:var(--plum)}
.pay-info span{font-size:11px;font-weight:300;color:var(--muted)}
.confirm-check{width:56px;height:56px;border-radius:50%;background:#e8f9ef;display:flex;align-items:center;justify-content:center;font-size:26px;margin:0 auto 16px}
.confirm-title{font-family:'Playfair Display',serif;font-size:24px;font-weight:400;color:var(--plum);text-align:center;margin-bottom:8px}
.confirm-sub{font-size:13px;font-weight:300;color:var(--muted);text-align:center;margin-bottom:22px;line-height:1.7}
.pay-detail-box{background:var(--bg);border:1px solid var(--border);border-radius:14px;padding:16px 18px;margin-bottom:18px}
.pay-detail-box h5{font-size:10px;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--plum);margin-bottom:12px}
.pay-detail-row{display:flex;justify-content:space-between;font-size:13px;padding:4px 0;color:var(--text)}
.pay-detail-row strong{font-weight:500;color:var(--plum)}
.ck-footer{padding:20px 32px;border-top:1px solid var(--border);display:flex;gap:10px;position:sticky;bottom:0;background:#fff;border-radius:0 0 28px 28px}
.ck-btn{flex:1;padding:13px;border-radius:100px;border:none;font-family:'DM Sans',sans-serif;font-size:13px;font-weight:500;cursor:pointer;transition:all .22s var(--spring)}
.ck-btn-back{background:var(--bg);color:var(--plum);border:1px solid var(--border)}.ck-btn-back:hover{border-color:var(--mauve)}
.ck-btn-next{background:var(--plum);color:#fff}.ck-btn-next:hover{background:var(--mauve);transform:translateY(-1px)}
.ck-btn-wa{background:var(--green);color:#fff;display:flex;align-items:center;justify-content:center;gap:8px;text-decoration:none}.ck-btn-wa:hover{background:#1fb059;transform:translateY(-1px)}
.ck-close{position:absolute;top:18px;right:18px;width:34px;height:34px;border-radius:50%;background:#fff;border:1.5px solid var(--border);font-size:13px;cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:3;transition:background .2s,transform .25s var(--spring);box-shadow:0 2px 8px rgba(45,27,46,.1);color:var(--plum)}
.ck-close:hover{background:var(--bg);transform:rotate(90deg)}

/* ── TOAST ── */
.toast{position:fixed;bottom:90px;left:50%;transform:translateX(-50%) translateY(36px);background:var(--plum);color:#fff;padding:13px 26px;border-radius:100px;font-size:14px;z-index:700;transition:transform .5s var(--spring),opacity .3s;white-space:nowrap;pointer-events:none;opacity:0;box-shadow:0 8px 28px rgba(45,27,46,.25)}
.toast.show{transform:translateX(-50%) translateY(0);opacity:1}

/* ── KEYFRAMES ── */
@keyframes fu{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:translateY(0)}}
@keyframes fi{from{opacity:0}to{opacity:1}}
