/* ─── Cart Drawer ─── */
.cd-overlay{position:fixed;inset:0;z-index:9000;pointer-events:none}
.cd-overlay.cd-open{pointer-events:auto}
.cd-backdrop{position:absolute;inset:0;background:rgba(0,0,0,.45);opacity:0;transition:opacity .3s;cursor:pointer}
.cd-overlay.cd-open .cd-backdrop{opacity:1}
.cd-panel{position:absolute;top:0;right:0;bottom:0;width:480px;max-width:100vw;background:#fff;display:flex;flex-direction:column;transform:translateX(100%);transition:transform .3s cubic-bezier(.4,0,.2,1);overflow:hidden;box-shadow:-4px 0 40px rgba(0,0,0,.14)}
.cd-overlay.cd-open .cd-panel{transform:translateX(0)}

/* Header */
.cd-hdr{display:flex;align-items:center;gap:8px;padding:14px 16px;border-bottom:1px solid #f0f0f0;flex-shrink:0;background:#fff;z-index:1}
.cd-back{background:none;border:none;cursor:pointer;font-size:20px;color:#333;padding:4px 8px 4px 0;line-height:1;display:flex;align-items:center}
.cd-hdr-title{font-size:17px;font-weight:700;color:#1c1c1c;flex:1}

/* Delivery badge */
.cd-delivery{display:flex;align-items:center;gap:10px;padding:10px 16px;background:#f8fff8;border-bottom:1px solid #e8f5e9;flex-shrink:0}
.cd-del-icon{width:34px;height:34px;background:#0c831f;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-size:15px;flex-shrink:0}
.cd-del-time{font-size:13px;font-weight:700;color:#1c1c1c}
.cd-del-sub{font-size:11px;color:#777}

/* Steps */
.cd-step{display:flex;flex-direction:column;flex:1;overflow:hidden;min-height:0}

/* Body */
.cd-body{flex:1;overflow-y:auto;overflow-x:hidden;-webkit-overflow-scrolling:touch}

/* Items */
.cd-item{display:flex;align-items:center;gap:12px;padding:14px 16px;border-bottom:1px solid #f5f5f5}
.cd-item-img{width:56px;height:56px;object-fit:cover;border-radius:8px;border:1px solid #f0f0f0;flex-shrink:0}
.cd-item-info{flex:1;min-width:0}
.cd-item-name{font-size:13px;font-weight:600;color:#1c1c1c;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.cd-item-size{font-size:11px;color:#888;margin-top:2px}
.cd-item-price{font-size:13px;font-weight:700;color:#1c1c1c;margin-top:4px}
.cd-item-qty{display:flex;align-items:center;border:1.5px solid #0c831f;border-radius:8px;overflow:hidden;flex-shrink:0}
.cd-qty-btn{width:32px;height:32px;background:#0c831f;border:none;color:#fff;font-size:18px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;line-height:1}
.cd-qty-btn:active{background:#0a6e1a}
.cd-qty-val{width:30px;height:32px;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;color:#0c831f}

/* Empty / loading */
.cd-empty{text-align:center;padding:48px 20px}
.cd-empty-icon{font-size:52px;margin-bottom:12px}
.cd-empty-text{font-size:14px;color:#999}
.cd-loading{text-align:center;padding:40px;color:#aaa;font-size:13px}

/* Bill */
.cd-bill{padding:16px;border-top:8px solid #f2f3f7}
.cd-bill-ttl{font-size:14px;font-weight:700;color:#1c1c1c;margin-bottom:12px}
.cd-bill-row{display:flex;justify-content:space-between;align-items:center;padding:5px 0;font-size:13px;color:#555}
.cd-bill-row.grand{border-top:1.5px dashed #e0e0e0;margin-top:8px;padding-top:10px;font-size:14px;font-weight:700;color:#1c1c1c}
.cd-bill-note{font-size:11px;color:#bbb;margin-top:6px}

/* Policy */
.cd-policy{padding:14px 16px;border-top:8px solid #f2f3f7}
.cd-policy-ttl{font-size:13px;font-weight:700;color:#1c1c1c;margin-bottom:4px}
.cd-policy-txt{font-size:12px;color:#999;line-height:1.5}

/* Address bar */
.cd-addr-bar{display:flex;align-items:center;gap:10px;padding:10px 16px;background:#f8fff8;border-top:1px solid #e8f5e9;cursor:pointer;flex-shrink:0}
.cd-addr-bar:hover{background:#f0fdf4}
.cd-addr-icon{color:#0c831f;font-size:16px;flex-shrink:0}
.cd-addr-info{flex:1;min-width:0}
.cd-addr-label{font-size:12px;font-weight:700;color:#1c1c1c}
.cd-addr-detail{font-size:11px;color:#888;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.cd-addr-change{font-size:12px;color:#0c831f;font-weight:700;flex-shrink:0}

/* Footer */
.cd-footer{flex-shrink:0}
.cd-footer-btn{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;background:#0c831f;cursor:pointer}
.cd-footer-btn:hover{background:#0a6e1a}
.cd-ftotal{color:#fff;font-size:15px;font-weight:700}
.cd-fcta{color:#fff;font-size:14px;font-weight:700}

/* Login / OTP step */
.cd-login-box{padding:36px 24px 20px;text-align:center}
.cd-login-logo{width:64px;height:64px;background:linear-gradient(135deg,#4f46e5,#7c3aed);border-radius:16px;margin:0 auto 16px;display:flex;align-items:center;justify-content:center;font-size:28px;color:#fff}
.cd-login-ttl{font-size:18px;font-weight:700;color:#1c1c1c;margin-bottom:4px}
.cd-login-sub{font-size:13px;color:#888;margin-bottom:24px}
.cd-phone-row{display:flex;border:1.5px solid #e0e0e0;border-radius:12px;overflow:hidden;margin-bottom:12px;text-align:left}
.cd-phone-pre{padding:13px 12px;background:#f5f5f5;font-size:14px;font-weight:600;color:#444;border-right:1px solid #e0e0e0;flex-shrink:0}
.cd-phone-inp{flex:1;border:none;outline:none;padding:13px 12px;font-size:15px;background:#fff;min-width:0}
.cd-otp-inp{width:100%;border:1.5px solid #e0e0e0;border-radius:12px;padding:14px 16px;font-size:22px;letter-spacing:8px;text-align:center;outline:none;margin-bottom:12px;box-sizing:border-box;font-family:inherit}
.cd-otp-inp:focus{border-color:#4f46e5}
.cd-cont-btn{width:100%;padding:14px;background:#0c831f;color:#fff;border:none;border-radius:12px;font-size:15px;font-weight:700;cursor:pointer;font-family:inherit}
.cd-cont-btn:disabled{background:#aaa;cursor:not-allowed}
.cd-resend-row{font-size:12px;color:#999;margin-top:10px}
.cd-resend-row a{color:#0c831f;cursor:pointer;text-decoration:none;font-weight:600}
.cd-field-err{color:#dc2626;font-size:12px;text-align:center;margin-bottom:8px;display:none;padding:6px 10px;background:#fef2f2;border-radius:8px}
.cd-success-msg{color:#0c831f;font-size:13px;text-align:center;margin-bottom:8px;display:none;font-weight:600}
.cd-back-link{font-size:12px;color:#0c831f;cursor:pointer;text-align:center;margin-top:14px;display:block}
.cd-tos{font-size:11px;color:#bbb;margin-top:10px;line-height:1.5}

/* Address step */
.cd-addr-add{display:flex;align-items:center;gap:12px;padding:16px;margin:8px 0;background:#fff;border:1.5px dashed #0c831f;border-radius:12px;cursor:pointer;font-size:14px;font-weight:600;color:#0c831f}
.cd-addr-add:hover{background:#f0fdf4}
.cd-addr-card{display:flex;align-items:flex-start;gap:12px;padding:14px;background:#fff;border:1.5px solid #e8e8e8;border-radius:12px;margin-bottom:10px;cursor:pointer;transition:border-color .2s}
.cd-addr-card:hover{border-color:#0c831f;background:#f8fff8}
.cd-addr-card.selected{border-color:#0c831f;background:#f0fdf4}
.cd-addr-type-icon{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0;background:#e8f5e9}
.cd-addr-type-icon.home{background:#e8f5e9}.cd-addr-type-icon.work{background:#e8f0fe}.cd-addr-type-icon.shop{background:#fff3e0}.cd-addr-type-icon.other{background:#fce4ec}
.cd-addr-card-info{flex:1;min-width:0}
.cd-addr-card-label{font-size:13px;font-weight:700;color:#1c1c1c}
.cd-addr-card-detail{font-size:12px;color:#777;margin-top:3px;line-height:1.4}
.cd-addr-card-name{font-size:12px;font-weight:600;color:#1c1c1c;margin-top:4px}
.cd-addr-deliver-btn{width:100%;padding:11px;background:#0c831f;color:#fff;border:none;border-radius:10px;font-size:13px;font-weight:700;cursor:pointer;margin-top:10px;font-family:inherit}

/* Per-field error */
.cd-af-err{display:none;color:#dc2626;font-size:11px;margin-top:3px;padding:3px 8px;background:#fef2f2;border-radius:6px}

/* Add address form */
.cd-type-row{display:flex;gap:8px;margin-bottom:16px;flex-wrap:wrap}
.cd-type-chip{flex:1;min-width:70px;padding:8px 4px;border:1.5px solid #e0e0e0;border-radius:10px;background:#fff;font-size:12px;font-weight:600;cursor:pointer;font-family:inherit;color:#555;transition:all .15s}
.cd-type-chip.active{border-color:#0c831f;background:#f0fdf4;color:#0c831f}
.cd-af-label{display:block;font-size:11px;font-weight:700;color:#555;text-transform:uppercase;letter-spacing:.4px;margin-bottom:4px;margin-top:12px}
.cd-af-inp{width:100%;border:1.5px solid #e0e0e0;border-radius:10px;padding:11px 12px;font-size:14px;font-family:inherit;outline:none;box-sizing:border-box;background:#fafafa;color:#1c1c1c}
.cd-af-inp:focus{border-color:#0c831f;background:#fff;box-shadow:0 0 0 3px rgba(12,131,31,.08)}

/* Mobile: bottom sheet */
@media(max-width:767px){
  .cd-panel{width:100%;top:auto;height:90vh;max-height:90vh;border-radius:16px 16px 0 0;transform:translateY(100%)}
  .cd-overlay.cd-open .cd-panel{transform:translateY(0)}
  .cd-login-box{padding:24px 20px 16px}
  .cd-login-logo{width:52px;height:52px;font-size:22px}
  .cd-otp-inp{font-size:20px;letter-spacing:6px}
  /* Center login/OTP content vertically so it doesn't float to top of 90vh panel */
  #cdStep_login .cd-body,
  #cdStep_otp .cd-body{display:flex;flex-direction:column;justify-content:center}
  #cdStep_address .cd-body,
  #cdStep_addAddr .cd-body{padding-bottom:16px}
}
