/*
Theme Name: Schmecktbesser
Theme URI: https://schmecktbesser.yogalingam.ch
Author: roYal-creation
Author URI: https://schmecktbesser.ch
Description: Individuelles Theme für Schmecktbesser – Daniel Roth Gewürze. Mit Mega-Navigation, Hero-Sektion, Trustbar, Produktgrid und Footer.
Version: 1.0
License: GNU General Public License v2 or later
Text Domain: schmecktbesser
*/

/* ============================================================
   CSS VARIABLEN
   ============================================================ */
:root {
  --white: #FFFFFF;
  --off-white: #F8F7F4;
  --border: #E5E2DA;
  --green-deep: #1E3A22;
  --green-mid: #2D5531;
  --green-light: #4A7C52;
  --green-pale: #EBF2EC;
  --gold: #C8943A;
  --text-dark: #1A1A18;
  --text-mid: #4A4A45;
  --text-light: #8A8A82;
}

/* ============================================================
   RESET & BASE
   ============================================================ */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body { font-family: 'Outfit', sans-serif; background: var(--white); color: var(--text-dark); overflow-x: hidden; }
img { max-width: 100%; height: auto; }
a { text-decoration: none; }
ul { list-style: none; }

/* ============================================================
   CONTAINER
   ============================================================ */
.sb-wrap {
  max-width: 1240px;
  margin: 0 auto;
  padding: 0 2.5rem;
  width: 100%;
}

/* ============================================================
   BUTTONS
   ============================================================ */
.sb-btn { display: inline-flex; align-items: center; padding: 0.55rem 1.2rem; border-radius: 6px; font-size: 0.875rem; font-weight: 500; text-decoration: none; transition: all 0.2s; white-space: nowrap; font-family: 'Outfit', sans-serif; cursor: pointer; }
.sb-btn-outline { border: 1.5px solid var(--border); color: var(--text-mid); background: transparent; }
.sb-btn-outline:hover { border-color: var(--green-deep); color: var(--green-deep); }
.sb-btn-green { background: var(--green-deep); color: white !important; border: 1.5px solid var(--green-deep); }
.sb-btn-green:hover { background: var(--green-mid); color: white !important; }

/* ============================================================
   TOP BAR
   ============================================================ */
.sb-topbar { background: var(--green-deep); color: rgba(255,255,255,0.85); font-size: 0.78rem; text-align: center; padding: 0.5rem 1rem; letter-spacing: 0.03em; }
.sb-topbar a { color: white; font-weight: 600; text-decoration: underline; }

/* ============================================================
   NAVIGATION
   ============================================================ */
.sb-nav { position: sticky; top: 0; z-index: 1000; background: var(--white); border-bottom: 1px solid var(--border); box-shadow: 0 1px 0 var(--border); }
.sb-nav-inner { max-width: 1240px; margin: 0 auto; padding: 0 2.5rem; height: 64px; display: flex; align-items: center; gap: 1.25rem; }

/* Suche */
.sb-nav-search { flex: 1; max-width: 420px; display: flex; align-items: center; gap: 0.5rem; background: var(--off-white); border: 1.5px solid var(--border); border-radius: 8px; padding: 0 0.75rem; height: 38px; transition: border-color 0.2s; }
.sb-nav-search:focus-within { border-color: #4a7c52; background: white; }
.sb-nav-search svg { color: var(--text-light); flex-shrink: 0; }
.sb-nav-search input[type="search"] { flex: 1; border: none; background: none; font-family: 'Outfit', sans-serif; font-size: 0.84rem; color: var(--text-dark); outline: none; }
.sb-nav-search input[type="search"]::placeholder { color: var(--text-light); }
.sb-nav-search button { background: none; border: none; color: var(--text-light); font-size: 1rem; cursor: pointer; padding: 0; line-height: 1; transition: color 0.15s; }
.sb-nav-search button:hover { color: #4a7c52; }

/* Zweite Reihe: Catbar */
.sb-nav-sortiment { display: flex; align-items: center; height: 44px; gap: 0; border-left: 1px solid var(--border); padding-left: 1rem; flex-wrap: nowrap; overflow: visible; }
.sb-nav-catbar-inner { max-width: 1240px; margin: 0 auto; padding: 0 2.5rem; display: flex; align-items: center; height: 44px; gap: 0; overflow: visible; }
.sb-nav-catbar { background: var(--white); border-top: 1px solid var(--border); overflow: visible; position: relative; z-index: 999; }
/* Nav Links in zweiter Reihe */
.sb-nav-links { display: flex; gap: 0; list-style: none; align-items: stretch; height: 44px; margin-right: 1.5rem; }
.sb-nav-links > li { position: relative; display: flex; align-items: center; }
.sb-nav-links > li > a { text-decoration: none; font-size: 0.82rem; font-weight: 500; color: var(--text-mid); padding: 0 0.9rem; height: 100%; display: flex; align-items: center; gap: 0.3rem; border-bottom: 2px solid transparent; transition: color 0.2s, border-color 0.2s; white-space: nowrap; }
.sb-nav-links > li > a:hover,
.sb-nav-links > li:hover > a { color: var(--green-deep); border-bottom-color: var(--green-deep); }
.sb-nav-chevron { font-size: 0.6rem; transition: transform 0.2s; display: inline-block; }
.sb-nav-links > li:hover .sb-nav-chevron { transform: rotate(180deg); }

/* Trennlinie */
.sb-nav-sort-link { display: flex; align-items: center; gap: 0.3rem; padding: 0 0.75rem; height: 44px; font-size: 0.95rem; font-weight: 500; color: var(--text-mid); text-decoration: none; white-space: nowrap; transition: all 0.15s; border-bottom: 2px solid transparent; }
.sb-nav-sort-link:hover { color: #4a7c52; border-bottom-color: #4a7c52; }

.sb-nav-sort-group { position: relative; display: flex; align-items: center; height: 44px; }
.sb-nav-sort-dropdown { display: flex; align-items: center; gap: 0.25rem; }
.sb-sort-chevron { font-size: 0.6rem; display: inline-block; transition: transform 0.2s; }
.sb-nav-sort-group:hover .sb-sort-chevron { transform: rotate(180deg); }
.sb-nav-sort-submenu { position: absolute; top: 100%; left: 0; background: var(--white); border: 1px solid var(--border); border-top: 2px solid #4a7c52; border-radius: 0 0 10px 10px; box-shadow: 0 8px 24px rgba(0,0,0,0.1); min-width: 210px; opacity: 0; visibility: hidden; pointer-events: none; transition: opacity 0.15s; z-index: 200; }
.sb-nav-sort-group:hover .sb-nav-sort-submenu { opacity: 1; visibility: visible; pointer-events: all; }
.sb-nav-sort-submenu a { display: block; padding: 0.6rem 1rem; font-size: 0.81rem; color: var(--text-mid); text-decoration: none; border-bottom: 1px solid var(--off-white); transition: all 0.12s; }
.sb-nav-sort-submenu a:last-child { border-bottom: none; }
.sb-nav-sort-submenu a:hover { background: var(--green-pale); color: #4a7c52; padding-left: 1.3rem; }

/* Logo */
.sb-nav-logo { display: flex; align-items: center; }
.sb-nav-logo a,
.sb-nav-logo .custom-logo-link {
  background: #4a7c52 !important;
  border-radius: 8px !important;
  padding: 4px 10px !important;
  display: inline-flex !important;
  align-items: center !important;
}
.sb-nav-logo img,
.sb-nav-logo a img,
.sb-nav-logo .custom-logo-link img,
.sb-nav-logo .custom-logo { height: 28px !important; width: auto !important; max-width: 130px !important; object-fit: contain !important; border-radius: 0 !important; }

/* Nav Links */
.sb-nav-links { display: flex; gap: 0; list-style: none; align-items: stretch; height: 68px; }
.sb-nav-links > li { position: relative; display: flex; align-items: center; }
.sb-nav-links > li > a { text-decoration: none; font-size: 0.875rem; font-weight: 500; color: var(--text-mid); padding: 0 1.1rem; height: 100%; display: flex; align-items: center; gap: 0.3rem; border-bottom: 2px solid transparent; transition: color 0.2s, border-color 0.2s; white-space: nowrap; }
.sb-nav-links > li > a:hover,
.sb-nav-links > li:hover > a { color: var(--green-deep); border-bottom-color: var(--green-deep); }
.sb-nav-chevron { font-size: 0.6rem; transition: transform 0.2s; display: inline-block; }
.sb-nav-links > li:hover .sb-nav-chevron { transform: rotate(180deg); }
.sb-nav-actions { display: flex; gap: 0.75rem; align-items: center; }

/* Mega Dropdown */
.sb-mega-drop { position: absolute; top: 100%; left: 50%; transform: translateX(-50%); background: var(--white); border: 1px solid var(--border); border-top: 2px solid var(--green-deep); border-radius: 0 0 16px 16px; box-shadow: 0 16px 48px rgba(0,0,0,0.12); padding: 1.5rem; min-width: 520px; opacity: 0; visibility: hidden; pointer-events: none; transition: opacity 0.18s, visibility 0.18s; }
.sb-nav-links > li:hover .sb-mega-drop { opacity: 1; visibility: visible; pointer-events: all; }
.sb-mega-label { font-size: 0.68rem; font-weight: 600; letter-spacing: 0.12em; text-transform: uppercase; color: var(--text-light); margin-bottom: 0.85rem; padding-bottom: 0.6rem; border-bottom: 1px solid var(--border); }
.sb-mega-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 0.3rem; }
.sb-mega-item { display: flex; align-items: center; gap: 0.7rem; padding: 0.6rem 0.7rem; border-radius: 8px; text-decoration: none; color: var(--text-mid); font-size: 0.86rem; font-weight: 500; transition: all 0.15s; }
.sb-mega-item:hover { background: var(--green-pale); color: var(--green-deep); }
.sb-mega-item-icon { width: 32px; height: 32px; flex-shrink: 0; background: var(--off-white); border-radius: 7px; display: flex; align-items: center; justify-content: center; font-size: 1rem; transition: background 0.15s; }
.sb-mega-item:hover .sb-mega-item-icon { background: white; }
.sb-mega-footer { margin-top: 0.85rem; padding-top: 0.75rem; border-top: 1px solid var(--border); }
.sb-mega-all { display: flex; align-items: center; justify-content: center; gap: 0.5rem; text-decoration: none; font-size: 0.82rem; font-weight: 600; color: var(--green-deep); padding: 0.55rem 1rem; border-radius: 8px; background: var(--green-pale); transition: all 0.15s; }
.sb-mega-all:hover { background: var(--green-deep); color: white; }
.sb-mega-all::after { content: ' →'; }

/* Mobile Hamburger */
.sb-nav-hamburger { display: none; flex-direction: column; gap: 5px; cursor: pointer; padding: 8px; border: none; background: none; }
.sb-nav-hamburger span { display: block; width: 24px; height: 2px; background: var(--text-dark); border-radius: 2px; transition: all 0.3s; }
.sb-mobile-menu { display: none; position: fixed; top: 108px; left: 0; right: 0; bottom: 0; background: white; z-index: 999; overflow-y: auto; padding: 1.5rem; flex-direction: column; gap: 0.5rem; }
.sb-mobile-search { display: flex; align-items: center; border: 1.5px solid var(--border); border-radius: 8px; overflow: hidden; margin-bottom: 0.75rem; }
.sb-mobile-search input[type="search"] { flex: 1; border: none; padding: 0.7rem 1rem; font-family: 'Outfit', sans-serif; font-size: 0.9rem; outline: none; }
.sb-mobile-menu.open { display: flex; }
.sb-mobile-menu a { display: block; padding: 0.8rem 1rem; border-radius: 8px; color: var(--text-mid); font-size: 0.95rem; font-weight: 500; border-bottom: 1px solid var(--border); }
.sb-mobile-menu a:hover { background: var(--green-pale); color: var(--green-deep); }
.sb-mobile-menu .sb-mobile-section-title { font-size: 0.7rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.1em; color: var(--text-light); padding: 1rem 1rem 0.3rem; }

/* ============================================================
   HERO
   ============================================================ */
.sb-hero { background: var(--off-white); border-bottom: 1px solid var(--border); }
.sb-hero-inner { max-width: 1240px; margin: 0 auto; padding: 0 2.5rem; display: grid; grid-template-columns: 55% 45%; min-height: 520px; align-items: center; gap: 2rem; }
.sb-hero-content { padding: 4rem 0; }
.sb-hero-eyebrow { display: inline-flex; align-items: center; gap: 0.4rem; background: var(--green-pale); color: var(--green-mid); font-size: 0.76rem; font-weight: 600; letter-spacing: 0.08em; text-transform: uppercase; padding: 0.3rem 0.8rem; border-radius: 4px; margin-bottom: 1.25rem; }
.sb-hero h1 { font-family: 'Lora', serif; font-size: clamp(2rem, 3.8vw, 3.4rem); font-weight: 700; line-height: 1.15; color: var(--text-dark); margin-bottom: 1.1rem; }
.sb-hero h1 em { font-style: normal; color: var(--green-light); }
.sb-hero p { font-size: 0.97rem; color: var(--text-mid); line-height: 1.75; margin-bottom: 2rem; font-weight: 300; max-width: 450px; }
.sb-hero-btns { display: flex; gap: 0.75rem; flex-wrap: wrap; }
.sb-hero-visual { display: flex; align-items: center; justify-content: flex-end; height: 100%; padding: 3rem 0; }
.sb-hero-img {
  width: 100%; max-width: 520px; height: auto;
  border-radius: 20px;
  object-fit: cover;
  box-shadow: 0 16px 48px rgba(0,0,0,0.12);
  display: block;
}
.sb-hero-img-placeholder {
  width: 100%; max-width: 520px; min-height: 320px;
  border-radius: 20px; border: 2px dashed var(--border);
  display: flex; align-items: center; justify-content: center;
  text-align: center; color: var(--text-light); font-size: 0.85rem;
  padding: 2rem; background: var(--off-white);
}
.sb-hero-mini-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 0.7rem; position: relative; z-index: 1; }
.sb-mini-card { background: rgba(255,255,255,0.06); border: 1px solid rgba(255,255,255,0.1); border-radius: 12px; padding: 1rem; display: flex; flex-direction: column; gap: 0.5rem; transition: background 0.2s; }
.sb-mini-card:hover { background: rgba(255,255,255,0.12); }
.sb-mini-card-icon { font-size: 1.8rem; line-height: 1; }
.sb-mini-card-name { color: white; font-size: 0.82rem; font-weight: 600; line-height: 1.3; }
.sb-mini-card-sub { color: rgba(255,255,255,0.45); font-size: 0.72rem; }
.sb-hero-banner-link { display: flex; align-items: center; justify-content: center; gap: 0.4rem; background: rgba(255,255,255,0.1); border: 1px solid rgba(255,255,255,0.15); border-radius: 8px; padding: 0.65rem; color: white; text-decoration: none; font-size: 0.82rem; font-weight: 500; position: relative; z-index: 1; transition: background 0.2s; }
.sb-hero-banner-link:hover { background: rgba(255,255,255,0.18); color: white; }
.sb-hero-banner-link::after { content: ' →'; }

/* ============================================================
   TRUST BAR
   ============================================================ */
.sb-trustbar { background: var(--off-white); border-top: 1px solid var(--border); border-bottom: 1px solid var(--border); padding: 2rem 0; }
.sb-trustbar-inner { max-width: 1240px; margin: 0 auto; padding: 0 2.5rem; display: grid; grid-template-columns: repeat(5, 1fr); gap: 1rem; }
.sb-trust-item { background: var(--white); border: 1.5px solid var(--border); border-radius: 12px; padding: 1.25rem 1rem; display: flex; flex-direction: column; align-items: center; text-align: center; gap: 0.6rem; transition: border-color 0.2s, box-shadow 0.2s; }
.sb-trust-item:hover { border-color: var(--green-light); box-shadow: 0 4px 14px rgba(30,58,34,0.08); }
.sb-trust-item-icon { width: 44px; height: 44px; background: var(--green-pale); border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 1.3rem; flex-shrink: 0; }
.sb-trust-item-title { font-size: 0.83rem; font-weight: 600; color: var(--text-dark); line-height: 1.3; }
.sb-trust-item-sub { font-size: 0.74rem; color: var(--text-light); line-height: 1.4; }

/* ============================================================
   SECTIONS ALLGEMEIN
   ============================================================ */
.sb-section-wrap { padding: 4rem 0; }
.sb-section-label { font-size: 0.72rem; font-weight: 600; letter-spacing: 0.12em; text-transform: uppercase; color: var(--green-light); margin-bottom: 0.4rem; }
.sb-section-title { font-family: 'Lora', serif; font-size: clamp(1.5rem, 2.5vw, 2.1rem); font-weight: 700; color: var(--text-dark); line-height: 1.2; }
.sb-section-desc { color: var(--text-light); font-size: 0.9rem; line-height: 1.7; margin-top: 0.5rem; max-width: 480px; }
.sb-section-header { margin-bottom: 2rem; }
.sb-section-header-row { display: flex; justify-content: space-between; align-items: flex-end; gap: 1rem; flex-wrap: wrap; }

/* ============================================================
   KATEGORIEN
   ============================================================ */
.sb-categories-bg { background: var(--off-white); border-top: 1px solid var(--border); border-bottom: 1px solid var(--border); }
.sb-cat-grid { display: grid; grid-template-columns: repeat(5, 1fr); gap: 0.85rem; }
.sb-cat-item { background: var(--white); border: 1.5px solid var(--border); border-radius: 12px; padding: 1.35rem 0.85rem; text-align: center; text-decoration: none; color: var(--text-mid); transition: all 0.2s; display: flex; flex-direction: column; align-items: center; gap: 0.55rem; }
.sb-cat-item:hover { border-color: var(--green-light); color: var(--green-deep); background: var(--green-pale); transform: translateY(-2px); box-shadow: 0 4px 14px rgba(30,58,34,0.08); }
.sb-cat-icon { width: 48px; height: 48px; background: var(--off-white); border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 1.5rem; transition: background 0.2s; }
.sb-cat-item:hover .sb-cat-icon { background: var(--green-pale); }
.sb-cat-name { font-size: 0.78rem; font-weight: 500; line-height: 1.35; }

/* ============================================================
   PRODUKTE
   ============================================================ */
.sb-products-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(235px, 1fr)); gap: 1.1rem; }
.sb-product-card { background: var(--white); border: 1.5px solid var(--border); border-radius: 12px; overflow: hidden; text-decoration: none; color: inherit; display: flex; flex-direction: column; transition: all 0.2s; }
.sb-product-card:hover { border-color: var(--green-light); box-shadow: 0 6px 20px rgba(30,58,34,0.1); transform: translateY(-3px); }
.sb-product-img-wrap { background: var(--off-white); aspect-ratio: 1; overflow: hidden; position: relative; }
.sb-product-img-wrap img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.4s; }
.sb-product-card:hover .sb-product-img-wrap img { transform: scale(1.04); }
.sb-product-badge { position: absolute; top: 0.65rem; left: 0.65rem; background: var(--green-deep); color: white; font-size: 0.66rem; font-weight: 600; letter-spacing: 0.06em; text-transform: uppercase; padding: 0.18rem 0.5rem; border-radius: 4px; }
.sb-product-body { padding: 0.9rem 1rem 1rem; display: flex; flex-direction: column; flex: 1; }
.sb-product-cat { font-size: 0.7rem; font-weight: 600; color: var(--green-light); letter-spacing: 0.06em; text-transform: uppercase; margin-bottom: 0.25rem; }
.sb-product-name { font-family: 'Lora', serif; font-size: 0.93rem; font-weight: 600; color: var(--text-dark); line-height: 1.4; flex: 1; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.sb-product-footer { display: flex; justify-content: space-between; align-items: center; margin-top: 0.75rem; padding-top: 0.65rem; border-top: 1px solid var(--border); }
.sb-product-price { font-size: 0.97rem; font-weight: 600; color: var(--green-deep); }
.sb-product-link { font-size: 0.76rem; font-weight: 600; color: var(--green-light); display: flex; align-items: center; gap: 0.25rem; transition: gap 0.2s; }
.sb-product-card:hover .sb-product-link { gap: 0.45rem; }
.sb-product-link::after { content: ' →'; }

/* ============================================================
   QUALITÄT
   ============================================================ */
.sb-quality-bg { background: var(--off-white); border-top: 1px solid var(--border); border-bottom: 1px solid var(--border); }
.sb-quality-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.25rem; }
.sb-quality-card { background: var(--white); border: 1.5px solid var(--border); border-radius: 12px; padding: 1.75rem; }
.sb-quality-icon { width: 46px; height: 46px; background: var(--green-pale); border-radius: 10px; display: flex; align-items: center; justify-content: center; font-size: 1.45rem; margin-bottom: 0.9rem; }
.sb-quality-card h3 { font-family: 'Lora', serif; font-size: 1rem; font-weight: 700; margin-bottom: 0.45rem; color: var(--text-dark); }
.sb-quality-card p { font-size: 0.86rem; color: var(--text-light); line-height: 1.65; }

/* ============================================================
   USP + KONTAKT
   ============================================================ */
