/* =====================================================================
   Ecom — Checkout (Day 8). SOL-style 3-step. Tokens only, no raw hex.
   ===================================================================== */
[x-cloak]{ display:none !important; }

.ecom-checkout{ padding:24px 0 56px; }

/* Steps progress */
.ecom-checkout .ecom-steps{
  display:flex; align-items:center; gap:0;
  background:var(--ecom-surface); border:1px solid var(--ecom-border);
  border-radius:var(--ecom-radius); padding:22px 28px; margin-bottom:24px;
}
.ecom-checkout .ecom-step{ display:flex; align-items:center; gap:12px; 
width: auto;
    border: 0px solid !important;}
.ecom-step__dot{
  width:34px; height:34px; border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  border:2px solid var(--ecom-border); color:transparent; font-size:14px;
  transition:all .2s;
}
.ecom-step.on .ecom-step__dot{ border-color:var(--ecom-navy); color:var(--ecom-navy); }
.ecom-step.done .ecom-step__dot{ background:var(--ecom-navy); border-color:var(--ecom-navy); color:#fff; }
.ecom-step__label{ font-size:var(--ecom-fs-lg); font-weight:var(--ecom-fw-bold); color:var(--ecom-navy); }
.ecom-step__bar{ flex:1; height:1px; background:var(--ecom-border); margin:0 18px; }

/* Cards */
.ecom-co-card{
  background:var(--ecom-surface); border:1px solid var(--ecom-border);
  border-radius:var(--ecom-radius); padding:22px; margin-bottom:18px;
}
.ecom-co-h{ font-size:var(--ecom-fs-lg); font-weight:var(--ecom-fw-bold); color:var(--ecom-navy); margin:0 0 14px; }
.ecom-co-h.orange{ color:var(--ecom-orange); }

/* Lines */
.ecom-co-lines{ display:flex; flex-direction:column; gap:10px; }
.ecom-co-line{
  display:grid; grid-template-columns:56px 1fr auto auto; gap:12px; align-items:center;
  padding:10px 0; border-bottom:1px solid var(--ecom-border);
}
.ecom-co-line:last-child{ border-bottom:none; }
.ecom-co-line img{ width:56px; height:56px; object-fit:contain; border:1px solid var(--ecom-border); border-radius:var(--ecom-radius-sm); }
.ecom-co-line__name{ font-weight:var(--ecom-fw-medium); color:var(--ecom-navy); font-size:var(--ecom-fs-sm); }
.ecom-co-line__pack{ font-size:12px; color:var(--ecom-muted); }
.ecom-co-line__qty{ font-size:var(--ecom-fs-sm); color:var(--ecom-muted); }
.ecom-co-line__total{ font-weight:var(--ecom-fw-bold); color:var(--ecom-navy); font-size:var(--ecom-fs-sm); }

/* Toggle */
.ecom-co-toggle{
  display:flex; align-items:center; justify-content:space-between;
  background:var(--ecom-surface-2); padding:14px 16px; border-radius:var(--ecom-radius-sm);
  margin-bottom:16px;
}
.ecom-co-toggle span{ font-weight:var(--ecom-fw-medium); color:var(--ecom-navy); }

/* Sections */
.ecom-co-section{ margin-top:22px; }
.ecom-co-section__head{ display:flex; align-items:center; justify-content:space-between; margin-bottom:12px; }
.ecom-addnew{ font-size:var(--ecom-fs-sm); }

/* Selects */
.ecom-co-select{
  width:100%; height:48px; padding:0 14px; margin-bottom:12px;
  border:1px solid var(--ecom-border); border-radius:var(--ecom-radius-sm);
  color:var(--ecom-navy); font-size:var(--ecom-fs-base);
  appearance:none; cursor:pointer;
}
.ecom-co-empty{ color:var(--ecom-muted); padding:12px 0; font-size:var(--ecom-fs-sm); }

/* Actions */
.ecom-co-actions{ display:flex; justify-content:space-between; gap:12px; margin-top:20px; }
.ecom-btn.disabled{ opacity:.5; pointer-events:none; }

/* Payment grid */
.ecom-co-grid{ display:grid; grid-template-columns:1fr 1fr; gap:18px; align-items:start; }
.ecom-co-kv{
  display:flex; justify-content:space-between; align-items:center;
  padding:9px 0; font-size:var(--ecom-fs-sm); color:var(--ecom-ink);
  border-bottom:1px solid var(--ecom-border);
}
.ecom-co-kv:last-child{ border-bottom:none; }
.ecom-co-kv .minus{ color:var(--ecom-success); }
.ecom-co-kv.grand{ font-size:var(--ecom-fs-lg); font-weight:var(--ecom-fw-bold); color:var(--ecom-navy); border-top:2px solid var(--ecom-border); margin-top:6px; padding-top:12px; }
.ecom-co-addr{ font-size:var(--ecom-fs-sm); color:var(--ecom-navy); margin-bottom:12px; line-height:1.5; }

/* Payment options */
.ecom-pay{
  display:flex; align-items:center; gap:12px; padding:14px 16px; margin-bottom:10px;
  border:1px solid var(--ecom-border); border-radius:var(--ecom-radius-sm);
  cursor:pointer; font-size:var(--ecom-fs-base); color:var(--ecom-ink);
}
.ecom-pay input{ accent-color:var(--ecom-orange); width:18px; height:18px; }
.ecom-pay.on{ border-color:var(--ecom-orange); background:var(--ecom-orange-soft); color:var(--ecom-navy); font-weight:var(--ecom-fw-medium); }

/* Bank transfer */
.ecom-bank-wrap{ margin:12px 0; padding:12px; background:var(--ecom-surface-2); border-radius:var(--ecom-radius-sm); }
.ecom-bank{
  display:block; padding:14px; margin-bottom:10px; cursor:pointer;
  border:1px solid var(--ecom-border); border-radius:var(--ecom-radius-sm); background:var(--ecom-surface);
}
.ecom-bank.on{ border-color:var(--ecom-orange); }
.ecom-bank input{ accent-color:var(--ecom-orange); margin-bottom:8px; }
.ecom-bank__head{ font-weight:var(--ecom-fw-bold); color:var(--ecom-navy); }
.ecom-bank__holder{ font-size:12px; color:var(--ecom-muted); text-transform:uppercase; margin-bottom:8px; }
.ecom-bank__row{ font-size:var(--ecom-fs-sm); color:var(--ecom-ink); padding:2px 0; }
.ecom-bank__row b{ color:var(--ecom-navy); }

/* Upload */
.ecom-upload{ margin-top:12px; }
.ecom-upload__label{ display:block; font-size:var(--ecom-fs-sm); font-weight:var(--ecom-fw-medium); color:var(--ecom-navy); margin-bottom:8px; }
.ecom-upload__input{
  width:100%; padding:12px; border:1px dashed var(--ecom-orange); border-radius:var(--ecom-radius-sm);
  color:var(--ecom-ink); font-size:var(--ecom-fs-sm); cursor:pointer; background:var(--ecom-surface);
}

/* Confirm */
.ecom-confirm{ width:100%; justify-content:center; margin-top:18px; }
.ecom-co-note{ text-align:center; font-size:12px; color:var(--ecom-muted); margin-top:12px; }

/* Success */
.ecom-success{
  max-width:560px; margin:40px auto; text-align:center;
  background:var(--ecom-surface); border:1px solid var(--ecom-border);
  border-radius:var(--ecom-radius); padding:40px 28px;
}
.ecom-success__icon i{ font-size:64px; color:var(--ecom-success); }
.ecom-success__title{ font-size:var(--ecom-fs-xl); font-weight:var(--ecom-fw-bold); color:var(--ecom-navy); margin:16px 0 8px; }
.ecom-success__sub{ color:var(--ecom-ink); margin-bottom:6px; }
.ecom-success__note{ color:var(--ecom-muted); font-size:var(--ecom-fs-sm); margin-bottom:24px; }
.ecom-success__summary{ text-align:start; margin:0 auto 24px; max-width:380px; }
.ecom-success__actions{ display:flex; gap:12px; justify-content:center; }

/* Responsive */
@media (max-width:820px){
  .ecom-co-grid{ grid-template-columns:1fr; }
  .ecom-steps{ padding:16px; }
  .ecom-step__label{ font-size:var(--ecom-fs-sm); }
}

/* Delivery type (speed tier) selector (Day 8) */
.ecom-tier-opts{ display:flex; flex-direction:column; gap:10px; }
.ecom-tier{
  display:flex; align-items:center; gap:12px; padding:14px 16px;
  border:1px solid var(--ecom-border); border-radius:var(--ecom-radius-sm);
  cursor:pointer; font-size:var(--ecom-fs-base); color:var(--ecom-ink);
}
.ecom-tier input{ accent-color:var(--ecom-orange); width:18px; height:18px; }
.ecom-tier.on{ border-color:var(--ecom-orange); background:var(--ecom-orange-soft); }
.ecom-tier__name{ flex:1; font-weight:var(--ecom-fw-medium); color:var(--ecom-navy); }
.ecom-tier__cost{ font-weight:var(--ecom-fw-bold); color:var(--ecom-orange); }
.ecom-tier-quote{ font-size:12px; color:var(--ecom-muted); margin-top:8px; }
.ecom-co-kv .free{ color:var(--ecom-success); font-weight:var(--ecom-fw-bold); }

.step2-checkout {
  width: 600px;
  margin: auto;
}