/* ============================================================
   Döner & Pizza Express — Front-End
   Markenfarben kommen aus theme_style_tag() (--primary / --accent).
   Anthrazit/Charcoal-Look ist fix.
   ============================================================ */
:root{
  --primary:#e03131; --primary-d:#c92a2a; --primary-dd:#a51e1e;
  --accent:#f0a020; --accent-d:#d98a12;
  --primary-soft:#fde8e8; --accent-soft:#fdeccd; --ring:rgba(224,49,49,.22);
  --charcoal:#1d1d1f; --ink:#2b2b2b; --bg:#fff7f0; --card:#fff;
  --muted:#8a8a8a; --line:#efe7dd; --green:#2f9e44;
  --shadow:0 6px 24px rgba(40,20,0,.08); --shadow-lg:0 14px 40px rgba(40,20,0,.16);
  --radius:16px; --nav-h:64px; --cart-w:370px;
  --fh:'Poppins','Segoe UI',system-ui,sans-serif;
  --fb:'Inter',system-ui,'Segoe UI',sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--fb);color:var(--ink);background:var(--bg);line-height:1.55;overflow-x:hidden}
h1,h2,h3,h4{font-family:var(--fh);color:var(--charcoal);line-height:1.15}
img{max-width:100%;display:block}
a{text-decoration:none;color:inherit}
button{font-family:inherit;cursor:pointer;border:none}
.wrap{max-width:1160px;margin:0 auto;padding:0 20px}
.hidden{display:none!important}