.sb-usp-bg { background: var(--green-deep); }
.sb-usp-inner { max-width: 1240px; margin: 0 auto; padding: 4rem 2.5rem; display: grid; grid-template-columns: 1fr 1fr; gap: 5rem; align-items: center; }
.sb-usp-label { color: var(--gold) !important; }
.sb-usp-title { color: white !important; }
.sb-usp-desc { color: rgba(255,255,255,0.6) !important; margin-top: 0.75rem; }
.sb-usp-list { margin-top: 1.75rem; display: flex; flex-direction: column; gap: 0.75rem; padding: 0; }
.sb-usp-item { display: flex; align-items: center; gap: 0.8rem; padding: 0.8rem 1rem; background: rgba(255,255,255,0.05); border: 1px solid rgba(255,255,255,0.1); border-radius: 8px; }
.sb-usp-icon { font-size: 1.2rem; flex-shrink: 0; }
.sb-usp-text { font-size: 0.88rem; color: rgba(255,255,255,0.8); line-height: 1.5; }
.sb-usp-text strong { color: white; font-weight: 600; }
.sb-contact-box { background: white; border-radius: 14px; padding: 2.25rem; }
.sb-contact-box h3 { font-family: 'Lora', serif; font-size: 1.25rem; font-weight: 700; color: var(--text-dark); margin-bottom: 0.4rem; }
.sb-contact-box > p { font-size: 0.86rem; color: var(--text-light); line-height: 1.65; margin-bottom: 1.35rem; }
.sb-contact-rows { display: flex; flex-direction: column; gap: 0.6rem; margin-bottom: 1.35rem; }
.sb-contact-row { display: flex; align-items: center; gap: 0.6rem; font-size: 0.86rem; color: var(--text-mid); }
.sb-contact-row-icon { width: 30px; height: 30px; background: var(--green-pale); border-radius: 6px; display: flex; align-items: center; justify-content: center; font-size: 0.9rem; flex-shrink: 0; }
.sb-btn-full { display: block; text-align: center; background: var(--green-deep); color: white !important; text-decoration: none; padding: 0.8rem; border-radius: 8px; font-weight: 600; font-size: 0.88rem; transition: background 0.2s; font-family: 'Outfit', sans-serif; }
.sb-btn-full:hover { background: var(--green-mid); }
.sb-btn-outline-sm { display: block; text-align: center; border: 1.5px solid var(--border); color: var(--text-mid) !important; text-decoration: none; padding: 0.7rem; border-radius: 8px; font-weight: 500; font-size: 0.84rem; margin-top: 0.55rem; transition: all 0.2s; }
.sb-btn-outline-sm:hover { border-color: var(--green-deep); color: var(--green-deep) !important; }


/* ============================================================
   ÜBER UNS SEKTION
   ============================================================ */
.sb-ueber-uns-bg { background: var(--white); border-top: 1px solid var(--border); }
.sb-ueber-uns-inner { padding: 4.5rem 0; display: flex; flex-direction: column; gap: 3rem; }
.sb-ueber-uns-intro { max-width: 640px; }
.sb-ueber-uns-lead { font-size: 1.05rem; color: var(--text-mid); line-height: 1.75; margin-top: 0.9rem; }
.sb-ueber-uns-cards { display: grid; grid-template-columns: 1fr 1fr; gap: 1.5rem; }
.sb-ueber-uns-card { background: var(--off-white); border: 1.5px solid var(--border); border-radius: 14px; padding: 2rem; }
.sb-ueber-uns-card-icon { font-size: 2rem; margin-bottom: 0.85rem; }
.sb-ueber-uns-card h3 { font-family: 'Lora', serif; font-size: 1.05rem; font-weight: 700; margin-bottom: 0.6rem; color: var(--text-dark); }
.sb-ueber-uns-card p { font-size: 0.88rem; color: var(--text-light); line-height: 1.7; }

/* ============================================================
   BOTTOM BANNER (grünes Design)
   ============================================================ */
.sb-bottom-banner { background: var(--green-deep); position: relative; overflow: hidden; }
.sb-bottom-banner::before { content: ''; position: absolute; top: -80px; right: -80px; width: 320px; height: 320px; border-radius: 50%; background: rgba(255,255,255,0.04); }
.sb-bottom-banner::after { content: ''; position: absolute; bottom: -60px; left: -60px; width: 240px; height: 240px; border-radius: 50%; background: rgba(255,255,255,0.03); }
.sb-bottom-banner-inner { max-width: 1240px; margin: 0 auto; padding: 4rem 2.5rem; position: relative; z-index: 1; display: grid; grid-template-columns: 1fr auto; gap: 3rem; align-items: center; }
.sb-bottom-banner-content h2 { font-family: 'Lora', serif; color: white; font-size: 2rem; font-weight: 700; margin-bottom: 0.6rem; }
.sb-bottom-banner-content p { color: rgba(255,255,255,0.65); font-size: 0.9rem; line-height: 1.6; max-width: 480px; }
.sb-bottom-banner-content .sb-section-label { color: rgba(255,255,255,0.5) !important; margin-bottom: 0.5rem; }
.sb-bottom-banner-actions { display: flex; flex-direction: column; gap: 0.75rem; min-width: 200px; }
.sb-btn-white { background: white; color: var(--green-deep) !important; border: 2px solid white; border-radius: 8px; padding: 0.75rem 1.5rem; font-weight: 700; font-size: 0.88rem; text-align: center; text-decoration: none; transition: all 0.2s; }
.sb-btn-white:hover { background: var(--green-pale); border-color: var(--green-pale); }
.sb-btn-outline-white { background: transparent; color: white !important; border: 2px solid rgba(255,255,255,0.4); border-radius: 8px; padding: 0.75rem 1.5rem; font-weight: 600; font-size: 0.88rem; text-align: center; text-decoration: none; transition: all 0.2s; }
.sb-btn-outline-white:hover { border-color: white; background: rgba(255,255,255,0.08); }
.sb-bottom-banner-pills { grid-column: 1 / -1; display: flex; flex-wrap: wrap; gap: 0.85rem; padding-top: 2rem; border-top: 1px solid rgba(255,255,255,0.1); margin-top: 0.5rem; }
.sb-bottom-banner-pills span { color: rgba(255,255,255,0.7); font-size: 0.82rem; display: flex; align-items: center; gap: 0.4rem; }
.sb-bottom-banner-pills span::after { content: '·'; margin-left: 0.45rem; color: rgba(255,255,255,0.25); }
.sb-bottom-banner-pills span:last-child::after { display: none; }
@media (max-width: 768px) {
  .sb-bottom-banner-inner { grid-template-columns: 1fr; gap: 2rem; }
  .sb-bottom-banner-content h2 { font-size: 1.5rem; }
  .sb-bottom-banner-actions { flex-direction: row; flex-wrap: wrap; }
  .sb-ueber-uns-cards { grid-template-columns: 1fr; }
  .sb-catbar-inner { overflow-x: auto; flex-wrap: nowrap; }
}

/* ============================================================
   FOOTER
   ============================================================ */
