/* ═══════════════════════════════════════════════════
   CAFE ORIX — ORDER PAGE CSS
   Constellation BG + Full Order Flow UI
═══════════════════════════════════════════════════ */
:root {
  --dark:   #312C51;  --purple: #48426D;
  --peach:  #F0C38E;  --pink:   #F1AA9B;
  --cream:  #FAF8F5;  --bg1:    #1d1833;
  --bg2:    #241d3f;  --bg3:    #2c2450;
  --green:  #4ade80;  --red:    #ef4444;
  --orange: #f97316;
  --card-bg: rgba(255,255,255,0.038);
  --card-br: rgba(255,255,255,0.075);
  --ease-sp: cubic-bezier(.34,1.56,.64,1);
  --ease-o:  cubic-bezier(.16,1,.3,1);
  --nav-h:   68px;
}
*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; }
body { font-family:'Nunito',sans-serif; background:var(--bg1); color:#fff; overflow-x:hidden; -webkit-font-smoothing:antialiased; }
a { text-decoration:none; color:inherit; }
button { cursor:pointer; border:none; font-family:'Nunito',sans-serif; }
input { font-family:'Poppins',sans-serif; }
::-webkit-scrollbar { width:5px; }
::-webkit-scrollbar-track { background:var(--bg1); }
::-webkit-scrollbar-thumb { background:var(--purple); border-radius:4px; }

/* ── CONSTELLATION CANVAS ── */
#bgCanvas {
  position:fixed; top:0; left:0;
  width:100%; height:100%;
  z-index:0; pointer-events:none;
}

/* ── SCROLL REVEAL ── */
.js-up { opacity:0; transform:translateY(32px); transition:opacity .65s var(--ease-o), transform .65s var(--ease-o); }
.js-up.visible { opacity:1; transform:translateY(0); }

/* ── SHARED ── */
.sec-tag {
  display:inline-flex; align-items:center; gap:7px;
  background:rgba(240,195,142,.1); border:1.5px solid rgba(240,195,142,.2);
  border-radius:50px; padding:7px 18px;
  font-family:'Poppins',sans-serif; font-size:.76rem; font-weight:600;
  color:var(--peach); margin-bottom:14px;
}
.sec-title { font-family:'Fredoka One',cursive; font-size:clamp(1.8rem,3.5vw,2.8rem); color:#fff; }
.sec-title span { color:var(--peach); }
.sec-sub { font-family:'Poppins',sans-serif; font-size:.88rem; color:rgba(255,255,255,.5); line-height:1.7; max-width:480px; }
.live-dot-sm {
  display:inline-block; width:8px; height:8px; border-radius:50%;
  background:var(--green); animation:pulseDot 1.6s ease-in-out infinite;
}
@keyframes pulseDot { 0%,100%{box-shadow:0 0 0 0 rgba(74,222,128,.5)} 50%{box-shadow:0 0 0 6px rgba(74,222,128,0)} }

.btn-shine {
  position:absolute; top:0; left:-80%; width:55%; height:100%;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent);
  transform:skewX(-20deg); animation:shine 3.5s ease-in-out infinite 1.5s;
}
@keyframes shine { 0%{left:-80%} 30%{left:130%} 100%{left:130%} }

/* ══════════════════════════════════════════
   PAGE HERO
══════════════════════════════════════════ */
.op-wrap { position:relative; z-index:1; padding-top:var(--nav-h); }
.op-hero {
  padding:55px 5% 40px;
  background:linear-gradient(180deg,#0f0c1a 0%,var(--bg1) 100%);
  text-align:center; position:relative;
}
.op-hero::before {
  content:''; position:absolute; inset:0;
  background:
    radial-gradient(ellipse 60% 50% at 50% 0%, rgba(240,195,142,.1) 0%,transparent 60%),
    radial-gradient(ellipse 40% 30% at 80% 80%, rgba(241,170,155,.08) 0%,transparent 50%);
  pointer-events:none;
}
.breadcrumb { display:flex; align-items:center; gap:8px; justify-content:center; font-family:'Poppins',sans-serif; font-size:.75rem; color:rgba(255,255,255,.35); margin-bottom:16px; }
.breadcrumb a { color:var(--peach); }
.breadcrumb i { font-size:.6rem; }
.op-title {

  font-family:'Fredoka One',cursive;

  font-size:clamp(2rem,4vw,3rem);

  line-height:.95;

  color:#fff;

  margin-bottom:10px;

  max-width:700px;

  margin-inline:auto;
}
.op-title span { color:var(--peach); }
.op-sub { font-family:'Poppins',sans-serif; font-size:.9rem; color:rgba(255,255,255,.5); margin-bottom:20px; }
.op-badges { display:flex; gap:12px; justify-content:center; flex-wrap:wrap; row-gap:10px;}
.op-badges span {
  display:flex; align-items:center; gap:6px;
  background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.1);
  border-radius:50px; padding:6px 14px;
  font-family:'Poppins',sans-serif; font-size:.74rem; font-weight:500;
  color:rgba(255,255,255,.65);
}
.op-badges span i { color:var(--peach); font-size:.72rem; }

/* ══════════════════════════════════════════
   STEP PROGRESS BAR
══════════════════════════════════════════ */
.steps-bar {
  display:flex; align-items:center; justify-content:center;
  gap:0; padding:20px 5%;
  background:rgba(0,0,0,.2);
  border-bottom:1px solid rgba(255,255,255,.05);
  position:sticky; top:var(--nav-h); z-index:80;
  backdrop-filter:blur(10px);
  overflow-x:auto;
  overflow-y:hidden;
  scrollbar-width:none;
}

.steps-bar::-webkit-scrollbar{

}
.step {

  display:flex;

  align-items:center;

  gap:8px;

  flex-direction:column;

  min-width:90px;

  flex-shrink:0;
}.step-ico {
  width:40px; height:40px; border-radius:50%;
  background:rgba(255,255,255,.06); border:2px solid rgba(255,255,255,.12);
  display:flex; align-items:center; justify-content:center;
  font-size:.85rem; color:rgba(255,255,255,.35);
  transition:all .4s var(--ease-sp);
}
.step span { font-family:'Poppins',sans-serif; font-size:.68rem; font-weight:600; color:rgba(255,255,255,.3); transition:color .3s; }
.step.active .step-ico { background:var(--peach); border-color:var(--peach); color:var(--dark); box-shadow:0 0 20px rgba(240,195,142,.4); }
.step.active span { color:var(--peach); }
.step.done .step-ico { background:rgba(74,222,128,.15); border-color:rgba(74,222,128,.4); color:var(--green); }
.step.done span { color:var(--green); }
.step-line { flex:1; height:2px; background:rgba(255,255,255,.08); margin-bottom:16px; min-width:40px; max-width:100px; transition:background .4s; }
.step-line.done { background:rgba(74,222,128,.35); }

/* ══════════════════════════════════════════
   MAIN LAYOUT
══════════════════════════════════════════ */
.op-main {
  display:grid;
  grid-template-columns:minmax(0,1fr) 340px;
  gap:24px;
  max-width:1300px;
  margin:0 auto;
  padding:24px 5% 80px;
  align-items:start;
}
.op-left { display:flex; flex-direction:column; gap:20px; }