/* Top bar */
.topbar{background:var(--charcoal);color:#fff;font-size:.82rem}
.topbar .wrap{display:flex;align-items:center;justify-content:space-between;min-height:38px;flex-wrap:wrap;gap:6px}
.topbar .left{display:flex;align-items:center;gap:16px;flex-wrap:wrap}
.open-dot{display:inline-flex;align-items:center;gap:7px;color:#d7d2cc}
.open-dot b{color:#7ddfa0}
.open-dot.closed b{color:#ff9b9b}
.open-dot .dot{width:8px;height:8px;border-radius:50%;background:#37d67a;box-shadow:0 0 0 3px rgba(55,214,122,.25)}
.open-dot.closed .dot{background:#e03131;box-shadow:0 0 0 3px rgba(224,49,49,.25)}
.topbar a{color:#e8e8e8}
.langsw{display:flex;gap:2px;align-items:center}
.langsw a{color:#bdbdbd;font-size:.78rem;font-weight:600;padding:3px 8px;border-radius:6px}
.langsw a.active{background:var(--accent);color:var(--charcoal)}

/* Nav */
header.nav{position:sticky;top:0;z-index:50;background:rgba(255,247,240,.93);backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
header.nav .wrap{display:flex;align-items:center;justify-content:space-between;height:var(--nav-h)}
.brand{display:flex;align-items:center;gap:11px}
.logo-mark{width:42px;height:42px;border-radius:12px;background:linear-gradient(135deg,var(--primary),var(--accent));display:grid;place-items:center;font-size:22px;box-shadow:var(--shadow);overflow:hidden}
.logo-mark img{width:100%;height:100%;object-fit:cover}
.brand-txt b{font-family:var(--fh);font-weight:800;font-size:1.05rem;color:var(--charcoal);display:block;letter-spacing:-.3px;line-height:1.1}
.brand-txt span{font-size:.68rem;letter-spacing:2px;text-transform:uppercase;color:var(--primary);font-weight:600}
.nav-links{display:flex;gap:26px}
.nav-links a{font-size:.9rem;font-weight:500;color:#444}
.nav-links a:hover{color:var(--primary)}
.nav-right{display:flex;align-items:center;gap:12px}
.btn{display:inline-flex;align-items:center;gap:8px;font-weight:600;border-radius:999px;padding:11px 20px;font-size:.9rem;transition:.2s}
.btn-primary{background:var(--primary);color:#fff;box-shadow:0 6px 16px var(--ring)}
.btn-primary:hover{background:var(--primary-d)}
.btn-ghost{background:#fff;color:var(--charcoal);border:1.5px solid var(--line)}
.btn-ghost:hover{border-color:var(--primary);color:var(--primary)}
.cart-btn{position:relative;background:var(--charcoal);color:#fff;border-radius:999px;padding:11px 18px;display:inline-flex;align-items:center;gap:9px;font-weight:600;font-size:.9rem}
.cart-btn:hover{background:#000}
.cart-btn .badge{position:absolute;top:-6px;right:-6px;background:var(--accent);color:var(--charcoal);font-size:.72rem;font-weight:800;min-width:21px;height:21px;padding:0 5px;border-radius:999px;display:grid;place-items:center}
.hamb{display:none;flex-direction:column;gap:5px;background:none;padding:8px}
.hamb span{width:24px;height:2px;background:var(--charcoal);border-radius:2px;transition:.25s}

/* Hero */
.hero{position:relative;overflow:hidden;background:radial-gradient(1200px 500px at 80% -10%,var(--accent-soft) 0,transparent 60%),linear-gradient(180deg,#fff7f0,#ffefe1)}
.hero .wrap{display:grid;grid-template-columns:1.05fr .95fr;gap:30px;align-items:center;padding:54px 20px 60px}
.hero .pill{display:inline-flex;align-items:center;gap:8px;background:#fff;border:1px solid var(--line);color:var(--primary);font-weight:700;font-size:.78rem;padding:7px 14px;border-radius:999px;box-shadow:var(--shadow)}
.hero h1{font-size:clamp(2.2rem,5vw,3.5rem);font-weight:800;letter-spacing:-1px;margin:16px 0 10px}
.hero h1 .hl{background:linear-gradient(120deg,var(--primary),var(--accent));-webkit-background-clip:text;background-clip:text;color:transparent}
.hero p.lead{font-size:1.08rem;color:#5a534c;max-width:460px;margin-bottom:22px}
.hero-cta{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:24px}
.hero-cta .btn{padding:14px 24px;font-size:.98rem}
.trust{display:flex;gap:20px;flex-wrap:wrap;align-items:center;color:#6a635c;font-size:.86rem;font-weight:500}
.trust .stars{color:var(--accent);letter-spacing:1px}
.trust .sep{width:1px;height:20px;background:var(--line)}
.hero-card{background:#fff;border-radius:24px;box-shadow:var(--shadow-lg);padding:22px;position:relative}
.hero-card .tag{position:absolute;top:-12px;left:22px;background:var(--primary);color:#fff;font-size:.74rem;font-weight:700;padding:6px 13px;border-radius:999px}
.hero-food{height:210px;border-radius:18px;background:linear-gradient(135deg,var(--accent-soft),#ffb36b);display:grid;place-items:center;font-size:92px;margin-bottom:16px}
.hero-card h3{font-size:1.25rem;margin-bottom:4px}
.hero-card .desc{font-size:.86rem;color:var(--muted);margin-bottom:14px}
.hero-card .row{display:flex;align-items:center;justify-content:space-between;gap:10px}
.price{font-family:var(--fh);font-weight:800;color:var(--primary);font-size:1.3rem;white-space:nowrap}
.add{background:var(--accent);color:var(--charcoal);font-weight:700;border-radius:12px;padding:11px 16px;font-size:.88rem;display:inline-flex;gap:7px;align-items:center}
.add:hover{background:var(--accent-d);color:#fff}

/* Feature strip */
.features{background:var(--charcoal);color:#fff}
.features .wrap{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;padding:20px}
.feat{display:flex;align-items:center;gap:12px}
.feat .ic{font-size:24px;width:46px;height:46px;border-radius:12px;background:rgba(255,255,255,.08);display:grid;place-items:center}
.feat b{display:block;font-size:.9rem}
.feat span{font-size:.77rem;color:#b9b3ac}

/* Sections */
section.block{padding:54px 0}
.sec-head{text-align:center;margin-bottom:32px}
.sec-head .kicker{color:var(--primary);font-weight:700;font-size:.8rem;letter-spacing:2.5px;text-transform:uppercase}
.sec-head h2{font-size:clamp(1.7rem,3.5vw,2.4rem);font-weight:800;margin-top:6px}
.sec-head p{color:#6a635c;margin-top:8px}

/* Tagesmenü */
.tages{background:linear-gradient(120deg,var(--primary),var(--primary-dd));color:#fff;border-radius:22px;overflow:hidden;box-shadow:var(--shadow-lg)}
.tages .inner{display:grid;grid-template-columns:1fr auto;gap:20px;align-items:center;padding:26px 30px}
.tages .date{font-size:.8rem;opacity:.9;font-weight:600;letter-spacing:1px;text-transform:uppercase}
.tages h3{color:#fff;font-size:1.6rem;margin:6px 0 4px}
.tages .desc{opacity:.95;max-width:520px}
.tages .tprice{text-align:center}
.tages .tprice .big{font-family:var(--fh);font-weight:800;font-size:2.4rem;line-height:1}
.tages .tprice small{opacity:.9}
.tages .add{margin-top:10px}
.tages-none{text-align:center;color:#6a635c;background:#fff;border:1px dashed var(--line);border-radius:16px;padding:24px}

/* Category pills */
.cats{position:sticky;top:var(--nav-h);z-index:30;background:var(--bg);padding:14px 0;border-bottom:1px solid var(--line)}
.cats .wrap{display:flex;gap:10px;overflow-x:auto;scrollbar-width:none}
.cats .wrap::-webkit-scrollbar{display:none}
.cat-pill{white-space:nowrap;background:#fff;border:1.5px solid var(--line);color:#555;font-weight:600;font-size:.88rem;padding:9px 16px;border-radius:999px;display:inline-flex;gap:7px;align-items:center;cursor:pointer}
.cat-pill.active{background:var(--charcoal);color:#fff;border-color:var(--charcoal)}

/* Menu grid */
.menu-cat{margin-bottom:38px;scroll-margin-top:130px}
.menu-cat h3.cat-title{font-size:1.4rem;font-weight:800;margin-bottom:4px;display:flex;align-items:center;gap:10px}
.menu-cat h3.cat-title small{font-size:.8rem;font-weight:600;color:var(--muted)}
.menu-cat .cat-sub{color:var(--muted);font-size:.9rem;margin-bottom:18px}
.grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}
.item{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:14px;display:flex;gap:14px;box-shadow:var(--shadow);transition:.2s}
.item:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}
.item .thumb{flex:0 0 84px;height:84px;border-radius:13px;display:grid;place-items:center;font-size:42px;background:linear-gradient(135deg,var(--accent-soft),#ffd3a8);overflow:hidden}
.item .thumb img{width:100%;height:100%;object-fit:cover}
.item .info{flex:1;min-width:0;display:flex;flex-direction:column}
.item .info .nm{font-weight:700;font-family:var(--fh);font-size:1rem;display:flex;align-items:center;gap:7px;flex-wrap:wrap}
.badge-veg{font-size:.62rem;background:#e6fcf0;color:var(--green);font-weight:700;padding:2px 6px;border-radius:5px;letter-spacing:.5px}
.badge-hot{font-size:.62rem;background:#ffe9e3;color:#e8590c;font-weight:700;padding:2px 6px;border-radius:5px}
.item .info .ds{font-size:.83rem;color:var(--muted);margin:3px 0 0;flex:1}
.item .foot{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-top:10px}
.item .sizes{display:flex;gap:6px;flex-wrap:wrap}
.item .sizes button{font-size:.74rem;font-weight:600;border:1.3px solid var(--line);background:#fff;color:#555;border-radius:8px;padding:4px 9px;cursor:pointer}
.item .sizes button.on{border-color:var(--primary);color:var(--primary);background:var(--primary-soft)}
.add-sm{background:var(--primary);color:#fff;width:38px;height:38px;border-radius:11px;font-size:1.3rem;display:grid;place-items:center;font-weight:600;flex:0 0 auto;box-shadow:0 4px 12px var(--ring)}
.add-sm:hover{background:var(--primary-d);transform:scale(1.05)}
.add-sm.pulse{animation:pulse .4s}
@keyframes pulse{0%{transform:scale(1)}50%{transform:scale(1.25)}100%{transform:scale(1)}}

/* Cart drawer */
.cart-overlay{position:fixed;inset:0;background:rgba(20,12,4,.45);opacity:0;visibility:hidden;transition:.25s;z-index:90}
.cart-overlay.open{opacity:1;visibility:visible}
.cart{position:fixed;top:0;right:0;height:100%;width:400px;max-width:92vw;background:#fff;z-index:100;transform:translateX(100%);transition:transform .3s cubic-bezier(.4,0,.2,1);display:flex;flex-direction:column;box-shadow:-10px 0 40px rgba(0,0,0,.2)}
.cart.open{transform:translateX(0)}
.cart-head{padding:20px;border-bottom:1px solid var(--line);display:flex;align-items:center;justify-content:space-between}
.cart-head h3{font-size:1.2rem}
.cart-head .x{background:#f3ece3;width:34px;height:34px;border-radius:10px;font-size:1.1rem;display:grid;place-items:center}
.mode-toggle{display:flex;gap:6px;padding:14px 20px;background:#fbf4ec}
.mode-toggle button{flex:1;padding:10px;border-radius:11px;font-weight:600;font-size:.86rem;background:#fff;border:1.5px solid var(--line);color:#666;display:flex;flex-direction:column;align-items:center;gap:2px;cursor:pointer}
.mode-toggle button.on{background:var(--charcoal);color:#fff;border-color:var(--charcoal)}
.mode-toggle button small{font-size:.7rem;opacity:.8;font-weight:500}
.cart-items{flex:1;overflow-y:auto;padding:8px 20px}
.cart-empty{text-align:center;color:var(--muted);padding:50px 16px}
.cart-empty .ico{font-size:48px;margin-bottom:10px}
.citem{display:flex;gap:12px;padding:14px 0;border-bottom:1px solid var(--line)}
.citem .ct{width:50px;height:50px;border-radius:11px;background:linear-gradient(135deg,var(--accent-soft),#ffd3a8);display:grid;place-items:center;font-size:26px;flex:0 0 auto}
.citem .cinfo{flex:1;min-width:0}
.citem .cinfo b{font-size:.92rem;font-family:var(--fh)}
.citem .cinfo .cmeta{font-size:.78rem;color:var(--muted)}
.qty{display:inline-flex;align-items:center;border:1.5px solid var(--line);border-radius:9px;overflow:hidden;margin-top:6px}
.qty button{width:28px;height:28px;background:#f7f0e8;font-size:1rem;color:#444;font-weight:700}
.qty span{width:30px;text-align:center;font-weight:700;font-size:.88rem}
.citem .cright{text-align:right;display:flex;flex-direction:column;align-items:flex-end;gap:6px}
.citem .cprice{font-weight:700;font-family:var(--fh);color:var(--charcoal)}
.citem .crm{background:none;color:var(--muted);font-size:.74rem;text-decoration:underline}
.cart-foot{padding:18px 20px 22px;border-top:1px solid var(--line);background:#fff}
.sumrow{display:flex;justify-content:space-between;font-size:.9rem;color:#5a534c;margin-bottom:7px}
.sumrow.total{font-size:1.18rem;font-weight:800;font-family:var(--fh);color:var(--charcoal);margin:10px 0 14px;padding-top:12px;border-top:1px dashed var(--line)}
.cart-foot .btn-primary{width:100%;justify-content:center;padding:15px;font-size:1rem}
.btn-primary:disabled,.cart-foot .btn-primary:disabled{background:#cbb8a8;box-shadow:none;cursor:not-allowed;opacity:.9}
.free-note{font-size:.8rem;font-weight:600;padding:9px 12px;border-radius:10px;margin-bottom:12px;text-align:center;background:#e6fcf0;color:var(--green)}
.free-note.warn{background:#fff4e6;color:#e8590c}

/* Gallery */
.gal{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}
.gal .gcell{aspect-ratio:1;border-radius:14px;display:grid;place-items:center;font-size:48px;overflow:hidden;background:linear-gradient(135deg,var(--accent-soft),#ff9b54)}
.gal .gcell img{width:100%;height:100%;object-fit:cover}
.gal .gcell:nth-child(2n){background:linear-gradient(135deg,#ffc2c2,#ff7a7a)}
.gal .gcell:nth-child(3n){background:linear-gradient(135deg,#b2f2bb,#69db7c)}
.gal .gcell:nth-child(4n){background:linear-gradient(135deg,#ffe066,#fcc419)}

/* Reviews */
.reviews{background:#ffefe1}
.rev-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-bottom:30px}
.rev{background:#fff;border-radius:var(--radius);padding:22px;box-shadow:var(--shadow)}
.rev .stars{color:var(--accent);font-size:1rem;letter-spacing:1px}
.rev p{font-size:.92rem;color:#4a443e;margin:10px 0 16px}
.rev .who{display:flex;align-items:center;gap:11px}
.rev .av{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,var(--primary),var(--accent));color:#fff;display:grid;place-items:center;font-weight:700;font-family:var(--fh)}
.rev .who b{font-size:.9rem;display:block}.rev .who span{font-size:.78rem;color:var(--muted)}
.review-form{max-width:620px;margin:0 auto;background:#fff;border-radius:var(--radius);padding:26px;box-shadow:var(--shadow)}
.review-form h3{font-size:1.2rem;margin-bottom:16px;text-align:center}
.rf-row{display:grid;grid-template-columns:1fr 160px;gap:14px}
.star-input{display:inline-flex;flex-direction:row-reverse;gap:4px;font-size:1.6rem}
.star-input input{display:none}
.star-input label{color:#d8ccbf;cursor:pointer}
.star-input input:checked ~ label,.star-input label:hover,.star-input label:hover ~ label{color:var(--accent)}
.flash{padding:12px 16px;border-radius:12px;font-weight:600;margin:0 auto 18px;max-width:620px;text-align:center}
.flash.ok{background:#e6fcf0;color:var(--green)}
.flash.err{background:#ffe3e3;color:var(--primary-dd)}

/* Hours + map */
.hm{display:grid;grid-template-columns:1fr 1.2fr;gap:24px;align-items:start}
.hours{background:#fff;border-radius:var(--radius);padding:26px;box-shadow:var(--shadow)}
.hours h3{font-size:1.3rem;margin-bottom:16px}
.hrow{display:flex;justify-content:space-between;padding:10px 0;border-bottom:1px solid var(--line);font-size:.92rem}
.hrow:last-child{border:none}
.hrow.today{color:var(--primary);font-weight:700}
.hrow .t{color:#555}
.hrow.today .t{color:var(--primary)}
.map{border-radius:var(--radius);overflow:hidden;min-height:320px;background:linear-gradient(135deg,#dfe7e3,#cdddd6);display:grid;place-items:center;color:#6a7a72;box-shadow:var(--shadow);position:relative}
.map iframe{width:100%;height:100%;min-height:320px;border:0;display:block}
.map .pin{font-size:54px}
.map .mlabel{position:absolute;bottom:14px;left:14px;background:#fff;padding:9px 14px;border-radius:10px;font-size:.84rem;font-weight:600;box-shadow:var(--shadow)}

/* Footer */
footer{background:var(--charcoal);color:#cfcac4;padding:48px 0 24px;margin-top:10px}
.fgrid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:28px}
footer h4{color:#fff;font-size:1rem;margin-bottom:14px}
footer a{display:block;color:#b5afa8;font-size:.88rem;padding:4px 0}
footer a:hover{color:var(--accent)}
footer p{font-size:.88rem;line-height:1.7}
.fbrand{display:flex;align-items:center;gap:11px;margin-bottom:14px}
.fbrand b{color:#fff;font-family:var(--fh);font-weight:800;font-size:1.1rem}
.fcopy{text-align:center;border-top:1px solid rgba(255,255,255,.1);margin-top:28px;padding-top:18px;font-size:.8rem;color:#8a847d}

/* Checkout (kasse.php) */
.kasse{max-width:980px;margin:0 auto;padding:30px 20px 60px}
.kasse .back{color:var(--primary);font-weight:600;font-size:.9rem;display:inline-block;margin-bottom:18px}
.kasse h1{font-size:1.8rem;margin-bottom:4px}
.kasse .grid2{display:grid;grid-template-columns:1.2fr 1fr;gap:24px;align-items:start;margin-top:20px}
.panel{background:#fff;border-radius:var(--radius);box-shadow:var(--shadow);border:1px solid var(--line)}
.panel .ph{padding:16px 22px;border-bottom:1px solid var(--line)}
.panel .ph h3{font-size:1.1rem}
.panel .pb{padding:20px 22px}
.kfield{margin-bottom:15px}
.kfield label{display:block;font-size:.84rem;font-weight:600;color:#444;margin-bottom:6px}
.kfield input,.kfield select,.kfield textarea{width:100%;border:1.5px solid var(--line);border-radius:11px;padding:11px 13px;font-family:inherit;font-size:.95rem;background:#fcfaf7;color:var(--ink)}
.kfield input:focus,.kfield select:focus,.kfield textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 4px var(--ring)}
.krow{display:grid;grid-template-columns:120px 1fr;gap:14px}
.kmode{display:flex;gap:10px;margin-bottom:18px}
.kmode label{flex:1;border:1.5px solid var(--line);border-radius:12px;padding:13px;text-align:center;cursor:pointer;font-weight:600;font-size:.9rem;background:#fff}
.kmode input{display:none}
.kmode input:checked + span{color:var(--primary)}
.kmode label:has(input:checked){border-color:var(--primary);background:var(--primary-soft)}
.kmode small{display:block;font-size:.74rem;color:var(--muted);font-weight:500;margin-top:2px}
.pays{display:flex;gap:10px;flex-wrap:wrap}
.pays label{border:1.5px solid var(--line);border-radius:11px;padding:10px 16px;cursor:pointer;font-weight:600;font-size:.88rem;background:#fff}
.pays input{display:none}
.pays label:has(input:checked){border-color:var(--primary);background:var(--primary-soft);color:var(--primary)}
.osum{padding:6px 0}
.osum .oitem{display:flex;justify-content:space-between;gap:10px;padding:10px 0;border-bottom:1px solid var(--line);font-size:.9rem}
.osum .oitem .oq{color:var(--primary);font-weight:700;margin-right:6px}
.osum .oitem .ov{font-size:.78rem;color:var(--muted)}
.kasse .btn-primary{width:100%;justify-content:center;padding:15px;font-size:1.02rem;margin-top:8px}
.success{max-width:560px;margin:60px auto;background:#fff;border-radius:20px;box-shadow:var(--shadow-lg);padding:40px 32px;text-align:center}
.success .big{font-size:54px;margin-bottom:8px}
.success h1{font-size:1.7rem;margin-bottom:10px}
.success .onum{display:inline-block;background:var(--charcoal);color:#fff;font-family:var(--fh);font-weight:800;font-size:1.4rem;padding:8px 22px;border-radius:12px;margin:12px 0}
.success p{color:#5a534c;margin-bottom:8px}

/* Responsive */
@media(max-width:900px){
  .nav-links{display:none}.hamb{display:flex}
  header.nav .nav-links.open{display:flex;position:absolute;top:var(--nav-h);left:0;right:0;flex-direction:column;background:#fff;padding:14px 20px;gap:14px;box-shadow:var(--shadow-lg);border-bottom:1px solid var(--line)}
  .hero .wrap{grid-template-columns:1fr;padding:36px 20px}
  .features .wrap{grid-template-columns:1fr 1fr;gap:18px}
  .grid{grid-template-columns:1fr}.gal{grid-template-columns:repeat(2,1fr)}
  .rev-grid{grid-template-columns:1fr}.hm{grid-template-columns:1fr}
  .fgrid{grid-template-columns:1fr 1fr}.tages .inner{grid-template-columns:1fr;text-align:center}
  .tages .desc{margin:0 auto}
  .kasse .grid2{grid-template-columns:1fr}.rf-row{grid-template-columns:1fr}
}
@media(max-width:480px){.cart{width:100%}.fgrid{grid-template-columns:1fr}.krow{grid-template-columns:1fr}}

/* ===== Mobile Schnell-Warenkorb-Leiste (unten fixiert) ===== */
.cart-bar{position:fixed;left:0;right:0;bottom:0;z-index:85;display:none;align-items:center;justify-content:space-between;gap:12px;width:100%;
  background:var(--charcoal);color:#fff;padding:12px 18px;padding-bottom:calc(12px + env(safe-area-inset-bottom));
  box-shadow:0 -8px 24px rgba(0,0,0,.2);font-family:var(--fb)}
.cart-bar.show{display:flex}
.cart-bar .cb-left{display:flex;align-items:center;gap:11px;font-weight:600;font-size:.95rem}
.cart-bar .cb-badge{background:var(--accent);color:var(--charcoal);min-width:26px;height:26px;border-radius:999px;display:grid;place-items:center;font-weight:800;font-size:.82rem;padding:0 7px}
.cart-bar .cb-right{display:flex;align-items:center;gap:12px;font-weight:800;font-family:var(--fh);font-size:1.02rem}
.cart-bar .cb-go{background:var(--primary);width:34px;height:34px;border-radius:50%;display:grid;place-items:center;font-size:1.05rem}
.cart-bar:active{transform:translateY(1px)}
@media(max-width:1119px){ body.cart-bar-open{padding-bottom:74px} }

/* ===== Persistenter Warenkorb rechts (Desktop) ===== */
@media(min-width:1120px){
  body.has-cart{padding-right:var(--cart-w)}
  body.has-cart .cart{transform:none;width:var(--cart-w);max-width:var(--cart-w);
    box-shadow:-14px 0 40px rgba(40,20,0,.07);border-left:1px solid var(--line)}
  body.has-cart .cart-overlay{display:none!important}
  body.has-cart .cart-head .x{display:none}        /* angedockt → nicht schliessbar */
  body.has-cart .cart-head h3{font-size:1.1rem}
  .cart-bar{display:none!important}                /* Desktop: Leiste aus, Korb ist immer offen */
}

/* ===== Produkt-Optionen-Fenster (Sauce/Extras/Ohne) ===== */
.opt-modal-ov{position:fixed;inset:0;background:rgba(20,12,4,.55);backdrop-filter:blur(3px);z-index:130;display:none;align-items:flex-end;justify-content:center;padding:0}
.opt-modal-ov.open{display:flex}
@media(min-width:600px){.opt-modal-ov{align-items:center;padding:20px}}
.opt-modal{background:#fff;border-radius:20px 20px 0 0;width:100%;max-width:460px;max-height:88vh;display:flex;flex-direction:column;position:relative;box-shadow:var(--shadow-lg);animation:zmIn .25s ease}
@media(min-width:600px){.opt-modal{border-radius:20px}}
.opt-modal .om-x{position:absolute;top:14px;right:14px;background:#f3ece3;width:32px;height:32px;border-radius:9px;font-size:1rem;color:#666;z-index:2}
.om-head{display:flex;align-items:center;gap:13px;padding:22px 22px 15px;border-bottom:1px solid var(--line)}
.om-head .om-emoji{font-size:34px;width:58px;height:58px;border-radius:14px;background:linear-gradient(135deg,var(--accent-soft),#ffd3a8);display:grid;place-items:center;flex:0 0 auto}
.om-head h3{font-size:1.18rem;padding-right:30px}
.om-body{flex:1;overflow-y:auto;padding:6px 22px}
.om-group{padding:15px 0;border-bottom:1px solid var(--line)}
.om-group:last-child{border:none}
.om-gname{font-weight:700;font-family:var(--fh);font-size:.98rem;margin-bottom:10px;display:flex;align-items:center;gap:8px}
.om-req{font-size:.64rem;background:var(--primary-soft);color:var(--primary);font-weight:700;padding:2px 8px;border-radius:6px;text-transform:uppercase;letter-spacing:.5px}
.om-item{display:flex;align-items:center;gap:11px;padding:11px 13px;border:1.5px solid var(--line);border-radius:12px;margin-bottom:8px;cursor:pointer;transition:.12s}
.om-item:hover{border-color:var(--primary)}
.om-item.on{border-color:var(--primary);background:var(--primary-soft)}
.om-item input{display:none}
.om-item .om-dot{width:21px;height:21px;border-radius:50%;border:2px solid #d8ccbf;flex:0 0 auto;display:grid;place-items:center;transition:.12s}
.om-item.multi .om-dot{border-radius:6px}
.om-item.on .om-dot{border-color:var(--primary);background:var(--primary)}
.om-item.on .om-dot::after{content:'';width:7px;height:7px;border-radius:50%;background:#fff}
.om-item.multi.on .om-dot::after{width:9px;height:9px;border-radius:2px}
.om-item .om-label{flex:1;font-size:.93rem;font-weight:500}
.om-item .om-price{font-weight:700;color:var(--primary);font-size:.88rem;white-space:nowrap}
.om-foot{padding:15px 22px;border-top:1px solid var(--line)}
.om-foot .om-add{width:100%;justify-content:center;padding:14px;font-size:1rem}
.citem .cmeta.copts{color:var(--primary-d);font-weight:500}
body.modal-open{overflow:hidden}

/* ===== Kundenkonto (konto.php) ===== */
.konto{max-width:920px;margin:0 auto;padding:30px 20px 60px}
.konto-head{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:22px;flex-wrap:wrap}
.konto-head h1{font-size:1.7rem}
.konto-head p{color:#6a635c;font-size:.92rem;margin-top:4px}
.konto-grid{display:grid;grid-template-columns:1fr 1.1fr;gap:22px;align-items:start}
.konto-auth{max-width:440px;margin:24px auto}
.auth-tabs{display:flex;gap:6px;background:#f1ece4;padding:5px;border-radius:13px;margin-bottom:18px}
.auth-tabs a{flex:1;text-align:center;padding:11px;border-radius:9px;font-weight:600;font-size:.92rem;color:#777}
.auth-tabs a.on{background:#fff;color:var(--charcoal);box-shadow:var(--shadow)}
.auth-alt{text-align:center;font-size:.88rem;color:var(--muted);margin-top:14px}
.auth-alt a{color:var(--primary);font-weight:600}
.ohist{border:1px solid var(--line);border-radius:13px;padding:13px 15px;margin-bottom:11px}
.ohist .oh-top{display:flex;align-items:center;gap:10px}
.ohist .oh-no{font-weight:800;font-family:var(--fh);color:var(--charcoal)}
.ohist .oh-total{margin-left:auto;font-weight:800;font-family:var(--fh);color:var(--primary)}
.ohist .oh-meta{font-size:.8rem;color:var(--muted);margin:6px 0 4px}
.ohist .oh-items{font-size:.88rem;color:#4a443e}
.empty-fe{text-align:center;color:var(--muted);padding:34px 16px}
.empty-fe .ico{font-size:42px;margin-bottom:8px}
.pill{display:inline-flex;align-items:center;gap:6px;font-size:.74rem;font-weight:700;padding:3px 10px;border-radius:999px}
.pill .pd{width:7px;height:7px;border-radius:50%}
.pill.p-new{background:#ffeaea;color:var(--primary)} .pill.p-new .pd{background:var(--primary)}
.pill.p-prep{background:#fff3da;color:#e8590c} .pill.p-prep .pd{background:#e8590c}
.pill.p-ready{background:#e7f5ff;color:#1971c2} .pill.p-ready .pd{background:#1971c2}
.pill.p-done{background:#e6fcf0;color:var(--green)} .pill.p-done .pd{background:var(--green)}
.pill.p-off{background:#f1eee9;color:#868179} .pill.p-off .pd{background:#868179}
.konto-nav{color:#e8e8e8;font-weight:600}
@media(max-width:760px){.konto-grid{grid-template-columns:1fr}}

/* ===== PLZ-Gate Modal + Chip ===== */
.plz-chip{display:inline-flex;align-items:center;gap:5px;background:rgba(255,255,255,.13);color:#fff;border:0;border-radius:999px;padding:3px 11px;font-size:.78rem;font-weight:600;cursor:pointer;font-family:var(--fb)}
.plz-chip:hover{background:rgba(255,255,255,.22)}
.plz-chip span{text-decoration:underline;text-underline-offset:2px}
body.modal-open{overflow:hidden}
.zone-modal-ov{position:fixed;inset:0;background:rgba(20,12,4,.55);z-index:120;display:none;align-items:center;justify-content:center;padding:20px}
.zone-modal-ov.open{display:flex}
.zone-modal{background:#fff;border-radius:20px;max-width:430px;width:100%;padding:28px 24px 24px;position:relative;box-shadow:var(--shadow-lg);text-align:center;animation:zmIn .25s ease}
@keyframes zmIn{from{transform:translateY(18px);opacity:0}to{transform:none;opacity:1}}
.zone-modal .zm-x{position:absolute;top:14px;right:14px;background:#f3ece3;width:32px;height:32px;border-radius:9px;font-size:1rem;color:#777}
.zone-modal .zm-x:hover{background:#e9ded0}
.zone-modal .zm-emoji{font-size:46px;line-height:1;margin-bottom:8px}
.zone-modal h3{font-size:1.35rem;margin-bottom:6px}
.zone-modal p{color:#6a635c;font-size:.92rem;margin-bottom:18px;line-height:1.5}
.zm-zones{display:flex;flex-direction:column;gap:9px;margin-bottom:14px;max-height:46vh;overflow-y:auto}
.zm-zone{display:flex;align-items:center;justify-content:space-between;gap:10px;border:1.5px solid var(--line);background:#fff;border-radius:13px;padding:13px 16px;cursor:pointer;transition:.15s}
.zm-zone:hover{border-color:var(--primary);background:var(--primary-soft);transform:translateY(-1px)}
.zm-zone .zm-plz{font-weight:700;font-family:var(--fh);color:var(--charcoal);font-size:.98rem}
.zm-zone .zm-min{font-size:.82rem;color:var(--muted);font-weight:600;white-space:nowrap}
.zm-pickup{width:100%;background:var(--charcoal);color:#fff;border-radius:12px;padding:13px;font-weight:600;font-size:.92rem;cursor:pointer}
.zm-pickup:hover{background:#000}
