:root{
  --bg:#f6f7fb;--card:#fff;--text:#0f172a;--muted:#64748b;--border:#e2e8f0;--brand:#ef4444;
  --shadow:0 10px 30px rgba(16,24,40,.08);
}
*{box-sizing:border-box}
html,body{height:100%}
.nefiss-body{margin:0;background:var(--bg);color:var(--text);font-family:system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif}
.topbar{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.92);backdrop-filter:blur(10px);
  border-bottom:1px solid var(--border);display:flex;gap:12px;align-items:center;justify-content:space-between;padding:10px 14px}
.brand{display:flex;gap:10px;align-items:center}
.logo{width:44px;height:44px;border-radius:14px;object-fit:cover;border:1px solid var(--border);background:#fff}
.title{font-weight:900}
.sub{font-size:12px;color:var(--muted);margin-top:2px}
.search{flex:1;max-width:520px}
.search input{width:100%;border:1px solid var(--border);border-radius:14px;padding:10px 12px;background:#fff}
.cartbtn{border:1px solid var(--border);background:#fff;border-radius:14px;padding:10px 12px;cursor:pointer;display:flex;align-items:center;gap:8px}
.cartcount{font-weight:900;background:#0f172a;color:#fff;border-radius:999px;padding:2px 8px;font-size:12px}
.layout{max-width:1240px;margin:0 auto;padding:14px}
.chips{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:10px}
.chip{font-size:12px;padding:6px 10px;border-radius:999px;border:1px solid var(--border);background:#fff;color:var(--muted);font-weight:800}
.chip.open{color:#067647;border-color:#a7f3d0;background:#ecfdf5}
.chip.closed{color:#b42318;border-color:#fecaca;background:#fff1f2}

.cats{display:flex;gap:8px;flex-wrap:wrap;margin:10px 0}
.cat{border:1px solid var(--border);background:#fff;border-radius:999px;padding:8px 10px;font-weight:900;cursor:pointer}
.cat.active{border-color:#fecaca;background:#fff1f2;color:#b42318}

.products{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}
.card{background:var(--card);border:1px solid var(--border);border-radius:18px;overflow:hidden;box-shadow:0 1px 2px rgba(16,24,40,.06)}
.imgwrap{position:relative}
.imgwrap img{width:100%;height:170px;object-fit:cover;background:#f1f5f9}
.badge{position:absolute;left:10px;top:10px;font-size:12px;font-weight:900;padding:6px 10px;border-radius:999px;background:rgba(255,255,255,.9);border:1px solid var(--border);color:#b42318}
.badge.hidden{display:none}
.body{padding:12px}
.name{font-weight:900}
.desc{color:var(--muted);font-size:12px;margin-top:4px;min-height:32px}
.bottom{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-top:10px}
.price{font-weight:900}
.btn{border:1px solid var(--border);background:#fff;border-radius:12px;padding:9px 10px;cursor:pointer;font-weight:900}
.btn:disabled{opacity:.55;cursor:not-allowed}
.btn.small{padding:4px 8px;border-radius:10px}
.btn.primary{background:linear-gradient(145deg,#ef4444,#fb7185);border-color:#fb7185;color:#fff}
.btn.big{width:100%;padding:12px 14px;border-radius:14px;font-size:16px;margin-top:10px}

.drawer{position:fixed;top:0;right:0;height:100%;width:380px;transform:translateX(110%);transition:.25s;z-index:60;padding:14px}
.drawer.open{transform:translateX(0)}
.drawer-card{height:100%;background:#fff;border:1px solid var(--border);border-radius:18px;box-shadow:var(--shadow);display:flex;flex-direction:column;overflow:hidden}
.drawer-top{display:flex;justify-content:space-between;align-items:center;padding:12px;border-bottom:1px solid var(--border)}
.drawer-close{border:none;background:transparent;font-size:18px;cursor:pointer}
.drawer-items{padding:12px;flex:1;overflow:auto}
.cart-row{display:flex;justify-content:space-between;align-items:center;padding:10px 0;border-bottom:1px dashed var(--border);gap:10px}
.cart-name .name{font-weight:900}
.cart-name .opt{color:var(--muted);font-size:12px;margin-top:2px}
.cart-name .price{color:var(--muted);font-size:12px;margin-top:2px}
.qty{display:flex;align-items:center;gap:8px}
.drawer-bottom{border-top:1px solid var(--border);padding:12px;display:flex;flex-direction:column;gap:10px}
.drawer-total{display:flex;justify-content:space-between;align-items:center}
.muted{color:var(--muted)}
.error{padding:14px;border:1px solid #fecaca;background:#fff1f2;border-radius:14px;color:#b42318;margin-top:12px}
.empty{padding:14px;border:1px dashed var(--border);background:#fff;border-radius:14px;color:var(--muted);font-weight:800}

.checkout-page,.payment-page{max-width:860px;margin:0 auto;padding:16px}
.checkout,.payment{background:#fff;border:1px solid var(--border);border-radius:18px;padding:14px;box-shadow:0 1px 2px rgba(16,24,40,.06)}
.ck-top{display:flex;justify-content:flex-start;margin-bottom:6px}
.checkout h2,.payment h2{margin:0 0 8px 0}
.row{display:flex;flex-direction:column;gap:6px;margin-top:10px}
.row2{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}
.checkout input,.checkout textarea,.checkout select{border:1px solid var(--border);border-radius:12px;padding:10px 12px;font-size:14px}
.locrow{display:flex;gap:10px;align-items:center}
.locrow input{flex:1}
.summary{margin-top:12px;padding:10px;border:1px dashed var(--border);border-radius:14px}
.warn{color:#b45309;margin-top:6px;font-weight:800}
.ok{color:#067647;margin-top:6px;font-weight:800}
.pactions{display:flex;gap:10px;flex-wrap:wrap;margin-top:10px}

.modal-overlay{position:fixed;inset:0;background:rgba(15,23,42,.55);display:none;align-items:center;justify-content:center;padding:16px;z-index:70}
.modal-overlay.open{display:flex}
.modal{width:min(640px, 96vw);background:#fff;border:1px solid var(--border);border-radius:18px;box-shadow:var(--shadow);display:none;overflow:hidden}
.modal.open{display:block}
.mhead{display:flex;justify-content:space-between;align-items:center;padding:12px;border-bottom:1px solid var(--border)}
.mclose{border:none;background:transparent;font-size:18px;cursor:pointer}
.mbody{padding:12px;display:flex;flex-direction:column;gap:12px;max-height:55vh;overflow:auto}
.g{border:1px solid var(--border);border-radius:14px;padding:10px}
.gtitle{display:flex;justify-content:space-between;align-items:center}
.gname{font-weight:900}
.req{font-size:12px;font-weight:900;color:#b42318}
.gchoices{display:flex;flex-direction:column;gap:8px;margin-top:8px}
.choice{display:flex;align-items:center;gap:10px;padding:8px;border:1px solid var(--border);border-radius:12px;cursor:pointer}
.choice input{accent-color:var(--brand)}
.clabel{font-weight:800}
.cprice{margin-left:auto;color:var(--muted);font-weight:900}
.mfoot{display:flex;justify-content:space-between;align-items:center;padding:12px;border-top:1px solid var(--border);gap:12px}
.mprice{display:flex;flex-direction:column}
.nefiss-toast{position:fixed;bottom:18px;left:50%;transform:translateX(-50%) translateY(10px);opacity:0;transition:.2s;background:#0f172a;color:#fff;padding:10px 14px;border-radius:999px;z-index:999}
.nefiss-toast.show{opacity:1;transform:translateX(-50%) translateY(0)}

@media (max-width:1100px){ .products{grid-template-columns:repeat(2,minmax(0,1fr))} }
@media (max-width:920px){
  .products{grid-template-columns:1fr}
  .drawer{width:92vw}
  .row2{grid-template-columns:1fr}
  .search{max-width:none}
}

@media (max-width:700px){
  .p{padding:10px}
  .card{padding:10px}
  .img{width:88px;height:88px}
  .title{font-size:14px}
  .desc{font-size:12px}
  .price{font-size:13px}
  .add{width:40px;height:40px}
}

@media (max-width:420px){
  .img{width:76px;height:76px}
  .add{width:38px;height:38px}
}
@media (max-width:520px){
  .topbar{padding:8px 10px}
  .logo{width:38px;height:38px;border-radius:12px}
  .products{gap:10px}
  .imgwrap img{height:124px}
  .body{padding:10px}
  .desc{min-height:0}
  .btn{padding:8px 10px}
}

@media (max-width:360px){ .drawer{width:100vw;padding:0} .drawer-card{border-radius:0} }


/* App feel: safe-area & bottom padding */
.layout{padding-bottom:92px}
.bottomnav{
  position:fixed;left:0;right:0;bottom:0;z-index:80;
  background:rgba(255,255,255,.96);backdrop-filter:blur(12px);
  border-top:1px solid var(--border);
  display:flex;justify-content:space-around;gap:6px;
  padding:8px 10px calc(8px + env(safe-area-inset-bottom));
}
.navitem{
  flex:1;max-width:92px;
  border:none;background:transparent;cursor:pointer;
  display:flex;flex-direction:column;align-items:center;gap:4px;
  color:#0f172a;font-weight:900;
  padding:8px 6px;border-radius:14px;
}
.navitem:active{transform:scale(.98)}
.navitem .ni{font-size:18px;line-height:18px}
.navitem .nt{font-size:11px;color:var(--muted)}
.navitem.cart{position:relative}
.navitem .badge{
  position:absolute;top:4px;right:16px;
  background:#0f172a;color:#fff;border-radius:999px;
  font-size:11px;padding:2px 7px;min-width:22px;text-align:center;
}
@media (min-width: 980px){
  .bottomnav{display:none}
  .layout{padding-bottom:18px}
}

/* Dim overlay behind drawer */
.dim{position:fixed;inset:0;background:rgba(15,23,42,.35);backdrop-filter:blur(2px);z-index:55;display:none}
.dim.open{display:block}

/* Compact cards (mobile-first) */
.products{grid-template-columns:repeat(2,minmax(0,1fr))}
.card.compact{display:flex;flex-direction:column}
.card.compact .imgwrap img{height:132px}
.card.compact .body{padding:10px}
.card.compact .top{display:flex;justify-content:space-between;align-items:flex-start;gap:8px}
.card.compact .name{font-size:14px}
.card.compact .desc{min-height:auto;max-height:34px;overflow:hidden}
.card.compact .actions{display:flex;justify-content:flex-end;margin-top:8px}
.badge2{position:absolute;left:10px;top:10px;font-size:11px;font-weight:900;padding:6px 10px;border-radius:999px;background:rgba(255,255,255,.9);border:1px solid var(--border);color:#b42318}
.badge2.hidden{display:none}

@media (max-width:520px){
  .topbar{gap:10px}
  .search input{border-radius:16px}
  .products{grid-template-columns:1fr}
  .card.compact{flex-direction:row}
  .card.compact .imgwrap{width:110px;flex:0 0 110px}
  .card.compact .imgwrap img{height:110px}
  .card.compact .body{flex:1}
  .navitem{max-width:none}
}

/* Checkout stepper */
.stepper{display:flex;gap:10px;justify-content:space-between;margin:10px 0 12px 0}
.step{flex:1;display:flex;align-items:center;gap:8px;border:1px solid var(--border);background:#fff;border-radius:16px;padding:10px}
.step .dot{width:26px;height:26px;border-radius:999px;border:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-weight:900;color:var(--muted)}
.step.active{border-color:#fecaca;background:#fff1f2}
.step.active .dot{border-color:#fb7185;color:#b42318}
.step .st{font-weight:900;font-size:12px}
.ck-step{display:none}
.ck-step.show{display:block}
.ck-actions{display:flex;gap:10px;justify-content:space-between;margin-top:12px}
.btn.ghost{background:transparent}

/* Thanks screen */
.thanks{text-align:center}
.thanks h2{margin:8px 0}