.sb-footer { background: #0D1F12; color: rgba(255,255,255,0.7); }
.sb-footer-inner { max-width: 1240px; margin: 0 auto; padding: 0 2.5rem; }

.sb-footer-top {
  display: grid;
  grid-template-columns: 1.6fr 1fr 1.2fr;
  gap: 3rem;
  padding: 3.5rem 0 2.5rem;
  border-bottom: 1px solid rgba(255,255,255,0.08);
}

/* Brand */
.sb-footer-logo img { height: 52px; width: auto; object-fit: contain; margin-bottom: 1rem; display: block; border-radius: 4px; }
.sb-footer-brand-text { font-size: 0.8rem; line-height: 1.7; color: rgba(255,255,255,0.45); margin-top: 0.75rem; }

/* Cols */
.sb-footer-col h4 { font-family: 'Outfit', sans-serif; font-size: 0.7rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.12em; color: rgba(255,255,255,0.9); margin-bottom: 0.85rem; }
.sb-footer-col a { display: block; font-size: 0.825rem; color: rgba(255,255,255,0.5); text-decoration: none; margin-bottom: 0.5rem; transition: color 0.15s; }
.sb-footer-col a:hover { color: #7FC47A; }

/* Partner & Payment Logos */
.sb-footer-badges { display: flex; flex-direction: column; gap: 0.5rem; margin-bottom: 0.25rem; }
.sb-footer-partner-logo { height: 40px; width: auto; object-fit: contain; max-width: 160px; }
.sb-footer-payment-badge {
  display: inline-flex; align-items: center; gap: 0.4rem;
  background: white; color: #1a1a1a;
  font-size: 0.75rem; font-weight: 700; letter-spacing: 0.05em;
  padding: 5px 12px; border-radius: 5px; width: fit-content;
}
.sb-footer-twint { font-size: 0.82rem; font-weight: 700; letter-spacing: 0; }

/* Bottom Bar */
.sb-footer-bottom { display: flex; justify-content: space-between; align-items: center; padding: 1.1rem 0; font-size: 0.775rem; color: rgba(255,255,255,0.3); }

/* Responsive */
@media (max-width: 960px) {
  .sb-footer-top { grid-template-columns: 1fr 1fr; gap: 2rem; }
}
@media (max-width: 640px) {
  .sb-footer-top { grid-template-columns: 1fr; }
  .sb-footer-bottom { flex-direction: column; gap: 0.4rem; text-align: center; }
}


/* ============================================================
   KATEGORIELEISTE (Virima-Stil)
   ============================================================ */
.sb-catbar-bg { background: var(--white); border-top: 1px solid var(--border); border-bottom: 1px solid var(--border); padding: 0; }
.sb-catbar-inner { display: flex; align-items: center; gap: 0; padding: 0; flex-wrap: wrap; min-height: 48px; }
.sb-catbar-label { font-size: 0.68rem; font-weight: 700; letter-spacing: 0.12em; text-transform: uppercase; color: var(--text-light); padding: 0 1.25rem; border-right: 1px solid var(--border); height: 48px; display: flex; align-items: center; white-space: nowrap; }
.sb-catbar-groups { display: flex; align-items: center; flex-wrap: wrap; gap: 0; flex: 1; }
.sb-catbar-group { position: relative; }
.sb-catbar-toggle { background: none; border: none; border-right: 1px solid var(--border); padding: 0 1.1rem; height: 48px; font-family: 'Outfit', sans-serif; font-size: 0.82rem; font-weight: 500; color: var(--text-mid); cursor: pointer; display: flex; align-items: center; gap: 0.35rem; transition: all 0.15s; white-space: nowrap; }
.sb-catbar-toggle:hover, .sb-catbar-group:hover .sb-catbar-toggle { background: var(--green-pale); color: var(--green-deep); }
.sb-catbar-toggle span { font-size: 0.7rem; transition: transform 0.2s; }
.sb-catbar-group:hover .sb-catbar-toggle span { transform: rotate(180deg); }
.sb-catbar-dropdown { position: absolute; top: 100%; left: 0; background: var(--white); border: 1px solid var(--border); border-top: 2px solid var(--green-deep); border-radius: 0 0 10px 10px; box-shadow: 0 8px 24px rgba(0,0,0,0.1); min-width: 220px; opacity: 0; visibility: hidden; pointer-events: none; transition: opacity 0.15s; z-index: 200; }
.sb-catbar-group:hover .sb-catbar-dropdown { opacity: 1; visibility: visible; pointer-events: all; }
.sb-catbar-dropdown a { display: block; padding: 0.65rem 1.1rem; font-size: 0.82rem; color: var(--text-mid); text-decoration: none; transition: all 0.12s; border-bottom: 1px solid var(--off-white); }
.sb-catbar-dropdown a:last-child { border-bottom: none; }
.sb-catbar-dropdown a:hover { background: var(--green-pale); color: var(--green-deep); padding-left: 1.4rem; }
.sb-catbar-link { display: flex; align-items: center; height: 48px; padding: 0 1.1rem; font-size: 0.82rem; font-weight: 500; color: var(--text-mid); text-decoration: none; border-right: 1px solid var(--border); transition: all 0.15s; white-space: nowrap; }
.sb-catbar-link:hover { background: var(--green-pale); color: var(--green-deep); }
.sb-catbar-showall { margin-left: auto; display: flex; align-items: center; height: 48px; padding: 0 1.25rem; font-size: 0.79rem; font-weight: 600; color: var(--green-deep); text-decoration: none; border-left: 1px solid var(--border); transition: all 0.15s; white-space: nowrap; }
.sb-catbar-showall:hover { background: var(--green-pale); }

/* ============================================================
   WOOCOMMERCE – SHOP / ARCHIV
   ============================================================ */
.sb-page-header { background: var(--off-white); border-bottom: 1px solid var(--border); padding: 2.5rem 0 1.5rem; }
.sb-page-header-sm { padding: 2rem 0 1.5rem; }
.sb-page-header-inner { display: flex; justify-content: space-between; align-items: flex-end; flex-wrap: wrap; gap: 1rem; padding-bottom: 1.25rem; }
.sb-page-title { font-family: 'Lora', serif; font-size: clamp(1.6rem, 2.5vw, 2.2rem); font-weight: 700; color: var(--text-dark); display: flex; align-items: baseline; gap: 0.75rem; }
.sb-page-subtitle { font-size: 0.9rem; color: var(--text-light); margin-top: 0.4rem; }
.sb-shop-toolbar select { border: 1.5px solid var(--border); border-radius: 8px; padding: 0.5rem 0.8rem; font-family: 'Outfit', sans-serif; font-size: 0.85rem; color: var(--text-mid); background: white; }

/* Kategorien Filter Bar */
.sb-cat-filter { display: flex; gap: 0.5rem; flex-wrap: wrap; padding: 1rem 0; border-top: 1px solid var(--border); margin-top: 0.5rem; overflow-x: auto; }
.sb-cat-filter-item { padding: 0.4rem 1rem; border-radius: 20px; font-size: 0.82rem; font-weight: 500; color: var(--text-mid); border: 1.5px solid var(--border); text-decoration: none; white-space: nowrap; transition: all 0.15s; background: white; }
.sb-cat-filter-item:hover { border-color: var(--green-light); color: var(--green-deep); }
.sb-cat-filter-item.active { background: var(--green-deep); color: white; border-color: var(--green-deep); }

/* Shop Produkte Grid */
.sb-shop-wrap { padding: 2.5rem 0 4rem; }
.woocommerce-loop-product__link { display: contents; }
ul.products { list-style: none; padding: 0; margin: 0; display: grid; grid-template-columns: repeat(auto-fill, minmax(235px, 1fr)); gap: 1.1rem; }
ul.products li.product { margin: 0 !important; padding: 0 !important; }
ul.products li.product a { display: contents; }

/* Verstecke WooCommerce Standard-Elemente die wir selbst rendern */
.woocommerce-result-count { display: none; }
/* Alle WC Standard-Elemente die wir nicht wollen */
.woocommerce-products-header { display: none; }
.woocommerce-breadcrumb { display: none !important; }
.woocommerce .woocommerce-product-details__short-description + .product_meta { display: none; }
/* Kategorie-Linkliste oben im Shop verstecken */
.woocommerce-loop-product__title { display: none; }
.woocommerce .products .product > a.woocommerce-loop-product__link:first-child { display: none; }
.woocommerce-ordering { margin: 0; }

/* Empty state */
.sb-empty-shop { text-align: center; padding: 5rem 1rem; }
.sb-empty-icon { font-size: 3rem; margin-bottom: 1rem; }
.sb-empty-shop h3 { font-family: 'Lora', serif; font-size: 1.4rem; margin-bottom: 0.5rem; }
.sb-empty-shop p { color: var(--text-light); margin-bottom: 1.5rem; }

/* Produkt Badge Varianten */
.sb-product-badge-new { background: var(--gold) !important; }
.sb-product-badge-out { background: #888 !important; }
.sb-product-no-img { display: flex; align-items: center; justify-content: center; font-size: 3rem; width: 100%; height: 100%; }

/* Pagination */
.sb-pagination { margin-top: 2.5rem; text-align: center; }
.sb-pagination .page-numbers { display: inline-flex; gap: 0.4rem; list-style: none; padding: 0; }
.woocommerce-pagination ul { list-style: none; padding: 0; display: inline-flex; gap: 0.4rem; }
.woocommerce-pagination ul li a,
.woocommerce-pagination ul li span { display: inline-flex; align-items: center; justify-content: center; width: 38px; height: 38px; border-radius: 8px; border: 1.5px solid var(--border); font-size: 0.875rem; font-weight: 500; color: var(--text-mid); text-decoration: none; transition: all 0.15s; }
.woocommerce-pagination ul li a:hover { border-color: var(--green-deep); color: var(--green-deep); }
.woocommerce-pagination ul li span.current { background: var(--green-deep); color: white; border-color: var(--green-deep); }


/* ============================================================
   KATEGORIELEISTE (Virima-Stil)
   ============================================================ */
.sb-catbar-bg { background: var(--white); border-top: 1px solid var(--border); border-bottom: 1px solid var(--border); padding: 0; }
.sb-catbar-inner { display: flex; align-items: center; gap: 0; padding: 0; flex-wrap: wrap; min-height: 48px; }
.sb-catbar-label { font-size: 0.68rem; font-weight: 700; letter-spacing: 0.12em; text-transform: uppercase; color: var(--text-light); padding: 0 1.25rem; border-right: 1px solid var(--border); height: 48px; display: flex; align-items: center; white-space: nowrap; }
.sb-catbar-groups { display: flex; align-items: center; flex-wrap: wrap; gap: 0; flex: 1; }
.sb-catbar-group { position: relative; }
.sb-catbar-toggle { background: none; border: none; border-right: 1px solid var(--border); padding: 0 1.1rem; height: 48px; font-family: 'Outfit', sans-serif; font-size: 0.82rem; font-weight: 500; color: var(--text-mid); cursor: pointer; display: flex; align-items: center; gap: 0.35rem; transition: all 0.15s; white-space: nowrap; }
.sb-catbar-toggle:hover, .sb-catbar-group:hover .sb-catbar-toggle { background: var(--green-pale); color: var(--green-deep); }
.sb-catbar-toggle span { font-size: 0.7rem; transition: transform 0.2s; }
.sb-catbar-group:hover .sb-catbar-toggle span { transform: rotate(180deg); }
.sb-catbar-dropdown { position: absolute; top: 100%; left: 0; background: var(--white); border: 1px solid var(--border); border-top: 2px solid var(--green-deep); border-radius: 0 0 10px 10px; box-shadow: 0 8px 24px rgba(0,0,0,0.1); min-width: 220px; opacity: 0; visibility: hidden; pointer-events: none; transition: opacity 0.15s; z-index: 200; }
.sb-catbar-group:hover .sb-catbar-dropdown { opacity: 1; visibility: visible; pointer-events: all; }
.sb-catbar-dropdown a { display: block; padding: 0.65rem 1.1rem; font-size: 0.82rem; color: var(--text-mid); text-decoration: none; transition: all 0.12s; border-bottom: 1px solid var(--off-white); }
.sb-catbar-dropdown a:last-child { border-bottom: none; }
.sb-catbar-dropdown a:hover { background: var(--green-pale); color: var(--green-deep); padding-left: 1.4rem; }
.sb-catbar-link { display: flex; align-items: center; height: 48px; padding: 0 1.1rem; font-size: 0.82rem; font-weight: 500; color: var(--text-mid); text-decoration: none; border-right: 1px solid var(--border); transition: all 0.15s; white-space: nowrap; }
.sb-catbar-link:hover { background: var(--green-pale); color: var(--green-deep); }
.sb-catbar-showall { margin-left: auto; display: flex; align-items: center; height: 48px; padding: 0 1.25rem; font-size: 0.79rem; font-weight: 600; color: var(--green-deep); text-decoration: none; border-left: 1px solid var(--border); transition: all 0.15s; white-space: nowrap; }
.sb-catbar-showall:hover { background: var(--green-pale); }

/* ============================================================
   WOOCOMMERCE – CHECKOUT
   ============================================================ */
.sb-checkout-wrap { padding: 2.5rem 0 5rem; max-width: 960px; }

/* WooCommerce Checkout Felder stylen */
.woocommerce-checkout .woocommerce-billing-fields h3,
.woocommerce-checkout .woocommerce-shipping-fields h3,
.woocommerce-checkout h3#order_review_heading { font-family: 'Lora', serif; font-size: 1.1rem; font-weight: 700; color: var(--text-dark); margin-bottom: 1rem; padding-bottom: 0.5rem; border-bottom: 1px solid var(--border); }
.woocommerce form .form-row label { font-size: 0.82rem; font-weight: 600; color: var(--text-mid); margin-bottom: 0.3rem; display: block; }
.woocommerce form .form-row input.input-text,
.woocommerce form .form-row textarea,
.woocommerce form .form-row select { border: 1.5px solid var(--border) !important; border-radius: 8px !important; padding: 0.6rem 0.8rem !important; font-family: 'Outfit', sans-serif !important; font-size: 0.875rem !important; width: 100%; transition: border-color 0.2s; }
.woocommerce form .form-row input.input-text:focus,
.woocommerce form .form-row textarea:focus,
.woocommerce form .form-row select:focus { border-color: var(--green-deep) !important; outline: none !important; box-shadow: none !important; }
#place_order { background: var(--green-deep) !important; color: white !important; border: none !important; border-radius: 8px !important; padding: 0.9rem 2rem !important; font-size: 1rem !important; font-weight: 600 !important; font-family: 'Outfit', sans-serif !important; cursor: pointer; transition: background 0.2s !important; width: 100%; }
#place_order:hover { background: var(--green-mid) !important; }
.woocommerce-checkout #payment { background: var(--off-white) !important; border-radius: 12px !important; border: 1.5px solid var(--border) !important; }
.woocommerce-checkout #payment ul.payment_methods { border-bottom: 1px solid var(--border) !important; }
.woocommerce-checkout #payment div.payment_box { background: white !important; border-radius: 8px !important; }
.woocommerce-checkout-review-order-table { width: 100%; border-collapse: collapse; font-size: 0.875rem; }
.woocommerce-checkout-review-order-table th,
.woocommerce-checkout-review-order-table td { padding: 0.6rem 0.75rem; border-bottom: 1px solid var(--border); }
.woocommerce-checkout-review-order-table tfoot tr:last-child td,
.woocommerce-checkout-review-order-table tfoot tr:last-child th { font-weight: 700; font-size: 1rem; color: var(--green-deep); border-top: 2px solid var(--border); }


/* ============================================================
   KATEGORIELEISTE (Virima-Stil)
   ============================================================ */
.sb-catbar-bg { background: var(--white); border-top: 1px solid var(--border); border-bottom: 1px solid var(--border); padding: 0; }
.sb-catbar-inner { display: flex; align-items: center; gap: 0; padding: 0; flex-wrap: wrap; min-height: 48px; }
.sb-catbar-label { font-size: 0.68rem; font-weight: 700; letter-spacing: 0.12em; text-transform: uppercase; color: var(--text-light); padding: 0 1.25rem; border-right: 1px solid var(--border); height: 48px; display: flex; align-items: center; white-space: nowrap; }
.sb-catbar-groups { display: flex; align-items: center; flex-wrap: wrap; gap: 0; flex: 1; }
.sb-catbar-group { position: relative; }
.sb-catbar-toggle { background: none; border: none; border-right: 1px solid var(--border); padding: 0 1.1rem; height: 48px; font-family: 'Outfit', sans-serif; font-size: 0.82rem; font-weight: 500; color: var(--text-mid); cursor: pointer; display: flex; align-items: center; gap: 0.35rem; transition: all 0.15s; white-space: nowrap; }
.sb-catbar-toggle:hover, .sb-catbar-group:hover .sb-catbar-toggle { background: var(--green-pale); color: var(--green-deep); }
.sb-catbar-toggle span { font-size: 0.7rem; transition: transform 0.2s; }
.sb-catbar-group:hover .sb-catbar-toggle span { transform: rotate(180deg); }
.sb-catbar-dropdown { position: absolute; top: 100%; left: 0; background: var(--white); border: 1px solid var(--border); border-top: 2px solid var(--green-deep); border-radius: 0 0 10px 10px; box-shadow: 0 8px 24px rgba(0,0,0,0.1); min-width: 220px; opacity: 0; visibility: hidden; pointer-events: none; transition: opacity 0.15s; z-index: 200; }
.sb-catbar-group:hover .sb-catbar-dropdown { opacity: 1; visibility: visible; pointer-events: all; }
.sb-catbar-dropdown a { display: block; padding: 0.65rem 1.1rem; font-size: 0.82rem; color: var(--text-mid); text-decoration: none; transition: all 0.12s; border-bottom: 1px solid var(--off-white); }
.sb-catbar-dropdown a:last-child { border-bottom: none; }
.sb-catbar-dropdown a:hover { background: var(--green-pale); color: var(--green-deep); padding-left: 1.4rem; }
.sb-catbar-link { display: flex; align-items: center; height: 48px; padding: 0 1.1rem; font-size: 0.82rem; font-weight: 500; color: var(--text-mid); text-decoration: none; border-right: 1px solid var(--border); transition: all 0.15s; white-space: nowrap; }
.sb-catbar-link:hover { background: var(--green-pale); color: var(--green-deep); }
.sb-catbar-showall { margin-left: auto; display: flex; align-items: center; height: 48px; padding: 0 1.25rem; font-size: 0.79rem; font-weight: 600; color: var(--green-deep); text-decoration: none; border-left: 1px solid var(--border); transition: all 0.15s; white-space: nowrap; }
.sb-catbar-showall:hover { background: var(--green-pale); }

/* ============================================================
   WOOCOMMERCE – MEIN KONTO
   ============================================================ */
.sb-myaccount-wrap { padding: 2.5rem 0 5rem; }
.woocommerce-MyAccount-navigation { float: left; width: 220px; }
.woocommerce-MyAccount-navigation ul { list-style: none; padding: 0; background: white; border: 1.5px solid var(--border); border-radius: 12px; overflow: hidden; }
.woocommerce-MyAccount-navigation ul li a { display: block; padding: 0.75rem 1.1rem; font-size: 0.875rem; font-weight: 500; color: var(--text-mid); text-decoration: none; border-bottom: 1px solid var(--border); transition: all 0.15s; }
.woocommerce-MyAccount-navigation ul li:last-child a { border-bottom: none; }
.woocommerce-MyAccount-navigation ul li a:hover,
.woocommerce-MyAccount-navigation ul li.is-active a { background: var(--green-pale); color: var(--green-deep); }
.woocommerce-MyAccount-content { float: right; width: calc(100% - 260px); }
.woocommerce-MyAccount-content h2 { font-family: 'Lora', serif; font-size: 1.2rem; font-weight: 700; margin-bottom: 1rem; }
.woocommerce-orders-table { width: 100%; border-collapse: collapse; font-size: 0.875rem; }
.woocommerce-orders-table th { background: var(--off-white); padding: 0.6rem 0.75rem; text-align: left; font-weight: 600; font-size: 0.78rem; text-transform: uppercase; letter-spacing: 0.05em; color: var(--text-mid); border-bottom: 1px solid var(--border); }
.woocommerce-orders-table td { padding: 0.75rem; border-bottom: 1px solid var(--border); color: var(--text-mid); }
.woocommerce-orders-table .button { background: var(--green-deep); color: white; padding: 0.3rem 0.8rem; border-radius: 6px; font-size: 0.8rem; font-weight: 500; text-decoration: none; transition: background 0.2s; }
.woocommerce-orders-table .button:hover { background: var(--green-mid); }


/* ============================================================
   KATEGORIELEISTE (Virima-Stil)
   ============================================================ */
.sb-catbar-bg { background: var(--white); border-top: 1px solid var(--border); border-bottom: 1px solid var(--border); padding: 0; }
.sb-catbar-inner { display: flex; align-items: center; gap: 0; padding: 0; flex-wrap: wrap; min-height: 48px; }
.sb-catbar-label { font-size: 0.68rem; font-weight: 700; letter-spacing: 0.12em; text-transform: uppercase; color: var(--text-light); padding: 0 1.25rem; border-right: 1px solid var(--border); height: 48px; display: flex; align-items: center; white-space: nowrap; }
.sb-catbar-groups { display: flex; align-items: center; flex-wrap: wrap; gap: 0; flex: 1; }
.sb-catbar-group { position: relative; }
.sb-catbar-toggle { background: none; border: none; border-right: 1px solid var(--border); padding: 0 1.1rem; height: 48px; font-family: 'Outfit', sans-serif; font-size: 0.82rem; font-weight: 500; color: var(--text-mid); cursor: pointer; display: flex; align-items: center; gap: 0.35rem; transition: all 0.15s; white-space: nowrap; }
.sb-catbar-toggle:hover, .sb-catbar-group:hover .sb-catbar-toggle { background: var(--green-pale); color: var(--green-deep); }
.sb-catbar-toggle span { font-size: 0.7rem; transition: transform 0.2s; }
.sb-catbar-group:hover .sb-catbar-toggle span { transform: rotate(180deg); }
.sb-catbar-dropdown { position: absolute; top: 100%; left: 0; background: var(--white); border: 1px solid var(--border); border-top: 2px solid var(--green-deep); border-radius: 0 0 10px 10px; box-shadow: 0 8px 24px rgba(0,0,0,0.1); min-width: 220px; opacity: 0; visibility: hidden; pointer-events: none; transition: opacity 0.15s; z-index: 200; }
.sb-catbar-group:hover .sb-catbar-dropdown { opacity: 1; visibility: visible; pointer-events: all; }
.sb-catbar-dropdown a { display: block; padding: 0.65rem 1.1rem; font-size: 0.82rem; color: var(--text-mid); text-decoration: none; transition: all 0.12s; border-bottom: 1px solid var(--off-white); }
.sb-catbar-dropdown a:last-child { border-bottom: none; }
.sb-catbar-dropdown a:hover { background: var(--green-pale); color: var(--green-deep); padding-left: 1.4rem; }
.sb-catbar-link { display: flex; align-items: center; height: 48px; padding: 0 1.1rem; font-size: 0.82rem; font-weight: 500; color: var(--text-mid); text-decoration: none; border-right: 1px solid var(--border); transition: all 0.15s; white-space: nowrap; }
.sb-catbar-link:hover { background: var(--green-pale); color: var(--green-deep); }
.sb-catbar-showall { margin-left: auto; display: flex; align-items: center; height: 48px; padding: 0 1.25rem; font-size: 0.79rem; font-weight: 600; color: var(--green-deep); text-decoration: none; border-left: 1px solid var(--border); transition: all 0.15s; white-space: nowrap; }
.sb-catbar-showall:hover { background: var(--green-pale); }

/* ============================================================
   WOOCOMMERCE – NOTICES / MELDUNGEN
   ============================================================ */
.woocommerce-message,
.woocommerce-info,
.woocommerce-error { border-radius: 8px !important; border-left: 4px solid var(--green-deep) !important; background: var(--green-pale) !important; color: var(--green-deep) !important; padding: 0.85rem 1rem 0.85rem 1.4rem !important; margin-bottom: 1.25rem !important; font-size: 0.875rem !important; list-style: none !important; }
.woocommerce-message::before, .woocommerce-info::before { margin-right: 0.5rem; }
.woocommerce-error { border-left-color: #DC2626 !important; background: #FEE2E2 !important; color: #DC2626 !important; }
.woocommerce-message .button,
.woocommerce-info .button { background: var(--green-deep); color: white; padding: 0.35rem 0.9rem; border-radius: 6px; font-size: 0.8rem; font-weight: 600; text-decoration: none; float: right; margin-top: -0.2rem; }

/* Warenkorb Icon in Nav */
.sb-nav-cart { position: relative; display: flex; align-items: center; gap: 0.4rem; text-decoration: none; color: var(--text-mid); font-size: 0.82rem; font-weight: 500; padding: 0.45rem 0.85rem; border: 1.5px solid var(--border); border-radius: 6px; transition: all 0.2s; white-space: nowrap; }
.sb-nav-cart:hover { border-color: var(--green-deep); color: var(--green-deep); }
.sb-nav-cart-count { background: var(--green-deep); color: white; font-size: 0.65rem; font-weight: 700; width: 18px; height: 18px; border-radius: 50%; display: flex; align-items: center; justify-content: center; position: absolute; top: -6px; right: -6px; }

/* ============================================================
   RESPONSIVE WOOCOMMERCE
   ============================================================ */
@media (max-width: 960px) {
  .sb-cart-grid { grid-template-columns: 1fr; }
  .sb-cart-summary { position: static; }
  .sb-cart-header-row { display: none; }
  .sb-cart-item { grid-template-columns: 1fr 1fr; grid-template-rows: auto auto; gap: 0.75rem; }
  .sb-cart-item-info { grid-column: 1 / -1; }
  .woocommerce-MyAccount-navigation { float: none; width: 100%; margin-bottom: 1.5rem; }
  .woocommerce-MyAccount-content { float: none; width: 100%; }
}
@media (max-width: 640px) {
  .sb-cat-filter { gap: 0.35rem; }
  .sb-cart-item { grid-template-columns: 1fr; }
  ul.products { grid-template-columns: repeat(2, 1fr); gap: 0.65rem; }
}


/* ============================================================
   KATEGORIELEISTE (Virima-Stil)
   ============================================================ */
.sb-catbar-bg { background: var(--white); border-top: 1px solid var(--border); border-bottom: 1px solid var(--border); padding: 0; }
.sb-catbar-inner { display: flex; align-items: center; gap: 0; padding: 0; flex-wrap: wrap; min-height: 48px; }
.sb-catbar-label { font-size: 0.68rem; font-weight: 700; letter-spacing: 0.12em; text-transform: uppercase; color: var(--text-light); padding: 0 1.25rem; border-right: 1px solid var(--border); height: 48px; display: flex; align-items: center; white-space: nowrap; }
.sb-catbar-groups { display: flex; align-items: center; flex-wrap: wrap; gap: 0; flex: 1; }
.sb-catbar-group { position: relative; }
.sb-catbar-toggle { background: none; border: none; border-right: 1px solid var(--border); padding: 0 1.1rem; height: 48px; font-family: 'Outfit', sans-serif; font-size: 0.82rem; font-weight: 500; color: var(--text-mid); cursor: pointer; display: flex; align-items: center; gap: 0.35rem; transition: all 0.15s; white-space: nowrap; }
.sb-catbar-toggle:hover, .sb-catbar-group:hover .sb-catbar-toggle { background: var(--green-pale); color: var(--green-deep); }
.sb-catbar-toggle span { font-size: 0.7rem; transition: transform 0.2s; }
.sb-catbar-group:hover .sb-catbar-toggle span { transform: rotate(180deg); }
.sb-catbar-dropdown { position: absolute; top: 100%; left: 0; background: var(--white); border: 1px solid var(--border); border-top: 2px solid var(--green-deep); border-radius: 0 0 10px 10px; box-shadow: 0 8px 24px rgba(0,0,0,0.1); min-width: 220px; opacity: 0; visibility: hidden; pointer-events: none; transition: opacity 0.15s; z-index: 200; }
.sb-catbar-group:hover .sb-catbar-dropdown { opacity: 1; visibility: visible; pointer-events: all; }
.sb-catbar-dropdown a { display: block; padding: 0.65rem 1.1rem; font-size: 0.82rem; color: var(--text-mid); text-decoration: none; transition: all 0.12s; border-bottom: 1px solid var(--off-white); }
.sb-catbar-dropdown a:last-child { border-bottom: none; }
.sb-catbar-dropdown a:hover { background: var(--green-pale); color: var(--green-deep); padding-left: 1.4rem; }
.sb-catbar-link { display: flex; align-items: center; height: 48px; padding: 0 1.1rem; font-size: 0.82rem; font-weight: 500; color: var(--text-mid); text-decoration: none; border-right: 1px solid var(--border); transition: all 0.15s; white-space: nowrap; }
.sb-catbar-link:hover { background: var(--green-pale); color: var(--green-deep); }
.sb-catbar-showall { margin-left: auto; display: flex; align-items: center; height: 48px; padding: 0 1.25rem; font-size: 0.79rem; font-weight: 600; color: var(--green-deep); text-decoration: none; border-left: 1px solid var(--border); transition: all 0.15s; white-space: nowrap; }
.sb-catbar-showall:hover { background: var(--green-pale); }

/* ============================================================
   WOOCOMMERCE – MEIN KONTO
   ============================================================ */
.sb-myaccount-wrap { padding: 2.5rem 0 5rem; }
.woocommerce-MyAccount-navigation { float: left; width: 220px; }
.woocommerce-MyAccount-navigation ul { list-style: none; padding: 0; background: white; border: 1.5px solid var(--border); border-radius: 12px; overflow: hidden; }
.woocommerce-MyAccount-navigation ul li a { display: block; padding: 0.75rem 1.1rem; font-size: 0.875rem; font-weight: 500; color: var(--text-mid); text-decoration: none; border-bottom: 1px solid var(--border); transition: all 0.15s; }
.woocommerce-MyAccount-navigation ul li:last-child a { border-bottom: none; }
.woocommerce-MyAccount-navigation ul li a:hover,
.woocommerce-MyAccount-navigation ul li.is-active a { background: var(--green-pale); color: var(--green-deep); }
.woocommerce-MyAccount-content { float: right; width: calc(100% - 260px); }
.woocommerce-MyAccount-content h2 { font-family: 'Lora', serif; font-size: 1.2rem; font-weight: 700; margin-bottom: 1rem; }
.woocommerce-orders-table { width: 100%; border-collapse: collapse; font-size: 0.875rem; }
.woocommerce-orders-table th { background: var(--off-white); padding: 0.6rem 0.75rem; text-align: left; font-weight: 600; font-size: 0.78rem; text-transform: uppercase; letter-spacing: 0.05em; color: var(--text-mid); border-bottom: 1px solid var(--border); }
.woocommerce-orders-table td { padding: 0.75rem; border-bottom: 1px solid var(--border); color: var(--text-mid); }
.woocommerce-orders-table .button { background: var(--green-deep); color: white; padding: 0.3rem 0.8rem; border-radius: 6px; font-size: 0.8rem; font-weight: 500; text-decoration: none; transition: background 0.2s; }
.woocommerce-orders-table .button:hover { background: var(--green-mid); }


/* ============================================================
   KATEGORIELEISTE (Virima-Stil)
   ============================================================ */
.sb-catbar-bg { background: var(--white); border-top: 1px solid var(--border); border-bottom: 1px solid var(--border); padding: 0; }
.sb-catbar-inner { display: flex; align-items: center; gap: 0; padding: 0; flex-wrap: wrap; min-height: 48px; }
.sb-catbar-label { font-size: 0.68rem; font-weight: 700; letter-spacing: 0.12em; text-transform: uppercase; color: var(--text-light); padding: 0 1.25rem; border-right: 1px solid var(--border); height: 48px; display: flex; align-items: center; white-space: nowrap; }
.sb-catbar-groups { display: flex; align-items: center; flex-wrap: wrap; gap: 0; flex: 1; }
.sb-catbar-group { position: relative; }
.sb-catbar-toggle { background: none; border: none; border-right: 1px solid var(--border); padding: 0 1.1rem; height: 48px; font-family: 'Outfit', sans-serif; font-size: 0.82rem; font-weight: 500; color: var(--text-mid); cursor: pointer; display: flex; align-items: center; gap: 0.35rem; transition: all 0.15s; white-space: nowrap; }
.sb-catbar-toggle:hover, .sb-catbar-group:hover .sb-catbar-toggle { background: var(--green-pale); color: var(--green-deep); }
.sb-catbar-toggle span { font-size: 0.7rem; transition: transform 0.2s; }
.sb-catbar-group:hover .sb-catbar-toggle span { transform: rotate(180deg); }
.sb-catbar-dropdown { position: absolute; top: 100%; left: 0; background: var(--white); border: 1px solid var(--border); border-top: 2px solid var(--green-deep); border-radius: 0 0 10px 10px; box-shadow: 0 8px 24px rgba(0,0,0,0.1); min-width: 220px; opacity: 0; visibility: hidden; pointer-events: none; transition: opacity 0.15s; z-index: 200; }
.sb-catbar-group:hover .sb-catbar-dropdown { opacity: 1; visibility: visible; pointer-events: all; }
.sb-catbar-dropdown a { display: block; padding: 0.65rem 1.1rem; font-size: 0.82rem; color: var(--text-mid); text-decoration: none; transition: all 0.12s; border-bottom: 1px solid var(--off-white); }
.sb-catbar-dropdown a:last-child { border-bottom: none; }
.sb-catbar-dropdown a:hover { background: var(--green-pale); color: var(--green-deep); padding-left: 1.4rem; }
.sb-catbar-link { display: flex; align-items: center; height: 48px; padding: 0 1.1rem; font-size: 0.82rem; font-weight: 500; color: var(--text-mid); text-decoration: none; border-right: 1px solid var(--border); transition: all 0.15s; white-space: nowrap; }
.sb-catbar-link:hover { background: var(--green-pale); color: var(--green-deep); }
.sb-catbar-showall { margin-left: auto; display: flex; align-items: center; height: 48px; padding: 0 1.25rem; font-size: 0.79rem; font-weight: 600; color: var(--green-deep); text-decoration: none; border-left: 1px solid var(--border); transition: all 0.15s; white-space: nowrap; }
.sb-catbar-showall:hover { background: var(--green-pale); }

/* ============================================================
   WOOCOMMERCE – NOTICES / MELDUNGEN
   ============================================================ */
.woocommerce-message,
.woocommerce-info,
.woocommerce-error { border-radius: 8px !important; border-left: 4px solid var(--green-deep) !important; background: var(--green-pale) !important; color: var(--green-deep) !important; padding: 0.85rem 1rem 0.85rem 1.4rem !important; margin-bottom: 1.25rem !important; font-size: 0.875rem !important; list-style: none !important; }
.woocommerce-message::before, .woocommerce-info::before { margin-right: 0.5rem; }
.woocommerce-error { border-left-color: #DC2626 !important; background: #FEE2E2 !important; color: #DC2626 !important; }
.woocommerce-message .button,
.woocommerce-info .button { background: var(--green-deep); color: white; padding: 0.35rem 0.9rem; border-radius: 6px; font-size: 0.8rem; font-weight: 600; text-decoration: none; float: right; margin-top: -0.2rem; }

/* Warenkorb Icon in Nav */
.sb-nav-cart { position: relative; display: flex; align-items: center; gap: 0.4rem; text-decoration: none; color: var(--text-mid); font-size: 0.82rem; font-weight: 500; padding: 0.45rem 0.85rem; border: 1.5px solid var(--border); border-radius: 6px; transition: all 0.2s; white-space: nowrap; }
.sb-nav-cart:hover { border-color: var(--green-deep); color: var(--green-deep); }
.sb-nav-cart-count { background: var(--green-deep); color: white; font-size: 0.65rem; font-weight: 700; width: 18px; height: 18px; border-radius: 50%; display: flex; align-items: center; justify-content: center; position: absolute; top: -6px; right: -6px; }

/* ============================================================
   RESPONSIVE WOOCOMMERCE
   ============================================================ */
@media (max-width: 960px) {
  .sb-cart-grid { grid-template-columns: 1fr; }
  .sb-cart-summary { position: static; }
  .sb-cart-header-row { display: none; }
  .sb-cart-item { grid-template-columns: 1fr 1fr; grid-template-rows: auto auto; gap: 0.75rem; }
  .sb-cart-item-info { grid-column: 1 / -1; }
  .woocommerce-MyAccount-navigation { float: none; width: 100%; margin-bottom: 1.5rem; }
  .woocommerce-MyAccount-content { float: none; width: 100%; }
}
@media (max-width: 640px) {
  .sb-cat-filter { gap: 0.35rem; }
  .sb-cart-item { grid-template-columns: 1fr; }
  ul.products { grid-template-columns: repeat(2, 1fr); gap: 0.65rem; }
}

/* ============================================================
   CHECKOUT – VOLLSTÄNDIGES STYLING
   ============================================================ */
.sb-checkout-wrap { padding: 2.5rem 0 5rem; }

.woocommerce-checkout .col2-set { display: grid; grid-template-columns: 1fr 1fr; gap: 2rem; margin-bottom: 2rem; }
.woocommerce-checkout .col2-set .col-1,
.woocommerce-checkout .col2-set .col-2 { float: none !important; width: 100% !important; }

/* Abschnitt-Boxen */
.woocommerce-checkout .woocommerce-billing-fields,
.woocommerce-checkout .woocommerce-shipping-fields,
.woocommerce-checkout #order_review_heading,
.woocommerce-checkout #payment { 
  background: white; 
  border: 1.5px solid var(--border); 
  border-radius: 12px; 
  padding: 1.75rem;
  margin-bottom: 1.5rem;
}

/* Section Titel */
.woocommerce-checkout h3 { 
  font-family: 'Lora', serif; 
  font-size: 1.05rem; 
  font-weight: 700; 
  color: var(--text-dark); 
  margin-bottom: 1.25rem !important; 
  padding-bottom: 0.75rem; 
  border-bottom: 1px solid var(--border); 
}

/* Formular-Felder */
.woocommerce-checkout .form-row { margin-bottom: 1rem !important; }
.woocommerce-checkout .form-row label { 
  font-size: 0.82rem !important; 
  font-weight: 600 !important; 
  color: var(--text-mid) !important; 
  margin-bottom: 0.3rem !important; 
  display: block !important; 
}
.woocommerce-checkout .form-row .required { color: var(--gold); }
.woocommerce-checkout input[type="text"],
.woocommerce-checkout input[type="email"],
.woocommerce-checkout input[type="tel"],
.woocommerce-checkout input[type="password"],
.woocommerce-checkout textarea,
.woocommerce-checkout select { 
  border: 1.5px solid var(--border) !important; 
  border-radius: 8px !important; 
  padding: 0.65rem 0.9rem !important; 
  font-family: 'Outfit', sans-serif !important; 
  font-size: 0.875rem !important; 
  color: var(--text-dark) !important;
  width: 100% !important; 
  transition: border-color 0.2s !important; 
  background: white !important;
  box-shadow: none !important;
}
.woocommerce-checkout input:focus,
.woocommerce-checkout textarea:focus,
.woocommerce-checkout select:focus { 
  border-color: var(--green-deep) !important; 
  outline: none !important; 
  box-shadow: 0 0 0 3px rgba(30,58,34,0.08) !important; 
}

/* Bestellübersicht rechts */
.woocommerce-checkout-review-order { }
#order_review { 
  background: white; 
  border: 1.5px solid var(--border); 
  border-radius: 12px; 
  padding: 1.75rem; 
}
.woocommerce-checkout-review-order-table { width: 100%; border-collapse: collapse; margin-bottom: 1rem; }
.woocommerce-checkout-review-order-table thead th { 
  font-size: 0.75rem; 
  font-weight: 600; 
  text-transform: uppercase; 
  letter-spacing: 0.08em; 
  color: var(--text-light); 
  padding: 0 0 0.75rem; 
  border-bottom: 1px solid var(--border); 
}
.woocommerce-checkout-review-order-table tbody td,
.woocommerce-checkout-review-order-table tfoot td,
.woocommerce-checkout-review-order-table tfoot th { 
  padding: 0.65rem 0; 
  border-bottom: 1px solid var(--border); 
  font-size: 0.875rem; 
  color: var(--text-mid); 
  vertical-align: middle;
}
.woocommerce-checkout-review-order-table tfoot .order-total td,
.woocommerce-checkout-review-order-table tfoot .order-total th { 
  font-weight: 700; 
  font-size: 1.05rem; 
  color: var(--green-deep); 
  border-top: 2px solid var(--border); 
  border-bottom: none; 
  padding-top: 0.85rem; 
}
.woocommerce-checkout-review-order-table .product-name { font-weight: 600; color: var(--text-dark); }
.woocommerce-checkout-review-order-table .product-total { text-align: right; font-weight: 600; color: var(--green-deep); }

/* Zahlungsmethoden */
#payment { background: var(--off-white) !important; }
#payment .payment_methods { list-style: none !important; padding: 0 !important; margin: 0 0 1.25rem !important; }
#payment .payment_methods li { 
  background: white; 
  border: 1.5px solid var(--border); 
  border-radius: 8px; 
  padding: 0.85rem 1rem !important; 
  margin-bottom: 0.5rem !important;
  transition: border-color 0.2s;
}
#payment .payment_methods li:has(input:checked) { border-color: var(--green-deep) !important; background: var(--green-pale); }
#payment .payment_methods li label { 
  font-weight: 600 !important; 
  font-size: 0.9rem !important; 
  color: var(--text-dark) !important; 
  cursor: pointer; 
  display: flex !important; 
  align-items: center; 
  gap: 0.5rem; 
}
#payment .payment_box { 
  background: var(--off-white) !important; 
  border-radius: 6px !important; 
  padding: 0.75rem !important; 
  margin-top: 0.5rem; 
  font-size: 0.84rem !important; 
  color: var(--text-light) !important; 
}

