/* ════════════════════════════════════════════════════════
   TAN Tantuni — Sipariş & Sepet sistemi (Getir/Yemeksepeti tarzı)
   Renk/font token'ları index.html :root içinden gelir.
   ════════════════════════════════════════════════════════ */

/* ── Menü kartı: Ekle butonu / adet sayacı ── */
.urun-sag{display:flex;flex-direction:column;align-items:flex-end;gap:10px;align-self:stretch;justify-content:space-between}
.ekle{
  display:inline-flex;align-items:center;justify-content:center;
  width:40px;height:40px;border-radius:13px;border:0;cursor:pointer;
  background:var(--turuncu);color:#fff;
  box-shadow:0 6px 16px rgba(196,98,26,.35);
  transition:transform .18s,box-shadow .18s,background .18s;
}
.ekle:hover{transform:translateY(-2px) scale(1.04);box-shadow:0 9px 20px rgba(196,98,26,.45)}
.ekle:active{transform:scale(.94)}
.ekle svg{width:20px;height:20px;stroke:#fff;fill:none;stroke-width:2.4;stroke-linecap:round}

.stepper{
  display:inline-flex;align-items:center;gap:2px;
  background:var(--turuncu);border-radius:13px;padding:3px;
  box-shadow:0 6px 16px rgba(196,98,26,.35);
}
.stepper button{
  width:34px;height:34px;border:0;background:transparent;cursor:pointer;
  display:inline-flex;align-items:center;justify-content:center;border-radius:10px;
  transition:background .15s;
}
.stepper button:hover{background:rgba(255,255,255,.16)}
.stepper button svg{width:18px;height:18px;stroke:#fff;fill:none;stroke-width:2.6;stroke-linecap:round}
.stepper .adet{min-width:24px;text-align:center;color:#fff;font-weight:800;font-size:15px;font-variant-numeric:tabular-nums}

/* ── Yüzen sepet butonu (FAB) ── */
.sepet-fab{
  position:fixed;z-index:72;right:clamp(16px,3vw,34px);bottom:clamp(16px,3vw,34px);
  display:flex;align-items:center;gap:12px;
  background:var(--komur);color:var(--krem);
  border:0;cursor:pointer;font-family:inherit;font-weight:700;
  padding:14px 20px 14px 16px;border-radius:99px;
  box-shadow:0 16px 40px rgba(28,20,13,.34);
  transform:translateY(140%);opacity:0;pointer-events:none;
  transition:transform .42s cubic-bezier(.2,.8,.25,1.2),opacity .3s;
}
.sepet-fab.gor{transform:none;opacity:1;pointer-events:auto}
.sepet-fab:hover{transform:translateY(-3px)}
.sepet-fab .fab-ikon{position:relative;display:inline-flex}
.sepet-fab .fab-ikon svg{width:24px;height:24px;stroke:var(--amber);fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.sepet-fab .rozet-adet{
  position:absolute;top:-8px;right:-9px;min-width:20px;height:20px;padding:0 5px;
  background:var(--kirmizi);color:#fff;border-radius:99px;
  font-size:11.5px;font-weight:800;display:flex;align-items:center;justify-content:center;
  border:2px solid var(--komur);
}
.sepet-fab .fab-tutar{font-size:15.5px;font-variant-numeric:tabular-nums}
.sepet-fab .fab-et{font-size:12px;opacity:.7;font-weight:600;letter-spacing:.04em;text-transform:uppercase}

/* ── Genel kayan panel (drawer / checkout) altyapısı ── */
.panel-overlay{
  position:fixed;inset:0;z-index:80;background:rgba(20,14,9,.55);
  backdrop-filter:blur(3px);opacity:0;pointer-events:none;transition:opacity .3s;
}
.panel-overlay.acik{opacity:1;pointer-events:auto}

.drawer{
  position:fixed;z-index:81;top:0;right:0;height:100%;width:min(440px,100%);
  background:var(--krem);display:flex;flex-direction:column;
  box-shadow:-20px 0 60px rgba(28,20,13,.25);
  transform:translateX(100%);transition:transform .42s cubic-bezier(.3,.8,.3,1);
}
.drawer.acik{transform:none}
.drawer-bas{
  display:flex;align-items:center;justify-content:space-between;
  padding:22px 24px;border-bottom:1px solid rgba(28,20,13,.09);
}
.drawer-bas h3{font-family:'Archivo Black';font-size:21px;text-transform:uppercase}
.kapat{width:40px;height:40px;border:0;background:rgba(28,20,13,.06);border-radius:12px;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;transition:background .15s}
.kapat:hover{background:rgba(28,20,13,.12)}
.kapat svg{width:20px;height:20px;stroke:var(--komur);stroke-width:2.4;fill:none;stroke-linecap:round}

.drawer-govde{flex:1;overflow-y:auto;overscroll-behavior:contain;padding:18px 24px;display:flex;flex-direction:column;gap:14px}

/* sepet satırı */
.sepet-satir{display:flex;gap:14px;align-items:center;background:var(--beyaz);border-radius:16px;padding:12px;box-shadow:0 4px 14px rgba(28,20,13,.05)}
.sepet-satir img{width:64px;height:64px;border-radius:12px;object-fit:cover;background:#fff;flex-shrink:0}
.sepet-satir.icecek img{object-fit:contain;padding:4px}
.sepet-satir .ss-bilgi{flex:1;min-width:0}
.sepet-satir .ss-ad{font-weight:700;font-size:14.5px;line-height:1.25}
.sepet-satir .ss-fiyat{color:var(--turuncu);font-weight:800;font-size:14px;margin-top:3px;font-variant-numeric:tabular-nums}
.sepet-satir .stepper{background:var(--krem);box-shadow:none;border:1.5px solid rgba(28,20,13,.12)}
.sepet-satir .stepper button svg{stroke:var(--komur)}
.sepet-satir .stepper .adet{color:var(--komur)}
.sepet-satir .stepper.cop button svg{stroke:var(--kirmizi)}

/* boş sepet */
.sepet-bos{text-align:center;color:var(--kahve);padding:54px 20px;display:flex;flex-direction:column;align-items:center;gap:14px}
.sepet-bos svg{width:54px;height:54px;stroke:var(--turuncu-acik);fill:none;stroke-width:1.5;opacity:.6}
.sepet-bos b{font-size:17px;color:var(--komur)}
.sepet-bos span{font-size:14px}

/* drawer alt — toplam + buton */
.drawer-alt{border-top:1px solid rgba(28,20,13,.09);padding:18px 24px calc(18px + env(safe-area-inset-bottom));background:var(--krem)}
.ozet-satir{display:flex;justify-content:space-between;font-size:14.5px;color:var(--kahve);margin-bottom:8px}
.ozet-satir.toplam{color:var(--komur);font-weight:800;font-size:18px;font-family:'Archivo Black';margin:12px 0 0;padding-top:12px;border-top:1px dashed rgba(28,20,13,.16)}
.ozet-satir b{font-variant-numeric:tabular-nums}
.min-uyari{background:#FBEAEA;color:#A33;border-radius:12px;padding:11px 14px;font-size:13px;font-weight:600;margin-bottom:12px;text-align:center}

.ana-btn{
  width:100%;border:0;cursor:pointer;font-family:inherit;font-weight:800;font-size:16px;
  background:var(--turuncu);color:#fff;padding:17px;border-radius:15px;
  display:flex;align-items:center;justify-content:center;gap:10px;
  box-shadow:0 10px 26px rgba(196,98,26,.4);transition:transform .2s,box-shadow .2s,opacity .2s;
}
.ana-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 14px 32px rgba(196,98,26,.5)}
.ana-btn:disabled{opacity:.45;cursor:not-allowed;box-shadow:none}
.ana-btn svg{width:19px;height:19px;stroke:#fff;fill:none;stroke-width:2.2;stroke-linecap:round;stroke-linejoin:round}
.ana-btn.wa{background:#25D366;box-shadow:0 10px 26px rgba(37,211,102,.4)}
.ana-btn.wa:hover:not(:disabled){box-shadow:0 14px 32px rgba(37,211,102,.5)}

/* ── Checkout paneli ── */
.checkout{
  position:fixed;z-index:81;top:0;right:0;height:100%;width:min(520px,100%);
  background:var(--krem);display:flex;flex-direction:column;
  box-shadow:-20px 0 60px rgba(28,20,13,.25);
  transform:translateX(100%);transition:transform .42s cubic-bezier(.3,.8,.3,1);
}
.checkout.acik{transform:none}
.cko-govde{flex:1;overflow-y:auto;overscroll-behavior:contain;padding:20px 24px;display:flex;flex-direction:column;gap:22px}
.cko-grup{display:flex;flex-direction:column;gap:12px}
.cko-grup > .baslik{font-family:'Archivo Black';font-size:13px;text-transform:uppercase;letter-spacing:.08em;color:var(--turuncu);display:flex;align-items:center;gap:9px}
.cko-grup > .baslik .no{width:22px;height:22px;border-radius:50%;background:var(--turuncu);color:#fff;display:inline-flex;align-items:center;justify-content:center;font-size:12px}

/* teslim tipi seçici */
.tip-sec{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.tip-sec label{position:relative;cursor:pointer}
.tip-sec input{position:absolute;opacity:0;pointer-events:none}
.tip-sec .kutu{border:2px solid rgba(28,20,13,.14);border-radius:14px;padding:15px;display:flex;flex-direction:column;gap:5px;transition:border-color .2s,background .2s}
.tip-sec .kutu b{font-size:15px}
.tip-sec .kutu span{font-size:12.5px;color:var(--kahve)}
.tip-sec input:checked + .kutu{border-color:var(--turuncu);background:#FFF3E9}
.tip-sec .kutu svg{width:22px;height:22px;stroke:var(--turuncu);fill:none;stroke-width:1.9;margin-bottom:3px}

/* form alanları */
.alan{display:flex;flex-direction:column;gap:6px}
.alan label{font-size:13px;font-weight:600;color:var(--kahve)}
.alan input,.alan select,.alan textarea{
  font-family:inherit;font-size:15px;color:var(--komur);
  background:var(--beyaz);border:1.5px solid rgba(28,20,13,.13);border-radius:12px;
  padding:13px 14px;transition:border-color .2s,box-shadow .2s;width:100%;
}
.alan input:focus,.alan select:focus,.alan textarea:focus{outline:0;border-color:var(--turuncu);box-shadow:0 0 0 3px rgba(196,98,26,.13)}
.alan textarea{resize:vertical;min-height:64px}
.alan.hata input,.alan.hata select{border-color:var(--kirmizi)}
.alan .hata-yazi{font-size:12px;color:var(--kirmizi);font-weight:600;display:none}
.alan.hata .hata-yazi{display:block}
.ikili{display:grid;grid-template-columns:1fr 1fr;gap:12px}

/* özet + onay */
.cko-ozet{background:var(--beyaz);border-radius:16px;padding:16px 18px;box-shadow:0 4px 14px rgba(28,20,13,.05)}
.cko-onay{display:flex;gap:11px;align-items:flex-start;font-size:13px;color:var(--kahve);line-height:1.5}
.cko-onay input{width:19px;height:19px;margin-top:1px;accent-color:var(--turuncu);flex-shrink:0;cursor:pointer}
.cko-onay a{color:var(--turuncu);font-weight:700;text-decoration:underline}
.cko-bilgi-not{font-size:12.5px;color:var(--kahve);background:#FFF3E9;border:1px solid rgba(196,98,26,.2);border-radius:12px;padding:12px 14px;line-height:1.5}
.cko-bilgi-not b{color:var(--turuncu-koyu)}

.guvenli-rozet{display:flex;align-items:center;justify-content:center;gap:7px;font-size:12px;color:var(--kahve);margin-top:12px;font-weight:600}
.guvenli-rozet svg{width:15px;height:15px;stroke:#1B7A3D;fill:none;stroke-width:2}

/* başarı ekranı */
.cko-basari{text-align:center;padding:40px 26px;display:flex;flex-direction:column;align-items:center;gap:16px}
.cko-basari .tik-daire{width:78px;height:78px;border-radius:50%;background:#E8F6EC;display:flex;align-items:center;justify-content:center}
.cko-basari .tik-daire svg{width:40px;height:40px;stroke:#1B7A3D;fill:none;stroke-width:2.4;stroke-linecap:round;stroke-linejoin:round}
.cko-basari h3{font-family:'Archivo Black';font-size:23px;text-transform:uppercase}
.cko-basari p{color:var(--kahve);font-size:15px;line-height:1.55;max-width:320px}
.cko-basari .siparis-no{background:var(--komur);color:var(--krem);font-weight:800;border-radius:12px;padding:10px 18px;letter-spacing:.06em}

/* ── Toast ── */
.toast{
  position:fixed;z-index:95;left:50%;bottom:30px;transform:translate(-50%,140%);
  background:var(--komur);color:var(--krem);font-weight:700;font-size:14px;
  padding:13px 22px;border-radius:99px;box-shadow:0 14px 34px rgba(28,20,13,.3);
  display:flex;align-items:center;gap:9px;opacity:0;transition:transform .4s cubic-bezier(.2,.8,.25,1.2),opacity .3s;
}
.toast.gor{transform:translate(-50%,0);opacity:1}
.toast svg{width:17px;height:17px;stroke:var(--amber);fill:none;stroke-width:2.4;stroke-linecap:round;stroke-linejoin:round}

body.govde-kilit{overflow:hidden}

/* ── MASA modu (QR) ── */
body.masa-modu nav{display:none}
body.masa-modu #menu{margin-top:0;border-radius:0}
.masa-bant{position:sticky;top:0;z-index:60;background:var(--komur);color:var(--krem);box-shadow:0 2px 14px rgba(28,20,13,.22)}
.masa-bant-ic{max-width:1180px;margin:0 auto;padding:11px clamp(14px,4vw,40px);display:flex;align-items:center;gap:14px;justify-content:space-between;flex-wrap:wrap}
.masa-bilgi{display:flex;align-items:center;gap:11px}
.masa-bilgi svg{width:26px;height:26px;stroke:var(--amber);fill:none;stroke-width:1.8}
.masa-bilgi b{font-family:'Archivo Black';font-size:16px;text-transform:uppercase;display:block;line-height:1}
.masa-bilgi span{font-size:12px;opacity:.72}
.servis-butonlar{display:flex;gap:8px;flex-wrap:wrap}
.servis-butonlar button{font:inherit;font-weight:700;font-size:13px;color:var(--krem);background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.2);border-radius:99px;padding:9px 15px;cursor:pointer;transition:background .15s,color .15s,border-color .15s}
.servis-butonlar button:hover{background:var(--amber);color:var(--komur);border-color:var(--amber)}
.servis-butonlar button:disabled{opacity:.45;cursor:default}
@media (max-width:560px){
  .masa-bant-ic{padding:9px 14px}
  .servis-butonlar{width:100%}
  .servis-butonlar button{flex:1;padding:9px 6px;font-size:12px}
}

@media (max-width:520px){
  .drawer,.checkout{width:100%}
  .sepet-fab{left:14px;right:14px;justify-content:center}
}
