
*{box-sizing:border-box}
body{margin:0;font-family:system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;color:#111}
h1,h2,h3{margin:.3rem 0 .4rem}
.hero{position:relative;overflow:hidden}
.hero-img{width:100%;height:50svh;object-fit:cover;display:block;
  -webkit-mask-image:linear-gradient(to bottom,rgba(0,0,0,1) 70%,rgba(0,0,0,0));
          mask-image:linear-gradient(to bottom,rgba(0,0,0,1) 70%,rgba(0,0,0,0));}
.open-state{text-align:center;font-weight:800;color:#c00;margin:.4rem 0 0}
.intro{text-align:center;padding:1rem 1rem .2rem}
.info{display:grid;gap:1rem;grid-template-columns:1fr;max-width:1100px;margin:0 auto;padding:0 1rem 1rem}
.info .mapbox{background:#eee;height:220px;border-radius:12px;display:flex;align-items:center;justify-content:center;color:#555}
.row-center{display:flex;gap:.8rem;justify-content:center;align-items:center;margin:1rem 0}
.pill{padding:.35rem .9rem;border-radius:999px;border:1px solid #ddd;background:#fafafa;font-weight:600}
.grid{display:grid;gap:14px}
@media (max-width:599px){.menus{grid-template-columns:repeat(2,minmax(0,1fr));}.hero-img{height:55svh}}
@media (min-width:600px){.menus{grid-template-columns:repeat(4,minmax(0,1fr));}}
.card{background:#fff;border:1px solid #eee;border-radius:14px;overflow:hidden;text-align:center}
.card img{width:100%;aspect-ratio:1/1;object-fit:cover;display:block}
.card h4{margin:.5rem 0 .2rem}
.price{font-weight:700;margin-bottom:.2rem}
.allergens{font-size:.9rem;color:#555;margin-bottom:.4rem}
.qty{display:flex;justify-content:center;align-items:center;gap:.4rem;padding:.4rem 0 .7rem}
.qty button{width:36px;height:36px;border-radius:10px;border:1px solid #ddd;background:#fafafa;font-size:20px}
.qty input{width:56px;padding:.35rem;border:1px solid #ddd;border-radius:8px;text-align:center}
.section-title{text-align:center;margin-top:2rem}
.sub{margin:.8rem 0 .4rem;text-align:center}
.checkout{display:grid;gap:16px;grid-template-columns:1fr;max-width:1100px;margin:1.2rem auto;padding:0 1rem 2rem}
.order,.payment{position:relative;background:#fff;border:1px solid #eee;border-radius:16px;padding:1rem}
.order h3,.payment h3{text-align:center}
#orderList{min-height:40px;padding:.4rem 0}
.total{font-weight:700;margin:.4rem 0}
.order label{display:block;margin:.4rem 0}
.order input[type=time], .order input[type=text], #custName{padding:.4rem;border:1px solid #ddd;border-radius:8px}
#sendBtn{margin-top:.6rem;padding:.6rem 1rem;border-radius:10px;border:0;background:#111;color:#fff;font-weight:700}
.payment.waiting .overlay{position:absolute;inset:0;background:rgba(255,255,255,.6);backdrop-filter:saturate(60%) blur(1.5px);border-radius:16px}
.waiting-text{font-weight:800;font-size:1.2rem;text-align:center;margin-top:.4rem}
.dots{display:inline-block;width:2ch;text-align:left;animation:dots 1.2s infinite steps(4,end)}
@keyframes dots{0%{content:"";}25%{content:".";}50%{content:"..";}75%{content:"...";}}
.foot{padding:2rem 1rem;text-align:center;color:#666;border-top:1px solid #eee}
