/* Container/Navigation */
.ds-menu{
  max-width:980px;
  margin:0 auto;
  --ds-sticky-offset:0px;     /* Höhe des Theme-Headers (per JS gesetzt) */
  --ds-cat-nav-height:0px;    /* Höhe der eigenen Pill-Nav (per JS gesetzt) */
}
.ds-cat-nav{display:flex;flex-wrap:wrap;gap:8px;align-items:center;margin:8px 0 16px}
.ds-cat-nav.sticky{position:sticky;top:var(--ds-sticky-offset,0px);z-index:20;background:#fff;padding:8px 0;border-bottom:1px solid #eee}
.admin-bar .ds-cat-nav.sticky{top:calc(var(--ds-sticky-offset,0px) + 32px)}
@media screen and (max-width:782px){
  .admin-bar .ds-cat-nav.sticky{top:calc(var(--ds-sticky-offset,0px) + 46px)}
}

/* Anker-Sprünge: damit die Sticky-Nav den Sektionsanfang nicht verdeckt,
 * wird oben darüber Platz gelassen. Setzt sich aus Theme-Header- und
 * Pill-Nav-Höhe zusammen. Plus 8px Sicherheitspuffer für Borders/Spacing. */
.ds-section{
  scroll-margin-top:calc(var(--ds-sticky-offset,0px) + var(--ds-cat-nav-height,0px) + 8px);
}
.admin-bar .ds-section{
  scroll-margin-top:calc(var(--ds-sticky-offset,0px) + var(--ds-cat-nav-height,0px) + 8px + 32px);
}
@media screen and (max-width:782px){
  .admin-bar .ds-section{
    scroll-margin-top:calc(var(--ds-sticky-offset,0px) + var(--ds-cat-nav-height,0px) + 8px + 46px);
  }
}
.ds-pill{border:1px solid #ddd;border-radius:999px;padding:6px 12px;text-decoration:none;font-size:.95rem}
.ds-pill.active{border-color:#333;font-weight:600}

.ds-section{margin:24px 0}
.ds-section-title{font-size:1.5rem;font-weight:700;border-bottom:2px solid #eee;padding-bottom:8px;margin-bottom:12px}
.ds-items{margin-top:8px}
/* Gleiche Höhe für Items im Zwei-Spalten-Layout */
.ds-two-col .ds-items{align-items:stretch}
.ds-two-col .ds-items .ds-item{height:100%}

/* Items */
.ds-item{display:grid;grid-template-columns:72px minmax(0,1fr);gap:12px;padding:12px 0;border-bottom:1px solid #f0f0f0;align-items:start;align-self:stretch}
.ds-item.no-thumb{grid-template-columns:minmax(0,1fr)}
.ds-media{width:72px}
.ds-body{min-width:0;width:100%;display:flex;flex-direction:column}
.ds-thumb{width:72px;height:72px;object-fit:cover;border-radius:8px;display:block}
.ds-line{display:block}
.ds-title{display:block;font-weight:600;line-height:1.3;word-break:break-word;overflow-wrap:anywhere}
.ds-dots{display:none}
.ds-desc{color:#555;margin-top:4px;font-size:.95rem}
.ds-price{font-weight:700;white-space:nowrap;text-align:right}
.ds-variants{margin-top:6px;display:flex;flex-wrap:wrap;gap:8px}
.ds-chip{border:1px solid #ddd;border-radius:999px;padding:2px 8px;font-size:.85rem}
.ds-item-footer{display:flex;justify-content:space-between;align-items:flex-end;gap:12px;margin-top:auto;padding-top:8px;width:100%}
.ds-codes{margin-top:0;font-size:.9rem;flex:1 1 auto;min-width:0}
.ds-codes .ds-code{text-decoration:underline dotted;cursor:pointer}
.ds-codes-empty{visibility:hidden}

/* MwSt.-Block */
.ds-vat{margin-top:16px;padding-top:12px;border-top:1px dashed #e0e0e0;color:#555;font-size:.9rem}
.ds-vat .ds-legend-open{display:inline-block;margin-right:10px;text-decoration:underline;cursor:pointer}

/* Modal */
body.ds-lock{overflow:hidden}
.ds-modal{position:fixed;inset:0;display:none;z-index:10000}
.ds-modal.is-open{display:block}
.ds-modal-backdrop{position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:10000}
.ds-modal-dialog{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);background:#fff;border-radius:12px;max-width:900px;width:92vw;max-height:80vh;overflow:auto;box-shadow:0 10px 30px rgba(0,0,0,.25);padding:20px;z-index:10001}
.ds-modal-close{position:absolute;top:6px;right:10px;font-size:20px;line-height:1;border:none;background:transparent;cursor:pointer}

/* Tabellen in Modals */
.ds-table-wrap{overflow:auto}
.ds-table-legend{width:100%;border-collapse:collapse;margin:8px 0}
.ds-table-legend th,.ds-table-legend td{border-bottom:1px solid #eee;padding:8px;text-align:left}

/* Responsive */
@media (max-width:600px){
  .ds-item{grid-template-columns:56px minmax(0,1fr)}
  .ds-item.no-thumb{grid-template-columns:minmax(0,1fr)}
  .ds-media{width:56px}
  .ds-thumb{width:56px;height:56px}
  .ds-item-footer{align-items:flex-start;gap:10px}
}
/* ===== Badges für Ernährungsweisen (nur Anzeige) ===== */
.ds-badges{display:flex;flex-wrap:wrap;gap:6px;margin-top:6px}
.ds-badge{font-size:.75rem;border:1px solid #ddd;border-radius:999px;padding:2px 8px;background:#fafafa;line-height:1.6}
.ds-badge-vegan{border-color:#71c17b}
.ds-badge-vegetarisch{border-color:#8bc34a}
.ds-badge-halal{border-color:#009688}
.ds-badge-koscher{border-color:#3f51b5}
.ds-badge-scharf{border-color:#ef5350}
.ds-badge-glutenfrei{border-color:#ff9800}
/* ===== Sold-out (dezent) ===== */
.ds-item.is-soldout { opacity: .6; }
.ds-soldout-badge{
  display:inline-block;
  margin-top:6px;
  font-size:.75rem;
  border:1px solid #ccc;
  border-radius:6px;
  padding:2px 8px;
  background:#f7f7f7;
  line-height:1.6;
}
/* ===== Specials (zeitgesteuert) ===== */
.ds-badge-special{
  display:inline-block;
  margin-top:6px;
  font-size:.75rem;
  border:1px solid #ff7043;
  border-radius:6px;
  padding:2px 8px;
  background:#fff7f3;
  line-height:1.6;
}
/* Layout-Fix: Preis und Allergene bleiben im Footer der jeweiligen Speise. */
.ds-item .ds-price{position:static;top:auto;right:auto;z-index:auto;}
.ds-item .ds-subline,.ds-item .ds-subleft,.ds-item .ds-subright,.ds-items .ds-item .ds-price-topright{all:unset;}
.ds-items .ds-item .ds-price-topright{position:static !important;transform:none !important;}

/* ===== Extras / Zutaten ===== */
.ds-extras-summary{margin-top:8px;font-size:.92rem;color:#444}
.ds-extras-trigger{padding:0;border:none;background:none;color:inherit;font:inherit;font-weight:600;text-decoration:underline;cursor:pointer}
.ds-extras-trigger:hover,.ds-extras-trigger:focus{text-decoration:none;outline:none}
.ds-extras-modal-dialog{max-width:560px}
.ds-extras-modal-groups{display:flex;flex-direction:column;gap:12px;margin-top:8px}
.ds-extras-group{padding:8px 10px;border:1px solid #eee;border-radius:10px;background:#fafafa;min-width:0}
.ds-extras-group-head{margin-bottom:4px}
.ds-extras-group-title{font-weight:700}
.ds-extras-options{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:4px}
.ds-extras-option{display:flex;flex-wrap:wrap;align-items:baseline;gap:6px}
.ds-extras-option-label{min-width:0}
.ds-extras-option-price{font-weight:600;white-space:nowrap;margin-left:4px}

.ds-extras-trigger{-webkit-appearance:none;appearance:none;-webkit-tap-highlight-color:transparent;touch-action:manipulation;}
.ds-extras-trigger, .ds-extras-trigger *{pointer-events:auto;}

/* ===========================================================
 * 2.9.0: Floating-Kategorie-Button (Action-Stack rechts unten)
 * Stapelt sich automatisch über dem Shop-Cart-Button, wenn das
 * Shop-Addon aktiv ist. Die exakte Cart-Höhe wird von JS in
 * --ds-cart-stack-offset gemessen und gesetzt.
 * ===========================================================*/

.ds-floatnav{
    position:fixed !important;
    right:20px !important;
    /* Default: 20px Abstand zum unteren Rand. Wenn Cart aktiv,
       schiebt JS den Button per --ds-cart-stack-offset nach oben. */
    bottom:calc(20px + var(--ds-cart-stack-offset, 0px)) !important;
    left:auto !important;
    top:auto !important;
    z-index:99989; /* knapp unter rsa-floatcart (99990), damit Cart-Toggle gewinnt bei Überlappung */
    transition:bottom .18s ease-out;
    /* 2.9.5: gegen Theme-Wrapper härten – siehe JS, das den Button ans body verschiebt. */
    margin:0 !important;
    transform:none !important;
}
.ds-floatnav-toggle{
    display:inline-flex;
    align-items:center;
    gap:8px;
    border:0;
    border-radius:999px;
    background:#2c2c2a;
    color:#fff;
    padding:12px 16px;
    box-shadow:0 10px 24px rgba(0,0,0,.18);
    cursor:pointer;
    font:inherit;
    font-weight:500;
    line-height:1;
    -webkit-appearance:none;
    appearance:none;
    -webkit-tap-highlight-color:transparent;
}
.ds-floatnav-toggle:hover,
.ds-floatnav-toggle:focus{
    background:#1a1a18;
    color:#fff;
    outline:none;
}
.ds-floatnav-toggle:focus-visible{
    box-shadow:0 0 0 3px rgba(255,255,255,.6), 0 0 0 5px #2c2c2a;
}
.ds-floatnav-icon{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    width:20px;height:20px;
}
.ds-floatnav-icon svg{display:block}
.ds-floatnav-label{font-size:14px;white-space:nowrap}

/* Mobile: nur Icon, kein Label (spart Platz, vermeidet Stapel-Konflikte) */
@media (max-width:600px){
    .ds-floatnav{
        right:14px !important;
        bottom:calc(14px + var(--ds-cart-stack-offset, 0px) + env(safe-area-inset-bottom,0px)) !important;
    }
    .ds-floatnav-toggle{padding:12px;border-radius:50%}
    .ds-floatnav-label{display:none}
}

/* Drawer */
.ds-floatnav-drawer{
    position:fixed !important;
    inset:0 !important;
    z-index:99995; /* über allen Floats, damit Drawer sichtbar bleibt */
}
.ds-floatnav-drawer[hidden]{display:none}
.ds-floatnav-backdrop{
    position:absolute;
    inset:0;
    background:rgba(0,0,0,.45);
    opacity:0;
    transition:opacity .2s ease-out;
}
.ds-floatnav-drawer.is-open .ds-floatnav-backdrop{opacity:1}
.ds-floatnav-panel{
    position:absolute;
    top:0;right:0;
    height:100dvh;
    width:min(360px,88vw);
    background:#fff;
    box-shadow:-10px 0 30px rgba(0,0,0,.16);
    transform:translateX(100%);
    transition:transform .22s ease-out;
    display:flex;
    flex-direction:column;
    padding:18px 16px 18px;
}
.ds-floatnav-drawer.is-open .ds-floatnav-panel{transform:translateX(0)}
.ds-floatnav-head{
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:12px;
    margin-bottom:10px;
    padding-bottom:10px;
    border-bottom:1px solid #eee;
}
.ds-floatnav-title{margin:0;font-size:1.05rem;font-weight:700}
.ds-floatnav-close{
    border:0;background:none;
    font-size:28px;line-height:1;
    cursor:pointer;
    width:36px;height:36px;
    border-radius:8px;
    color:#222;
}
.ds-floatnav-close:hover,.ds-floatnav-close:focus{background:#f1f1f1;outline:none}
.ds-floatnav-list{
    display:flex;
    flex-direction:column;
    gap:2px;
    overflow-y:auto;
    -webkit-overflow-scrolling:touch;
    padding-right:4px;
}
.ds-floatnav-link{
    display:block;
    padding:12px 14px;
    border-radius:10px;
    text-decoration:none;
    color:#222;
    font-size:.98rem;
    line-height:1.3;
    border:1px solid transparent;
}
.ds-floatnav-link:hover,
.ds-floatnav-link:focus{
    background:#f5f5f5;
    color:#000;
    border-color:#ececec;
    outline:none;
}
.ds-floatnav-link.is-active{
    background:#f1f1f1;
    border-color:#ddd;
    font-weight:600;
}

/* Wenn Floating-Nav aktiv ist, brauchen Section-Sprünge keinen
   Top-Offset für das Sticky-Pill-Menü mehr — wir nullen --ds-cat-nav-height. */
.ds-menu.ds-has-floating-nav{--ds-cat-nav-height:0px}

/* Body bekommt eine Klasse, wenn Drawer offen ist → kein Doppelscroll */
body.ds-floatnav-open{overflow:hidden}