/* Bestellung aufgeben Button */
#place_order { 
  width: 100% !important; 
  background: var(--green-deep) !important; 
  color: white !important; 
  border: none !important; 
  border-radius: 8px !important; 
  padding: 1rem !important; 
  font-size: 1rem !important; 
  font-weight: 600 !important; 
  font-family: 'Outfit', sans-serif !important; 
  cursor: pointer !important; 
  transition: background 0.2s !important; 
  margin-top: 1rem !important;
  letter-spacing: 0.02em;
}
#place_order:hover { background: var(--green-mid) !important; }

/* Checkout Layout – Billing links, Order rechts */
.woocommerce-checkout form.checkout { display: grid; grid-template-columns: 1fr 420px; gap: 2rem; align-items: start; }
.woocommerce-checkout form.checkout .col2-set { grid-column: 1; }
.woocommerce-checkout form.checkout #order_review_heading { grid-column: 2; grid-row: 1; }
.woocommerce-checkout form.checkout #order_review { grid-column: 2; grid-row: 2; }

/* Bestellbestätigung */
.woocommerce-order { background: white; border: 1.5px solid var(--border); border-radius: 12px; padding: 2rem; }
.woocommerce-order .woocommerce-order-overview { list-style: none; padding: 0; display: grid; grid-template-columns: repeat(4, 1fr); gap: 1rem; margin-bottom: 2rem; }
.woocommerce-order .woocommerce-order-overview li { background: var(--off-white); border-radius: 8px; padding: 1rem; font-size: 0.85rem; }
.woocommerce-order .woocommerce-order-overview li strong { display: block; font-size: 0.95rem; color: var(--green-deep); }

/* Responsive Checkout */
@media (max-width: 960px) {
  .woocommerce-checkout form.checkout { grid-template-columns: 1fr; }
  .woocommerce-checkout form.checkout #order_review_heading,
  .woocommerce-checkout form.checkout #order_review { grid-column: 1; grid-row: auto; }
  .woocommerce-checkout .col2-set { grid-template-columns: 1fr; }
}

/* ============================================================
   NAV – WARENKORB KOMPAKT
   ============================================================ */
/* Nav-Actions Abstand reduzieren */
.sb-nav-actions { display: flex; gap: 0.5rem; align-items: center; }
.sb-nav-actions .sb-btn { padding: 0.45rem 1rem; font-size: 0.82rem; }


/* ============================================================
   WARENKORB – KOMPLETT NEU
   ============================================================ */
.sb-cart-title-count { font-family: 'Outfit', sans-serif; font-size: 0.8rem; font-weight: 600; color: var(--green-mid); background: var(--green-pale); border: 1px solid var(--green-light); padding: 0.2rem 0.65rem; border-radius: 20px; letter-spacing: 0.02em; }

.sb-cart-page { padding: 2.5rem 0 5rem; }

/* Leerer Warenkorb */
.sb-empty-cart { text-align: center; padding: 6rem 1rem; }
.sb-empty-cart-icon { font-size: 3.5rem; margin-bottom: 1rem; }
.sb-empty-cart h3 { font-family: 'Lora', serif; font-size: 1.4rem; margin-bottom: 0.5rem; }
.sb-empty-cart p { color: var(--text-light); margin-bottom: 1.75rem; }

/* Layout: 2 Spalten */
.sb-cart-layout { display: grid; grid-template-columns: 1fr 360px; gap: 2rem; align-items: start; }

/* ── LINKE SEITE ── */
.sb-cart-left { display: flex; flex-direction: column; gap: 0; }

/* Tabellen-Header */
.sb-cart-head { display: grid; grid-template-columns: 2.5fr 1fr 1.2fr 1fr 36px; gap: 1rem; padding: 0 1rem 0.6rem; font-size: 0.72rem; font-weight: 600; text-transform: uppercase; letter-spacing: 0.08em; color: var(--text-light); border-bottom: 2px solid var(--border); }

/* Produkt-Zeilen */
.sb-cart-rows { display: flex; flex-direction: column; gap: 0.5rem; margin-top: 0.5rem; }
.sb-cart-row { display: grid; grid-template-columns: 2.5fr 1fr 1.2fr 1fr 36px; gap: 1rem; align-items: center; padding: 1rem; background: white; border: 1.5px solid var(--border); border-radius: 10px; transition: border-color 0.2s; }
.sb-cart-row:hover { border-color: var(--green-light); }

/* Produkt-Info */
.sb-cart-product { display: flex; align-items: center; gap: 0.85rem; }
.sb-cart-img { width: 60px; height: 60px; flex-shrink: 0; border-radius: 8px; overflow: hidden; background: var(--off-white); display: flex; align-items: center; justify-content: center; }
.sb-cart-img img { width: 100%; height: 100%; object-fit: cover; }
.sb-cart-img-placeholder { font-size: 1.5rem; }
.sb-cart-product-name { font-size: 0.875rem; font-weight: 600; color: var(--text-dark); text-decoration: none; line-height: 1.4; display: block; }
.sb-cart-product-name:hover { color: var(--green-deep); }
.sb-cart-product-variants { font-size: 0.75rem; color: var(--text-light); margin-top: 0.2rem; }
.sb-cart-product-variants span { display: block; }

/* Preis */
.sb-cart-price { font-size: 0.875rem; color: var(--text-mid); font-weight: 500; }
.sb-cart-price .woocommerce-Price-amount { font-size: 0.875rem; }

/* Menge +/- */
.sb-qty-wrap { display: inline-flex; align-items: center; border: 1.5px solid var(--border); border-radius: 8px; overflow: hidden; background: white; }
.sb-qbtn { width: 32px; height: 34px; border: none; background: transparent; font-size: 1.1rem; cursor: pointer; color: var(--text-mid); transition: background 0.15s; font-family: 'Outfit', sans-serif; display: flex; align-items: center; justify-content: center; }
.sb-qbtn:hover { background: var(--off-white); color: var(--green-deep); }
.sb-qval { width: 34px; text-align: center; font-size: 0.9rem; font-weight: 600; color: var(--text-dark); }

/* Zeilensumme */
.sb-cart-subtotal { font-size: 0.95rem; font-weight: 700; color: var(--green-deep); }
.sb-cart-subtotal .woocommerce-Price-amount { font-size: 0.95rem; font-weight: 700; }