/* ══════════════════════════════════════════
   ORDER CARDS
══════════════════════════════════════════ */
.oc {
  background:var(--card-bg); backdrop-filter:blur(8px);
  border:1px solid var(--card-br); border-radius:22px;
  overflow:hidden; transition:box-shadow .3s, border-color .3s;
}
.oc:focus-within { border-color:rgba(240,195,142,.25); box-shadow:0 0 0 3px rgba(240,195,142,.07); }
.oc-hd {
  display:flex; align-items:center; gap:14px;
  padding:22px 24px 18px;
  border-bottom:1px solid rgba(255,255,255,.05);
}
.oc-num {
  width:36px; height:36px; border-radius:10px; flex-shrink:0;
  background:linear-gradient(135deg,var(--dark),var(--purple));
  border:1px solid rgba(240,195,142,.2);
  display:flex; align-items:center; justify-content:center;
  font-family:'Fredoka One',cursive; font-size:.95rem; color:var(--peach);
}
.oc-hd-info { flex:1; }
.oc-hd-info h3 { font-family:'Fredoka One',cursive; font-size:1.1rem; color:#fff; margin-bottom:2px; }
.oc-hd-info span { font-family:'Poppins',sans-serif; font-size:.74rem; color:rgba(255,255,255,.4); }
.oc-done { display:flex; align-items:center; gap:5px; font-family:'Poppins',sans-serif; font-size:.74rem; font-weight:600; color:var(--green); }
.oc-expand {
  display:flex; align-items:center; gap:6px;
  background:rgba(240,195,142,.1); border:1px solid rgba(240,195,142,.2);
  color:var(--peach); border-radius:50px; padding:7px 14px;
  font-family:'Poppins',sans-serif; font-size:.74rem; font-weight:600;
  transition:all .2s;
}
.oc-expand:hover { background:rgba(240,195,142,.18); }
.oc-body { padding:22px 24px; }

/* ── Delivery/Pickup Toggle ── */
.dp-toggle {
  display:flex; gap:0; background:rgba(0,0,0,.2); border-radius:50px;
  padding:4px; margin-bottom:22px; position:relative; width:fit-content;
}
.dp-btn {
  display:flex; align-items:center; gap:7px;
  background:none; color:rgba(255,255,255,.45);
  font-family:'Poppins',sans-serif; font-size:.82rem; font-weight:600;
  padding:10px 22px; border-radius:50px; z-index:1; position:relative;
  transition:color .3s; white-space:nowrap;
}
.dp-btn.active { color:var(--dark); }
.dp-btn i { font-size:.82rem; }
.dp-slider {
  position:absolute; top:4px; left:4px;
  height:calc(100% - 8px); border-radius:50px;
  background:linear-gradient(135deg,var(--peach),var(--pink));
  transition:all .4s var(--ease-sp);
  box-shadow:0 4px 16px rgba(240,195,142,.3);
}

/* ── Location ── */
.loc-row { display:flex; gap:10px; margin-bottom:12px; }
.loc-input-wrap {
  flex:1; display:flex; align-items:center; gap:0;
  background:rgba(255,255,255,.06); border:1.5px solid rgba(255,255,255,.1);
  border-radius:14px; overflow:hidden; transition:border-color .25s;
}
.loc-input-wrap:focus-within { border-color:rgba(240,195,142,.4); }
.loc-icon { padding:0 14px; color:rgba(240,195,142,.6); font-size:.9rem; flex-shrink:0; }
.loc-input {
  flex:1; background:none; border:none; outline:none;
  color:#fff; font-size:.85rem; padding:13px 0;
}
.loc-input::placeholder { color:rgba(255,255,255,.3); }
.loc-detect-btn {
  background:none; color:rgba(255,255,255,.4);
  padding:0 14px; font-size:.9rem; transition:color .25s; height:100%;
}
.loc-detect-btn:hover { color:var(--peach); }
.loc-check-btn {
  background:linear-gradient(135deg,var(--peach),var(--pink));
  color:var(--dark); border-radius:14px; padding:0 18px;
  font-family:'Fredoka One',cursive; font-size:.9rem;
  display:flex; align-items:center; gap:7px; white-space:nowrap;
  transition:all .25s; position:relative; overflow:hidden;
}
.loc-check-btn:hover { transform:scale(1.04); box-shadow:0 6px 20px rgba(240,195,142,.3); }

.loc-status {
  font-family:'Poppins',sans-serif; font-size:.78rem;
  padding:0 4px; min-height:18px; transition:all .3s;
}
.loc-status.ok { color:var(--green); }
.loc-status.err { color:var(--red); }
.loc-status.checking { color:rgba(255,255,255,.4); }

/* ETA Box */
.eta-box {
  display:flex; align-items:center; gap:14px;
  background:rgba(74,222,128,.07); border:1px solid rgba(74,222,128,.2);
  border-radius:14px; padding:14px 18px; margin-top:12px;
  animation:slideDown .4s var(--ease-o);
}
@keyframes slideDown { from{opacity:0;transform:translateY(-8px)} to{opacity:1;transform:translateY(0)} }
.eta-icon { width:40px; height:40px; border-radius:50%; background:rgba(74,222,128,.15); display:flex; align-items:center; justify-content:center; color:var(--green); font-size:1rem; flex-shrink:0; }
.eta-info { flex:1; }
.eta-label { font-family:'Poppins',sans-serif; font-size:.72rem; color:rgba(255,255,255,.4); display:block; }
.eta-time { font-family:'Fredoka One',cursive; font-size:1.2rem; color:var(--green); }
.eta-live { display:flex; align-items:center; gap:6px; font-family:'Poppins',sans-serif; font-size:.68rem; color:var(--green); }
.eta-dot { width:6px; height:6px; border-radius:50%; background:var(--green); animation:pulseDot 1.5s ease-in-out infinite; }

/* Pickup info */
.pickup-info { display:flex; flex-direction:column; gap:12px; margin-bottom:16px; }
.pi-row { display:flex; align-items:flex-start; gap:10px; font-family:'Poppins',sans-serif; font-size:.83rem; color:rgba(255,255,255,.6); }
.pi-row i { color:var(--peach); width:16px; flex-shrink:0; margin-top:1px; }
.pi-row strong { color:#fff; }
.pickup-map-stub {
  height:120px; border-radius:14px;
  background:linear-gradient(135deg,var(--bg2),var(--bg3));
  border:1px solid rgba(255,255,255,.08);
  display:flex; flex-direction:column; align-items:center; justify-content:center; gap:8px;
  color:rgba(240,195,142,.5); font-size:.83rem;
}
.pickup-map-stub i { font-size:2rem; color:rgba(240,195,142,.3); }

/* ── Quick Menu ── */
.quick-menu { animation:slideDown .4s var(--ease-o); margin-bottom:20px; }
.qm-tabs { display:flex; gap:6px; flex-wrap:wrap; margin-bottom:16px; }
.qt {
  background:rgba(255,255,255,.06); border:1.5px solid rgba(255,255,255,.1);
  color:rgba(255,255,255,.55); border-radius:50px; padding:7px 14px;
  font-family:'Poppins',sans-serif; font-size:.74rem; font-weight:600;
  display:flex; align-items:center; gap:5px; transition:all .2s;
}
.qt.active { background:var(--dark); border-color:rgba(240,195,142,.3); color:var(--peach); }
.qt:hover:not(.active) { border-color:rgba(255,255,255,.25); }
.qt i { font-size:.72rem; }
.qm-grid {

  display:grid;

  grid-template-columns:repeat(auto-fit,minmax(220px,1fr));

  gap:10px;
}
.qm-item {
  display:flex; align-items:center; gap:10px;
  background:rgba(255,255,255,.04); border:1px solid rgba(255,255,255,.07);
  border-radius:14px; padding:12px 14px; cursor:pointer;
  transition:all .2s;
}
.qm-item:hover { background:rgba(240,195,142,.06); border-color:rgba(240,195,142,.2); transform:translateY(-2px); }
.qm-ico { width:40px; height:40px; border-radius:10px; display:flex; align-items:center; justify-content:center; font-size:1.1rem; flex-shrink:0; }
.qm-info { flex:1; min-width:0; }
.qm-name { font-family:'Nunito',sans-serif; font-weight:700; font-size:.85rem; color:#fff; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.qm-price { font-family:'Fredoka One',cursive; font-size:.82rem; color:var(--peach); }
.qm-add {
  background:linear-gradient(135deg,var(--dark),var(--purple));
  color:var(--peach); border-radius:50%; width:28px; height:28px;
  display:flex; align-items:center; justify-content:center;
  font-size:.75rem; flex-shrink:0; transition:all .2s;
}
.qm-item:hover .qm-add { background:linear-gradient(135deg,var(--peach),var(--pink)); color:var(--dark); }

/* ── Cart Items List ── */
.cart-items-list { display:flex; flex-direction:column; gap:12px; }
.ci-item {
  display:flex; align-items:center; gap:12px;
  padding:12px; background:rgba(255,255,255,.03);
  border:1px solid rgba(255,255,255,.07); border-radius:14px;
  animation:slideDown .35s var(--ease-o);
  transition:border-color .2s;
  flex-wrap:wrap;
}
.ci-item:hover { border-color:rgba(240,195,142,.18); }
.ci-ico { width:44px; height:44px; border-radius:12px; display:flex; align-items:center; justify-content:center; font-size:1.2rem; flex-shrink:0; }
.ci-info { flex:1; min-width:0; }
.ci-name { font-family:'Nunito',sans-serif; font-weight:700; font-size:.9rem; color:#fff; }
.ci-cat { font-family:'Poppins',sans-serif; font-size:.7rem; color:rgba(255,255,255,.35); }
.ci-price { font-family:'Fredoka One',cursive; font-size:1rem; color:var(--peach); margin-right:8px; min-width:70px;
text-align:right;}
.ci-qty { display:flex; align-items:center; border:1.5px solid rgba(255,255,255,.1); border-radius:50px; overflow:hidden; }
.ciq-btn { width:28px; height:28px; background:none; color:rgba(255,255,255,.5); font-size:.95rem; font-weight:700; display:flex; align-items:center; justify-content:center; transition:all .2s; }
.ciq-btn:hover { background:rgba(255,255,255,.08); color:#fff; }
.ciq-n { width:30px; text-align:center; font-family:'Nunito',sans-serif; font-weight:700; font-size:.85rem; color:#fff; }
.ci-remove { color:rgba(255,255,255,.2); font-size:.82rem; padding:4px; transition:color .2s; background:none; }
.ci-remove:hover { color:var(--red); }
.cart-empty-state { text-align:center; padding:40px; color:rgba(255,255,255,.3); }
.cart-empty-state i { font-size:2.5rem; margin-bottom:10px; display:block; }
.cart-empty-state p { font-family:'Poppins',sans-serif; font-size:.85rem; margin-bottom:14px; }
.cart-empty-state button { background:rgba(240,195,142,.1); border:1px solid rgba(240,195,142,.25); color:var(--peach); border-radius:50px; padding:8px 20px; font-family:'Poppins',sans-serif; font-size:.8rem; font-weight:600; transition:all .2s; }

/* ── Promo ── */
.promo-row { display:flex; gap:10px; margin-bottom:10px; }
.promo-input-wrap { flex:1; display:flex; align-items:center; background:rgba(255,255,255,.06); border:1.5px solid rgba(255,255,255,.1); border-radius:14px; overflow:hidden; transition:border-color .25s; }
.promo-input-wrap:focus-within { border-color:rgba(240,195,142,.4); }
.promo-icon { padding:0 14px; color:rgba(240,195,142,.5); font-size:.9rem; flex-shrink:0; }
.promo-input { flex:1; background:none; border:none; outline:none; color:var(--peach); font-size:.85rem; font-weight:600; padding:13px 0; letter-spacing:1px; }
.promo-input::placeholder { color:rgba(255,255,255,.25); font-weight:400; letter-spacing:0; }
.promo-btn { background:linear-gradient(135deg,var(--dark),var(--purple)); color:var(--peach); border-radius:14px; padding:0 22px; font-family:'Fredoka One',cursive; font-size:.9rem; transition:all .25s; }
.promo-btn:hover { transform:scale(1.04); box-shadow:0 5px 15px rgba(49,44,81,.4); }
.promo-status { font-family:'Poppins',sans-serif; font-size:.78rem; margin:4px 0 14px; min-height:16px; transition:all .3s; }
.promo-status.ok { color:var(--green); }
.promo-status.err { color:var(--red); }
.promo-chips { display:flex; gap:8px; flex-wrap:wrap; }
.promo-chip { background:rgba(255,255,255,.04); border:1px solid rgba(255,255,255,.1); border-radius:50px; padding:6px 14px; font-family:'Poppins',sans-serif; font-size:.72rem; font-weight:600; color:rgba(255,255,255,.55); cursor:pointer; display:flex; align-items:center; gap:5px; transition:all .2s; }
.promo-chip i { color:var(--peach); font-size:.68rem; }
.promo-chip:hover { border-color:rgba(240,195,142,.3); color:var(--peach); background:rgba(240,195,142,.06); }

/* ── Payment Options ── */
.pay-options { display:flex; flex-direction:column; gap:12px; }
.pay-opt {
  background:rgba(255,255,255,.03); border:1.5px solid rgba(255,255,255,.08);
  border-radius:16px; overflow:hidden; cursor:pointer; transition:all .25s;
}
.pay-opt:hover { border-color:rgba(255,255,255,.18); }
.pay-opt.active { border-color:rgba(240,195,142,.35); background:rgba(240,195,142,.04); }
.po-top { display:flex; align-items:center; gap:14px; padding:16px 18px; }
.po-icon { width:40px; height:40px; border-radius:12px; background:rgba(255,255,255,.06); display:flex; align-items:center; justify-content:center; font-size:1rem; color:var(--peach); flex-shrink:0; }
.po-top > div:nth-child(2) { flex:1; }
.po-top b { font-family:'Nunito',sans-serif; font-weight:700; font-size:.9rem; color:#fff; display:block; margin-bottom:2px; }
.po-top span { font-family:'Poppins',sans-serif; font-size:.72rem; color:rgba(255,255,255,.4); }
.po-radio { width:20px; height:20px; border-radius:50%; border:2px solid rgba(255,255,255,.2); display:flex; align-items:center; justify-content:center; transition:border-color .25s; }
.pay-opt.active .po-radio { border-color:var(--peach); }
.po-dot { width:10px; height:10px; border-radius:50%; background:var(--peach); transform:scale(0); transition:transform .25s var(--ease-sp); }
.pay-opt.active .po-dot { transform:scale(1); }
.po-body { padding:0 18px 18px; }

/* Card preview */
.card-preview {
  background:linear-gradient(135deg,var(--dark) 0%,var(--purple) 60%,#6b4d8a 100%);
  border-radius:16px; padding:20px 22px; margin-bottom:18px;
  position:relative; overflow:hidden; border:1px solid rgba(255,255,255,.1);
  box-shadow:0 12px 40px rgba(0,0,0,.3);
}
.card-preview::before { content:''; position:absolute; top:-30px; right:-30px; width:120px; height:120px; border-radius:50%; background:rgba(240,195,142,.06); }
.card-preview::after  { content:''; position:absolute; bottom:-40px; left:-20px; width:100px; height:100px; border-radius:50%; background:rgba(241,170,155,.06); }
.cp-top { display:flex; align-items:center; justify-content:space-between; margin-bottom:22px; position:relative; z-index:1; }
.cp-chip { width:32px; height:24px; border-radius:5px; background:rgba(240,195,142,.3); display:flex; align-items:center; justify-content:center; color:var(--peach); font-size:.65rem; }
.cp-brand { font-family:'Fredoka One',cursive; font-size:1.1rem; color:rgba(255,255,255,.6); font-style:italic; }
.cp-num { font-family:'Courier New',monospace; font-size:1.15rem; color:#fff; letter-spacing:.12em; margin-bottom:16px; position:relative; z-index:1; }
.cp-bot { display:flex; gap:30px; position:relative; z-index:1; }
.cp-bot > div { display:flex; flex-direction:column; gap:2px; }
.cp-bot span { font-size:.6rem; color:rgba(255,255,255,.4); text-transform:uppercase; letter-spacing:1px; }
.cp-bot b { font-family:'Poppins',sans-serif; font-size:.8rem; font-weight:600; color:#fff; }

.card-fields { display:flex; flex-direction:column; gap:12px; }
.cf-group { display:flex; flex-direction:column; gap:5px; }
.cf-group label { font-family:'Poppins',sans-serif; font-size:.72rem; font-weight:600; color:rgba(255,255,255,.4); }
.cf-input { background:rgba(255,255,255,.07); border:1.5px solid rgba(255,255,255,.1); border-radius:10px; padding:11px 14px; color:#fff; font-size:.85rem; outline:none; transition:border-color .25s; }
.cf-input:focus { border-color:rgba(240,195,142,.4); background:rgba(255,255,255,.1); }
.cf-input::placeholder { color:rgba(255,255,255,.25); }
.cf-row { display:grid; grid-template-columns:1fr auto auto; gap:10px; }
.cf-row .cf-group:last-child input { width:70px; }

/* UPI apps */
.upi-apps { display:flex; gap:8px; flex-wrap:wrap; }
.upi-app { display:flex; flex-direction:column; align-items:center; gap:5px; background:rgba(255,255,255,.05); border:1.5px solid rgba(255,255,255,.1); border-radius:12px; padding:10px 16px; color:rgba(255,255,255,.5); font-family:'Poppins',sans-serif; font-size:.7rem; font-weight:600; transition:all .2s; }
.upi-app i { font-size:1.2rem; }
.upi-app.active { border-color:rgba(240,195,142,.35); background:rgba(240,195,142,.07); color:var(--peach); }
.upi-app:hover:not(.active) { border-color:rgba(255,255,255,.22); }

/* COD info */
.cod-info { display:flex; align-items:flex-start; gap:10px; background:rgba(249,115,22,.08); border:1px solid rgba(249,115,22,.2); border-radius:12px; padding:14px; }
.cod-info i { color:var(--orange); flex-shrink:0; margin-top:1px; }
.cod-info span { font-family:'Poppins',sans-serif; font-size:.78rem; color:rgba(255,255,255,.6); line-height:1.55; }

/* ── Place Order Button ── */
.place-order-btn {
  background:linear-gradient(135deg,var(--peach),var(--pink));
  color:var(--dark); border:none; border-radius:18px;
  padding:18px; width:100%;
  font-family:'Fredoka One',cursive; font-size:1.1rem;
  display:flex; align-items:center; justify-content:center; gap:10px;
  position:relative; overflow:hidden;
  transition:all .3s var(--ease-sp);
  box-shadow:0 8px 30px rgba(240,195,142,.3);
}
.place-order-btn:hover { transform:translateY(-3px); box-shadow:0 14px 40px rgba(240,195,142,.45); }
.place-order-btn:active { transform:scale(.98); }
.place-order-btn.loading { pointer-events:none; opacity:.8; }

/* ══════════════════════════════════════════
   RIGHT COLUMN — CART SUMMARY
══════════════════════════════════════════ */
.op-right { position:sticky;   top:calc(var(--nav-h) + 20px);
 }
.cart-summary { background:var(--card-bg); backdrop-filter:blur(10px); border:1px solid var(--card-br); border-radius:22px; padding:24px; }
.cs-head { display:flex; align-items:center; justify-content:space-between; margin-bottom:18px; }
.cs-head h3 { font-family:'Fredoka One',cursive; font-size:1.15rem; color:#fff; display:flex; align-items:center; gap:8px; }
.cs-head h3 i { color:var(--peach); }
.cs-items-count { font-family:'Poppins',sans-serif; font-size:.72rem; font-weight:600; color:rgba(255,255,255,.35); background:rgba(255,255,255,.07); border-radius:50px; padding:4px 10px; }
.cs-items { display:flex; flex-direction:column; gap:8px; margin-bottom:18px; max-height:260px; overflow-y:auto; }
.cs-items::-webkit-scrollbar { width:3px; }
.cs-items::-webkit-scrollbar-thumb { background:var(--purple); }
.cs-item { display:flex; align-items:center; gap:10px; padding:8px 10px; background:rgba(255,255,255,.03); border-radius:10px; }
.csi-ico { width:32px; height:32px; border-radius:8px; display:flex; align-items:center; justify-content:center; font-size:.88rem; flex-shrink:0; }
.csi-name { flex:1; font-family:'Nunito',sans-serif; font-weight:700; font-size:.82rem; color:#fff; }
.csi-qty { font-family:'Poppins',sans-serif; font-size:.7rem; color:rgba(255,255,255,.35); margin-right:4px; }
.csi-price { font-family:'Fredoka One',cursive; font-size:.88rem; color:var(--peach); }

.cs-calc { display:flex; flex-direction:column; gap:8px; margin-bottom:16px; }
.cs-row { display:flex; justify-content:space-between; align-items:center; font-family:'Poppins',sans-serif; font-size:.82rem; color:rgba(255,255,255,.5); }
.cs-row strong { color:#fff; font-family:'Nunito',sans-serif; font-weight:700; }
.discount-lbl { color:var(--green); display:flex; align-items:center; gap:5px; }
.discount-val { color:var(--green) !important; }
.cs-sep { height:1px; background:rgba(255,255,255,.07); margin:4px 0; }
.total-row { font-size:.95rem; }
.total-row span { font-family:'Fredoka One',cursive; font-size:1rem; color:#fff; }
.total-row strong { font-family:'Fredoka One',cursive; font-size:1.5rem; color:var(--peach); }

.cs-eta { display:flex; align-items:center; gap:8px; font-family:'Poppins',sans-serif; font-size:.75rem; color:rgba(255,255,255,.4); background:rgba(255,255,255,.04); border-radius:10px; padding:10px 12px; margin-bottom:14px; }
.cs-eta i { color:var(--peach); }
.cs-order-btn { width:100%; padding:15px; background:linear-gradient(135deg,var(--peach),var(--pink)); color:var(--dark); border-radius:14px; font-family:'Fredoka One',cursive; font-size:1rem; display:flex; align-items:center; justify-content:center; gap:9px; position:relative; overflow:hidden; transition:all .3s; box-shadow:0 6px 20px rgba(240,195,142,.25); margin-bottom:10px; }
.cs-order-btn:hover { transform:translateY(-2px); box-shadow:0 10px 30px rgba(240,195,142,.38); }
.cs-secure { text-align:center; font-family:'Poppins',sans-serif; font-size:.7rem; color:rgba(255,255,255,.25); display:flex; align-items:center; justify-content:center; gap:5px; }
.cs-secure i { color:rgba(240,195,142,.4); }

/* ══════════════════════════════════════════
   ORDER SUCCESS OVERLAY
══════════════════════════════════════════ */
.order-success-overlay {
  position:fixed; inset:0; background:rgba(0,0,0,.7);
  backdrop-filter:blur(8px); z-index:2000;
  display:flex; align-items:center; justify-content:center;
  padding:20px; opacity:0; pointer-events:none;
  transition:opacity .4s;
}
.order-success-overlay.show { opacity:1; pointer-events:all; }
.os-card {
  background:var(--bg2); border:1px solid rgba(240,195,142,.2);
  border-radius:28px; padding:44px 40px; text-align:center;
  max-width:420px; width:100%;
  transform:scale(.8) translateY(30px);
  transition:transform .5s var(--ease-sp);
}
.order-success-overlay.show .os-card { transform:scale(1) translateY(0); }
.os-check { width:80px; height:80px; border-radius:50%; background:rgba(74,222,128,.15); border:2px solid rgba(74,222,128,.4); display:flex; align-items:center; justify-content:center; margin:0 auto 20px; animation:checkBounce .7s var(--ease-sp) .2s both; }
.os-check i { font-size:2.2rem; color:var(--green); }
@keyframes checkBounce { from{transform:scale(0) rotate(-45deg);opacity:0} 60%{transform:scale(1.2) rotate(5deg);opacity:1} to{transform:scale(1);opacity:1} }
.os-card h2 { font-family:'Fredoka One',cursive; font-size:2rem; color:#fff; margin-bottom:8px; }
.os-card p { font-family:'Poppins',sans-serif; font-size:.88rem; color:rgba(255,255,255,.55); margin-bottom:20px; }
.os-id { background:rgba(255,255,255,.06); border-radius:10px; padding:10px 16px; font-family:'Poppins',sans-serif; font-size:.82rem; color:rgba(255,255,255,.5); margin-bottom:14px; }
.os-id strong { color:var(--peach); }
.os-eta-big { display:flex; align-items:center; justify-content:center; gap:8px; font-family:'Poppins',sans-serif; font-size:.88rem; color:rgba(255,255,255,.6); margin-bottom:24px; }
.os-eta-big i { color:var(--peach); }
.os-eta-big strong { color:#fff; }
.os-track-btn { background:linear-gradient(135deg,var(--peach),var(--pink)); color:var(--dark); border-radius:50px; padding:13px 28px; font-family:'Fredoka One',cursive; font-size:1rem; display:inline-flex; align-items:center; gap:8px; transition:all .25s; }
.os-track-btn:hover { transform:scale(1.04); }

/* ══════════════════════════════════════════
   ORDER TRACKING SECTION
══════════════════════════════════════════ */
.order-track-section { padding:80px 5%; background:linear-gradient(180deg,var(--bg1) 0%,var(--bg2) 100%); }
.ots-inner { max-width:820px; margin:0 auto; }
.ots-hd { text-align:center; margin-bottom:36px; }
.ots-hd h2 { font-family:'Fredoka One',cursive; font-size:2.2rem; color:#fff; margin-bottom:8px; }

.ots-card { background:var(--card-bg); border:1px solid var(--card-br); border-radius:24px; padding:28px; margin-bottom:24px; }
.otc-top { display:flex; align-items:center; justify-content:space-between; margin-bottom:28px; flex-wrap:wrap; gap:12px; }
.otc-id { font-family:'Poppins',sans-serif; font-size:.8rem; color:rgba(255,255,255,.4); }
.otc-id strong { color:var(--peach); font-size:.9rem; }
.otc-time { display:flex; align-items:center; gap:6px; font-family:'Poppins',sans-serif; font-size:.8rem; color:rgba(255,255,255,.5); margin-top:4px; }
.otc-time i { color:var(--peach); }
.otc-badge { display:flex; align-items:center; gap:7px; border-radius:50px; padding:8px 16px; font-family:'Poppins',sans-serif; font-size:.78rem; font-weight:700; }
.otc-badge.preparing { background:rgba(240,195,142,.15); color:var(--peach); border:1px solid rgba(240,195,142,.25); }
.otc-badge.out { background:rgba(74,222,128,.12); color:var(--green); border:1px solid rgba(74,222,128,.25); }
.otc-badge.delivered { background:rgba(74,222,128,.15); color:var(--green); border:1px solid rgba(74,222,128,.3); }
.otc-pulse { width:8px; height:8px; border-radius:50%; background:currentColor; animation:pulseDot 1.5s ease-in-out infinite; flex-shrink:0; }

/* Tracker */
.tracker { display:flex; align-items:center; margin-bottom:24px; }
.track-step { display:flex; flex-direction:column; align-items:center; gap:8px; flex-shrink:0; }
.ts-ico { width:48px; height:48px; border-radius:50%; border:2px solid rgba(255,255,255,.12); display:flex; align-items:center; justify-content:center; font-size:1rem; color:rgba(255,255,255,.3); background:rgba(255,255,255,.04); transition:all .5s; }
.track-step.done .ts-ico { background:rgba(74,222,128,.15); border-color:rgba(74,222,128,.4); color:var(--green); }
.track-step.active .ts-ico { background:rgba(240,195,142,.15); border-color:rgba(240,195,142,.4); color:var(--peach); animation:activeStep 2s ease-in-out infinite; }
@keyframes activeStep { 0%,100%{box-shadow:0 0 0 0 rgba(240,195,142,.3)} 50%{box-shadow:0 0 0 8px rgba(240,195,142,0)} }
.ts-info { text-align:center; }
.ts-info b { font-family:'Nunito',sans-serif; font-weight:700; font-size:.78rem; color:#fff; display:block; white-space:nowrap; }
.ts-info span { font-family:'Poppins',sans-serif; font-size:.65rem; color:rgba(255,255,255,.35); white-space:nowrap; }
.track-line { flex:1; height:2px; background:rgba(255,255,255,.08); margin-bottom:22px; transition:background .5s; }
.track-line.done { background:rgba(74,222,128,.35); }

/* Driver info */
.driver-info { display:flex; align-items:center; gap:14px; background:rgba(74,222,128,.06); border:1px solid rgba(74,222,128,.18); border-radius:14px; padding:14px 18px; margin-bottom:18px; animation:slideDown .4s var(--ease-o); }
.di-avatar { width:44px; height:44px; border-radius:50%; background:linear-gradient(135deg,var(--dark),var(--purple)); border:2px solid rgba(240,195,142,.2); display:flex; align-items:center; justify-content:center; color:var(--peach); font-size:1rem; flex-shrink:0; }
.di-details { flex:1; }
.di-details b { font-family:'Nunito',sans-serif; font-weight:800; font-size:.9rem; color:#fff; display:block; }
.di-details span { font-family:'Poppins',sans-serif; font-size:.72rem; color:rgba(255,255,255,.4); }
.di-call { display:flex; align-items:center; gap:6px; background:rgba(74,222,128,.15); border:1px solid rgba(74,222,128,.3); color:var(--green); border-radius:50px; padding:7px 16px; font-family:'Poppins',sans-serif; font-size:.75rem; font-weight:600; transition:all .2s; }
.di-call:hover { background:rgba(74,222,128,.25); }

.track-items-preview { border-top:1px solid rgba(255,255,255,.07); padding-top:18px; }
.tip-label { font-family:'Poppins',sans-serif; font-size:.76rem; font-weight:600; color:rgba(255,255,255,.35); margin-bottom:10px; display:flex; align-items:center; gap:7px; }
.tip-list { display:flex; flex-direction:column; gap:7px; }
.tip-item { display:flex; align-items:center; gap:10px; font-family:'Poppins',sans-serif; font-size:.78rem; color:rgba(255,255,255,.6); }
.tip-item i { width:24px; height:24px; border-radius:6px; display:flex; align-items:center; justify-content:center; font-size:.7rem; }

.new-order-btn { display:flex; align-items:center; gap:8px; background:rgba(255,255,255,.06); border:1.5px solid rgba(255,255,255,.12); color:rgba(255,255,255,.7); border-radius:50px; padding:12px 24px; font-family:'Fredoka One',cursive; font-size:.95rem; margin:0 auto; transition:all .3s; }
.new-order-btn:hover { border-color:var(--peach); color:var(--peach); }

/* ══════════════════════════════════════════
   ORDER HISTORY
══════════════════════════════════════════ */
.order-history-section { padding:80px 5%; }
.ohs-inner { max-width:1300px; margin:0 auto; }
.ohs-hd { text-align:center; margin-bottom:40px; display:flex; flex-direction:column; align-items:center; }
.ohs-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:20px; }
.oh-card { background:var(--card-bg); border:1px solid var(--card-br); border-radius:20px; padding:22px; opacity:0; transform:translateY(28px); transition:opacity .6s var(--ease-o), transform .6s var(--ease-o), border-color .25s, box-shadow .25s; }
.oh-card.visible { opacity:1; transform:translateY(0); }
.oh-card:hover { border-color:rgba(240,195,142,.2); box-shadow:0 12px 35px rgba(0,0,0,.2); }
.ohc-top { display:flex; align-items:center; justify-content:space-between; margin-bottom:14px; }
.ohc-id { font-family:'Poppins',sans-serif; font-size:.78rem; font-weight:600; color:var(--peach); }
.ohc-status { font-family:'Poppins',sans-serif; font-size:.72rem; font-weight:600; display:flex; align-items:center; gap:5px; border-radius:50px; padding:4px 10px; }
.ohc-status.delivered { background:rgba(74,222,128,.12); color:var(--green); border:1px solid rgba(74,222,128,.2); }
.ohc-items { display:flex; flex-direction:column; gap:7px; margin-bottom:16px; padding-bottom:16px; border-bottom:1px solid rgba(255,255,255,.06); }
.ohc-items span { font-family:'Poppins',sans-serif; font-size:.78rem; color:rgba(255,255,255,.55); display:flex; align-items:center; gap:7px; }
.ohc-items span i { color:rgba(240,195,142,.5); font-size:.72rem; width:14px; }
.ohc-bot { display:flex; align-items:center; justify-content:space-between; }
.ohc-meta { font-family:'Poppins',sans-serif; font-size:.72rem; color:rgba(255,255,255,.3); display:flex; align-items:center; gap:5px; }
.ohc-meta i { color:rgba(240,195,142,.4); }
.reorder-btn { display:flex; align-items:center; gap:5px; background:linear-gradient(135deg,var(--dark),var(--purple)); color:var(--peach); border-radius:50px; padding:7px 14px; font-family:'Poppins',sans-serif; font-size:.72rem; font-weight:600; transition:all .25s; border:1px solid rgba(240,195,142,.15); }
.reorder-btn:hover { transform:scale(1.06); box-shadow:0 4px 14px rgba(49,44,81,.4); }

/* Mobile bottom bar */
.mob-order-bar { display:none; position:fixed; bottom:0; left:0; right:0; z-index:400; background:rgba(49,44,81,.97); backdrop-filter:blur(14px); border-top:1px solid rgba(240,195,142,.12); padding:12px 5%; align-items:center; justify-content:space-between; gap:14px; }
.mob-total span { font-family:'Poppins',sans-serif; font-size:.72rem; color:rgba(255,255,255,.4); display:block; }
.mob-total strong { font-family:'Fredoka One',cursive; font-size:1.4rem; color:var(--peach); }
.mob-place-btn { background:linear-gradient(135deg,var(--peach),var(--pink)); color:var(--dark); border-radius:50px; padding:12px 24px; font-family:'Fredoka One',cursive; font-size:.95rem; display:flex; align-items:center; gap:7px; flex-shrink:0; transition:all .25s; }
.mob-place-btn:hover { transform:scale(1.04); }

/* ══════════════════════════════════════════
   RESPONSIVE
══════════════════════════════════════════ */
@media (max-width:1100px) {
  .op-main { grid-template-columns:1fr 340px; gap:20px; }
}
@media (max-width:900px) {
  .op-main { grid-template-columns:1fr; }
  .op-right { position:static; }
  .cart-summary { display:none; }
  .mob-order-bar { display:flex; }
  .op-left { padding-bottom:80px; }
  .nav-links { display:none; }
  .ham-btn { display:flex; }
  .ohs-grid { grid-template-columns:1fr 1fr; gap:16px; }
  .cf-row { grid-template-columns:1fr 1fr; }
  .cf-row .cf-group:last-child input { width:100%; }
}
@media (max-width:640px) {
  .op-main { padding:18px 4% 80px; }
  .order-track-section, .order-history-section { padding:60px 4%; }
  .ohs-grid { grid-template-columns:1fr; }
  .tracker { flex-direction:column; align-items:flex-start; gap:0; }
  .track-step { flex-direction:row; gap:14px; padding:10px 0; }
  .ts-ico { flex-shrink:0; }
  .ts-info { text-align:left; }
  .track-line { width:2px; height:30px; margin:0 0 0 23px; flex:none; }
  .steps-bar { gap:4px; padding:14px 3%; }
  .step-ico { width:32px; height:32px; font-size:.72rem; }
  .step span { font-size:.6rem; }
  .step-line { min-width:20px; }
  .qm-grid { grid-template-columns:1fr; }
  .promo-chips { flex-direction:column; }
  .pay-options .po-top { gap:10px; }
}
@media (max-width:400px) {
  .op-hero { padding:40px 4% 28px; }
  .oc-hd { padding:16px 16px 14px; }
  .oc-body { padding:16px; }
  .dp-btn { padding:8px 14px; font-size:.76rem; }
}

/* ═══════════════════════════════════════════════════
   CAFE ORIX — ORDER.CSS  (Part 2 — missing styles)
   Paste this AFTER the CSS you already have
═══════════════════════════════════════════════════ */

/* ── Payment body inner ── */
.po-radio {
  margin-left:auto;
  width:20px; height:20px; border-radius:50%;
  border:2px solid rgba(255,255,255,.2);
  display:flex; align-items:center; justify-content:center;
  transition:.3s; flex-shrink:0;
}
.pay-opt.active .po-radio { border-color:var(--peach); }
.po-dot {
  width:10px; height:10px; border-radius:50%;
  background:var(--peach); transform:scale(0); transition:.3s;
}
.pay-opt.active .po-dot { transform:scale(1); }
.po-top > div:nth-child(2) b {
  display:block; font-family:'Nunito',sans-serif;
  font-weight:700; font-size:.9rem; color:#fff;
}
.po-top > div:nth-child(2) span {
  font-family:'Poppins',sans-serif; font-size:.73rem;
  color:rgba(255,255,255,.4);
}
.po-body { padding:0 18px 18px; animation:slideDown .35s var(--ease-o); }

/* ── Card Preview ── */
.card-preview {
  background:linear-gradient(135deg,var(--dark) 0%,var(--purple) 100%);
  border:1px solid rgba(240,195,142,.2);
  border-radius:18px; padding:22px; margin-bottom:18px;
  position:relative; overflow:hidden; min-height:130px;
}
.card-preview::before {
  content:''; position:absolute; inset:0;
  background:radial-gradient(ellipse 70% 60% at 80% 20%, rgba(240,195,142,.12), transparent);
}
.cp-top { display:flex; justify-content:space-between; align-items:center; margin-bottom:18px; }
.cp-chip { color:var(--peach); font-size:1.2rem; }
.cp-brand { font-family:'Fredoka One',cursive; font-size:1.1rem; color:rgba(255,255,255,.5); letter-spacing:2px; }
.cp-num { font-family:'Fredoka One',cursive; font-size:1.05rem; color:#fff; letter-spacing:2px; margin-bottom:16px; }
.cp-bot { display:flex; gap:28px; }
.cp-bot > div { display:flex; flex-direction:column; }
.cp-bot span { font-family:'Poppins',sans-serif; font-size:.6rem; color:rgba(255,255,255,.35); margin-bottom:2px; letter-spacing:1px; }
.cp-bot b { font-family:'Nunito',sans-serif; font-weight:800; font-size:.78rem; color:rgba(255,255,255,.8); }

/* ── Card Fields ── */
.card-fields { display:flex; flex-direction:column; gap:12px; }
.cf-group { display:flex; flex-direction:column; gap:5px; }
.cf-group label { font-family:'Poppins',sans-serif; font-size:.72rem; color:rgba(255,255,255,.45); }
.cf-input {
  background:rgba(255,255,255,.06); border:1.5px solid rgba(255,255,255,.1);
  border-radius:12px; padding:11px 14px; color:#fff;
  font-size:.85rem; outline:none; transition:border-color .25s;
}
.cf-input:focus { border-color:rgba(240,195,142,.4); background:rgba(240,195,142,.04); }
.cf-input::placeholder { color:rgba(255,255,255,.25); }
.cf-row { display:grid; grid-template-columns:2fr 1fr 1fr; gap:10px; }

/* ── UPI Apps ── */
.upi-apps { display:flex; gap:10px; flex-wrap:wrap; }
.upi-app {
  display:flex; flex-direction:column; align-items:center; gap:5px;
  background:rgba(255,255,255,.05); border:1.5px solid rgba(255,255,255,.1);
  border-radius:14px; padding:12px 14px; font-size:.75rem;
  font-family:'Poppins',sans-serif; font-weight:600; color:rgba(255,255,255,.55);
  cursor:pointer; transition:all .25s; min-width:72px;
}
.upi-app i { font-size:1.4rem; }
.upi-app.active { border-color:rgba(240,195,142,.4); color:var(--peach); background:rgba(240,195,142,.08); }
.upi-app:hover:not(.active) { border-color:rgba(255,255,255,.22); }

/* ── COD info ── */
.cod-info {
  display:flex; align-items:flex-start; gap:10px;
  background:rgba(240,195,142,.07); border:1px solid rgba(240,195,142,.15);
  border-radius:12px; padding:14px 16px;
  font-family:'Poppins',sans-serif; font-size:.8rem; color:rgba(255,255,255,.6);
  line-height:1.6;
}
.cod-info i { color:var(--peach); flex-shrink:0; margin-top:1px; }

/* ── Place Order Button ── */
.place-order-btn {
  width:100%; padding:17px; border-radius:18px;
  background:linear-gradient(135deg,var(--peach),var(--pink));
  color:var(--dark); font-family:'Fredoka One',cursive; font-size:1.1rem;
  letter-spacing:.5px; display:flex; align-items:center; justify-content:center; gap:10px;
  position:relative; overflow:hidden; transition:all .3s;
  box-shadow:0 8px 30px rgba(240,195,142,.25);
}
.place-order-btn:hover { transform:translateY(-3px); box-shadow:0 14px 40px rgba(240,195,142,.35); }

/* ══════════════════════════════════════════
   RIGHT COLUMN — Cart Summary
══════════════════════════════════════════ */
.op-right { position:sticky; top:calc(var(--nav-h) + 70px); height:fit-content; }

.cart-summary {
  background:rgba(255,255,255,.04);
  backdrop-filter:blur(10px);
  border:1px solid rgba(255,255,255,.08);
  border-radius:22px; padding:26px;
  display:flex; flex-direction:column; gap:0;
}
.cs-head {
  display:flex; align-items:center; justify-content:space-between;
  padding-bottom:16px; border-bottom:1px solid rgba(255,255,255,.07);
  margin-bottom:16px;
}
.cs-head h3 {
  font-family:'Fredoka One',cursive; font-size:1.15rem; color:var(--peach);
  display:flex; align-items:center; gap:8px;
}
.cs-head h3 i { font-size:.95rem; }
.cs-items-count {
  font-family:'Poppins',sans-serif; font-size:.75rem; font-weight:600;
  background:rgba(240,195,142,.1); color:var(--peach); border-radius:50px;
  padding:4px 12px;
}

/* Summary items */
.cs-items { margin-bottom:16px; display:flex; flex-direction:column; gap:4px; }
.csi-row {
  display:flex; align-items:center; justify-content:space-between;
  padding:7px 0; border-bottom:1px solid rgba(255,255,255,.04);
}
.csi-name {
  font-family:'Poppins',sans-serif; font-size:.78rem; color:rgba(255,255,255,.6);
  flex:1; min-width:0; overflow:hidden; text-overflow:ellipsis; white-space:nowrap;
}
.csi-val {
  font-family:'Fredoka One',cursive; font-size:.85rem; color:var(--peach);
  flex-shrink:0; margin-left:10px;
}

/* Calc */
.cs-calc { display:flex; flex-direction:column; gap:8px; margin-bottom:16px; }
.cs-row {
  display:flex; align-items:center; justify-content:space-between;
  font-family:'Poppins',sans-serif; font-size:.82rem;
}
.cs-row span { color:rgba(255,255,255,.5); }
.cs-row strong { color:#fff; font-family:'Nunito',sans-serif; font-weight:700; }
.discount-row { color:var(--green) !important; }
.discount-lbl { color:var(--green) !important; display:flex; align-items:center; gap:6px; }
.discount-val { color:var(--green) !important; }
.gst-row span { color:rgba(255,255,255,.4); font-size:.75rem; }
.cs-sep { height:1px; background:rgba(255,255,255,.08); margin:6px 0; }
.total-row span { color:#fff !important; font-family:'Nunito',sans-serif; font-weight:800; font-size:1rem; }
.total-row strong { color:var(--peach) !important; font-family:'Fredoka One',cursive; font-size:1.2rem; }

/* ETA */
.cs-eta {
  display:flex; align-items:center; gap:8px;
  background:rgba(255,255,255,.04); border:1px solid rgba(255,255,255,.07);
  border-radius:12px; padding:11px 14px; margin-bottom:16px;
  font-family:'Poppins',sans-serif; font-size:.78rem; color:rgba(255,255,255,.5);
}
.cs-eta i { color:var(--peach); flex-shrink:0; }

/* Summary order btn */
.cs-order-btn {
  width:100%; padding:14px; border-radius:14px;
  background:linear-gradient(135deg,var(--peach),var(--pink));
  color:var(--dark); font-family:'Fredoka One',cursive; font-size:1rem;
  display:flex; align-items:center; justify-content:center; gap:8px;
  position:relative; overflow:hidden; transition:all .3s; margin-bottom:12px;
}
.cs-order-btn:hover { transform:translateY(-2px); box-shadow:0 10px 28px rgba(240,195,142,.3); }

.cs-secure {
  display:flex; align-items:center; justify-content:center; gap:6px;
  font-family:'Poppins',sans-serif; font-size:.72rem; color:rgba(255,255,255,.3);
}
.cs-secure i { color:var(--green); }

/* ══════════════════════════════════════════
   ORDER SUCCESS OVERLAY
══════════════════════════════════════════ */
.order-success-overlay {
  position:fixed; inset:0; z-index:800;
  background:rgba(0,0,0,.75); backdrop-filter:blur(10px);
  display:none; align-items:center; justify-content:center;
  padding:20px;
}
.os-card {
  background:linear-gradient(135deg,var(--bg2),var(--bg3));
  border:1px solid rgba(240,195,142,.2);
  border-radius:28px; padding:40px 36px; text-align:center;
  max-width:420px; width:100%;
  animation:popIn .5s cubic-bezier(.34,1.56,.64,1);
}
@keyframes popIn { from{transform:scale(.6);opacity:0} to{transform:scale(1);opacity:1} }
.os-check {
  width:80px; height:80px; border-radius:50%;
  background:linear-gradient(135deg,#4ade80,#16a34a);
  display:flex; align-items:center; justify-content:center;
  font-size:2rem; color:#fff; margin:0 auto 20px;
  box-shadow:0 0 40px rgba(74,222,128,.4);
  animation:pulse 2s ease-in-out infinite;
}
@keyframes pulse { 0%,100%{box-shadow:0 0 30px rgba(74,222,128,.4)} 50%{box-shadow:0 0 60px rgba(74,222,128,.6)} }
.os-card h2 { font-family:'Fredoka One',cursive; font-size:2rem; color:#fff; margin-bottom:8px; }
.os-card p { font-family:'Poppins',sans-serif; font-size:.88rem; color:rgba(255,255,255,.55); margin-bottom:20px; }
.os-id {
  background:rgba(240,195,142,.08); border:1px solid rgba(240,195,142,.15);
  border-radius:12px; padding:12px; margin-bottom:16px;
  font-family:'Poppins',sans-serif; font-size:.82rem; color:rgba(255,255,255,.5);
}
.os-id strong { font-family:'Fredoka One',cursive; font-size:1.1rem; color:var(--peach); margin-left:6px; }
.os-eta-big {
  display:flex; align-items:center; justify-content:center; gap:10px;
  font-family:'Poppins',sans-serif; font-size:.88rem; color:rgba(255,255,255,.6);
  margin-bottom:24px;
}
.os-eta-big i { color:var(--peach); }
.os-eta-big strong { color:#fff; }
.os-track-btn {
  width:100%; padding:14px; border-radius:14px;
  background:linear-gradient(135deg,var(--peach),var(--pink));
  color:var(--dark); font-family:'Fredoka One',cursive; font-size:1rem;
  display:flex; align-items:center; justify-content:center; gap:8px;
  transition:all .3s;
}
.os-track-btn:hover { transform:translateY(-2px); box-shadow:0 10px 28px rgba(240,195,142,.3); }

/* ══════════════════════════════════════════
   LIVE ORDER TRACKING SECTION
══════════════════════════════════════════ */
.order-track-section {
  padding:70px 5%; background:rgba(0,0,0,.2);
  border-top:1px solid rgba(255,255,255,.05);
}
.ots-inner { max-width:700px; margin:0 auto; }
.ots-hd { text-align:center; margin-bottom:32px; }
.ots-hd h2 { font-family:'Fredoka One',cursive; font-size:clamp(1.6rem,3vw,2.2rem); color:#fff; margin-top:8px; }

.ots-card {
  background:var(--card-bg); backdrop-filter:blur(8px);
  border:1px solid var(--card-br); border-radius:22px;
  padding:28px; margin-bottom:28px;
}
.otc-top { display:flex; align-items:flex-start; justify-content:space-between; gap:14px; margin-bottom:28px; flex-wrap:wrap; }
.otc-id { font-family:'Nunito',sans-serif; font-size:.82rem; color:rgba(255,255,255,.4); margin-bottom:4px; }
.otc-id strong { color:var(--peach); }
.otc-time { display:flex; align-items:center; gap:7px; font-family:'Poppins',sans-serif; font-size:.82rem; color:rgba(255,255,255,.7); }
.otc-time i { color:var(--peach); }
.otc-badge {
  display:flex; align-items:center; gap:7px;
  border-radius:50px; padding:8px 16px;
  font-family:'Poppins',sans-serif; font-size:.78rem; font-weight:600;
}
.otc-badge.preparing { background:rgba(240,195,142,.1); border:1px solid rgba(240,195,142,.2); color:var(--peach); }
.otc-badge.out { background:rgba(72,66,109,.4); border:1px solid rgba(241,170,155,.3); color:var(--pink); }
.otc-badge.delivered { background:rgba(74,222,128,.1); border:1px solid rgba(74,222,128,.3); color:var(--green); }
.otc-pulse {
  width:8px; height:8px; border-radius:50%; background:currentColor;
  animation:pulseDot 1.4s ease-in-out infinite;
}

/* Tracker steps */
.tracker { display:flex; align-items:flex-start; gap:0; margin-bottom:24px; }
.track-step { display:flex; flex-direction:column; align-items:center; flex:1; gap:0; }
.ts-ico {
  width:44px; height:44px; border-radius:50%;
  background:rgba(255,255,255,.06); border:2px solid rgba(255,255,255,.12);
  display:flex; align-items:center; justify-content:center;
  font-size:.9rem; color:rgba(255,255,255,.3);
  transition:all .5s cubic-bezier(.34,1.56,.64,1);
  margin-bottom:8px;
}
.track-step.done .ts-ico { background:rgba(74,222,128,.15); border-color:rgba(74,222,128,.4); color:var(--green); }
.track-step.active .ts-ico {
  background:linear-gradient(135deg,var(--dark),var(--purple));
  border-color:var(--peach); color:var(--peach);
  box-shadow:0 0 20px rgba(240,195,142,.3);
}
.ts-info { text-align:center; }
.ts-info b { display:block; font-family:'Nunito',sans-serif; font-weight:700; font-size:.78rem; color:rgba(255,255,255,.7); margin-bottom:2px; }
.ts-info span { font-family:'Poppins',sans-serif; font-size:.67rem; color:rgba(255,255,255,.3); }
.track-step.active .ts-info b { color:var(--peach); }
.track-step.done .ts-info b { color:var(--green); }

.track-line {
  flex:1; height:2px; background:rgba(255,255,255,.08);
  margin-top:21px; transition:background .6s;
}
.track-line.done { background:rgba(74,222,128,.35); }

/* Driver info */
.driver-info {
  display:flex; align-items:center; gap:14px;
  background:rgba(255,255,255,.04); border:1px solid rgba(255,255,255,.08);
  border-radius:16px; padding:14px 18px; margin-bottom:20px;
  animation:slideDown .4s var(--ease-o);
}
.di-avatar {
  width:44px; height:44px; border-radius:50%;
  background:linear-gradient(135deg,var(--dark),var(--purple));
  border:2px solid rgba(240,195,142,.2);
  display:flex; align-items:center; justify-content:center;
  color:var(--peach); font-size:1.1rem; flex-shrink:0;
}
.di-details { flex:1; }
.di-details b { display:block; font-family:'Nunito',sans-serif; font-weight:700; font-size:.9rem; }
.di-details span { font-family:'Poppins',sans-serif; font-size:.73rem; color:rgba(255,255,255,.4); }
.di-call {
  display:flex; align-items:center; gap:7px;
  background:rgba(74,222,128,.1); border:1px solid rgba(74,222,128,.3);
  color:var(--green); border-radius:50px; padding:8px 16px;
  font-family:'Poppins',sans-serif; font-size:.78rem; font-weight:600;
  transition:all .25s;
}
.di-call:hover { background:rgba(74,222,128,.2); }

/* Tip list */
.track-items-preview { margin-top:4px; }
.tip-label {
  font-family:'Poppins',sans-serif; font-size:.75rem; font-weight:600;
  color:rgba(255,255,255,.35); margin-bottom:10px;
  display:flex; align-items:center; gap:6px;
}
.tip-label i { color:var(--peach); }
.tip-list { display:flex; flex-wrap:wrap; gap:8px; }
.tip-chip {
  background:rgba(255,255,255,.05); border:1px solid rgba(255,255,255,.1);
  border-radius:50px; padding:5px 12px;
  font-family:'Poppins',sans-serif; font-size:.72rem; color:rgba(255,255,255,.55);
  display:flex; align-items:center; gap:6px;
}
.tip-chip i { color:var(--peach); font-size:.68rem; }

.new-order-btn {
  display:flex; align-items:center; justify-content:center; gap:8px;
  background:rgba(240,195,142,.08); border:1.5px solid rgba(240,195,142,.2);
  color:var(--peach); border-radius:14px; padding:13px 28px;
  font-family:'Fredoka One',cursive; font-size:1rem;
  margin:0 auto; transition:all .25s;
}
.new-order-btn:hover { background:rgba(240,195,142,.15); transform:translateY(-2px); }

/* ══════════════════════════════════════════
   ORDER HISTORY SECTION
══════════════════════════════════════════ */
.order-history-section {
  padding:70px 5% 80px;
  background:linear-gradient(180deg,#0f0c1a,var(--bg1));
  border-top:1px solid rgba(255,255,255,.04);
}
.ohs-inner { max-width:1100px; margin:0 auto; }
.ohs-hd { margin-bottom:40px; }
.ohs-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(280px,1fr)); gap:18px; }

.oh-card {
  background:var(--card-bg); backdrop-filter:blur(6px);
  border:1px solid var(--card-br); border-radius:18px;
  padding:20px; transition:all .3s;
}
.oh-card:hover { border-color:rgba(240,195,142,.22); transform:translateY(-4px); box-shadow:0 16px 40px rgba(0,0,0,.3); }
.ohc-top { display:flex; align-items:center; justify-content:space-between; margin-bottom:14px; }
.ohc-id { font-family:'Fredoka One',cursive; font-size:.95rem; color:var(--peach); }
.ohc-status {
  font-family:'Poppins',sans-serif; font-size:.7rem; font-weight:600;
  border-radius:50px; padding:4px 12px;
}
.ohc-status.delivered { background:rgba(74,222,128,.1); color:var(--green); border:1px solid rgba(74,222,128,.25); }
.ohc-status.cancelled { background:rgba(239,68,68,.1); color:#ef4444; border:1px solid rgba(239,68,68,.25); }

.ohc-items {
  display:flex; flex-direction:column; gap:6px;
  border-bottom:1px solid rgba(255,255,255,.06); padding-bottom:14px; margin-bottom:14px;
}
.ohc-item {
  display:flex; align-items:center; gap:8px;
  font-family:'Poppins',sans-serif; font-size:.78rem; color:rgba(255,255,255,.6);
}
.ohc-item i { color:var(--peach); font-size:.72rem; width:14px; }

.ohc-meta { display:flex; align-items:center; justify-content:space-between; margin-bottom:14px; }
.ohc-date { font-family:'Poppins',sans-serif; font-size:.72rem; color:rgba(255,255,255,.35); display:flex; align-items:center; gap:5px; }
.ohc-date i { font-size:.65rem; }
.ohc-total { font-family:'Fredoka One',cursive; font-size:1.05rem; color:var(--peach); }

.ohc-reorder {
  width:100%; padding:11px; border-radius:12px;
  background:rgba(240,195,142,.08); border:1.5px solid rgba(240,195,142,.2);
  color:var(--peach); font-family:'Fredoka One',cursive; font-size:.9rem;
  display:flex; align-items:center; justify-content:center; gap:7px;
  transition:all .25s;
}
.ohc-reorder:hover { background:rgba(240,195,142,.15); transform:scale(1.02); }

/* ══════════════════════════════════════════
   MOBILE BOTTOM TAB BAR
══════════════════════════════════════════ */
.mob-tabbar {
  display:none; position:fixed; bottom:0; left:0; right:0; z-index:700;
  background:rgba(15,12,26,.97); backdrop-filter:blur(20px);
  border-top:1px solid rgba(240,195,142,.1);
  padding:8px 0 max(8px, env(safe-area-inset-bottom));
}
.mob-tabbar-inner { display:flex; justify-content:space-around; }
.mtab {
  display:flex; flex-direction:column; align-items:center; gap:3px;
  color:rgba(255,255,255,.35); font-family:'Nunito',sans-serif; font-weight:700;
  font-size:.6rem; padding:4px 8px; cursor:pointer; transition:.3s;
  background:none; border:none; flex:1; position:relative;
}
.mtab i { font-size:1.2rem; display:block; transition:.3s; }
.mtab.active, .mtab:hover { color:var(--peach); }
.mtab.active i { transform:scale(1.15); }
.mtab-pip { width:16px; height:3px; border-radius:3px; background:var(--peach); margin-bottom:1px; opacity:0; transition:.3s; }
.mtab.active .mtab-pip { opacity:1; }

/* ══════════════════════════════════════════
   RESPONSIVE
══════════════════════════════════════════ */
@media (max-width:1100px) {
  .op-main { grid-template-columns:1fr 340px; gap:20px; }
}

@media (max-width:900px) {
  .op-main { grid-template-columns:1fr; }
  .op-right { position:static; }
  .cart-summary { border-radius:18px; }
  .nav-links { display:none; }
  .mob-tabbar { display:block; }
  body { padding-bottom:68px; }
  .steps-bar { gap:0; padding:16px 3%; overflow-x:auto; }
  .step span { display:none; }
  .step-ico { width:34px; height:34px; font-size:.75rem; }
  .step-line { min-width:24px; }
}

@media (max-width:640px) {
  .op-hero { padding:40px 5% 30px; }
  .op-title { font-size:1.8rem; }
  .op-badges { gap:8px; }
  .op-badges span { font-size:.7rem; padding:5px 11px; }
  .oc-hd { flex-wrap:wrap; gap:10px; }
  .qm-grid { grid-template-columns:1fr; }
  .cf-row { grid-template-columns:1fr 1fr; }
  .upi-apps { gap:8px; }
  .upi-app { min-width:60px; padding:10px 10px; }
  .ohs-grid { grid-template-columns:1fr; }
  .tracker { gap:0; }
  .ts-info b { font-size:.68rem; }
  .ts-info span { font-size:.6rem; }
  .dp-toggle { width:100%; }
  .dp-btn { flex:1; justify-content:center; }
  .loc-row { flex-direction:column; }
  .loc-check-btn { width:100%; justify-content:center; padding:13px; }
  .cs-head h3 { font-size:1rem; }
}

@media (max-width:380px) {
  .oc-body { padding:14px 14px; }
  .oc-hd { padding:16px 14px 14px; }
  .cart-summary { padding:18px; }
}

@media(max-width:768px){

  .op-main{
    grid-template-columns:1fr;
  }

  .op-title{
    font-size:clamp(2rem,4vw,3rem);
    line-height:.95;
    text-align:center;
  }

  .op-sub{
    text-align:center;
  }

  .op-badges{
    justify-content:center;
  }

  .loc-row,
  .promo-row{
    flex-direction:column;
  }

  .loc-check-btn,
  .promo-btn{
    width:100%;
    height:52px;
    justify-content:center;
  }

  .qm-grid{
    grid-template-columns:1fr;
  }

  .op-right{
    position:relative;
    top:auto;
  }

  .steps-bar{
    overflow-x:auto;
    justify-content:flex-start;
    padding-inline:20px;
  }
}

/* =========================================
PERFECT RESPONSIVE SYSTEM
========================================= */

/* LARGE LAPTOP */

@media(max-width:1400px){

  .op-wrap{

    max-width:1200px;
  }
}

/* LAPTOP */

@media(max-width:1200px){

  .op-main{

    gap:40px;
  }

  .op-title{

    font-size:clamp(2.4rem,5vw,4.5rem);
  }

  .hero-plate{

    width:420px;
    height:420px;
  }
}

/* TABLET */

@media(max-width:992px){

  .op-main{

    grid-template-columns:1fr;

    text-align:center;

    gap:70px;
  }

  .op-left{

    display:flex;

    flex-direction:column;

    align-items:center;
  }

  .op-sub{

    max-width:650px;
  }

  .hero-floating{

    position:relative;

    inset:auto;

    margin:12px auto;
  }

  .hero-plate{

    width:360px;
    height:360px;
  }

  .steps-bar{

    overflow-x:auto;

    justify-content:flex-start;

    padding-bottom:10px;
  }
}

/* MOBILE */

@media(max-width:768px){

  section{

    padding:80px 20px;
  }

  .op-title{

    font-size:2.8rem;

    line-height:.92;
  }

  .op-sub{

    font-size:.95rem;

    line-height:1.7;
  }

  .hero-btns{

    width:100%;

    flex-direction:column;
  }

  .hero-btns button{

    width:100%;
  }

  .hero-plate{

    width:280px;
    height:280px;
  }

  .hero-floating{

    width:100%;

    max-width:260px;
  }

  .delivery-card{

    position:relative;

    left:auto;

    bottom:auto;

    margin-top:20px;
  }

  .qm-grid{

    grid-template-columns:1fr;
  }

  .cart-layout{

    grid-template-columns:1fr;
  }
}

/* SMALL MOBILE */

@media(max-width:480px){

  .op-title{

    font-size:2.2rem;
  }

  .hero-plate{

    width:220px;
    height:220px;
  }

  .badge{

    font-size:.72rem;
  }

  .hero-floating{

    font-size:.78rem;

    padding:10px 14px;
  }

  .step{

    min-width:120px;
  }
}

/* =========================================
RESPONSIVE FIX
========================================= */

@media(max-width:1100px){

  .op-main{

    grid-template-columns:1fr;
  }

  .op-right{

    position:relative;

    top:auto;
  }
}

@media(max-width:768px){

  section,
  .op-hero{

    padding-left:20px;
    padding-right:20px;
  }

  .op-title{

    font-size:2.3rem;

    line-height:.92;
  }

  .op-sub{

    font-size:.84rem;

    line-height:1.6;
  }

  .op-badges{

    gap:8px;
  }

  .op-badges span{

    font-size:.68rem;

    padding:6px 12px;
  }

  .steps-bar{

    justify-content:flex-start;

    padding-inline:16px;
  }

  .oc-hd{

    padding:18px;
  }

  .oc-body{

    padding:18px;
  }

  .loc-row,
  .promo-row{

    flex-direction:column;
  }

  .loc-check-btn,
  .promo-btn{

    width:100%;

    justify-content:center;

    height:50px;
  }

  .qm-grid{

    grid-template-columns:1fr;
  }

  .pay-options{

    gap:10px;
  }

  .cf-row{

    grid-template-columns:1fr;
  }

  .place-order-btn{

    font-size:1rem;

    padding:16px;
  }
}

@media(max-width:480px){

  .op-title{

    font-size:1.9rem;
  }

  .sec-title{

    font-size:1.5rem;
  }

  .oc-num{

    width:32px;
    height:32px;
  }

  .oc-hd-info h3{

    font-size:1rem;
  }

  .ci-item{

    padding:10px;
  }

  .ci-name{

    font-size:.82rem;
  }

  .ci-price{

    font-size:.88rem;
  }

  .step{

    min-width:75px;
  }
}