
:root{ --fg:#111; --muted:#666; }
*{box-sizing:border-box}
html,body{margin:0;padding:0;font-family:-apple-system,system-ui,Segoe UI,Roboto,Helvetica,Arial,sans-serif;color:var(--fg)}
.hero{position:relative;width:100%;height:50svh;background:#eee url('assets/images/hero.jpg') center/cover no-repeat}
@media(max-width:700px){ .hero{height:55svh} }
.fade-bottom{position:absolute;left:0;right:0;bottom:0;height:120px;background:linear-gradient(180deg, rgba(255,255,255,0), #fff 80%)}
.open-state{text-align:center;margin:8px 0 0;font-weight:800;color:#c00}
.intro{text-align:center;padding:8px 16px 24px}.lead{color:var(--muted)}
.info{display:grid;gap:20px;grid-template-columns:1fr;max-width:1100px;margin:0 auto;padding:0 16px 8px}
.info h2{text-align:center}
.info img{width:100%;display:block;border-radius:12px}
.toggles{display:flex;gap:8px;justify-content:center;padding:16px}
.pill{border:0;background:#1111;padding:10px 18px;border-radius:999px;font-weight:700}
.pill.active{background:#111;color:#fff}
.section-title{text-align:center;margin:28px 0 8px}
.category-tabs{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;padding:6px 16px 12px}
.category-tabs a{text-decoration:none;color:#333;background:#f7f7f7;padding:6px 10px;border-radius:8px}
.menu-grid{max-width:1200px;margin:0 auto;padding:10px 16px 24px;display:grid;gap:16px;grid-template-columns:repeat(4,minmax(0,1fr))}
@media(max-width:820px){ .menu-grid{grid-template-columns:repeat(2,minmax(0,1fr))} }
.card{border:1px solid #eee;border-radius:14px;overflow:hidden;background:#fff;display:flex;flex-direction:column;text-align:center}
.card img{width:100%;aspect-ratio:4/3;object-fit:cover;display:block}
.card h3{margin:10px 10px 6px}
.card .price{font-weight:800;margin:0}
.card .allergens,.card .desc{margin:6px 10px 10px;color:#555;font-size:.95rem}
.qty{display:flex;justify-content:center;align-items:center;gap:8px;padding:10px}
.qty input{width:64px;text-align:center;padding:6px 8px}
.qty button{width:36px;height:36px;border-radius:8px;border:1px solid #ddd;background:#fafafa;cursor:pointer;font-size:18px}
.hidden{display:none}
#order{max-width:900px;margin:10px auto;padding:0 16px 24px}
#order h2,#payment h2{text-align:center}
#orderItems{border:1px solid #eee;border-radius:12px;padding:12px;min-height:40px;margin-top:8px}
.order-row{display:flex;justify-content:space-between;padding:6px 8px;border-bottom:1px dashed #eee}
.order-total{display:flex;justify-content:space-between;font-weight:800;margin:12px 0}
.order-form{display:grid;grid-template-columns:1fr 1fr auto;gap:10px;align-items:center}
.order-form input{padding:8px 10px;border:1px solid #ddd;border-radius:8px}
#sendBtn{padding:10px 14px;background:#111;color:#fff;border:none;border-radius:8px;cursor:pointer}
.order-id{margin-left:10px;color:#555}
.payment{max-width:900px;margin:10px auto 40px;padding:16px;border-radius:14px;background:#fafafa;border:1px solid #eee;text-align:center}
.payment.pending{opacity:.55;pointer-events:none}
.vipps{font-weight:800}
.pending-msg{font-size:1.25rem;font-weight:900}
.dots::after{content:'·  ';animation:dots 1.5s infinite steps(4,end)}
@keyframes dots{0%{content:'·  '}25%{content:'·· '}50%{content:'···'}75%{content:' ··'}100%{content:'  ·'}}
.footer{text-align:center;color:#888;padding:30px 0}