/* Entfernen */
.sb-cart-remove-btn { display: flex; align-items: center; justify-content: center; width: 28px; height: 28px; background: #FEE2E2; color: #DC2626; border-radius: 6px; text-decoration: none; transition: all 0.15s; }
.sb-cart-remove-btn:hover { background: #DC2626; color: white; }

/* Footer Aktionen */
.sb-cart-footer { display: flex; align-items: center; justify-content: space-between; margin-top: 1.25rem; flex-wrap: wrap; gap: 0.75rem; }
.sb-coupon-wrap { display: flex; gap: 0.5rem; }
.sb-coupon-input { border: 1.5px solid var(--border); border-radius: 8px; padding: 0.5rem 0.9rem; font-family: 'Outfit', sans-serif; font-size: 0.85rem; color: var(--text-mid); outline: none; transition: border-color 0.2s; width: 200px; }
.sb-coupon-input:focus { border-color: var(--green-deep); }

/* WooCommerce Coupon-Form verstecken (wir nutzen eigenes) */
.woocommerce-cart .coupon { display: none !important; }
.woocommerce-cart .actions { display: none !important; }
.woocommerce-cart table.cart { display: none !important; }
.woocommerce-cart .cart-collaterals { display: none !important; }

/* ── RECHTE SEITE: Zusammenfassung ── */
.sb-cart-right { position: sticky; top: 88px; }
.sb-cart-summary-card { background: white; border: 1.5px solid var(--border); border-radius: 14px; padding: 1.75rem; }
.sb-cart-summary-heading { font-family: 'Lora', serif; font-size: 1.1rem; font-weight: 700; color: var(--text-dark); margin-bottom: 1.25rem; padding-bottom: 0.75rem; border-bottom: 1px solid var(--border); }

/* Versand-Fortschrittsbalken */
.sb-shipping-progress { margin-bottom: 1.25rem; padding: 0.85rem; background: var(--off-white); border-radius: 8px; }
.sb-shipping-progress-bar { height: 6px; background: var(--border); border-radius: 3px; overflow: hidden; margin-bottom: 0.5rem; }
.sb-shipping-progress-fill { height: 100%; background: var(--green-light); border-radius: 3px; transition: width 0.4s; }
.sb-shipping-progress-text { font-size: 0.78rem; color: var(--text-mid); margin: 0; }
.sb-shipping-achieved { background: var(--green-pale); color: var(--green-mid); font-size: 0.82rem; font-weight: 600; padding: 0.6rem 0.85rem; border-radius: 8px; margin-bottom: 1.25rem; }

/* Summen-Zeilen */
.sb-summary-rows { display: flex; flex-direction: column; gap: 0.7rem; margin-bottom: 1.25rem; }
.sb-summary-row { display: flex; justify-content: space-between; align-items: center; font-size: 0.88rem; color: var(--text-mid); }
.sb-summary-row span:first-child { color: var(--text-light); }
.sb-summary-row-discount { color: var(--green-light); }
.sb-summary-row-discount span:first-child { color: var(--green-light); }
.sb-remove-coupon { color: #DC2626; margin-left: 0.4rem; font-size: 0.75rem; text-decoration: none; }
.sb-summary-total { font-size: 1.05rem !important; font-weight: 700; color: var(--text-dark) !important; padding-top: 0.85rem; border-top: 2px solid var(--border); margin-top: 0.15rem; }
.sb-summary-total span { color: var(--green-deep) !important; }
.sb-free-label { color: var(--green-light); font-weight: 600; }
.sb-summary-tax { font-size: 0.73rem; color: var(--text-light); margin: -0.5rem 0 1rem; }

/* Kasse-Button */
.sb-checkout-cta { display: flex; align-items: center; justify-content: center; gap: 0.5rem; width: 100%; background: var(--green-deep); color: white !important; text-decoration: none; padding: 0.9rem 1.5rem; border-radius: 8px; font-size: 0.95rem; font-weight: 600; transition: background 0.2s; margin-bottom: 1.1rem; }
.sb-checkout-cta:hover { background: var(--green-mid); color: white !important; }

/* Trust Liste */
.sb-cart-trust-list { display: flex; flex-direction: column; gap: 0.45rem; padding-top: 1rem; border-top: 1px solid var(--border); }
.sb-cart-trust-row { font-size: 0.8rem; color: var(--text-light); display: flex; align-items: center; gap: 0.5rem; }

/* Responsive Warenkorb */
@media (max-width: 960px) {
  .sb-cart-layout { grid-template-columns: 1fr; }
  .sb-cart-right { position: static; }
  .sb-cart-head { display: none; }
  .sb-cart-row { grid-template-columns: auto 1fr; grid-template-rows: auto auto auto; gap: 0.6rem 0.85rem; }
  .sb-cart-product { grid-column: 1 / -1; }
  .sb-cart-price::before { content: attr(data-label) ': '; font-size: 0.72rem; color: var(--text-light); font-weight: 600; text-transform: uppercase; }
  .sb-cart-subtotal::before { content: 'Gesamt: '; font-size: 0.72rem; color: var(--text-light); font-weight: 600; text-transform: uppercase; }
  .sb-cart-remove { grid-column: 2; grid-row: 1; justify-self: end; align-self: start; }
}
@media (max-width: 640px) {
  .sb-coupon-wrap { flex-wrap: wrap; }
  .sb-coupon-input { width: 100%; }
}



/* ============================================================
   KATEGORIELEISTE (Virima-Stil)
   ============================================================ */
.sb-catbar-bg { background: var(--white); border-top: 1px solid var(--border); border-bottom: 1px solid var(--border); padding: 0; }
.sb-catbar-inner { display: flex; align-items: center; gap: 0; padding: 0; flex-wrap: wrap; min-height: 48px; }
.sb-catbar-label { font-size: 0.68rem; font-weight: 700; letter-spacing: 0.12em; text-transform: uppercase; color: var(--text-light); padding: 0 1.25rem; border-right: 1px solid var(--border); height: 48px; display: flex; align-items: center; white-space: nowrap; }
.sb-catbar-groups { display: flex; align-items: center; flex-wrap: wrap; gap: 0; flex: 1; }
.sb-catbar-group { position: relative; }
.sb-catbar-toggle { background: none; border: none; border-right: 1px solid var(--border); padding: 0 1.1rem; height: 48px; font-family: 'Outfit', sans-serif; font-size: 0.82rem; font-weight: 500; color: var(--text-mid); cursor: pointer; display: flex; align-items: center; gap: 0.35rem; transition: all 0.15s; white-space: nowrap; }
.sb-catbar-toggle:hover, .sb-catbar-group:hover .sb-catbar-toggle { background: var(--green-pale); color: var(--green-deep); }
.sb-catbar-toggle span { font-size: 0.7rem; transition: transform 0.2s; }
.sb-catbar-group:hover .sb-catbar-toggle span { transform: rotate(180deg); }
.sb-catbar-dropdown { position: absolute; top: 100%; left: 0; background: var(--white); border: 1px solid var(--border); border-top: 2px solid var(--green-deep); border-radius: 0 0 10px 10px; box-shadow: 0 8px 24px rgba(0,0,0,0.1); min-width: 220px; opacity: 0; visibility: hidden; pointer-events: none; transition: opacity 0.15s; z-index: 200; }
.sb-catbar-group:hover .sb-catbar-dropdown { opacity: 1; visibility: visible; pointer-events: all; }
.sb-catbar-dropdown a { display: block; padding: 0.65rem 1.1rem; font-size: 0.82rem; color: var(--text-mid); text-decoration: none; transition: all 0.12s; border-bottom: 1px solid var(--off-white); }
.sb-catbar-dropdown a:last-child { border-bottom: none; }
.sb-catbar-dropdown a:hover { background: var(--green-pale); color: var(--green-deep); padding-left: 1.4rem; }
.sb-catbar-link { display: flex; align-items: center; height: 48px; padding: 0 1.1rem; font-size: 0.82rem; font-weight: 500; color: var(--text-mid); text-decoration: none; border-right: 1px solid var(--border); transition: all 0.15s; white-space: nowrap; }
.sb-catbar-link:hover { background: var(--green-pale); color: var(--green-deep); }
.sb-catbar-showall { margin-left: auto; display: flex; align-items: center; height: 48px; padding: 0 1.25rem; font-size: 0.79rem; font-weight: 600; color: var(--green-deep); text-decoration: none; border-left: 1px solid var(--border); transition: all 0.15s; white-space: nowrap; }
.sb-catbar-showall:hover { background: var(--green-pale); }

/* ============================================================
   WOOCOMMERCE – MEIN KONTO
   ============================================================ */
.sb-myaccount-wrap { padding: 2.5rem 0 5rem; }
.woocommerce-MyAccount-navigation { float: left; width: 220px; }
.woocommerce-MyAccount-navigation ul { list-style: none; padding: 0; background: white; border: 1.5px solid var(--border); border-radius: 12px; overflow: hidden; }
.woocommerce-MyAccount-navigation ul li a { display: block; padding: 0.75rem 1.1rem; font-size: 0.875rem; font-weight: 500; color: var(--text-mid); text-decoration: none; border-bottom: 1px solid var(--border); transition: all 0.15s; }
.woocommerce-MyAccount-navigation ul li:last-child a { border-bottom: none; }
.woocommerce-MyAccount-navigation ul li a:hover,
.woocommerce-MyAccount-navigation ul li.is-active a { background: var(--green-pale); color: var(--green-deep); }
.woocommerce-MyAccount-content { float: right; width: calc(100% - 260px); }
.woocommerce-MyAccount-content h2 { font-family: 'Lora', serif; font-size: 1.2rem; font-weight: 700; margin-bottom: 1rem; }
.woocommerce-orders-table { width: 100%; border-collapse: collapse; font-size: 0.875rem; }
.woocommerce-orders-table th { background: var(--off-white); padding: 0.6rem 0.75rem; text-align: left; font-weight: 600; font-size: 0.78rem; text-transform: uppercase; letter-spacing: 0.05em; color: var(--text-mid); border-bottom: 1px solid var(--border); }
.woocommerce-orders-table td { padding: 0.75rem; border-bottom: 1px solid var(--border); color: var(--text-mid); }
.woocommerce-orders-table .button { background: var(--green-deep); color: white; padding: 0.3rem 0.8rem; border-radius: 6px; font-size: 0.8rem; font-weight: 500; text-decoration: none; transition: background 0.2s; }
.woocommerce-orders-table .button:hover { background: var(--green-mid); }


/* ============================================================
   KATEGORIELEISTE (Virima-Stil)
   ============================================================ */
.sb-catbar-bg { background: var(--white); border-top: 1px solid var(--border); border-bottom: 1px solid var(--border); padding: 0; }
.sb-catbar-inner { display: flex; align-items: center; gap: 0; padding: 0; flex-wrap: wrap; min-height: 48px; }
.sb-catbar-label { font-size: 0.68rem; font-weight: 700; letter-spacing: 0.12em; text-transform: uppercase; color: var(--text-light); padding: 0 1.25rem; border-right: 1px solid var(--border); height: 48px; display: flex; align-items: center; white-space: nowrap; }
.sb-catbar-groups { display: flex; align-items: center; flex-wrap: wrap; gap: 0; flex: 1; }
.sb-catbar-group { position: relative; }
.sb-catbar-toggle { background: none; border: none; border-right: 1px solid var(--border); padding: 0 1.1rem; height: 48px; font-family: 'Outfit', sans-serif; font-size: 0.82rem; font-weight: 500; color: var(--text-mid); cursor: pointer; display: flex; align-items: center; gap: 0.35rem; transition: all 0.15s; white-space: nowrap; }
.sb-catbar-toggle:hover, .sb-catbar-group:hover .sb-catbar-toggle { background: var(--green-pale); color: var(--green-deep); }
.sb-catbar-toggle span { font-size: 0.7rem; transition: transform 0.2s; }
.sb-catbar-group:hover .sb-catbar-toggle span { transform: rotate(180deg); }
.sb-catbar-dropdown { position: absolute; top: 100%; left: 0; background: var(--white); border: 1px solid var(--border); border-top: 2px solid var(--green-deep); border-radius: 0 0 10px 10px; box-shadow: 0 8px 24px rgba(0,0,0,0.1); min-width: 220px; opacity: 0; visibility: hidden; pointer-events: none; transition: opacity 0.15s; z-index: 200; }
.sb-catbar-group:hover .sb-catbar-dropdown { opacity: 1; visibility: visible; pointer-events: all; }
.sb-catbar-dropdown a { display: block; padding: 0.65rem 1.1rem; font-size: 0.82rem; color: var(--text-mid); text-decoration: none; transition: all 0.12s; border-bottom: 1px solid var(--off-white); }
.sb-catbar-dropdown a:last-child { border-bottom: none; }
.sb-catbar-dropdown a:hover { background: var(--green-pale); color: var(--green-deep); padding-left: 1.4rem; }
.sb-catbar-link { display: flex; align-items: center; height: 48px; padding: 0 1.1rem; font-size: 0.82rem; font-weight: 500; color: var(--text-mid); text-decoration: none; border-right: 1px solid var(--border); transition: all 0.15s; white-space: nowrap; }
.sb-catbar-link:hover { background: var(--green-pale); color: var(--green-deep); }
.sb-catbar-showall { margin-left: auto; display: flex; align-items: center; height: 48px; padding: 0 1.25rem; font-size: 0.79rem; font-weight: 600; color: var(--green-deep); text-decoration: none; border-left: 1px solid var(--border); transition: all 0.15s; white-space: nowrap; }
.sb-catbar-showall:hover { background: var(--green-pale); }

/* ============================================================
   WOOCOMMERCE – NOTICES / MELDUNGEN
   ============================================================ */
.woocommerce-message,
.woocommerce-info,
.woocommerce-error { border-radius: 8px !important; border-left: 4px solid var(--green-deep) !important; background: var(--green-pale) !important; color: var(--green-deep) !important; padding: 0.85rem 1rem 0.85rem 1.4rem !important; margin-bottom: 1.25rem !important; font-size: 0.875rem !important; list-style: none !important; }
.woocommerce-message::before, .woocommerce-info::before { margin-right: 0.5rem; }
.woocommerce-error { border-left-color: #DC2626 !important; background: #FEE2E2 !important; color: #DC2626 !important; }
.woocommerce-message .button,
.woocommerce-info .button { background: var(--green-deep); color: white; padding: 0.35rem 0.9rem; border-radius: 6px; font-size: 0.8rem; font-weight: 600; text-decoration: none; float: right; margin-top: -0.2rem; }

/* Warenkorb Icon in Nav */
.sb-nav-cart { position: relative; display: flex; align-items: center; gap: 0.4rem; text-decoration: none; color: var(--text-mid); font-size: 0.82rem; font-weight: 500; padding: 0.45rem 0.85rem; border: 1.5px solid var(--border); border-radius: 6px; transition: all 0.2s; white-space: nowrap; }
.sb-nav-cart:hover { border-color: var(--green-deep); color: var(--green-deep); }
.sb-nav-cart-count { background: var(--green-deep); color: white; font-size: 0.65rem; font-weight: 700; width: 18px; height: 18px; border-radius: 50%; display: flex; align-items: center; justify-content: center; position: absolute; top: -6px; right: -6px; }

/* ============================================================
   RESPONSIVE WOOCOMMERCE
   ============================================================ */
@media (max-width: 960px) {
  .sb-cart-grid { grid-template-columns: 1fr; }
  .sb-cart-summary { position: static; }
  .sb-cart-header-row { display: none; }
  .sb-cart-item { grid-template-columns: 1fr 1fr; grid-template-rows: auto auto; gap: 0.75rem; }
  .sb-cart-item-info { grid-column: 1 / -1; }
  .woocommerce-MyAccount-navigation { float: none; width: 100%; margin-bottom: 1.5rem; }
  .woocommerce-MyAccount-content { float: none; width: 100%; }
}
@media (max-width: 640px) {
  .sb-cat-filter { gap: 0.35rem; }
  .sb-cart-item { grid-template-columns: 1fr; }
  ul.products { grid-template-columns: repeat(2, 1fr); gap: 0.65rem; }
}


/* ============================================================
   KATEGORIELEISTE (Virima-Stil)
   ============================================================ */
.sb-catbar-bg { background: var(--white); border-top: 1px solid var(--border); border-bottom: 1px solid var(--border); padding: 0; }
.sb-catbar-inner { display: flex; align-items: center; gap: 0; padding: 0; flex-wrap: wrap; min-height: 48px; }
.sb-catbar-label { font-size: 0.68rem; font-weight: 700; letter-spacing: 0.12em; text-transform: uppercase; color: var(--text-light); padding: 0 1.25rem; border-right: 1px solid var(--border); height: 48px; display: flex; align-items: center; white-space: nowrap; }
.sb-catbar-groups { display: flex; align-items: center; flex-wrap: wrap; gap: 0; flex: 1; }
.sb-catbar-group { position: relative; }
.sb-catbar-toggle { background: none; border: none; border-right: 1px solid var(--border); padding: 0 1.1rem; height: 48px; font-family: 'Outfit', sans-serif; font-size: 0.82rem; font-weight: 500; color: var(--text-mid); cursor: pointer; display: flex; align-items: center; gap: 0.35rem; transition: all 0.15s; white-space: nowrap; }
.sb-catbar-toggle:hover, .sb-catbar-group:hover .sb-catbar-toggle { background: var(--green-pale); color: var(--green-deep); }
.sb-catbar-toggle span { font-size: 0.7rem; transition: transform 0.2s; }
.sb-catbar-group:hover .sb-catbar-toggle span { transform: rotate(180deg); }
.sb-catbar-dropdown { position: absolute; top: 100%; left: 0; background: var(--white); border: 1px solid var(--border); border-top: 2px solid var(--green-deep); border-radius: 0 0 10px 10px; box-shadow: 0 8px 24px rgba(0,0,0,0.1); min-width: 220px; opacity: 0; visibility: hidden; pointer-events: none; transition: opacity 0.15s; z-index: 200; }
.sb-catbar-group:hover .sb-catbar-dropdown { opacity: 1; visibility: visible; pointer-events: all; }
.sb-catbar-dropdown a { display: block; padding: 0.65rem 1.1rem; font-size: 0.82rem; color: var(--text-mid); text-decoration: none; transition: all 0.12s; border-bottom: 1px solid var(--off-white); }
.sb-catbar-dropdown a:last-child { border-bottom: none; }
.sb-catbar-dropdown a:hover { background: var(--green-pale); color: var(--green-deep); padding-left: 1.4rem; }
.sb-catbar-link { display: flex; align-items: center; height: 48px; padding: 0 1.1rem; font-size: 0.82rem; font-weight: 500; color: var(--text-mid); text-decoration: none; border-right: 1px solid var(--border); transition: all 0.15s; white-space: nowrap; }
.sb-catbar-link:hover { background: var(--green-pale); color: var(--green-deep); }
.sb-catbar-showall { margin-left: auto; display: flex; align-items: center; height: 48px; padding: 0 1.25rem; font-size: 0.79rem; font-weight: 600; color: var(--green-deep); text-decoration: none; border-left: 1px solid var(--border); transition: all 0.15s; white-space: nowrap; }
.sb-catbar-showall:hover { background: var(--green-pale); }

/* ============================================================
   WOOCOMMERCE – MEIN KONTO
   ============================================================ */
.sb-myaccount-wrap { padding: 2.5rem 0 5rem; }
.woocommerce-MyAccount-navigation { float: left; width: 220px; }
.woocommerce-MyAccount-navigation ul { list-style: none; padding: 0; background: white; border: 1.5px solid var(--border); border-radius: 12px; overflow: hidden; }
.woocommerce-MyAccount-navigation ul li a { display: block; padding: 0.75rem 1.1rem; font-size: 0.875rem; font-weight: 500; color: var(--text-mid); text-decoration: none; border-bottom: 1px solid var(--border); transition: all 0.15s; }
.woocommerce-MyAccount-navigation ul li:last-child a { border-bottom: none; }
.woocommerce-MyAccount-navigation ul li a:hover,
.woocommerce-MyAccount-navigation ul li.is-active a { background: var(--green-pale); color: var(--green-deep); }
.woocommerce-MyAccount-content { float: right; width: calc(100% - 260px); }
.woocommerce-MyAccount-content h2 { font-family: 'Lora', serif; font-size: 1.2rem; font-weight: 700; margin-bottom: 1rem; }
.woocommerce-orders-table { width: 100%; border-collapse: collapse; font-size: 0.875rem; }
.woocommerce-orders-table th { background: var(--off-white); padding: 0.6rem 0.75rem; text-align: left; font-weight: 600; font-size: 0.78rem; text-transform: uppercase; letter-spacing: 0.05em; color: var(--text-mid); border-bottom: 1px solid var(--border); }
.woocommerce-orders-table td { padding: 0.75rem; border-bottom: 1px solid var(--border); color: var(--text-mid); }
.woocommerce-orders-table .button { background: var(--green-deep); color: white; padding: 0.3rem 0.8rem; border-radius: 6px; font-size: 0.8rem; font-weight: 500; text-decoration: none; transition: background 0.2s; }
.woocommerce-orders-table .button:hover { background: var(--green-mid); }


/* ============================================================
   KATEGORIELEISTE (Virima-Stil)
   ============================================================ */
.sb-catbar-bg { background: var(--white); border-top: 1px solid var(--border); border-bottom: 1px solid var(--border); padding: 0; }
.sb-catbar-inner { display: flex; align-items: center; gap: 0; padding: 0; flex-wrap: wrap; min-height: 48px; }
.sb-catbar-label { font-size: 0.68rem; font-weight: 700; letter-spacing: 0.12em; text-transform: uppercase; color: var(--text-light); padding: 0 1.25rem; border-right: 1px solid var(--border); height: 48px; display: flex; align-items: center; white-space: nowrap; }
.sb-catbar-groups { display: flex; align-items: center; flex-wrap: wrap; gap: 0; flex: 1; }
.sb-catbar-group { position: relative; }
.sb-catbar-toggle { background: none; border: none; border-right: 1px solid var(--border); padding: 0 1.1rem; height: 48px; font-family: 'Outfit', sans-serif; font-size: 0.82rem; font-weight: 500; color: var(--text-mid); cursor: pointer; display: flex; align-items: center; gap: 0.35rem; transition: all 0.15s; white-space: nowrap; }
.sb-catbar-toggle:hover, .sb-catbar-group:hover .sb-catbar-toggle { background: var(--green-pale); color: var(--green-deep); }
.sb-catbar-toggle span { font-size: 0.7rem; transition: transform 0.2s; }
.sb-catbar-group:hover .sb-catbar-toggle span { transform: rotate(180deg); }
.sb-catbar-dropdown { position: absolute; top: 100%; left: 0; background: var(--white); border: 1px solid var(--border); border-top: 2px solid var(--green-deep); border-radius: 0 0 10px 10px; box-shadow: 0 8px 24px rgba(0,0,0,0.1); min-width: 220px; opacity: 0; visibility: hidden; pointer-events: none; transition: opacity 0.15s; z-index: 200; }
.sb-catbar-group:hover .sb-catbar-dropdown { opacity: 1; visibility: visible; pointer-events: all; }
.sb-catbar-dropdown a { display: block; padding: 0.65rem 1.1rem; font-size: 0.82rem; color: var(--text-mid); text-decoration: none; transition: all 0.12s; border-bottom: 1px solid var(--off-white); }
.sb-catbar-dropdown a:last-child { border-bottom: none; }
.sb-catbar-dropdown a:hover { background: var(--green-pale); color: var(--green-deep); padding-left: 1.4rem; }
.sb-catbar-link { display: flex; align-items: center; height: 48px; padding: 0 1.1rem; font-size: 0.82rem; font-weight: 500; color: var(--text-mid); text-decoration: none; border-right: 1px solid var(--border); transition: all 0.15s; white-space: nowrap; }
.sb-catbar-link:hover { background: var(--green-pale); color: var(--green-deep); }
.sb-catbar-showall { margin-left: auto; display: flex; align-items: center; height: 48px; padding: 0 1.25rem; font-size: 0.79rem; font-weight: 600; color: var(--green-deep); text-decoration: none; border-left: 1px solid var(--border); transition: all 0.15s; white-space: nowrap; }
.sb-catbar-showall:hover { background: var(--green-pale); }

/* ============================================================
   WOOCOMMERCE – NOTICES / MELDUNGEN
   ============================================================ */
.woocommerce-message,
.woocommerce-info,
.woocommerce-error { border-radius: 8px !important; border-left: 4px solid var(--green-deep) !important; background: var(--green-pale) !important; color: var(--green-deep) !important; padding: 0.85rem 1rem 0.85rem 1.4rem !important; margin-bottom: 1.25rem !important; font-size: 0.875rem !important; list-style: none !important; }
.woocommerce-message::before, .woocommerce-info::before { margin-right: 0.5rem; }
.woocommerce-error { border-left-color: #DC2626 !important; background: #FEE2E2 !important; color: #DC2626 !important; }
.woocommerce-message .button,
.woocommerce-info .button { background: var(--green-deep); color: white; padding: 0.35rem 0.9rem; border-radius: 6px; font-size: 0.8rem; font-weight: 600; text-decoration: none; float: right; margin-top: -0.2rem; }

/* Warenkorb Icon in Nav */
.sb-nav-cart { position: relative; display: flex; align-items: center; gap: 0.4rem; text-decoration: none; color: var(--text-mid); font-size: 0.82rem; font-weight: 500; padding: 0.45rem 0.85rem; border: 1.5px solid var(--border); border-radius: 6px; transition: all 0.2s; white-space: nowrap; }
.sb-nav-cart:hover { border-color: var(--green-deep); color: var(--green-deep); }
.sb-nav-cart-count { background: var(--green-deep); color: white; font-size: 0.65rem; font-weight: 700; width: 18px; height: 18px; border-radius: 50%; display: flex; align-items: center; justify-content: center; position: absolute; top: -6px; right: -6px; }

/* ============================================================
   RESPONSIVE WOOCOMMERCE
   ============================================================ */
@media (max-width: 960px) {
  .sb-cart-grid { grid-template-columns: 1fr; }
  .sb-cart-summary { position: static; }
  .sb-cart-header-row { display: none; }
  .sb-cart-item { grid-template-columns: 1fr 1fr; grid-template-rows: auto auto; gap: 0.75rem; }
  .sb-cart-item-info { grid-column: 1 / -1; }
  .woocommerce-MyAccount-navigation { float: none; width: 100%; margin-bottom: 1.5rem; }
  .woocommerce-MyAccount-content { float: none; width: 100%; }
}
@media (max-width: 640px) {
  .sb-cat-filter { gap: 0.35rem; }
  .sb-cart-item { grid-template-columns: 1fr; }
  ul.products { grid-template-columns: repeat(2, 1fr); gap: 0.65rem; }
}

/* ============================================================
   CHECKOUT – VOLLSTÄNDIGES STYLING
   ============================================================ */
.sb-checkout-wrap { padding: 2.5rem 0 5rem; }

.woocommerce-checkout .col2-set { display: grid; grid-template-columns: 1fr 1fr; gap: 2rem; margin-bottom: 2rem; }
.woocommerce-checkout .col2-set .col-1,
.woocommerce-checkout .col2-set .col-2 { float: none !important; width: 100% !important; }

/* Abschnitt-Boxen */
.woocommerce-checkout .woocommerce-billing-fields,
.woocommerce-checkout .woocommerce-shipping-fields,
.woocommerce-checkout #order_review_heading,
.woocommerce-checkout #payment { 
  background: white; 
  border: 1.5px solid var(--border); 
  border-radius: 12px; 
  padding: 1.75rem;
  margin-bottom: 1.5rem;
}

/* Section Titel */
.woocommerce-checkout h3 { 
  font-family: 'Lora', serif; 
  font-size: 1.05rem; 
  font-weight: 700; 
  color: var(--text-dark); 
  margin-bottom: 1.25rem !important; 
  padding-bottom: 0.75rem; 
  border-bottom: 1px solid var(--border); 
}

/* Formular-Felder */
.woocommerce-checkout .form-row { margin-bottom: 1rem !important; }
.woocommerce-checkout .form-row label { 
  font-size: 0.82rem !important; 
  font-weight: 600 !important; 
  color: var(--text-mid) !important; 
  margin-bottom: 0.3rem !important; 
  display: block !important; 
}
.woocommerce-checkout .form-row .required { color: var(--gold); }
.woocommerce-checkout input[type="text"],
.woocommerce-checkout input[type="email"],
.woocommerce-checkout input[type="tel"],
.woocommerce-checkout input[type="password"],
.woocommerce-checkout textarea,
.woocommerce-checkout select { 
  border: 1.5px solid var(--border) !important; 
  border-radius: 8px !important; 
  padding: 0.65rem 0.9rem !important; 
  font-family: 'Outfit', sans-serif !important; 
  font-size: 0.875rem !important; 
  color: var(--text-dark) !important;
  width: 100% !important; 
  transition: border-color 0.2s !important; 
  background: white !important;
  box-shadow: none !important;
}
.woocommerce-checkout input:focus,
.woocommerce-checkout textarea:focus,
.woocommerce-checkout select:focus { 
  border-color: var(--green-deep) !important; 
  outline: none !important; 
  box-shadow: 0 0 0 3px rgba(30,58,34,0.08) !important; 
}

/* Bestellübersicht rechts */
.woocommerce-checkout-review-order { }
#order_review { 
  background: white; 
  border: 1.5px solid var(--border); 
  border-radius: 12px; 
  padding: 1.75rem; 
}
.woocommerce-checkout-review-order-table { width: 100%; border-collapse: collapse; margin-bottom: 1rem; }
.woocommerce-checkout-review-order-table thead th { 
  font-size: 0.75rem; 
  font-weight: 600; 
  text-transform: uppercase; 
  letter-spacing: 0.08em; 
  color: var(--text-light); 
  padding: 0 0 0.75rem; 
  border-bottom: 1px solid var(--border); 
}
.woocommerce-checkout-review-order-table tbody td,
.woocommerce-checkout-review-order-table tfoot td,
.woocommerce-checkout-review-order-table tfoot th { 
  padding: 0.65rem 0; 
  border-bottom: 1px solid var(--border); 
  font-size: 0.875rem; 
  color: var(--text-mid); 
  vertical-align: middle;
}
.woocommerce-checkout-review-order-table tfoot .order-total td,
.woocommerce-checkout-review-order-table tfoot .order-total th { 
  font-weight: 700; 
  font-size: 1.05rem; 
  color: var(--green-deep); 
  border-top: 2px solid var(--border); 
  border-bottom: none; 
  padding-top: 0.85rem; 
}
.woocommerce-checkout-review-order-table .product-name { font-weight: 600; color: var(--text-dark); }
.woocommerce-checkout-review-order-table .product-total { text-align: right; font-weight: 600; color: var(--green-deep); }

/* Zahlungsmethoden */
#payment { background: var(--off-white) !important; }
#payment .payment_methods { list-style: none !important; padding: 0 !important; margin: 0 0 1.25rem !important; }
#payment .payment_methods li { 
  background: white; 
  border: 1.5px solid var(--border); 
  border-radius: 8px; 
  padding: 0.85rem 1rem !important; 
  margin-bottom: 0.5rem !important;
  transition: border-color 0.2s;
}
#payment .payment_methods li:has(input:checked) { border-color: var(--green-deep) !important; background: var(--green-pale); }
#payment .payment_methods li label { 
  font-weight: 600 !important; 
  font-size: 0.9rem !important; 
  color: var(--text-dark) !important; 
  cursor: pointer; 
  display: flex !important; 
  align-items: center; 
  gap: 0.5rem; 
}
#payment .payment_box { 
  background: var(--off-white) !important; 
  border-radius: 6px !important; 
  padding: 0.75rem !important; 
  margin-top: 0.5rem; 
  font-size: 0.84rem !important; 
  color: var(--text-light) !important; 
}

/* Bestellung aufgeben Button */
#place_order { 
  width: 100% !important; 
  background: var(--green-deep) !important; 
  color: white !important; 
  border: none !important; 
  border-radius: 8px !important; 
  padding: 1rem !important; 
  font-size: 1rem !important; 
  font-weight: 600 !important; 
  font-family: 'Outfit', sans-serif !important; 
  cursor: pointer !important; 
  transition: background 0.2s !important; 
  margin-top: 1rem !important;
  letter-spacing: 0.02em;
}
#place_order:hover { background: var(--green-mid) !important; }

/* Checkout Layout – Billing links, Order rechts */
.woocommerce-checkout form.checkout { display: grid; grid-template-columns: 1fr 420px; gap: 2rem; align-items: start; }
.woocommerce-checkout form.checkout .col2-set { grid-column: 1; }
.woocommerce-checkout form.checkout #order_review_heading { grid-column: 2; grid-row: 1; }
.woocommerce-checkout form.checkout #order_review { grid-column: 2; grid-row: 2; }

