/* ============================================================
   oneday withme — cart + checkout styles
   ============================================================ */

/* Cart icon button in nav */
.cart-trigger{
  position:relative;
  width:42px;height:42px;border:1px solid var(--line);border-radius:50%;
  background:#fff;cursor:pointer;
  display:inline-flex;align-items:center;justify-content:center;
  transition:border-color .25s ease,background .25s ease;
  margin-left:14px;
}
.cart-trigger:hover{border-color:var(--ink);background:var(--bg-soft)}
.cart-trigger svg{width:18px;height:18px;stroke:var(--ink);stroke-width:1.6;fill:none}
.cart-badge{
  position:absolute;top:-4px;right:-4px;
  min-width:18px;height:18px;padding:0 5px;border-radius:9px;
  background:var(--accent);color:#fff;
  font-size:.62rem;font-weight:600;letter-spacing:.04em;
  display:none;align-items:center;justify-content:center;
}

/* Quick Add button on card (overlay) */
.col-card{position:relative}
.col-card .quick-add{
  position:absolute;top:14px;right:14px;z-index:3;
  width:38px;height:38px;border-radius:50%;border:0;
  background:rgba(255,255,255,.95);color:var(--ink);
  cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  font-size:1.3rem;line-height:1;font-weight:300;
  opacity:0;transform:translateY(-6px);
  transition:opacity .35s ease,transform .35s ease,background .25s ease;
  box-shadow:0 6px 16px -6px rgba(0,0,0,.25);
}
.col-card:hover .quick-add{opacity:1;transform:translateY(0)}
.col-card .quick-add:hover{background:var(--ink);color:#fff}
@media (hover:none){
  .col-card .quick-add{opacity:1;transform:none}
}

/* Drawer */
.drawer-backdrop{
  position:fixed;inset:0;background:rgba(20,15,10,.4);
  opacity:0;pointer-events:none;transition:opacity .35s ease;z-index:90;
}
.drawer-backdrop.show{opacity:1;pointer-events:auto}

.drawer{
  position:fixed;top:0;right:0;bottom:0;width:460px;max-width:92vw;
  background:var(--bg);z-index:100;
  transform:translateX(100%);transition:transform .4s cubic-bezier(.2,.7,.2,1);
  display:flex;flex-direction:column;
  box-shadow:-30px 0 60px -20px rgba(0,0,0,.25);
}
.drawer.open{transform:none}
.drawer-head{
  display:flex;align-items:center;justify-content:space-between;
  padding:24px 26px;border-bottom:1px solid var(--line);
}
.drawer-head h3{
  font-family:"Cormorant Garamond",serif;font-size:1.6rem;font-weight:400;margin:0;
}
.drawer-close{
  background:transparent;border:0;cursor:pointer;font-size:1.5rem;color:var(--ink);
  width:36px;height:36px;display:flex;align-items:center;justify-content:center;
}
.drawer-body{flex:1;overflow-y:auto;padding:8px 0}

.cart-empty{padding:60px 30px;text-align:center;color:var(--muted)}
.cart-empty svg{width:48px;height:48px;stroke:var(--muted);stroke-width:1.4;fill:none;margin-bottom:14px}

.cart-row{
  display:grid;grid-template-columns:80px 1fr auto;gap:14px;
  padding:18px 26px;border-bottom:1px solid var(--line);
}
.cart-row img{width:80px;height:100px;object-fit:cover;background:var(--bg-soft)}
.cart-row-info{display:flex;flex-direction:column;gap:6px}
.cart-row-code{font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;color:var(--muted)}
.cart-row-name{font-family:"Cormorant Garamond",serif;font-size:1.15rem;line-height:1.2;color:var(--ink)}
.cart-row-controls{display:flex;align-items:center;gap:10px;margin-top:4px}
.cart-row-controls button{
  width:26px;height:26px;border:1px solid var(--line);background:#fff;cursor:pointer;
  font-size:1rem;line-height:1;color:var(--ink);
  display:flex;align-items:center;justify-content:center;
  transition:background .2s ease,border-color .2s ease;
}
.cart-row-controls button:hover{border-color:var(--ink);background:var(--bg-soft)}
.cart-row-controls span{min-width:22px;text-align:center;font-size:.95rem}
.cart-row-controls .rm{
  width:auto;padding:0 8px;margin-left:6px;font-size:.7rem;color:var(--muted);
  letter-spacing:.1em;text-transform:uppercase;border-color:transparent;
}
.cart-row-controls .rm:hover{color:#c4493b;border-color:#c4493b;background:#fff}
.cart-row-price{font-family:"Cormorant Garamond",serif;font-size:1.2rem;color:var(--ink);align-self:flex-start}

.free-ship-hint{
  margin:12px 26px;padding:12px 14px;background:var(--bg-soft);
  font-size:.85rem;color:var(--ink-soft);border-radius:2px;text-align:center;
}

.drawer-foot{
  padding:24px 26px;border-top:1px solid var(--line);background:#fff;
}
.promo-input{
  display:flex;gap:8px;margin-bottom:16px;
}
.promo-input input{
  flex:1;padding:11px 12px;border:1px solid var(--line);background:#fff;
  font-family:inherit;font-size:.92rem;color:var(--ink);
  text-transform:uppercase;letter-spacing:.05em;
}
.promo-input input:focus{outline:0;border-color:var(--ink)}
.promo-input button{
  padding:11px 18px;background:var(--ink);color:var(--bg);border:0;cursor:pointer;
  font-family:inherit;font-size:.74rem;letter-spacing:.18em;text-transform:uppercase;
  transition:background .2s ease;
}
.promo-input button:hover{background:#000}

.cart-summary-row{
  display:flex;justify-content:space-between;align-items:center;
  margin-bottom:8px;color:var(--ink-soft);font-size:.95rem;
}
.cart-summary-row.total{
  margin-top:10px;padding-top:14px;border-top:1px solid var(--line);
  color:var(--ink);font-size:1.1rem;font-weight:500;
}
.cart-summary-row.total span:last-child{font-family:"Cormorant Garamond",serif;font-size:1.6rem;font-weight:400}
.btn-checkout{
  width:100%;margin-top:18px;padding:16px;
  background:var(--ink);color:var(--bg);border:0;cursor:pointer;
  font-family:inherit;font-size:.82rem;letter-spacing:.22em;text-transform:uppercase;
  transition:background .25s ease;
}
.btn-checkout:hover{background:#000}
.shop-more{
  display:block;text-align:center;margin-top:10px;
  font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;color:var(--ink-soft);
  cursor:pointer;
}

/* Checkout modal */
.checkout-modal{
  position:fixed;inset:0;background:rgba(20,15,10,.55);z-index:110;
  display:none;align-items:flex-start;justify-content:center;
  padding:30px 16px;overflow-y:auto;
}
.checkout-modal.show{display:flex}
.co-card{
  background:var(--bg);width:100%;max-width:780px;border-radius:2px;
  display:flex;flex-direction:column;max-height:calc(100vh - 60px);
  box-shadow:0 40px 80px -20px rgba(0,0,0,.4);
}
.co-head{
  padding:24px 30px;border-bottom:1px solid var(--line);
  display:flex;align-items:center;justify-content:space-between;
}
.co-head h2{font-family:"Cormorant Garamond",serif;font-size:1.7rem;font-weight:400;margin:0}
.co-close{background:transparent;border:0;font-size:1.4rem;cursor:pointer;color:var(--ink);padding:4px 8px}

.co-progress{
  list-style:none;padding:0;margin:0;display:flex;gap:0;
  border-bottom:1px solid var(--line);background:#fff;
}
.co-progress li{
  flex:1;text-align:center;padding:16px 12px;font-size:.72rem;letter-spacing:.18em;
  text-transform:uppercase;color:var(--muted);position:relative;
  transition:color .25s ease;
}
.co-progress li.active{color:var(--ink);background:var(--bg)}
.co-progress li.done{color:var(--accent)}
.co-progress li:not(:last-child)::after{
  content:"";position:absolute;right:0;top:50%;width:1px;height:24px;
  background:var(--line);transform:translateY(-50%);
}
.co-progress .step-num{
  display:inline-flex;width:22px;height:22px;border-radius:50%;border:1px solid currentColor;
  align-items:center;justify-content:center;margin-right:6px;font-size:.7rem;
  vertical-align:middle;
}

.co-body{padding:30px;overflow-y:auto;flex:1}
.co-step{display:none}
.co-step.active{display:block}

.co-items{margin-bottom:24px;display:flex;flex-direction:column;gap:12px}
.co-item{
  display:grid;grid-template-columns:60px 1fr auto;gap:14px;align-items:center;
  padding:12px;background:var(--bg-soft);
}
.co-item img{width:60px;height:75px;object-fit:cover;background:#fff}

.co-totals{
  background:var(--bg-soft);padding:16px 18px;margin-bottom:24px;
}
.co-totals .cart-summary-row{margin-bottom:6px;font-size:.92rem}
.co-totals .cart-summary-row.total{font-size:1.05rem}

.field{display:flex;flex-direction:column;gap:6px;margin-bottom:16px}
.field label{font-size:.74rem;letter-spacing:.18em;text-transform:uppercase;color:var(--ink-soft)}
.field input, .field textarea, .field select{
  background:#fff;border:1px solid var(--line);padding:13px 14px;
  font-family:inherit;font-size:.95rem;color:var(--ink);
  transition:border-color .2s ease;
}
.field input:focus,.field textarea:focus,.field select:focus{outline:0;border-color:var(--ink)}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.field textarea{resize:vertical;min-height:70px}

.co-foot{
  padding:20px 30px;border-top:1px solid var(--line);background:#fff;
  display:flex;justify-content:space-between;align-items:center;gap:14px;
}
.co-foot .secondary{
  background:transparent;border:1px solid var(--line);color:var(--ink-soft);
  padding:13px 22px;cursor:pointer;font-family:inherit;
  font-size:.74rem;letter-spacing:.22em;text-transform:uppercase;
}
.co-foot .primary{
  background:var(--ink);color:var(--bg);border:0;padding:14px 26px;
  cursor:pointer;font-family:inherit;
  font-size:.78rem;letter-spacing:.22em;text-transform:uppercase;
}
.co-foot .primary:hover{background:#000}

/* Payment step */
.pay-summary{
  display:flex;justify-content:space-between;gap:14px;
  padding:14px 18px;background:var(--bg-soft);margin-bottom:18px;
  font-size:.92rem;
}
.pay-summary-row{display:flex;align-items:center;gap:12px}
.pay-summary-row span{color:var(--muted);font-size:.72rem;letter-spacing:.18em;text-transform:uppercase}
.pay-summary-row strong.amount{color:var(--accent);font-family:"Cormorant Garamond",serif;font-size:1.5rem;font-weight:400}
.pay-summary-row strong{color:var(--ink);font-size:1rem;font-weight:500}

.pay-tabs{
  display:flex;gap:0;margin-bottom:22px;
  border-bottom:1px solid var(--line);
}
.pay-tab{
  flex:1;padding:14px 18px;background:transparent;border:0;cursor:pointer;
  font-family:inherit;font-size:.84rem;letter-spacing:.08em;color:var(--ink-soft);
  display:flex;align-items:center;justify-content:center;gap:8px;
  border-bottom:2px solid transparent;margin-bottom:-1px;
  transition:color .25s ease,border-color .25s ease;
}
.pay-tab:hover{color:var(--ink)}
.pay-tab.active{color:var(--ink);border-bottom-color:var(--ink);font-weight:500}
.pay-tab svg{flex-shrink:0}

.pay-pane{display:none}
.pay-pane.active{display:block}

/* Bank card */
.bank-card{background:#fff;border:1px solid var(--line);padding:0}
.bank-head{
  display:flex;align-items:center;gap:14px;
  padding:18px 22px;background:#f4faf3;border-bottom:1px solid var(--line);
}
.bank-logo{flex-shrink:0;width:44px;height:44px;border-radius:50%;
  background:#fff;display:flex;align-items:center;justify-content:center;
  border:1px solid #d4e8d3}
.bank-name{font-weight:600;color:#138f2d;font-size:1.05rem}
.bank-type{font-size:.78rem;color:var(--muted);margin-top:2px}
.bank-rows{padding:8px 22px}
.bank-row{
  display:flex;justify-content:space-between;align-items:center;
  padding:14px 0;border-bottom:1px solid var(--line);gap:14px;
}
.bank-row:last-child{border-bottom:0}
.bank-row-label{font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);flex-shrink:0}
.bank-row-val{display:flex;align-items:center;gap:10px;text-align:right}
.copy-btn-sm{
  background:transparent;border:1px solid var(--line);
  width:30px;height:30px;border-radius:4px;cursor:pointer;
  font-size:.9rem;color:var(--ink-soft);
  display:inline-flex;align-items:center;justify-content:center;
  transition:all .2s ease;flex-shrink:0;
}
.copy-btn-sm:hover{background:var(--ink);color:#fff;border-color:var(--ink)}
.copy-btn-sm.copied{background:#138f2d;color:#fff;border-color:#138f2d}

.pp-not-configured{
  text-align:center;padding:50px 30px;background:var(--bg-soft);
  border:1px dashed var(--line);
}
.pp-not-configured h4{margin:0 0 8px;font-family:"Cormorant Garamond",serif;font-weight:400;font-size:1.4rem}
.pp-not-configured p{margin:0;color:var(--ink-soft);font-size:.92rem;line-height:1.6}

.pay-grid{display:grid;grid-template-columns:auto 1fr;gap:32px;align-items:center}
.qr-wrap{
  padding:18px;background:#fff;border:1px solid var(--line);
  display:flex;flex-direction:column;align-items:center;gap:10px;
}
.qr-wrap .pp-logo{
  font-family:"Cormorant Garamond",serif;font-style:italic;
  color:var(--accent);letter-spacing:.06em;font-size:.95rem;
}
#qrCanvas{width:220px;height:220px;display:flex;align-items:center;justify-content:center;background:#fff}
#qrCanvas img,#qrCanvas canvas{display:block}

.pay-info dl{margin:0;display:grid;grid-template-columns:auto 1fr;gap:8px 18px;font-size:.95rem}
.pay-info dt{color:var(--muted);font-size:.78rem;letter-spacing:.15em;text-transform:uppercase}
.pay-info dd{margin:0;color:var(--ink);font-family:"Cormorant Garamond",serif;font-size:1.15rem}
.pay-info .amount{font-size:2rem;color:var(--accent)}
.pay-note{
  margin-top:22px;padding:14px 16px;background:var(--bg-soft);
  font-size:.88rem;color:var(--ink-soft);line-height:1.55;
}
.pay-note strong{color:var(--ink)}

/* Success step */
.succ-icon{
  width:64px;height:64px;border-radius:50%;background:#e8f3ea;color:#1f7a3a;
  display:flex;align-items:center;justify-content:center;font-size:2rem;
  margin:0 auto 18px;
}
.succ-body{text-align:center;max-width:520px;margin:0 auto}
.succ-body h3{font-family:"Cormorant Garamond",serif;font-weight:400;font-size:2rem;margin:0 0 8px}
.succ-body p{color:var(--ink-soft);margin:0 0 22px}
.succ-info{
  background:var(--bg-soft);padding:18px;text-align:left;margin:0 auto 22px;
  display:grid;grid-template-columns:auto 1fr;gap:8px 16px;font-size:.92rem;max-width:420px;
}
.succ-info dt{color:var(--muted);font-size:.74rem;letter-spacing:.15em;text-transform:uppercase}
.succ-info dd{margin:0;color:var(--ink)}
.succ-actions{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}
.succ-actions .line-btn{
  background:#06c755;color:#fff;border:0;padding:14px 24px;cursor:pointer;
  font-family:inherit;font-size:.78rem;letter-spacing:.18em;text-transform:uppercase;
  display:inline-flex;align-items:center;gap:8px;text-decoration:none;
}
.succ-actions .copy-btn{
  background:#fff;color:var(--ink);border:1px solid var(--ink);padding:13px 22px;cursor:pointer;
  font-family:inherit;font-size:.78rem;letter-spacing:.18em;text-transform:uppercase;
}
.succ-msg{
  text-align:left;padding:14px 16px;background:#fff;border:1px dashed var(--line);
  font-size:.82rem;color:var(--ink-soft);white-space:pre-wrap;margin-top:20px;
  font-family:"Consolas","SF Mono",monospace;line-height:1.55;
}

/* Product detail modal */
.product-modal{
  position:fixed;inset:0;background:rgba(20,15,10,.55);z-index:108;
  display:none;align-items:center;justify-content:center;
  padding:30px 16px;overflow-y:auto;
}
.product-modal.show{display:flex}
.pd-card{
  background:var(--bg);width:100%;max-width:920px;
  display:grid;grid-template-columns:1fr 1fr;gap:0;
  position:relative;box-shadow:0 40px 80px -20px rgba(0,0,0,.4);
  max-height:calc(100vh - 60px);overflow:hidden;
}
.pd-close{
  position:absolute;top:16px;right:16px;z-index:5;
  background:rgba(255,255,255,.9);border:0;
  width:38px;height:38px;border-radius:50%;cursor:pointer;
  font-size:1.2rem;color:var(--ink);
  display:flex;align-items:center;justify-content:center;
  transition:background .25s ease;
}
.pd-close:hover{background:#fff}
.pd-image{background:var(--bg-soft);overflow:hidden}
.pd-image img{width:100%;height:100%;object-fit:cover;display:block}
.pd-info{padding:50px 44px;display:flex;flex-direction:column;overflow-y:auto}
.pd-code{font-size:.74rem;letter-spacing:.24em;text-transform:uppercase;color:var(--muted);margin-bottom:8px}
.pd-name{
  font-family:"Cormorant Garamond",serif;font-weight:400;
  font-size:clamp(1.8rem,3vw,2.6rem);line-height:1.1;margin:0 0 10px;
}
.pd-desc{color:var(--ink-soft);font-size:.96rem;margin-bottom:18px;line-height:1.55}
.pd-price{
  font-family:"Cormorant Garamond",serif;font-size:2rem;color:var(--accent);
  padding-bottom:22px;border-bottom:1px solid var(--line);margin-bottom:22px;
}

.pd-section{margin-bottom:22px}
.pd-label{font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;color:var(--ink-soft);margin-bottom:10px}
.size-options{display:flex;gap:10px}
.size-btn{
  min-width:48px;height:42px;padding:0 14px;
  background:#fff;border:1px solid var(--line);cursor:pointer;
  font-family:inherit;font-size:.95rem;color:var(--ink);
  transition:all .2s ease;
}
.size-btn:hover{border-color:var(--ink)}
.size-btn.active{background:var(--ink);color:var(--bg);border-color:var(--ink)}
.qty-controls{display:inline-flex;align-items:center;border:1px solid var(--line);background:#fff}
.qty-controls button{
  width:42px;height:42px;background:transparent;border:0;cursor:pointer;
  font-size:1.1rem;color:var(--ink);
  display:flex;align-items:center;justify-content:center;
  transition:background .2s ease;
}
.qty-controls button:hover{background:var(--bg-soft)}
.qty-controls span{min-width:50px;text-align:center;font-size:1rem}

.pd-add{
  margin-top:8px;padding:18px 24px;
  background:var(--ink);color:var(--bg);border:0;cursor:pointer;
  font-family:inherit;font-size:.84rem;letter-spacing:.22em;text-transform:uppercase;
  display:flex;align-items:center;justify-content:space-between;gap:14px;
  transition:background .25s ease;
}
.pd-add:hover{background:#000}
.pd-add span:last-child{
  font-family:"Cormorant Garamond",serif;font-size:1.25rem;letter-spacing:.02em;text-transform:none;
}
.pd-shopee{
  margin-top:14px;text-align:center;display:inline-block;
  font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;color:var(--ink-soft);
}
.pd-shopee:hover{color:var(--ink)}

@media (max-width:760px){
  .pd-card{grid-template-columns:1fr;max-height:calc(100vh - 40px)}
  .pd-image{aspect-ratio:1/1;max-height:50vh}
  .pd-info{padding:30px 24px}
}

/* Toast */
.toast{
  position:fixed;bottom:24px;left:50%;transform:translateX(-50%) translateY(20px);
  background:var(--ink);color:var(--bg);padding:13px 22px;
  font-size:.88rem;letter-spacing:.04em;
  opacity:0;pointer-events:none;transition:opacity .3s ease,transform .3s ease;
  z-index:200;border-radius:2px;
}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}

@media (max-width:680px){
  .pay-grid{grid-template-columns:1fr;text-align:center}
  .pay-info dl{justify-items:center}
  .field-row{grid-template-columns:1fr}
  .co-progress li{font-size:.62rem;padding:14px 8px}
  .co-progress .step-num{display:none}
  .drawer{width:100%}
}