/* Bestellbestätigung */
.woocommerce-order { background: white; border: 1.5px solid var(--border); border-radius: 12px; padding: 2rem; }
.woocommerce-order .woocommerce-order-overview { list-style: none; padding: 0; display: grid; grid-template-columns: repeat(4, 1fr); gap: 1rem; margin-bottom: 2rem; }
.woocommerce-order .woocommerce-order-overview li { background: var(--off-white); border-radius: 8px; padding: 1rem; font-size: 0.85rem; }
.woocommerce-order .woocommerce-order-overview li strong { display: block; font-size: 0.95rem; color: var(--green-deep); }

/* Responsive Checkout */
@media (max-width: 960px) {
  .woocommerce-checkout form.checkout { grid-template-columns: 1fr; }
  .woocommerce-checkout form.checkout #order_review_heading,
  .woocommerce-checkout form.checkout #order_review { grid-column: 1; grid-row: auto; }
  .woocommerce-checkout .col2-set { grid-template-columns: 1fr; }
}

/* ============================================================
   NAV – WARENKORB KOMPAKT
   ============================================================ */
/* Nav-Actions Abstand reduzieren */
.sb-nav-actions { display: flex; gap: 0.5rem; align-items: center; }
.sb-nav-actions .sb-btn { padding: 0.45rem 1rem; font-size: 0.82rem; }


/* ============================================================
   WARENKORB – KOMPLETT NEU
   ============================================================ */
.sb-cart-title-count { font-family: 'Outfit', sans-serif; font-size: 0.8rem; font-weight: 600; color: var(--green-mid); background: var(--green-pale); border: 1px solid var(--green-light); padding: 0.2rem 0.65rem; border-radius: 20px; letter-spacing: 0.02em; }

.sb-cart-page { padding: 2.5rem 0 5rem; }

/* Leerer Warenkorb */
.sb-empty-cart { text-align: center; padding: 6rem 1rem; }
.sb-empty-cart-icon { font-size: 3.5rem; margin-bottom: 1rem; }
.sb-empty-cart h3 { font-family: 'Lora', serif; font-size: 1.4rem; margin-bottom: 0.5rem; }
.sb-empty-cart p { color: var(--text-light); margin-bottom: 1.75rem; }

/* Layout: 2 Spalten */
.sb-cart-layout { display: grid; grid-template-columns: 1fr 360px; gap: 2rem; align-items: start; }

/* ── LINKE SEITE ── */
.sb-cart-left { display: flex; flex-direction: column; gap: 0; }

/* Tabellen-Header */
.sb-cart-head { display: grid; grid-template-columns: 2.5fr 1fr 1.2fr 1fr 36px; gap: 1rem; padding: 0 1rem 0.6rem; font-size: 0.72rem; font-weight: 600; text-transform: uppercase; letter-spacing: 0.08em; color: var(--text-light); border-bottom: 2px solid var(--border); }

/* Produkt-Zeilen */
.sb-cart-rows { display: flex; flex-direction: column; gap: 0.5rem; margin-top: 0.5rem; }
.sb-cart-row { display: grid; grid-template-columns: 2.5fr 1fr 1.2fr 1fr 36px; gap: 1rem; align-items: center; padding: 1rem; background: white; border: 1.5px solid var(--border); border-radius: 10px; transition: border-color 0.2s; }
.sb-cart-row:hover { border-color: var(--green-light); }

/* Produkt-Info */
.sb-cart-product { display: flex; align-items: center; gap: 0.85rem; }
.sb-cart-img { width: 60px; height: 60px; flex-shrink: 0; border-radius: 8px; overflow: hidden; background: var(--off-white); display: flex; align-items: center; justify-content: center; }
.sb-cart-img img { width: 100%; height: 100%; object-fit: cover; }
.sb-cart-img-placeholder { font-size: 1.5rem; }
.sb-cart-product-name { font-size: 0.875rem; font-weight: 600; color: var(--text-dark); text-decoration: none; line-height: 1.4; display: block; }
.sb-cart-product-name:hover { color: var(--green-deep); }
.sb-cart-product-variants { font-size: 0.75rem; color: var(--text-light); margin-top: 0.2rem; }
.sb-cart-product-variants span { display: block; }

/* Preis */
.sb-cart-price { font-size: 0.875rem; color: var(--text-mid); font-weight: 500; }
.sb-cart-price .woocommerce-Price-amount { font-size: 0.875rem; }

/* Menge +/- */
.sb-qty-wrap { display: inline-flex; align-items: center; border: 1.5px solid var(--border); border-radius: 8px; overflow: hidden; background: white; }
.sb-qbtn { width: 32px; height: 34px; border: none; background: transparent; font-size: 1.1rem; cursor: pointer; color: var(--text-mid); transition: background 0.15s; font-family: 'Outfit', sans-serif; display: flex; align-items: center; justify-content: center; }
.sb-qbtn:hover { background: var(--off-white); color: var(--green-deep); }
.sb-qval { width: 34px; text-align: center; font-size: 0.9rem; font-weight: 600; color: var(--text-dark); }

/* Zeilensumme */
.sb-cart-subtotal { font-size: 0.95rem; font-weight: 700; color: var(--green-deep); }
.sb-cart-subtotal .woocommerce-Price-amount { font-size: 0.95rem; font-weight: 700; }

/* Entfernen */
.sb-cart-remove-btn { display: flex; align-items: center; justify-content: center; width: 28px; height: 28px; background: #FEE2E2; color: #DC2626; border-radius: 6px; text-decoration: none; transition: all 0.15s; }
.sb-cart-remove-btn:hover { background: #DC2626; color: white; }

/* Footer Aktionen */
.sb-cart-footer { display: flex; align-items: center; justify-content: space-between; margin-top: 1.25rem; flex-wrap: wrap; gap: 0.75rem; }
.sb-coupon-wrap { display: flex; gap: 0.5rem; }
.sb-coupon-input { border: 1.5px solid var(--border); border-radius: 8px; padding: 0.5rem 0.9rem; font-family: 'Outfit', sans-serif; font-size: 0.85rem; color: var(--text-mid); outline: none; transition: border-color 0.2s; width: 200px; }
.sb-coupon-input:focus { border-color: var(--green-deep); }

/* WooCommerce Coupon-Form verstecken (wir nutzen eigenes) */
.woocommerce-cart .coupon { display: none !important; }
.woocommerce-cart .actions { display: none !important; }
.woocommerce-cart table.cart { display: none !important; }
.woocommerce-cart .cart-collaterals { display: none !important; }

/* ── RECHTE SEITE: Zusammenfassung ── */
.sb-cart-right { position: sticky; top: 88px; }
.sb-cart-summary-card { background: white; border: 1.5px solid var(--border); border-radius: 14px; padding: 1.75rem; }
.sb-cart-summary-heading { font-family: 'Lora', serif; font-size: 1.1rem; font-weight: 700; color: var(--text-dark); margin-bottom: 1.25rem; padding-bottom: 0.75rem; border-bottom: 1px solid var(--border); }

/* Versand-Fortschrittsbalken */
.sb-shipping-progress { margin-bottom: 1.25rem; padding: 0.85rem; background: var(--off-white); border-radius: 8px; }
.sb-shipping-progress-bar { height: 6px; background: var(--border); border-radius: 3px; overflow: hidden; margin-bottom: 0.5rem; }
.sb-shipping-progress-fill { height: 100%; background: var(--green-light); border-radius: 3px; transition: width 0.4s; }
.sb-shipping-progress-text { font-size: 0.78rem; color: var(--text-mid); margin: 0; }
.sb-shipping-achieved { background: var(--green-pale); color: var(--green-mid); font-size: 0.82rem; font-weight: 600; padding: 0.6rem 0.85rem; border-radius: 8px; margin-bottom: 1.25rem; }

/* Summen-Zeilen */
.sb-summary-rows { display: flex; flex-direction: column; gap: 0.7rem; margin-bottom: 1.25rem; }
.sb-summary-row { display: flex; justify-content: space-between; align-items: center; font-size: 0.88rem; color: var(--text-mid); }
.sb-summary-row span:first-child { color: var(--text-light); }
.sb-summary-row-discount { color: var(--green-light); }
.sb-summary-row-discount span:first-child { color: var(--green-light); }
.sb-remove-coupon { color: #DC2626; margin-left: 0.4rem; font-size: 0.75rem; text-decoration: none; }
.sb-summary-total { font-size: 1.05rem !important; font-weight: 700; color: var(--text-dark) !important; padding-top: 0.85rem; border-top: 2px solid var(--border); margin-top: 0.15rem; }
.sb-summary-total span { color: var(--green-deep) !important; }
.sb-free-label { color: var(--green-light); font-weight: 600; }
.sb-summary-tax { font-size: 0.73rem; color: var(--text-light); margin: -0.5rem 0 1rem; }

/* Kasse-Button */
.sb-checkout-cta { display: flex; align-items: center; justify-content: center; gap: 0.5rem; width: 100%; background: var(--green-deep); color: white !important; text-decoration: none; padding: 0.9rem 1.5rem; border-radius: 8px; font-size: 0.95rem; font-weight: 600; transition: background 0.2s; margin-bottom: 1.1rem; }
.sb-checkout-cta:hover { background: var(--green-mid); color: white !important; }

/* Trust Liste */
.sb-cart-trust-list { display: flex; flex-direction: column; gap: 0.45rem; padding-top: 1rem; border-top: 1px solid var(--border); }
.sb-cart-trust-row { font-size: 0.8rem; color: var(--text-light); display: flex; align-items: center; gap: 0.5rem; }

/* Responsive Warenkorb */
@media (max-width: 960px) {
  .sb-cart-layout { grid-template-columns: 1fr; }
  .sb-cart-right { position: static; }
  .sb-cart-head { display: none; }
  .sb-cart-row { grid-template-columns: auto 1fr; grid-template-rows: auto auto auto; gap: 0.6rem 0.85rem; }
  .sb-cart-product { grid-column: 1 / -1; }
  .sb-cart-price::before { content: attr(data-label) ': '; font-size: 0.72rem; color: var(--text-light); font-weight: 600; text-transform: uppercase; }
  .sb-cart-subtotal::before { content: 'Gesamt: '; font-size: 0.72rem; color: var(--text-light); font-weight: 600; text-transform: uppercase; }
  .sb-cart-remove { grid-column: 2; grid-row: 1; justify-self: end; align-self: start; }
}
@media (max-width: 640px) {
  .sb-coupon-wrap { flex-wrap: wrap; }
  .sb-coupon-input { width: 100%; }
}


/* ============================================================
   CHECKOUT – NEU
   ============================================================ */

/* checkout steps → unified .sb-steps-bar */

/* Seiten-Layout */
.sb-checkout-page { padding: 2rem 0 5rem; }
.sb-checkout-form { display: grid; grid-template-columns: 1fr 420px; gap: 2rem; align-items: start; }
.sb-checkout-left { display: flex; flex-direction: column; gap: 1.25rem; }
.sb-checkout-right { display: flex; flex-direction: column; gap: 1.25rem; position: sticky; top: 88px; }

/* Box */
.sb-checkout-box { background: white; border: 1.5px solid var(--border); border-radius: 12px; padding: 1.5rem 1.75rem; }
.sb-checkout-box-title { display: flex; align-items: center; gap: 0.65rem; font-family: 'Lora', serif; font-size: 1rem; font-weight: 700; color: var(--text-dark); margin-bottom: 1.25rem; padding-bottom: 0.75rem; border-bottom: 1px solid var(--border); }
.sb-checkout-box-num { display: flex; align-items: center; justify-content: center; width: 26px; height: 26px; background: var(--green-deep); color: white; border-radius: 50%; font-family: 'Outfit', sans-serif; font-size: 0.75rem; font-weight: 700; flex-shrink: 0; }
.sb-checkout-summary-box .sb-checkout-box-num { background: var(--green-light); }

/* Formular-Felder */
.woocommerce-billing-fields .form-row,
.woocommerce-shipping-fields .form-row,
.woocommerce-additional-fields .form-row { margin-bottom: 0.9rem !important; }
.woocommerce-billing-fields .form-row label,
.woocommerce-shipping-fields .form-row label,
.woocommerce-additional-fields .form-row label { font-size: 0.8rem !important; font-weight: 600 !important; color: var(--text-mid) !important; margin-bottom: 0.35rem !important; display: block !important; }
.woocommerce-billing-fields .form-row .required,
.woocommerce-shipping-fields .form-row .required { color: var(--gold) !important; }

/* Alle Input-Felder */
.woocommerce-checkout input[type="text"],
.woocommerce-checkout input[type="email"],
.woocommerce-checkout input[type="tel"],
.woocommerce-checkout input[type="date"],
.woocommerce-checkout input[type="password"],
.woocommerce-checkout input[type="number"],
.woocommerce-checkout textarea,
.woocommerce-checkout select {
  border: 1.5px solid var(--border) !important;
  border-radius: 8px !important;
  padding: 0.6rem 0.85rem !important;
  font-family: 'Outfit', sans-serif !important;
  font-size: 0.875rem !important;
  color: var(--text-dark) !important;
  width: 100% !important;
  box-sizing: border-box !important;
  background: white !important;
  box-shadow: none !important;
  transition: border-color 0.2s !important;
  appearance: auto;
}
.woocommerce-checkout input:focus,
.woocommerce-checkout textarea:focus,
.woocommerce-checkout select:focus {
  border-color: var(--green-deep) !important;
  outline: none !important;
  box-shadow: 0 0 0 3px rgba(30,58,34,0.07) !important;
}
.woocommerce-checkout .form-row-first,
.woocommerce-checkout .form-row-last { float: none !important; width: 100% !important; }

/* 2-spaltig: Vorname / Nachname */
.woocommerce-billing-fields__field-wrapper,
.woocommerce-shipping-fields__field-wrapper { display: grid; grid-template-columns: 1fr 1fr; gap: 0 1rem; }
.woocommerce-billing-fields__field-wrapper .form-row,
.woocommerce-shipping-fields__field-wrapper .form-row { float: none !important; width: auto !important; }
.woocommerce-billing-fields__field-wrapper .form-row-wide,
.woocommerce-shipping-fields__field-wrapper .form-row-wide { grid-column: 1 / -1; }

/* WC Header in Billing/Shipping entfernen */
.woocommerce-billing-fields > h3,
.woocommerce-shipping-fields > h3 { display: none; }

/* Checkbox Lieferadresse */
#ship-to-different-address { margin-bottom: 0.75rem; }
#ship-to-different-address label { font-weight: 600 !important; font-size: 0.875rem !important; cursor: pointer; display: flex !important; align-items: center; gap: 0.5rem; }

/* Bestellübersicht rechts */
.sb-checkout-order-table { }
.sb-co-item { display: flex; align-items: center; gap: 0.75rem; padding: 0.65rem 0; border-bottom: 1px solid var(--border); }
.sb-co-item-img { position: relative; flex-shrink: 0; }
.sb-co-item-img img { width: 48px; height: 48px; border-radius: 6px; object-fit: cover; }
.sb-co-qty { position: absolute; top: -6px; right: -6px; background: var(--green-deep); color: white; font-size: 0.65rem; font-weight: 700; width: 18px; height: 18px; border-radius: 50%; display: flex; align-items: center; justify-content: center; }
.sb-co-name { flex: 1; font-size: 0.84rem; font-weight: 500; color: var(--text-dark); line-height: 1.3; }
.sb-co-price { font-size: 0.875rem; font-weight: 700; color: var(--green-deep); white-space: nowrap; }
.sb-co-price .woocommerce-Price-amount { font-size: 0.875rem; }

/* Totals */
.sb-co-totals { display: flex; flex-direction: column; gap: 0.55rem; padding-top: 0.85rem; }
.sb-co-row { display: flex; justify-content: space-between; font-size: 0.84rem; color: var(--text-light); }
.sb-co-discount { color: var(--green-light); }
.sb-co-total { font-size: 1rem; font-weight: 700; color: var(--text-dark); padding-top: 0.65rem; border-top: 2px solid var(--border); margin-top: 0.2rem; }
.sb-co-total span:last-child { color: var(--green-deep); }
.sb-co-tax { font-size: 0.72rem; color: var(--text-light); margin: 0.2rem 0 0; }
.sb-free-label { color: var(--green-light); font-weight: 600; }

/* Zahlungsmethoden */
#payment { background: transparent !important; border: none !important; padding: 0 !important; }
#payment .payment_methods { list-style: none !important; padding: 0 !important; margin: 0 0 1rem !important; display: flex; flex-direction: column; gap: 0.5rem; }
#payment .payment_methods li { background: white !important; border: 1.5px solid var(--border) !important; border-radius: 8px !important; padding: 0.85rem 1rem !important; transition: border-color 0.2s; }
#payment .payment_methods li:has(input:checked) { border-color: var(--green-deep) !important; background: var(--green-pale) !important; }
#payment .payment_methods li label { font-weight: 600 !important; font-size: 0.875rem !important; cursor: pointer !important; display: flex !important; align-items: center !important; gap: 0.5rem !important; color: var(--text-dark) !important; }
#payment .payment_box { background: var(--off-white) !important; border-radius: 6px !important; padding: 0.75rem !important; margin-top: 0.5rem !important; font-size: 0.82rem !important; color: var(--text-light) !important; }
.woocommerce-checkout #payment div.place-order { padding: 0 !important; }

/* Bestellung aufgeben */
#place_order {
  width: 100% !important; background: var(--green-deep) !important; color: white !important;
  border: none !important; border-radius: 8px !important; padding: 0.95rem !important;
  font-size: 1rem !important; font-weight: 600 !important; font-family: 'Outfit', sans-serif !important;
  cursor: pointer !important; transition: background 0.2s !important; letter-spacing: 0.02em;
}
#place_order:hover { background: var(--green-mid) !important; }

/* Trust Icons */
.sb-checkout-trust { display: flex; justify-content: space-between; flex-wrap: wrap; gap: 0.5rem; padding: 0.75rem 1rem; background: var(--off-white); border-radius: 8px; }
.sb-checkout-trust-item { font-size: 0.78rem; color: var(--text-light); }

/* Gutschein-Notice */
.woocommerce-info { border-left: 3px solid var(--green-light) !important; background: var(--green-pale) !important; color: var(--green-deep) !important; border-radius: 8px !important; padding: 0.75rem 1rem !important; font-size: 0.84rem !important; margin-bottom: 1.5rem !important; }
.woocommerce-info a { color: var(--green-deep) !important; font-weight: 600; }

/* Bestellbestätigung */
.woocommerce-order-received .sb-checkout-page { max-width: 700px; }
.woocommerce-thankyou-order-received { font-family: 'Lora', serif; font-size: 1.3rem; font-weight: 700; color: var(--green-deep); margin-bottom: 1.5rem !important; }
.woocommerce-order-overview { list-style: none !important; padding: 0 !important; display: grid !important; grid-template-columns: repeat(2, 1fr) !important; gap: 1rem !important; margin-bottom: 2rem !important; }
.woocommerce-order-overview li { background: white; border: 1.5px solid var(--border); border-radius: 10px; padding: 1rem 1.25rem !important; font-size: 0.84rem !important; }
.woocommerce-order-overview li strong { display: block; font-size: 1rem; color: var(--green-deep); margin-top: 0.25rem; }

/* Responsive */
@media (max-width: 960px) {
  .sb-checkout-form { grid-template-columns: 1fr; }
  .sb-checkout-right { position: static; }
}
@media (max-width: 640px) {
  .woocommerce-billing-fields__field-wrapper,
  .woocommerce-shipping-fields__field-wrapper { grid-template-columns: 1fr; }
  .sb-checkout-steps { font-size: 0.72rem; }
}


/* ============================================================
   WARENKORB HEADER – NEU
   ============================================================ */
.sb-cart-header { background: var(--off-white); border-bottom: 1px solid var(--border); padding: 1.5rem 0 0; }

.sb-cart-breadcrumb { display: flex; align-items: center; gap: 0.4rem; font-size: 0.78rem; color: var(--text-light); margin-bottom: 1rem; }
.sb-cart-breadcrumb a { color: var(--text-light); text-decoration: none; transition: color 0.15s; }
.sb-cart-breadcrumb a:hover { color: var(--green-deep); }
.sb-cart-breadcrumb span:not(:last-child) { color: var(--border); }

.sb-cart-header-inner { display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: 1rem; padding-bottom: 1.5rem; }

.sb-cart-heading { font-family: 'Lora', serif; font-size: 1.75rem; font-weight: 700; color: var(--text-dark); display: flex; align-items: center; gap: 0.65rem; }

/* Steps */
/* cart steps → unified .sb-steps-bar */

@media (max-width: 640px) {
  .sb-cart-header-inner { flex-direction: column; align-items: flex-start; }
  .sb-cart-step-label { display: none; }
  .sb-cart-step-line { width: 24px; }
}

/* ============================================================
   CHECKOUT – NEU (WC Standard Order Review rechts)
   ============================================================ */

.sb-cart-step-line-done { background: var(--green-light) !important; }

.sb-checkout-page { padding: 2rem 0 5rem; }
.sb-checkout-form { display: grid; grid-template-columns: 1fr 420px; gap: 2rem; align-items: start; }
.sb-checkout-left { display: flex; flex-direction: column; gap: 1.25rem; }
.sb-checkout-right { display: flex; flex-direction: column; gap: 1rem; position: sticky; top: 88px; }

/* Checkout Boxen links */
.sb-checkout-box { background: white; border: 1.5px solid var(--border); border-radius: 12px; padding: 1.5rem 1.75rem; }
.sb-checkout-box-title { display: flex; align-items: center; gap: 0.65rem; font-family: 'Lora', serif; font-size: 1rem; font-weight: 700; color: var(--text-dark); margin-bottom: 1.25rem; padding-bottom: 0.75rem; border-bottom: 1px solid var(--border); }
.sb-checkout-box-num { width: 26px; height: 26px; background: var(--green-deep); color: white; border-radius: 50%; font-family: 'Outfit', sans-serif; font-size: 0.75rem; font-weight: 700; display: flex; align-items: center; justify-content: center; flex-shrink: 0; }

/* Formular-Felder */
.woocommerce-billing-fields > h3,
.woocommerce-shipping-fields > h3 { display: none !important; }
.woocommerce-billing-fields__field-wrapper,
.woocommerce-shipping-fields__field-wrapper { display: grid; grid-template-columns: 1fr 1fr; gap: 0 1rem; }
.woocommerce-billing-fields__field-wrapper .form-row,
.woocommerce-shipping-fields__field-wrapper .form-row { float: none !important; width: auto !important; margin-bottom: 0.85rem !important; }
.woocommerce-billing-fields__field-wrapper .form-row-wide,
.woocommerce-shipping-fields__field-wrapper .form-row-wide { grid-column: 1 / -1; }
.form-row label { font-size: 0.8rem !important; font-weight: 600 !important; color: var(--text-mid) !important; margin-bottom: 0.3rem !important; display: block !important; }
.form-row .required { color: var(--gold) !important; }
.woocommerce-checkout input[type="text"],
.woocommerce-checkout input[type="email"],
.woocommerce-checkout input[type="tel"],
.woocommerce-checkout input[type="date"],
.woocommerce-checkout input[type="password"],
.woocommerce-checkout textarea,
.woocommerce-checkout select { border: 1.5px solid var(--border) !important; border-radius: 8px !important; padding: 0.6rem 0.85rem !important; font-family: 'Outfit', sans-serif !important; font-size: 0.875rem !important; color: var(--text-dark) !important; width: 100% !important; box-sizing: border-box !important; background: white !important; box-shadow: none !important; transition: border-color 0.2s !important; }
.woocommerce-checkout input:focus,
.woocommerce-checkout textarea:focus,
.woocommerce-checkout select:focus { border-color: var(--green-deep) !important; outline: none !important; box-shadow: 0 0 0 3px rgba(30,58,34,0.07) !important; }
#ship-to-different-address label { font-weight: 600 !important; font-size: 0.875rem !important; cursor: pointer; display: flex !important; align-items: center; gap: 0.5rem; }

/* ── RECHTE SEITE: WC Order Review Box ── */
.sb-checkout-order-box { background: white; border: 1.5px solid var(--border); border-radius: 12px; overflow: hidden; }

/* WC Order Review Tabelle */
.woocommerce-checkout-review-order { }
.woocommerce-checkout-review-order-table { width: 100%; border-collapse: collapse; }

/* Header */
.woocommerce-checkout-review-order-table thead tr th { background: var(--off-white); font-size: 0.75rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.08em; color: var(--text-mid); padding: 0.85rem 1.25rem; border-bottom: 1px solid var(--border); }

/* Produkt-Zeilen */
.woocommerce-checkout-review-order-table tbody tr.cart_item td { padding: 0.85rem 1.25rem; border-bottom: 1px solid var(--border); vertical-align: middle; }
.woocommerce-checkout-review-order-table tbody tr.cart_item td.product-name { font-size: 0.875rem; font-weight: 500; color: var(--text-dark); }
.woocommerce-checkout-review-order-table tbody tr.cart_item td.product-name .product-quantity { color: var(--text-light); font-size: 0.8rem; }
.woocommerce-checkout-review-order-table tbody tr.cart_item td.product-total { text-align: right; font-weight: 600; color: var(--text-dark); font-size: 0.9rem; }

/* Summen */
.woocommerce-checkout-review-order-table tfoot tr th,
.woocommerce-checkout-review-order-table tfoot tr td { padding: 0.7rem 1.25rem; border-bottom: 1px solid var(--border); font-size: 0.875rem; color: var(--text-mid); }
.woocommerce-checkout-review-order-table tfoot tr td { text-align: right; }
.woocommerce-checkout-review-order-table tfoot tr.cart-subtotal th,
.woocommerce-checkout-review-order-table tfoot tr.cart-subtotal td { font-weight: 600; }
.woocommerce-checkout-review-order-table tfoot tr.order-total th,
.woocommerce-checkout-review-order-table tfoot tr.order-total td { font-size: 1.05rem !important; font-weight: 700 !important; color: var(--text-dark) !important; border-top: 2px solid var(--border) !important; border-bottom: none !important; padding: 1rem 1.25rem !important; }
.woocommerce-checkout-review-order-table tfoot tr.order-total td { color: var(--green-deep) !important; }
.woocommerce-checkout-review-order-table tfoot tr td .woocommerce-Price-amount { font-weight: inherit; }

/* Gutschein-Feld in Order Review */
.woocommerce-checkout-review-order .woocommerce-checkout-payment { }
#coupon_code_checkout_wrapper,
.checkout_coupon { padding: 1.25rem; border-bottom: 1px solid var(--border); }
.checkout_coupon input { border: 1.5px solid var(--border) !important; border-radius: 8px !important; padding: 0.6rem 0.85rem !important; font-family: 'Outfit', sans-serif !important; font-size: 0.875rem !important; width: 100% !important; margin-bottom: 0.5rem; box-sizing: border-box; }
.checkout_coupon button { width: 100% !important; background: var(--green-deep) !important; color: white !important; border: none !important; border-radius: 8px !important; padding: 0.7rem !important; font-weight: 600 !important; font-size: 0.875rem !important; cursor: pointer !important; text-transform: uppercase; letter-spacing: 0.05em; transition: background 0.2s; }
.checkout_coupon button:hover { background: var(--green-mid) !important; }

/* Zahlungsmethoden */
#payment { padding: 1.25rem !important; background: transparent !important; border: none !important; }
#payment .payment_methods { list-style: none !important; padding: 0 !important; margin: 0 0 1rem !important; display: flex; flex-direction: column; gap: 0.5rem; }
#payment .payment_methods li { background: white !important; border: 1.5px solid var(--border) !important; border-radius: 8px !important; padding: 0.75rem 1rem !important; transition: all 0.15s; }
#payment .payment_methods li:has(input:checked) { border-color: var(--green-deep) !important; background: var(--green-pale) !important; }
#payment .payment_methods li label { font-weight: 600 !important; font-size: 0.875rem !important; cursor: pointer !important; display: flex !important; align-items: center !important; gap: 0.6rem !important; color: var(--text-dark) !important; }
#payment .payment_methods li label img { height: 24px !important; width: auto !important; border-radius: 4px; }
#payment .payment_box { background: var(--off-white) !important; border-radius: 6px !important; padding: 0.65rem 0.85rem !important; margin-top: 0.5rem !important; font-size: 0.82rem !important; color: var(--text-light) !important; }

/* AGB Checkbox */
.woocommerce-terms-and-conditions-wrapper { margin-bottom: 1rem; font-size: 0.84rem; color: var(--text-mid); }
.woocommerce-terms-and-conditions-wrapper a { color: var(--green-deep); }

/* Bestellung aufgeben */
.woocommerce-checkout #payment div.place-order { padding: 0 !important; }
#place_order { width: 100% !important; background: var(--green-deep) !important; color: white !important; border: none !important; border-radius: 8px !important; padding: 1rem !important; font-size: 0.95rem !important; font-weight: 700 !important; font-family: 'Outfit', sans-serif !important; cursor: pointer !important; transition: background 0.2s !important; text-transform: uppercase; letter-spacing: 0.06em; }
#place_order:hover { background: var(--green-mid) !important; }

/* Notices */
.woocommerce-info { border-left: 3px solid var(--green-light) !important; background: var(--green-pale) !important; color: var(--green-deep) !important; border-radius: 8px !important; padding: 0.75rem 1rem !important; font-size: 0.84rem !important; margin-bottom: 1.5rem !important; list-style: none !important; }
.woocommerce-info a { color: var(--green-deep) !important; font-weight: 600; }

/* Trust */
.sb-checkout-trust { display: flex; flex-direction: column; gap: 0.4rem; padding: 0.85rem 1.1rem; background: var(--off-white); border-radius: 8px; }
.sb-checkout-trust-item { font-size: 0.79rem; color: var(--text-light); display: flex; align-items: center; gap: 0.4rem; }

/* Bestellbestätigung */
.woocommerce-thankyou-order-received { font-family: 'Lora', serif; font-size: 1.3rem; font-weight: 700; color: var(--green-deep); margin-bottom: 1.5rem !important; }
.woocommerce-order-overview { list-style: none !important; padding: 0 !important; display: grid !important; grid-template-columns: repeat(2,1fr) !important; gap: 1rem !important; margin-bottom: 2rem !important; }
.woocommerce-order-overview li { background: white; border: 1.5px solid var(--border); border-radius: 10px; padding: 1rem 1.25rem !important; font-size: 0.84rem !important; }
.woocommerce-order-overview li strong { display: block; font-size: 1rem; color: var(--green-deep); margin-top: 0.25rem; }

/* Responsive */
@media (max-width: 960px) {
  .sb-checkout-form { grid-template-columns: 1fr; }
  .sb-checkout-right { position: static; }
}
@media (max-width: 640px) {
  .woocommerce-billing-fields__field-wrapper,
  .woocommerce-shipping-fields__field-wrapper { grid-template-columns: 1fr; }
}


/* ============================================================
   EINHEITLICHE CHECKOUT STEPS – alle Seiten
   ============================================================ */
.sb-steps-bar { display: flex; align-items: center; gap: 0; }

.sb-step-item { display: flex; align-items: center; gap: 0.5rem; }
.sb-step-circle {
  width: 30px; height: 30px; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-size: 0.75rem; font-weight: 700; font-family: 'Outfit', sans-serif;
  background: white; color: var(--text-light);
  border: 2px solid var(--border);
  transition: all 0.2s; flex-shrink: 0; text-decoration: none;
}
.sb-step-label { font-size: 0.8rem; font-weight: 500; color: var(--text-light); white-space: nowrap; }
.sb-step-connector { width: 48px; height: 2px; background: var(--border); margin: 0 0.4rem; flex-shrink: 0; }

/* Aktiver Step */
.sb-step-active .sb-step-circle { background: var(--green-deep); color: white; border-color: var(--green-deep); }
.sb-step-active .sb-step-label  { color: var(--green-deep); font-weight: 700; }

/* Erledigter Step */
.sb-step-done .sb-step-circle { background: var(--green-pale); color: var(--green-light); border-color: var(--green-light); }
.sb-step-done .sb-step-label  { color: var(--green-light); }
.sb-step-connector-done { background: var(--green-light); }

/* Thankyou Seite */
.sb-thankyou-wrap { padding: 2.5rem 0 5rem; max-width: 860px; }
.sb-thankyou-hero { text-align: center; padding: 2.5rem 1rem 2rem; background: var(--green-pale); border-radius: 14px; margin-bottom: 2rem; border: 1px solid rgba(74,124,82,0.15); }
.sb-thankyou-icon { font-size: 3rem; margin-bottom: 0.75rem; }
.sb-thankyou-hero h2 { font-family: 'Lora', serif; font-size: 1.5rem; font-weight: 700; color: var(--green-deep); margin-bottom: 0.5rem; }
.sb-thankyou-hero p { color: var(--text-mid); font-size: 0.9rem; max-width: 520px; margin: 0 auto; }

.sb-thankyou-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 1.25rem; margin-bottom: 1.25rem; }
.sb-thankyou-box { background: white; border: 1.5px solid var(--border); border-radius: 12px; padding: 1.5rem; }
.sb-thankyou-box h3 { font-family: 'Lora', serif; font-size: 0.95rem; font-weight: 700; color: var(--text-dark); margin-bottom: 1rem; padding-bottom: 0.6rem; border-bottom: 1px solid var(--border); }
.sb-thankyou-meta { display: flex; flex-direction: column; gap: 0.6rem; }
.sb-thankyou-meta-row { display: flex; justify-content: space-between; font-size: 0.84rem; color: var(--text-light); }
.sb-thankyou-meta-row strong { color: var(--text-dark); }
.sb-thankyou-total { padding-top: 0.65rem; border-top: 1px solid var(--border); font-size: 0.95rem !important; }
.sb-thankyou-total strong { color: var(--green-deep) !important; font-size: 1.05rem; }
.sb-order-status { background: var(--green-pale); color: var(--green-mid); padding: 0.15rem 0.5rem; border-radius: 4px; font-size: 0.78rem; }
.sb-thankyou-address { font-style: normal; font-size: 0.875rem; color: var(--text-mid); line-height: 1.6; }
.sb-thankyou-email { font-size: 0.84rem; color: var(--text-light); margin-top: 0.4rem; }
.sb-thankyou-products { margin-bottom: 1.25rem; }
.sb-thankyou-actions { display: flex; gap: 1rem; flex-wrap: wrap; }

@media (max-width: 640px) {
  .sb-steps-bar { gap: 0; }
  .sb-step-label { display: none; }
  .sb-step-connector { width: 24px; }
  .sb-thankyou-grid { grid-template-columns: 1fr; }
}

/* WC Standard Breadcrumb überall verstecken */
.woocommerce-breadcrumb, nav.woocommerce-breadcrumb { display: none !important; }

/* ============================================================
   ZAHLUNGSMETHODEN – KOMPLETT OVERRIDE
   ============================================================ */

/* Container */
#payment { background: transparent !important; border: none !important; padding: 0 !important; }

/* Zahlungsmethoden Liste */
#payment ul.payment_methods { 
  list-style: none !important; padding: 0 !important; 
  margin: 0 0 1.25rem !important; border: none !important;
  display: flex; flex-direction: column; gap: 0.6rem;
}

/* Einzelne Methode */
#payment ul.payment_methods li.payment_method_bacs,
#payment ul.payment_methods li.payment_method_cheque,
#payment ul.payment_methods li.payment_method_cod,
#payment ul.payment_methods li.payment_method_twint,
#payment ul.payment_methods li { 
  background: white !important; 
  border: 1.5px solid var(--border) !important; 
  border-radius: 10px !important; 
  padding: 0 !important;
  margin: 0 !important;
  overflow: hidden;
  transition: border-color 0.2s, box-shadow 0.2s;
}
#payment ul.payment_methods li:has(input:checked) { 
  border-color: var(--green-deep) !important; 
  box-shadow: 0 0 0 3px rgba(30,58,34,0.08) !important;
}

/* Label innerhalb der Methode */
#payment ul.payment_methods li label { 
  display: flex !important; 
  align-items: center !important; 
  gap: 0.75rem !important; 
  padding: 0.9rem 1.1rem !important;
  font-size: 0.9rem !important; 
  font-weight: 600 !important; 
  color: var(--text-dark) !important; 
  cursor: pointer !important;
  width: 100% !important;
  box-sizing: border-box !important;
}

/* Radio Button verstecken, eigenen bauen */
#payment ul.payment_methods li input[type="radio"] { 
  width: 18px !important; 
  height: 18px !important; 
  accent-color: var(--green-deep) !important;
  flex-shrink: 0 !important;
  cursor: pointer !important;
}

/* Logo im Label */
#payment ul.payment_methods li label img { 
  height: 24px !important; 
  width: auto !important; 
  max-width: 80px !important;
  object-fit: contain !important;
  border-radius: 4px;
  margin-left: auto !important;
}

/* Info-Box unter Zahlungsmethode */
#payment .payment_box { 
  background: var(--off-white) !important; 
  border-top: 1px solid var(--border) !important;
  border-radius: 0 !important; 
  padding: 0.75rem 1.1rem !important; 
  margin: 0 !important;
  font-size: 0.82rem !important; 
  color: var(--text-light) !important; 
  line-height: 1.5 !important;
}

/* AGB Checkbox */
.woocommerce-terms-and-conditions-wrapper { 
  margin-bottom: 1.25rem;
  padding: 0.9rem 1.1rem;
  background: var(--off-white);
  border-radius: 8px;
  border: 1.5px solid var(--border);
}
.woocommerce-terms-and-conditions-wrapper .woocommerce-form__label { 
  display: flex !important; 
  align-items: flex-start !important; 
  gap: 0.65rem !important;
  font-size: 0.84rem !important;
  color: var(--text-mid) !important;
  cursor: pointer;
  line-height: 1.5 !important;
}
.woocommerce-terms-and-conditions-wrapper input[type="checkbox"] {
  width: 17px !important;
  height: 17px !important;
  margin-top: 2px !important;
  accent-color: var(--green-deep) !important;
  flex-shrink: 0 !important;
  cursor: pointer !important;
}
.woocommerce-terms-and-conditions-wrapper a { 
  color: var(--green-deep) !important; 
  font-weight: 600; 
  text-decoration: underline;
}

/* Bestellung aufgeben Button */
#place_order { 
  width: 100% !important; 
  background: var(--green-deep) !important; 
  color: white !important; 
  border: none !important; 
  border-radius: 10px !important; 
  padding: 1rem !important; 
  font-size: 1rem !important; 
  font-weight: 700 !important; 
  font-family: 'Outfit', sans-serif !important; 
  cursor: pointer !important; 
  transition: background 0.2s, transform 0.1s !important; 
  letter-spacing: 0.02em;
  margin-bottom: 0 !important;
}
#place_order:hover { background: var(--green-mid) !important; }
#place_order:active { transform: scale(0.99) !important; }

/* Trust unter dem Button */
.sb-checkout-trust { 
  display: grid !important;
  grid-template-columns: 1fr 1fr !important;
  gap: 0.5rem !important;
  padding: 1rem !important;
  background: var(--off-white) !important;
  border-radius: 8px !important;
  margin-top: 1rem !important;
}
.sb-checkout-trust-item { 
  font-size: 0.78rem !important; 
  color: var(--text-light) !important;
  display: flex !important;
  align-items: center !important;
  gap: 0.35rem !important;
}


/* ============================================================
   ZAHLUNGSMETHODEN – FINAL CLEAN
   ============================================================ */

/* WC Breadcrumb überall killen */
.woocommerce-breadcrumb,
nav.woocommerce-breadcrumb,
.woocommerce-checkout .woocommerce-breadcrumb,
.woocommerce-cart .woocommerce-breadcrumb { display: none !important; visibility: hidden !important; height: 0 !important; margin: 0 !important; padding: 0 !important; }

/* Payment Container */
#payment { background: transparent !important; border: none !important; padding: 0 !important; margin: 0 !important; }
#payment ul.payment_methods { list-style: none !important; padding: 0 !important; margin: 0 0 1rem !important; border: none !important; display: flex; flex-direction: column; gap: 0.5rem; }

/* Jede Zahlungsmethode als saubere Karte */
#payment ul.payment_methods li { 
  background: white !important; 
  border: 1.5px solid var(--border) !important; 
  border-radius: 10px !important; 
  padding: 0 !important; margin: 0 !important;
  overflow: hidden; transition: border-color 0.2s, box-shadow 0.15s;
  list-style: none !important;
}
#payment ul.payment_methods li:hover { border-color: var(--green-light) !important; }
#payment ul.payment_methods li:has(input:checked) { 
  border-color: var(--green-deep) !important; 
  box-shadow: 0 0 0 3px rgba(30,58,34,0.08) !important; 
}

/* Label = klickbare Zeile */
#payment ul.payment_methods li label { 
  display: flex !important; align-items: center !important; gap: 0.85rem !important; 
  padding: 1rem 1.1rem !important; width: 100% !important; box-sizing: border-box !important;
  font-size: 0.9rem !important; font-weight: 600 !important; color: var(--text-dark) !important; 
  cursor: pointer !important; margin: 0 !important;
}
#payment ul.payment_methods li label img { 
  height: 22px !important; width: auto !important; max-width: 70px !important;
  object-fit: contain !important; margin-left: auto !important; border-radius: 3px;
}

/* Radio-Button custom */
#payment ul.payment_methods li input[type="radio"] { 
  width: 18px !important; height: 18px !important; margin: 0 !important;
  accent-color: var(--green-deep) !important; cursor: pointer !important; flex-shrink: 0 !important;
}

/* Beschreibungstext unter Methode */
#payment .payment_box { 
  background: #F7FAF7 !important; border-top: 1px solid var(--border) !important;
  border-radius: 0 !important; padding: 0.65rem 1.1rem !important; margin: 0 !important;
  font-size: 0.8rem !important; color: var(--text-light) !important; line-height: 1.5 !important;
}
#payment .payment_box p { margin: 0 !important; }

/* AGB Checkbox */
.woocommerce-terms-and-conditions-wrapper { 
  margin: 0 0 1rem !important; padding: 0.85rem 1rem !important;
  background: var(--off-white) !important; border-radius: 8px !important;
  border: 1.5px solid var(--border) !important;
}
.woocommerce-terms-and-conditions-wrapper .woocommerce-form__label-for-checkbox { 
  display: flex !important; align-items: flex-start !important; gap: 0.6rem !important;
  font-size: 0.83rem !important; color: var(--text-mid) !important; 
  cursor: pointer !important; line-height: 1.5 !important; margin: 0 !important;
}
.woocommerce-terms-and-conditions-wrapper input[type="checkbox"] {
  width: 16px !important; height: 16px !important; margin-top: 2px !important;
  accent-color: var(--green-deep) !important; flex-shrink: 0 !important; cursor: pointer !important;
}
.woocommerce-terms-and-conditions-wrapper a { color: var(--green-deep) !important; font-weight: 600; }

/* Place Order Button */
#place_order, .woocommerce-checkout #place_order { 
  width: 100% !important; display: block !important;
  background: var(--green-deep) !important; color: white !important; 
  border: none !important; border-radius: 10px !important; 
  padding: 1rem 1.5rem !important; font-size: 1rem !important; font-weight: 700 !important; 
  font-family: 'Outfit', sans-serif !important; cursor: pointer !important; 
  transition: background 0.2s !important; letter-spacing: 0.02em; margin: 0 !important;
}
#place_order:hover { background: var(--green-mid) !important; }

/* Trust Grid */
.sb-checkout-trust { 
  display: grid !important; grid-template-columns: 1fr 1fr !important; gap: 0.45rem !important;
  padding: 0.9rem 1rem !important; background: var(--off-white) !important;
  border-radius: 8px !important; margin-top: 0.85rem !important;
}
.sb-checkout-trust-item { font-size: 0.77rem !important; color: var(--text-light) !important; display: flex !important; align-items: center !important; gap: 0.3rem !important; }

/* ============================================================
   ZAHLUNGSMETHODEN – Radio inline mit Label
   ============================================================ */
#payment ul.payment_methods li label {
  flex-direction: row !important;
  align-items: center !important;
  gap: 0.75rem !important;
  padding: 0.9rem 1.1rem !important;
  min-height: unset !important;
}
/* Radio direkt neben Text, kein separater Block oben */
#payment ul.payment_methods li input[type="radio"] {
  position: static !important;
  float: none !important;
  margin: 0 !important;
  width: 18px !important;
  height: 18px !important;
  flex-shrink: 0 !important;
  order: 0 !important;
}
/* Text direkt daneben */
#payment ul.payment_methods li label span,
#payment ul.payment_methods li label {
  display: flex !important;
  align-items: center !important;
  width: 100% !important;
}
/* Methodenname */
#payment ul.payment_methods li .wc-payment-method-title,
#payment ul.payment_methods li label > span:not(:last-child) { order: 1 !important; }
/* Logo ganz rechts */
#payment ul.payment_methods li label img { order: 2 !important; margin-left: 0.5rem !important; }


/* ============================================================
   PAYMENT + GUTSCHEIN FINAL FIX
   ============================================================ */

/* Payment: alles in einer Zeile mit ruby-ähnlichem Inline-Layout */
#payment ul.payment_methods li.wc_payment_method { display: block !important; }
#payment ul.payment_methods li.wc_payment_method > label {
  display: flex !important;
  flex-direction: row !important;
  align-items: center !important;
  gap: 0.75rem !important;
  padding: 0.85rem 1.1rem !important;
  width: 100% !important;
  box-sizing: border-box !important;
  cursor: pointer !important;
}
#payment ul.payment_methods li.wc_payment_method > label input[type="radio"] {
  display: inline-block !important;
  vertical-align: middle !important;
  width: 17px !important; height: 17px !important;
  margin: 0 !important; padding: 0 !important;
  flex-shrink: 0 !important;
  accent-color: var(--green-deep) !important;
}
#payment ul.payment_methods li.wc_payment_method > label img {
  display: inline-block !important;
  margin-left: auto !important;
  height: 22px !important; width: auto !important;
  vertical-align: middle !important;
}

/* Gutschein-Notice – schöne eigene Box */
.woocommerce-info.woocommerce-form-coupon-toggle {
  display: flex !important;
  align-items: center !important;
  gap: 0.6rem !important;
  background: white !important;
  border: 1.5px solid var(--border) !important;
  border-left: 4px solid var(--green-light) !important;
  border-radius: 8px !important;
  padding: 0.9rem 1.25rem 0.9rem 1.4rem !important;
  margin-bottom: 1.5rem !important;
  font-size: 0.875rem !important;
  color: var(--text-mid) !important;
  box-shadow: none !important;
}
.woocommerce-info.woocommerce-form-coupon-toggle::before { content: '🏷️'; font-style: normal !important; margin-right: 0.4rem; flex-shrink: 0; }
.woocommerce-info.woocommerce-form-coupon-toggle a {
  color: var(--green-deep) !important;
  font-weight: 600 !important;
  text-decoration: none !important;
  border-bottom: 1px dashed var(--green-light);
}
.woocommerce-info.woocommerce-form-coupon-toggle a:hover { border-bottom-style: solid; }

/* Gutschein-Formular wenn ausgeklappt */
.woocommerce-form-coupon {
  background: var(--off-white) !important;
  border: 1.5px solid var(--border) !important;
  border-radius: 8px !important;
  padding: 1rem 1.25rem !important;
  margin-bottom: 1.5rem !important;
  display: flex !important;
  align-items: flex-end !important;
  gap: 0.75rem !important;
  flex-wrap: wrap !important;
}
.woocommerce-form-coupon p { margin: 0 !important; flex: 1 !important; min-width: 200px !important; }
.woocommerce-form-coupon input#coupon_code {
  border: 1.5px solid var(--border) !important;
  border-radius: 8px !important;
  padding: 0.6rem 0.9rem !important;
  font-family: 'Outfit', sans-serif !important;
  font-size: 0.875rem !important;
  width: 100% !important;
  box-sizing: border-box !important;
}
.woocommerce-form-coupon input#coupon_code:focus { border-color: var(--green-deep) !important; outline: none !important; }
.woocommerce-form-coupon .button {
  background: var(--green-deep) !important;
  color: white !important;
  border: none !important;
  border-radius: 8px !important;
  padding: 0.6rem 1.25rem !important;
  font-size: 0.875rem !important;
  font-weight: 600 !important;
  font-family: 'Outfit', sans-serif !important;
  cursor: pointer !important;
  white-space: nowrap !important;
  transition: background 0.2s !important;
}
.woocommerce-form-coupon .button:hover { background: var(--green-mid) !important; }


/* TWINT Logo Margin Fix */
#payment ul.payment_methods li img,
.woocommerce-checkout #payment ul.payment_methods li img,
ul.payment_methods li img { margin-left: 0 !important; margin: 0 !important; }


/* TWINT Logo – kein Auto-Margin, direkt neben Text */
#payment ul.payment_methods li label img,
#payment ul.payment_methods li.payment_method_mame_twint label img,
#payment ul.payment_methods li.payment_method_twint label img {
  margin-left: 0.5rem !important;
  margin-right: 0 !important;
}
.sb-nav-actions { display: flex; gap: 0.75rem; align-items: center; margin-left: auto; }

/* ============================================================
   SINGLE PRODUCT PAGE
   ============================================================ */
.sb-breadcrumb { background: var(--off-white); border-bottom: 1px solid var(--border); padding: 0.75rem 0; font-size: 0.82rem; }
.sb-breadcrumb-inner { max-width: 1240px; margin: 0 auto; padding: 0 2.5rem; display: flex; align-items: center; gap: 0.4rem; flex-wrap: wrap; }
.sb-breadcrumb a { color: var(--text-light); text-decoration: none; transition: color 0.15s; }
.sb-breadcrumb a:hover { color: var(--green-deep); }
.sb-breadcrumb-sep { color: var(--text-light); opacity: 0.5; }
.sb-breadcrumb-current { color: var(--text-mid); font-weight: 500; }

.sb-product-page { padding: 3rem 0 4rem; }
.sb-product-page .sb-product-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 4rem;
  align-items: start;
}

/* Bilder-Spalte */
.sb-product-images { position: sticky; top: 120px; }
.sb-product-main-img { background: var(--off-white); border-radius: 16px; overflow: hidden; aspect-ratio: 1; display: flex; align-items: center; justify-content: center; position: relative; border: 1.5px solid var(--border); }
.sb-product-main-img img { width: 100%; height: 100%; object-fit: contain; transition: transform 0.3s; }
.sb-product-main-img:hover img { transform: scale(1.04); }
.sb-product-badge-img { position: absolute; top: 14px; left: 14px; background: var(--green-deep); color: white; font-size: 0.72rem; font-weight: 600; padding: 0.3rem 0.8rem; border-radius: 20px; text-transform: uppercase; letter-spacing: 0.06em; }
.sb-product-thumbs { display: flex; gap: 0.6rem; margin-top: 0.75rem; flex-wrap: wrap; }
.sb-product-thumb { width: 68px; height: 68px; border-radius: 8px; overflow: hidden; cursor: pointer; border: 2px solid var(--border); background: var(--off-white); transition: border-color 0.15s; flex-shrink: 0; }
.sb-product-thumb img { width: 100%; height: 100%; object-fit: contain; }
.sb-product-thumb.active, .sb-product-thumb:hover { border-color: var(--green-deep); }

/* Info-Spalte */
.sb-product-cat-tag { display: inline-flex; align-items: center; gap: 0.35rem; background: var(--green-pale); color: var(--green-mid); font-size: 0.78rem; font-weight: 600; padding: 0.3rem 0.85rem; border-radius: 20px; text-decoration: none; margin-bottom: 0.85rem; transition: background 0.15s; }
.sb-product-cat-tag:hover { background: #d0e8d4; }
.sb-product-title { font-family: 'Lora', serif; font-size: clamp(1.4rem, 2.5vw, 2rem); font-weight: 700; line-height: 1.2; color: var(--text-dark); margin: 0 0 0.5rem; }
.sb-product-subtitle { color: var(--text-mid); font-size: 0.9rem; margin: 0 0 1rem; }
.sb-product-badges { display: flex; flex-wrap: wrap; gap: 0.4rem; margin-bottom: 1.25rem; }
.sb-badge { display: inline-flex; align-items: center; gap: 0.25rem; font-size: 0.72rem; font-weight: 600; padding: 0.3rem 0.75rem; border-radius: 20px; }
.sb-badge-green { background: var(--green-pale); color: var(--green-mid); }
.sb-badge-gold { background: #FDF4E3; color: #8B6914; }

.sb-product-price-row { display: flex; align-items: baseline; gap: 0.6rem; margin-bottom: 0.3rem; }
.sb-product-price { font-size: 2rem; font-weight: 700; color: var(--text-dark); }
.sb-product-price ins { text-decoration: none; }
.sb-product-price del { font-size: 1.2rem; color: var(--text-light); font-weight: 400; }
.sb-product-unit { font-size: 0.85rem; color: var(--text-light); }
.sb-product-shipping { font-size: 0.82rem; color: var(--text-light); margin: 0 0 1.5rem; }
.sb-product-shipping a { color: var(--green-mid); text-decoration: none; }

/* WooCommerce Add-to-Cart */
.sb-woo-form { margin-bottom: 1rem; }
.sb-woo-form .quantity { display: inline-flex; align-items: center; }
.sb-woo-form .qty { border: 1.5px solid var(--border); border-radius: 8px; padding: 0.55rem 0.75rem; font-size: 1rem; width: 68px; text-align: center; font-family: 'Outfit', sans-serif; }
.sb-woo-form .single_add_to_cart_button {
  background: var(--green-deep) !important;
  color: white !important;
  border: none !important;
  border-radius: 10px !important;
  padding: 0.75rem 2rem !important;
  font-size: 1rem !important;
  font-weight: 600 !important;
  cursor: pointer !important;
  font-family: 'Outfit', sans-serif !important;
  transition: background 0.2s !important;
  margin-left: 0.75rem !important;
}
.sb-woo-form .single_add_to_cart_button:hover { background: var(--green-mid) !important; }

/* Formular bestellen Link */
.sb-btn-order { display: inline-flex; align-items: center; gap: 0.4rem; font-size: 0.875rem; color: var(--green-mid); text-decoration: none; font-weight: 500; margin-bottom: 1.5rem; border-bottom: 1px dashed var(--green-light); padding-bottom: 0.1rem; transition: color 0.15s; }
.sb-btn-order:hover { color: var(--green-deep); }

/* Trust Items */
.sb-product-trust { display: flex; flex-direction: column; gap: 0.5rem; background: var(--off-white); border-radius: 10px; padding: 1rem 1.25rem; margin-bottom: 1.5rem; border: 1px solid var(--border); }
.sb-product-trust-item { display: flex; align-items: center; gap: 0.6rem; font-size: 0.85rem; color: var(--text-mid); }
.sb-product-trust-icon { font-size: 1rem; }

/* Tabs */
.sb-product-tabs { display: flex; gap: 0; border-bottom: 2px solid var(--border); margin-bottom: 1.25rem; }
.sb-tab-btn { background: none; border: none; border-bottom: 2px solid transparent; margin-bottom: -2px; padding: 0.6rem 1.1rem; font-family: 'Outfit', sans-serif; font-size: 0.875rem; font-weight: 500; color: var(--text-light); cursor: pointer; transition: all 0.15s; }
.sb-tab-btn.active { color: var(--green-deep); border-bottom-color: var(--green-deep); }
.sb-tab-btn:hover { color: var(--text-mid); }
.sb-tab-content { display: none; }
.sb-tab-content.active { display: block; }
.sb-tab-text { font-size: 0.9rem; color: var(--text-mid); line-height: 1.75; }
.sb-tab-list { padding-left: 1.25rem; margin: 0.75rem 0; }
.sb-tab-list li { font-size: 0.875rem; color: var(--text-mid); margin-bottom: 0.4rem; }
.sb-ingredients-table { width: 100%; border-collapse: collapse; font-size: 0.875rem; }
.sb-ingredients-table th { background: var(--off-white); padding: 0.5rem 0.75rem; text-align: left; font-weight: 600; color: var(--text-dark); font-size: 0.8rem; text-transform: uppercase; letter-spacing: 0.05em; }
.sb-ingredients-table td { padding: 0.5rem 0.75rem; border-bottom: 1px solid var(--border); color: var(--text-mid); }
.sb-ingredients-table tr:last-child td { border-bottom: none; }

/* Ähnliche Produkte */
.sb-related { background: var(--off-white); border-top: 1px solid var(--border); padding: 3.5rem 0 4rem; }
.sb-related-header { display: flex; justify-content: space-between; align-items: flex-end; margin-bottom: 1.75rem; }
.sb-related-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1rem; }

/* Mobile Single Product */
@media (max-width: 768px) {
  .sb-product-page { padding: 1.5rem 0 3rem; }
  .sb-product-page .sb-product-grid {
    grid-template-columns: 1fr !important;
    gap: 1.5rem;
  }
  .sb-product-images { position: static; }
  .sb-product-title { font-size: 1.4rem; }
  .sb-product-price { font-size: 1.6rem; }
  .sb-woo-form .single_add_to_cart_button { width: 100%; margin-left: 0 !important; margin-top: 0.75rem !important; }
  .sb-woo-form form.cart { display: flex; flex-direction: column; gap: 0.5rem; }
  .sb-related-grid { grid-template-columns: repeat(2, 1fr); }
  .sb-related-header { flex-direction: column; align-items: flex-start; gap: 0.75rem; }
  .sb-breadcrumb-inner { padding: 0 1rem; }
}
@media (max-width: 480px) {
  .sb-product-thumbs { gap: 0.4rem; }
  .sb-product-thumb { width: 56px; height: 56px; }
  .sb-related-grid { grid-template-columns: 1fr; }
}

/* ============================================================
   MOBILE RESPONSIVE – NAVIGATION & LAYOUT (max-width: 960px)
   ============================================================ */

@media (max-width: 960px) {

  /* --- NAV: Hamburger einblenden, Desktop-Elemente ausblenden --- */
  .sb-nav-hamburger { display: flex !important; margin-left: auto; }
  .sb-nav-actions   { display: none !important; }
  .sb-nav-catbar    { display: none !important; }
  .sb-nav-search    { max-width: 100% !important; flex: 1; }

  .sb-nav-inner {
    padding: 0 1rem;
    height: 60px;
    gap: 0.75rem;
  }

  /* Mobile-Menu: verschiebt Ankerpunkt auf neue Nav-Höhe */
  .sb-mobile-menu { top: 60px !important; }

  /* --- HERO: Einspaltig --- */
  .sb-hero-inner {
    grid-template-columns: 1fr !important;
    min-height: auto !important;
    padding: 0 1.25rem !important;
    gap: 1.5rem;
  }
  .sb-hero-content  { padding: 2.5rem 0 1rem; }
  .sb-hero-visual   { justify-content: center; padding: 0 0 2rem; }
  .sb-hero-img      { max-height: 280px; width: 100%; object-fit: contain; border-radius: 12px; }
  .sb-hero h1       { font-size: clamp(1.7rem, 5vw, 2.4rem); }

  /* --- TRUST BAR: scrollbar horizontal --- */
  .sb-trustbar-inner {
    display: flex;
    overflow-x: auto;
    gap: 0;
    padding: 0 1rem;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
  }
  .sb-trustbar-inner::-webkit-scrollbar { display: none; }
  .sb-trust-item {
    flex: 0 0 auto;
    min-width: 160px;
    padding: 0.85rem 1rem;
    border-right: 1px solid rgba(255,255,255,0.1);
  }

  /* --- PRODUKTGRID: 2 Spalten --- */
  .sb-products-grid {
    grid-template-columns: repeat(2, 1fr) !important;
    gap: 0.85rem !important;
  }

  /* --- WRAP: kleinere Seitenränder --- */
  .sb-wrap { padding: 0 1.25rem !important; }

  /* --- FOOTER: 1 Spalte --- */
  .sb-footer-top { grid-template-columns: 1fr !important; gap: 1.5rem !important; }
  .sb-footer-bottom { flex-direction: column; text-align: center; gap: 0.4rem; }
  .sb-footer-inner { padding: 0 1.25rem !important; }

  /* --- ÜBER UNS: 1 Spalte --- */
  .sb-ueber-uns-inner { grid-template-columns: 1fr !important; }
  .sb-ueber-uns-cards { grid-template-columns: 1fr !important; }

  /* --- BOTTOM BANNER --- */
  .sb-bottom-banner-inner { grid-template-columns: 1fr !important; gap: 1.5rem; }
  .sb-bottom-banner-actions { flex-direction: row; flex-wrap: wrap; }

}

/* ============================================================
   MOBILE RESPONSIVE – KLEINE SCREENS (max-width: 480px)
   ============================================================ */

@media (max-width: 480px) {

  /* Suche kompakter */
  .sb-nav-search { display: none !important; }

  /* Produktgrid: 1 Spalte auf sehr kleinen Screens */
  .sb-products-grid {
    grid-template-columns: 1fr !important;
  }

  /* Hero noch kompakter */
  .sb-hero-content { padding: 2rem 0 0.75rem; }
  .sb-hero p { font-size: 0.9rem; }
  .sb-hero-btns { flex-direction: column; }
  .sb-hero-btns .sb-btn { width: 100%; justify-content: center; padding: 0.75rem 1rem; font-size: 0.9rem; }

  /* Trust items noch schmaler */
  .sb-trust-item { min-width: 140px; }

  /* Section titles */
  .sb-section-title { font-size: clamp(1.3rem, 4vw, 1.7rem) !important; }

}

/* ============================================================
   HAMBURGER ANIMATION (open-State)
   ============================================================ */
.sb-nav-hamburger.open span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.sb-nav-hamburger.open span:nth-child(2) { opacity: 0; }
.sb-nav-hamburger.open span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

/* ============================================================
   MOBILE MENU – WARENKORB & BESTELLEN BUTTON
   ============================================================ */
.sb-mobile-actions {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
  margin-top: 1rem;
  padding-top: 1rem;
  border-top: 1px solid var(--border);
}
.sb-mobile-cart {
  display: flex;
  align-items: center;
  gap: 0.6rem;
  padding: 0.8rem 1rem;
  border-radius: 8px;
  border: 1.5px solid var(--border);
  color: var(--text-mid);
  font-size: 0.95rem;
  font-weight: 500;
  text-decoration: none;
  transition: all 0.15s;
}
.sb-mobile-cart:hover { border-color: var(--green-deep); color: var(--green-deep); background: var(--green-pale); }
.sb-mobile-cart-count {
  background: var(--green-deep);
  color: white;
  font-size: 0.72rem;
  font-weight: 700;
  padding: 0.1rem 0.5rem;
  border-radius: 20px;
  margin-left: auto;
}
.sb-mobile-bestellen {
  width: 100%;
  justify-content: center;
  padding: 0.8rem 1rem !important;
  font-size: 0.95rem !important;
  border-radius: 8px;
}

/* ============================================================
   MOBILE MENU – ACCORDION & LINK STYLES
   ============================================================ */

/* Normaler Link-Eintrag */
.sb-mobile-link {
  display: block;
  padding: 0.8rem 1rem;
  border-radius: 8px;
  color: var(--text-mid);
  font-size: 0.95rem;
  font-weight: 500;
  border-bottom: 1px solid var(--border);
  text-decoration: none;
  transition: background 0.15s, color 0.15s;
}
.sb-mobile-link:hover { background: var(--green-pale); color: var(--green-deep); }

/* Accordion (Einträge mit Untermenü) */
.sb-mobile-accordion { border-bottom: 1px solid var(--border); }

.sb-mobile-accordion-btn {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0.8rem 1rem;
  background: none;
  border: none;
  font-family: 'Outfit', sans-serif;
  font-size: 0.95rem;
  font-weight: 500;
  color: var(--text-mid);
  cursor: pointer;
  text-align: left;
  transition: color 0.15s;
}
.sb-mobile-accordion-btn:hover,
.sb-mobile-accordion-btn[aria-expanded="true"] { color: var(--green-deep); }

.sb-mobile-chevron {
  font-size: 0.6rem;
  transition: transform 0.25s;
  flex-shrink: 0;
}
.sb-mobile-accordion-btn[aria-expanded="true"] .sb-mobile-chevron {
  transform: rotate(180deg);
}

/* Accordion Body */
.sb-mobile-accordion-body {
  display: flex;
  flex-direction: column;
  background: var(--off-white);
  border-top: 1px solid var(--border);
  padding: 0.4rem 0;
  max-height: 0;
  opacity: 0;
  overflow: hidden;
  transition: max-height 0.3s ease, opacity 0.25s ease;
}
.sb-mobile-accordion-body.open { display: flex; }

.sb-mobile-sub-link {
  display: block;
  padding: 0.65rem 1.5rem;
  font-size: 0.88rem;
  color: var(--text-mid);
  text-decoration: none;
  transition: background 0.12s, color 0.12s;
}
.sb-mobile-sub-link:hover { background: var(--green-pale); color: var(--green-deep); }
.sb-mobile-sub-all {
  font-weight: 600;
  color: var(--green-mid);
  border-top: 1px solid var(--border);
  margin-top: 0.25rem;
  padding-top: 0.65rem;
}

/* Suche mit Icon */
.sb-mobile-search {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  border: 1.5px solid var(--border);
  border-radius: 8px;
  overflow: hidden;
  margin-bottom: 0.75rem;
  padding: 0 0.75rem;
  height: 42px;
  background: var(--off-white);
}
.sb-mobile-search svg { color: var(--text-light); flex-shrink: 0; }
.sb-mobile-search input[type="search"] {
  flex: 1;
  border: none;
  background: none;
  padding: 0;
  font-family: 'Outfit', sans-serif;
  font-size: 0.9rem;
  outline: none;
  color: var(--text-dark);
}
