/*
Theme Name:  Hof Wunderlich
Theme URI:   https://hof-wunderlich.at
Author:      Hof Wunderlich
Description: Saisonales Theme für Erdbeer- & Kürbishof Wunderlich – Waldviertel & Stockerau
Version:     1.0
License:     GNU General Public License v2 or later
Text Domain: hof-wunderlich
*/

:root {
  --strawberry:    #D93A52; --strawberry-bg: #FFF0F2;
  --waldviertel:   #5C8C3A; --waldviertel-bg:#F0F7EA;
  --tulip:         #C0559A; --tulip-bg:      #FDF0F8;
  --pumpkin:       #D96B0A; --pumpkin-bg:    #FFF3E8;
  --breakfast:     #2E7D5E; --breakfast-bg:  #EEF7F3;
  --saison:        #5C6BC0; --saison-bg:     #EEF0FF;
  --dark:#1E1810; --mid:#5a4a40; --light:#FAF6F1; --white:#FFFFFF;
  --border:rgba(30,24,16,.09); --nav-h:76px; --radius:20px;
  --shadow:0 8px 40px rgba(30,24,16,.13);
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:'DM Sans',sans-serif;background:var(--light);color:var(--dark);overflow-x:hidden}

h1 {
	word-break: break-word;
}
/* NAV */
.nav-wrap{top:0;z-index:510;background:var(--white);border-bottom:1.5px solid var(--border);box-shadow:0 2px 20px rgba(30,24,16,.05)}
.nav-inner{max-width:1320px;margin:0 auto;height:var(--nav-h);display:flex;align-items:center;padding:0 32px}
.logo{display:flex;align-items:center;gap:11px;text-decoration:none;margin-right:auto;flex-shrink:0}
.custom-logo-link {
  display: flex;
  align-items: center;
}

.custom-logo-link img,
.custom-logo {
  height: 52px;
  width: auto;
  display: block;
}

/* Logo immer links, Rest rechts */
.nav-inner {
  justify-content: space-between;
}

.custom-logo-link {
  margin-right: auto;
  display: flex;
  align-items: center;
}

.custom-logo-link img,
.custom-logo {
  height: 52px;
  width: auto;
  display: block;
}

/* Das leere .logo <a> ausblenden wenn custom logo aktiv */
.custom-logo-link ~ .logo {
  display: none;
}
.logo-mark{width:44px;height:44px;border-radius:14px;background:var(--light);display:flex;align-items:center;justify-content:center;font-size:22px;transition:transform .35s}
.logo:hover .logo-mark{transform:rotate(-8deg) scale(1.08)}
.logo-copy b{display:block;font-family:'Lora',serif;font-size:1.15rem;color:var(--dark);line-height:1.15}
.logo-copy small{font-size:11px;font-weight:500;color:var(--mid);letter-spacing:.08em;text-transform:uppercase}
.nav-items,.nav-items ul{list-style:none;margin:0;padding:0}
.nav-items{display:flex;align-items:center;height:100%;gap:0}
.nav-items>li{position:static;height:100%;display:flex;align-items:center}
.nav-items>li>a{padding:0 16px;height:100%;display:flex;align-items:center;font-size:14px;font-weight:700;color:var(--dark);text-decoration:none;position:relative;transition:color .2s;white-space:nowrap}
.nav-items>li>a::after{content:'';position:absolute;bottom:0;left:16px;right:16px;height:3px;border-radius:3px 3px 0 0;background:var(--strawberry);transform:scaleX(0);transition:transform .25s}
.nav-items>li>a:hover{color:var(--strawberry)}
.nav-items>li>a:hover::after{transform:scaleX(1)}
.nav-item{position:static!important;height:100%;display:flex;align-items:center}
.nav-trigger{display:flex;align-items:center;gap:5px;padding:0 16px;height:100%;font-size:14px;font-weight:700;color:var(--dark);background:none;border:none;cursor:pointer;font-family:'DM Sans',sans-serif;white-space:nowrap;position:relative;transition:color .2s}
.nav-trigger::after{content:'';position:absolute;bottom:0;left:16px;right:16px;height:3px;border-radius:3px 3px 0 0;background:currentColor;transform:scaleX(0);transition:transform .25s}
.nav-item.open .nav-trigger{color:var(--accent,var(--strawberry))}
.nav-item.open .nav-trigger::after{transform:scaleX(1)}
.nav-trigger svg{width:11px;height:11px;transition:transform .25s;stroke:currentColor;fill:none;stroke-width:2.5;stroke-linecap:round;stroke-linejoin:round;flex-shrink:0}
.nav-item.open .nav-trigger svg{transform:rotate(180deg)}
.nav-cta{margin-left:10px;padding:9px 20px;border-radius:50px;background:var(--dark);color:white!important;font-size:13px;font-weight:700;text-decoration:none;transition:transform .2s,background .2s;white-space:nowrap}
.nav-cta:hover{background:var(--strawberry)!important;transform:translateY(-1px)}

/* MEGA */
.mega{position:absolute;top:var(--nav-h);left:0;right:0;background:var(--white);border-top:1.5px solid var(--border);border-bottom:1.5px solid var(--border);box-shadow:0 20px 60px rgba(30,24,16,.12);pointer-events:none;opacity:0;transform:translateY(-10px);transition:opacity .28s,transform .28s;z-index:400}
.nav-item.open .mega{pointer-events:auto;opacity:1;transform:translateY(0)}
.mega-inner{max-width:1320px;margin:0 auto;padding:36px 32px 40px;display:grid;gap:36px}
.mega-intro{display:flex;flex-direction:column;justify-content:center;padding-right:32px;border-right:1.5px solid var(--border)}
.mega-intro .mi-eyebrow{font-size:11px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;margin-bottom:10px}
.mega-intro h3{font-family:'Lora',serif;font-size:1.4rem;line-height:1.2;color:var(--dark);margin-bottom:11px}
.mega-intro h3 i{font-style:italic}
.mega-intro p{font-size:13px;color:var(--mid);line-height:1.65;margin-bottom:18px}
.mega-intro-cta{display:inline-flex;align-items:center;gap:6px;font-size:13px;font-weight:700;text-decoration:none;transition:gap .2s}
.mega-intro-cta:hover{gap:10px}
.mega-cards{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.mega-card{border-radius:14px;overflow:hidden;text-decoration:none;display:flex;align-items:stretch;transition:transform .3s,box-shadow .3s;border:1.5px solid var(--border);background:white}
.mega-card:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:transparent}
.mega-card-accent{width:5px;flex-shrink:0}
.mega-card-content{padding:14px 16px;display:flex;align-items:center;gap:12px;flex:1}
.mega-card-icon{font-size:32px;flex-shrink:0;line-height:1;animation:cardWobble 5s ease-in-out infinite}
@keyframes cardWobble{0%,100%{transform:rotate(-4deg) scale(1)}50%{transform:rotate(4deg) scale(1.06)}}
.mega-card:nth-child(2) .mega-card-icon{animation-delay:.7s}
.mega-card:nth-child(3) .mega-card-icon{animation-delay:1.4s}
.mega-card:nth-child(4) .mega-card-icon{animation-delay:2.1s}
.mega-card-text{flex:1;min-width:0}
.mega-card-text h4{font-family:'Lora',serif;font-size:.95rem;color:var(--dark);margin-bottom:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.mega-card-text p{font-size:11.5px;color:var(--mid);line-height:1.4}
.mega-card-badge{font-size:10px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:white;border-radius:50px;padding:3px 8px;align-self:flex-start;flex-shrink:0}

#navWaldviertel{--accent:var(--waldviertel)}
#navWaldviertel .mega-inner{grid-template-columns:240px 1fr}
#navWaldviertel .mega-intro .mi-eyebrow{color:var(--waldviertel)}
#navWaldviertel .mega-intro h3 i{color:var(--waldviertel)}
#navWaldviertel .mega-intro-cta{color:var(--waldviertel)}
#navWaldviertel .mega-cards{grid-template-columns:1fr 1fr;grid-template-rows:auto auto}
#navWaldviertel .mega-card-hero{grid-column:span 2;border-radius:16px;overflow:hidden;text-decoration:none;display:flex;align-items:stretch;transition:transform .3s,box-shadow .3s;border:1.5px solid var(--border);background:white;min-height:80px}
#navWaldviertel .mega-card-hero:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:transparent}
#navWaldviertel .mega-card-hero .mega-card-accent{width:5px;background:var(--waldviertel);flex-shrink:0}
#navWaldviertel .mega-card-hero .mega-card-content{padding:18px 20px;gap:16px}
#navWaldviertel .mega-card-hero .mega-card-icon{font-size:44px}
#navWaldviertel .mega-card-hero .mega-card-text h4{font-size:1.15rem;white-space:normal}
#navWaldviertel .mega-card-hero .mega-card-text p{font-size:12.5px}
.mc-waldviertel .mega-card-accent{background:var(--waldviertel)}.mc-waldviertel .mega-card-badge{background:var(--waldviertel)}
.mc-wv-jam .mega-card-accent{background:#A0522D}.mc-wv-jam .mega-card-badge{background:#A0522D}
.mc-wv-online .mega-card-accent{background:var(--saison)}.mc-wv-online .mega-card-badge{background:var(--saison)}

#navSaison{--accent:var(--strawberry)}
#navSaison .mega-inner{grid-template-columns:240px 1fr}
#navSaison .mega-intro .mi-eyebrow{color:var(--strawberry)}
#navSaison .mega-intro h3 i{color:var(--strawberry)}
#navSaison .mega-intro-cta{color:var(--strawberry)}
.mc-tulip .mega-card-accent{background:var(--tulip)}.mc-tulip .mega-card-badge{background:var(--tulip)}
.mc-strawberry .mega-card-accent{background:var(--strawberry)}.mc-strawberry .mega-card-badge{background:var(--strawberry)}
.mc-breakfast .mega-card-accent{background:var(--breakfast)}.mc-breakfast .mega-card-badge{background:var(--breakfast)}
.mc-pumpkin .mega-card-accent{background:var(--pumpkin)}.mc-pumpkin .mega-card-badge{background:var(--pumpkin)}

/* BURGER + MOBILE */
.burger{display:none;flex-direction:column;justify-content:center;gap:5px;width:40px;height:40px;background:none;border:none;cursor:pointer;padding:4px;margin-left:8px;border-radius:10px;transition:background .2s;flex-shrink:0}
.burger:hover,
.burger:focus,
.burger:active {
  background: none;
  outline: none;
}
.burger span{display:block;height:2.5px;border-radius:3px;background:var(--dark);transition:transform .3s,opacity .3s,width .3s;transform-origin:center}
.burger span:nth-child(1){width:22px}.burger span:nth-child(2){width:28px}.burger span:nth-child(3){width:18px}
.burger.is-open span:nth-child(1){width:26px;transform:translateY(7.5px) rotate(45deg)}
.burger.is-open span:nth-child(2){opacity:0;transform:scaleX(0)}
.burger.is-open span:nth-child(3){width:26px;transform:translateY(-7.5px) rotate(-45deg)}

.mobile-menu-inner{padding:22px 20px 30px;display:flex;flex-direction:column;gap:0}
.mob-category{margin-bottom:18px}
.mob-section-label{font-size:11px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;margin-bottom:10px;display:flex;align-items:center;gap:6px}
.mob-section-label.wv{color:var(--waldviertel)}.mob-section-label.sai{color:var(--strawberry)}
.mob-season-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.mob-season-card{border-radius:13px;padding:13px 11px;text-decoration:none;display:flex;flex-direction:column;gap:3px;transition:transform .2s}
.mob-season-card:active{transform:scale(.97)}
.msc-waldviertel{background:var(--waldviertel-bg)}.msc-strawberry{background:var(--strawberry-bg)}
.msc-tulip{background:var(--tulip-bg)}.msc-pumpkin{background:var(--pumpkin-bg)}.msc-breakfast{background:var(--breakfast-bg)}
.msc-icon{font-size:24px;line-height:1;margin-bottom:3px}
.msc-name{font-size:13px;font-weight:700;color:var(--dark)}
.msc-time{font-size:10px;font-weight:700;letter-spacing:.05em;text-transform:uppercase}
.msc-waldviertel .msc-time{color:var(--waldviertel)}.msc-strawberry .msc-time{color:var(--strawberry)}
.msc-tulip .msc-time{color:var(--tulip)}.msc-pumpkin .msc-time{color:var(--pumpkin)}.msc-breakfast .msc-time{color:var(--breakfast)}
.mob-divider{height:1.5px;background:var(--border);margin:16px 0}
.mob-links{display:flex;flex-direction:column;gap:2px;margin-bottom:18px}
.mob-links a{text-decoration:none;font-size:15px;font-weight:700;color:var(--dark);padding:9px 4px;border-radius:8px;transition:color .2s,background .2s,padding-left .2s}
.mob-links a:hover{color:var(--strawberry);background:var(--strawberry-bg);padding-left:12px}
.mob-cta{text-align:center;justify-content:center;width:100%}

/* HERO */
.hero{position:relative;min-height:calc(100vh - var(--nav-h));display:flex;align-items:center;overflow:hidden;background:linear-gradient(145deg,#F0F7EA 0%,var(--light) 45%,#FFF0F5 100%)}
.blob{position:absolute;border-radius:50%;filter:blur(70px);opacity:.3;pointer-events:none}
.blob-1{width:520px;height:520px;background:#C8E6A0;top:-140px;right:-60px;animation:blobFloat 10s ease-in-out infinite}
.blob-2{width:360px;height:360px;background:#FFD6DE;bottom:-80px;left:-50px;animation:blobFloat 13s ease-in-out infinite reverse}
.blob-3{width:220px;height:220px;background:#FFD9B0;top:40%;left:38%;animation:blobFloat 8s ease-in-out infinite 2s}
@keyframes blobFloat{0%,100%{transform:translate(0,0) scale(1)}40%{transform:translate(20px,-28px) scale(1.06)}70%{transform:translate(-14px,14px) scale(.95)}}
.hero-content{position:relative;z-index:2;max-width:1320px;margin:0 auto;padding:80px 32px;display:grid;grid-template-columns:1fr 1fr;align-items:center;gap:60px;width:100%}
.eyebrow{display:inline-flex;align-items:center;gap:8px;background:white;border:1.5px solid var(--border);border-radius:50px;padding:6px 16px;font-size:12px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--waldviertel);margin-bottom:26px;box-shadow:0 2px 10px rgba(0,0,0,.05);animation:fadeUp .5s ease both}
@keyframes fadeUp{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}
.hero-left h1{font-family:'Lora',serif;font-size:clamp(2.5rem,5vw,4rem);line-height:1.1;color:var(--dark);margin-bottom:20px;animation:fadeUp .5s .1s ease both}
.hero-left h1 i{font-style:italic;color:var(--waldviertel)}
.hero-left p{font-size:1.05rem;color:var(--mid);line-height:1.75;max-width:460px;margin-bottom:36px;animation:fadeUp .5s .2s ease both}
.hero-actions{display:flex;gap:12px;flex-wrap:wrap;animation:fadeUp .5s .3s ease both}
.btn{display:inline-flex;align-items:center;gap:7px;padding:13px 28px;border-radius:50px;font-family:'DM Sans',sans-serif;font-size:15px;font-weight:700;text-decoration:none;border:none;cursor:pointer;transition:transform .2s,box-shadow .2s}
.btn:hover{transform:translateY(-3px);box-shadow:0 8px 24px rgba(0,0,0,.14)}
.btn-dark{background:var(--dark);color:white}.btn-ghost{background:white;color:var(--dark);border:2px solid rgba(30,24,16,.15)}
.btn-ghost:hover{border-color:var(--dark)}.btn-wv{background:var(--waldviertel);color:white}
.btn-strawberry{background:var(--strawberry);color:white}.btn-tulip{background:var(--tulip);color:white}
.btn-pumpkin{background:var(--pumpkin);color:white}.btn-breakfast{background:var(--breakfast);color:white}
.hero-right{display:grid;grid-template-columns:1fr 1fr;gap:18px;animation:fadeUp .5s .15s ease both}
.hero-card{border-radius:22px;padding:30px 24px;display:flex;flex-direction:column;gap:10px;text-decoration:none;transition:transform .3s,box-shadow .3s;position:relative;overflow:hidden;min-height:280px}
.hero-card:hover{transform:translateY(-6px) scale(1.02);box-shadow:0 16px 48px rgba(0,0,0,.13)}
.hc-waldviertel{background:linear-gradient(145deg,#C8E6A0 0%,#F0F7EA 100%)}
.hc-saison{background:linear-gradient(145deg,#FFD6DE 0%,#FFF3E8 60%,#F5C6E8 100%)}
.hc-icon{font-size:52px;line-height:1;display:block;filter:drop-shadow(0 6px 16px rgba(0,0,0,.15));animation:cardWobble 5s ease-in-out infinite}
.hero-card:nth-child(2) .hc-icon{animation-delay:1.2s}
.hc-title{font-family:'Lora',serif;font-size:1.2rem;font-weight:700;color:var(--dark);line-height:1.25}
.hc-sub{font-size:11px;font-weight:700;letter-spacing:.07em;text-transform:uppercase}
.hc-waldviertel .hc-sub{color:var(--waldviertel)}.hc-saison .hc-sub{color:var(--strawberry)}
.hc-chips{display:flex;flex-wrap:wrap;gap:5px;margin-top:4px}
.hc-chip{font-size:11px;font-weight:700;padding:3px 10px;border-radius:50px;color:white}
.hc-waldviertel .hc-chip:nth-child(1){background:var(--waldviertel)}.hc-waldviertel .hc-chip:nth-child(2){background:#A0522D}.hc-waldviertel .hc-chip:nth-child(3){background:#A0522D} 

.hc-waldviertel .hc-chip:nth-child(4) { background: #A0522D; }
.hc-waldviertel .hc-chip:nth-child(5) { background: #A0522D; }

.hc-saison .hc-chip:nth-child(1){background:var(--tulip)}.hc-saison .hc-chip:nth-child(2){background:var(--strawberry)}.hc-saison .hc-chip:nth-child(3){background:var(--breakfast)}.hc-saison .hc-chip:nth-child(4){background:var(--pumpkin)}
.hc-arrow{position:absolute;bottom:16px;right:16px;width:30px;height:30px;border-radius:50%;background:white;display:flex;align-items:center;justify-content:center;font-size:13px;opacity:0;transform:scale(.7);transition:opacity .25s,transform .25s}
.hero-card:hover .hc-arrow{opacity:1;transform:scale(1)}

/* TICKER */
.ticker-wrap{background:var(--dark);overflow:hidden}
.ticker-track{display:flex;animation:ticker 24s linear infinite;white-space:nowrap}
@keyframes ticker{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.ticker-item{display:inline-flex;align-items:center;gap:10px;padding:14px 34px;font-size:13px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:rgba(255,255,255,.5);border-right:1px solid rgba(255,255,255,.07);flex-shrink:0}
.ticker-item em{font-style:normal;font-size:16px}

/* SECTIONS */
.section{max-width:1260px;margin:0 auto;padding:90px 32px}
.section-head{margin-bottom:48px}
.section-tag{display:inline-block;font-size:11px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;margin-bottom:10px}
.section-head h2{font-family:'Lora',serif;font-size:clamp(2rem,3.5vw,2.8rem);line-height:1.15;color:var(--dark)}
.section-head h2 i{font-style:italic}
.feature-row{display:grid;grid-template-columns:1fr 1fr;gap:24px;align-items:stretch}
.feature-row.reverse{direction:rtl}.feature-row.reverse>*{direction:ltr}
.feat-visual{border-radius:var(--radius);display:flex;align-items:center;justify-content:center;font-size:120px;min-height:340px;position:relative;overflow:hidden}
.feat-visual .fv-emoji{filter:drop-shadow(0 10px 28px rgba(0,0,0,.2));animation:cardWobble 5s ease-in-out infinite;line-height:1}
.fv-waldviertel{background:linear-gradient(145deg,#C8E6A0,#F0F7EA)}.fv-strawberry{background:linear-gradient(145deg,#FFD6DE,#FFF0F2)}
.fv-tulip{background:linear-gradient(145deg,#F5C6E8,#FDF0F8)}.fv-pumpkin{background:linear-gradient(145deg,#FFD9B0,#FFF3E8)}.fv-breakfast{background:linear-gradient(145deg,#B8E4D0,#EEF7F3)}
.fv-tag{position:absolute;top:18px;right:18px;background:white;border-radius:50px;padding:5px 14px;font-size:11px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;box-shadow:0 3px 12px rgba(0,0,0,.08)}
.feat-text{border-radius:var(--radius);background:white;padding:44px 40px;display:flex;flex-direction:column;justify-content:center;border:1.5px solid var(--border)}
.feat-text .ft-eyebrow{font-size:11px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;margin-bottom:12px;display:flex;align-items:center;gap:8px}
.feat-text h3{font-family:'Lora',serif;font-size:1.85rem;margin-bottom:14px;line-height:1.2;color:var(--dark)}
.feat-text p{font-size:14.5px;color:var(--mid);line-height:1.75;margin-bottom:26px}
.feat-highlights{display:flex;flex-direction:column;gap:9px;margin-bottom:28px}
.feat-highlight{display:flex;align-items:center;gap:10px;font-size:14px;font-weight:500;color:var(--dark)}
.feat-highlight .fh-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}
.fv-waldviertel-dot{background:var(--waldviertel)}.fv-strawberry-dot{background:var(--strawberry)}
.fv-tulip-dot{background:var(--tulip)}.fv-pumpkin-dot{background:var(--pumpkin)}.fv-breakfast-dot{background:var(--breakfast)}
.section-divider{max-width:1260px;margin:0 auto;padding:0 32px 48px;display:flex;align-items:center;gap:20px}
.section-divider::before,.section-divider::after{content:'';flex:1;height:1.5px;background:var(--border)}
.section-divider span{font-size:11px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--mid);white-space:nowrap;padding:0 4px}



/* ════════ FOTO STRIP ════════ */
.foto-wrap { position: relative; }

.foto-strip {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  height: 300px;
	gap: 0;
}
.foto-item {
  position: relative;
  overflow: hidden;
 
}

.foto-item img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform .5s ease;
}
.foto-item:hover img { transform: scale(1.06); }
.foto-overlay {
  position: absolute;
  inset: 0;
  background: rgba(30,24,16,.22);
  transition: background .3s;
}
.foto-item:hover .foto-overlay { background: rgba(30,24,16,.08); }

/* SVG Welle */
.foto-wave {
  position: absolute;
  bottom: -2px;
  left: 0;
  right: 0;
  z-index: 3;
  line-height: 0;
}
.foto-wave svg { width: 100%; display: block; }

/* Logo Deko Kreis */
.foto-deko {
  position: absolute;
  bottom: -36px;
  left: 50%;
  transform: translateX(-50%);
  width: 72px;
  height: 72px;
  border-radius: 50%;
  border: 4px solid #1E1810;
  overflow: hidden;
  z-index: 4;
  box-shadow: 0 4px 20px rgba(0,0,0,.3);
	padding: 10px;
	background: #1E1810;
}
.foto-deko img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  display: block;
}

/* ════════ CTA BAND ════════ */
.new-cta {
  background: #1E1810;
  display: grid;
  grid-template-columns: 1fr 1fr;
  padding-top: 56px;
}
.new-cta-left {
  padding: 40px 56px 60px;
  display: flex;
  flex-direction: column;
  gap: 20px;
  justify-content: center;
  border-right: 1px solid rgba(255,255,255,.07);
}
.new-cta-eyebrow {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--strawberry);
}
.new-cta-left h2 {
  font-family: 'Lora', serif;
  font-size: clamp(1.8rem, 3vw, 2.4rem);
  line-height: 1.15;
  color: white;
}
.new-cta-left h2 em {
  font-style: italic;
  color: var(--strawberry);
}
.new-cta-left p {
  font-size: 15px;
  color: rgba(255,255,255,.4);
  line-height: 1.75;
  max-width: 380px;
}
.new-cta-btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: var(--strawberry);
  color: white;
  padding: 14px 28px;
  border-radius: 50px;
  font-weight: 700;
  font-size: 14px;
  text-decoration: none;
  width: fit-content;
  transition: transform .2s, box-shadow .2s;
  box-shadow: 0 4px 20px rgba(217,58,82,.3);
}
.new-cta-btn:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 28px rgba(217,58,82,.4);
  color: white;
}

.new-cta-right {
  padding: 40px 56px 60px;
  display: flex;
  flex-direction: column;
  justify-content: center;
}
.new-cta-right h3 {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: rgba(255,255,255,.25);
  margin-bottom: 20px;
}
.contact-item {
  display: flex;
  align-items: center;
  gap: 16px;
  padding: 14px 0;
  border-bottom: 1px solid rgba(255,255,255,.06);
}
.contact-item:last-child { border-bottom: none; }
.contact-icon {
  width: 38px;
  height: 38px;
  border-radius: 10px;
  background: rgba(255,255,255,.06);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  font-size: 15px;
  color: rgba(255,255,255,.4);
}
.contact-label {
  font-size: 14px;
  font-weight: 700;
  color: white;
  display: block;
  text-decoration: none;
  transition: color .2s;
}

.contact-sub {
  font-size: 12px;
  color: rgba(255,255,255,.3);
  display: block;
  margin-top: 2px;
}

/* ════════ FOOTER LEISTE ════════ */
.site-footer {
  background: #130d08;
  padding: 18px 32px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 10px;
}
.footer-copy { font-size: 12px; color: rgba(255,255,255,.25); }
.footer-copy strong { color: rgba(255,255,255,.45); }
.footer-links { display: flex; align-items: center; gap: 14px; }
.footer-links a {
  font-size: 12px;
  color: rgba(255,255,255,.25);
  text-decoration: none;
  transition: color .2s;
}
.footer-links a:hover { color: rgba(255,255,255,0.9) }
.footer-divider { width: 1px; height: 12px; background: rgba(255,255,255,.1); }

/* ════════ RESPONSIVE ════════ */
@media(max-width:960px){
  .foto-strip { height: 220px; }
  .foto-item { clip-path: none !important; margin-right: 0; }
  .new-cta { grid-template-columns: 1fr; padding-top: 48px; }
  .new-cta-left { padding: 40px 32px; border-right: none; border-bottom: 1px solid rgba(255,255,255,.07); }
  .new-cta-right { padding: 36px 32px 48px; }
}
@media(max-width:640px){
  .foto-strip { grid-template-columns: repeat(2, 1fr); height: 180px; }
  .new-cta-left { padding: 40px 24px; gap: 16px; }
  .new-cta-right { padding: 32px 24px 48px; }
  .site-footer { padding: 16px 20px; }
}

/* ════════ RESPONSIVE ════════ */
@media(max-width:960px){
  .foto-strip { grid-template-columns: repeat(2, 1fr); height: 200px; }
  .new-cta { grid-template-columns: 1fr; }
  .new-cta-left { padding: 48px 32px; border-right: none; border-bottom: 1px solid rgba(255,255,255,.08); }
  .new-cta-right { padding: 40px 32px; }
}
@media(max-width:640px){
  .foto-strip { height: 160px; }
  .new-cta-left { padding: 40px 24px; gap: 16px; }
  .new-cta-right { padding: 32px 24px; }
  .site-footer { padding: 16px 20px; }
  .footer-links { gap: 10px; }
}

/* RESPONSIVE */
@media(max-width:1000px){.mega-inner{grid-template-columns:1fr!important}.mega-intro{border-right:none;padding-right:0;border-bottom:1.5px solid var(--border);padding-bottom:18px;margin-bottom:4px}#navWaldviertel .mega-cards{grid-template-columns:1fr 1fr}}
@media(max-width:960px){.hero-content{grid-template-columns:1fr}.feature-row{grid-template-columns:1fr}.feature-row.reverse{direction:ltr}}
@media(max-width:768px){.nav-items{display:none}.nav-cta{display:none}.burger{display:flex}.mobile-menu{display:block}.hero-right{grid-template-columns:1fr 1fr}}
@media(max-width:480px){.hero-right{grid-template-columns:1fr}}


.ip-icon {
	color: rgba(255,255,255,.4);
	margin-bottom: 10px;
}


.fv-photo {
  position: absolute;
  bottom: -20px;
  right: -20px;
  width: 120px;
  height: 120px;
  object-fit: cover;
  border-radius: 50%;
  border: 5px solid white;
  box-shadow: 0 4px 20px rgba(0,0,0,.15);
  z-index: 3;
}



/*
.mobile-menu {
  display: none;
  position: fixed;
  top: 0; left: 0; right: 0; bottom: 0;
  height: 100dvh;
  background: var(--white);
  box-shadow: 0 20px 50px rgba(30,24,16,.14);
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
  z-index: 999;
}
.mobile-menu.open {
  display: block;
}
body.menu-open {
  overflow: hidden;
  
}

*/

.mobile-menu {
  position: fixed;
  top: 0; left: 0; right: 0; bottom: 0;
  height: 100dvh;
  background: var(--white);
  box-shadow: -10px 0 50px rgba(30,24,16,.2);
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
  z-index: 999;
  transform: translateX(100%);
  transition: transform .35s cubic-bezier(.4,0,.2,1);
  visibility: hidden;
}
.mobile-menu.open {
  transform: translateX(0);
  visibility: visible;
}
body.menu-open {
  overflow: hidden;
}


.mob-overlay {
  position: fixed;
  inset: 0;
  background: rgba(30,24,16,.6);
  backdrop-filter: blur(2px);
  z-index: 998;
  opacity: 0;
  visibility: hidden;
  transition: opacity .35s ease, visibility .35s ease;
}
body.menu-open .mob-overlay {
  opacity: 1;
  visibility: visible;
}
/*
position: absolute;
  top: 20px; right: 20px;
  width: 40px; height: 40px;
  border-radius: 50%;
  background: var(--dark);
  border: none;
  display: flex; align-items: center; justify-content: center;
  font-size: 16px; color: white;
  cursor: pointer;
  transition: background .2s, color .2s;
  -webkit-tap-highlight-color: transparent; 
*/
.mob-close {
	width: 40px; height: 40px;
  border-radius: 50%;
  background: var(--dark);
  border: 1.5px solid rgba(255,255,255,.15);
  display: flex; align-items: center; justify-content: center;
  font-size: 16px; color: white;
  cursor: pointer; flex-shrink: 0;
  transition: background .2s;
  -webkit-tap-highlight-color: transparent;
  position: static; /* überschreibt das alte absolute */
  
}
.mob-close:hover,
.mob-close:focus,
.mob-close:active {
  background: var(--dark);
  color: white;
  outline: none;
}

/* Mobile menu inner braucht position relative für absolute X */
.mobile-menu-inner {
  position: relative;
 
}

@media(max-width:640px){
  .feld-card {
    flex-wrap: wrap;
  }
  .feld-status {
    width: 100%;
    justify-content: flex-start;
  }
}
@media(max-width:640px){
  .entdecke-section {
    overflow: hidden;
  }
}









/* ════════════════════════════════
   PAGE: REZEPTE
════════════════════════════════ */

/* Hero */
.rezepte-hero{background:linear-gradient(145deg,#FFF0F2 0%,var(--light) 55%,#F0F7EA 100%);padding:100px 32px 80px;text-align:center;position:relative;overflow:hidden}
.rezepte-hero .blob-a{width:400px;height:400px;background:#FFD6DE;top:-100px;right:-60px}
.rezepte-hero .blob-b{width:280px;height:280px;background:#C8E6A0;bottom:-60px;left:-40px}
.rezepte-hero-inner{position:relative;z-index:2;max-width:680px;margin:0 auto}
.rezepte-eyebrow{display:inline-flex;align-items:center;gap:8px;background:white;border:1.5px solid var(--border);border-radius:50px;padding:6px 18px;font-size:12px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--strawberry);margin-bottom:24px;box-shadow:0 2px 10px rgba(0,0,0,.05);animation:fadeUp .5s ease both}
.rezepte-hero h1{font-family:'Lora',serif;font-size:clamp(2.4rem,5vw,3.6rem);line-height:1.1;color:var(--dark);margin-bottom:20px;animation:fadeUp .5s .1s ease both}
.rezepte-hero h1 i{font-style:italic;color:var(--strawberry)}
.rezepte-hero p{font-size:1.05rem;color:var(--mid);line-height:1.8;animation:fadeUp .5s .2s ease both}

/* Content wrapper */
.rezepte-content{padding:60px 32px 90px}
.rezepte-content-inner{max-width:1260px;margin:0 auto}

/* ── WP Delicious Override Styles ──
   Diese Styles passen das WP Delicious Grid
   ans Design von Hof Wunderlich an.
   Passe die Selektoren an falls nötig –
   prüfe die echten Klassen mit dem Browser-Inspector.
*/

/* Grid Layout */
.rezepte-content .wpd-recipes-list,
.rezepte-content .recipe-card-list {
  display: grid !important;
  grid-template-columns: repeat(3, 1fr) !important;
  gap: 24px !important;
  list-style: none !important;
  padding: 0 !important;
}

/* Einzelne Karte */
.rezepte-content .wpd-recipe-card,
.rezepte-content .recipe-card {
  background: white !important;
  border-radius: 22px !important;
  overflow: hidden !important;
  border: 1.5px solid var(--border) !important;
  box-shadow: none !important;
  transition: transform .3s, box-shadow .3s !important;
  font-family: 'DM Sans', sans-serif !important;
}
.rezepte-content .wpd-recipe-card:hover,
.rezepte-content .recipe-card:hover {
  transform: translateY(-6px) !important;
  box-shadow: var(--shadow) !important;
}

/* Bild */
.rezepte-content .wpd-recipe-card img,
.rezepte-content .recipe-card img {
  width: 100% !important;
  height: 200px !important;
  object-fit: cover !important;
  display: block !important;
}

/* Titel */
.rezepte-content .wpd-recipe-card h2,
.rezepte-content .wpd-recipe-card h3,
.rezepte-content .recipe-card h2,
.rezepte-content .recipe-card h3 {
  font-family: 'Lora', serif !important;
  color: var(--dark) !important;
  font-size: 1.15rem !important;
}

/* Links */
.rezepte-content a {
  color: var(--strawberry) !important;
}

/* Inspiration Banner */
.rezepte-inspiration{background:var(--strawberry-bg);padding:80px 32px;text-align:center}
.rezepte-inspiration-inner{max-width:600px;margin:0 auto}
.rezepte-inspiration h2{font-family:'Lora',serif;font-size:clamp(1.8rem,3vw,2.4rem);color:var(--dark);margin-bottom:14px}
.rezepte-inspiration h2 i{font-style:italic;color:var(--strawberry)}
.rezepte-inspiration p{font-size:15px;color:var(--mid);line-height:1.7;margin-bottom:28px}

/* Responsive */
@media(max-width:960px){
  .rezepte-content .wpd-recipes-list,
  .rezepte-content .recipe-card-list{grid-template-columns:repeat(2,1fr)!important}
}
@media(max-width:640px){
  .rezepte-content .wpd-recipes-list,
  .rezepte-content .recipe-card-list{grid-template-columns:1fr!important}
}

/* ════════════════════════════════
   PAGE: REZEPTE MIT POPUP
════════════════════════════════ */

/* Hero */
.rezepte-hero{background:linear-gradient(145deg,#FFF0F2 0%,var(--light) 55%,#F0F7EA 100%);padding:100px 32px 80px;text-align:center;position:relative;overflow:hidden}
.rezepte-hero .blob-a{width:400px;height:400px;background:#FFD6DE;top:-100px;right:-60px}
.rezepte-hero .blob-b{width:280px;height:280px;background:#C8E6A0;bottom:-60px;left:-40px}
.rezepte-hero-inner{position:relative;z-index:2;max-width:680px;margin:0 auto}
.rezepte-eyebrow{display:inline-flex;align-items:center;gap:8px;background:white;border:1.5px solid var(--border);border-radius:50px;padding:6px 18px;font-size:12px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--strawberry);margin-bottom:24px;box-shadow:0 2px 10px rgba(0,0,0,.05);animation:fadeUp .5s ease both}
.rezepte-hero h1{font-family:'Lora',serif;font-size:clamp(2.4rem,5vw,3.6rem);line-height:1.1;color:var(--dark);margin-bottom:20px;animation:fadeUp .5s .1s ease both}
.rezepte-hero h1 i{font-style:italic;color:var(--strawberry)}
.rezepte-hero p{font-size:1.05rem;color:var(--mid);line-height:1.8;animation:fadeUp .5s .2s ease both}

/* Grid */
.rezepte-section{padding:60px 32px 90px;max-width:1260px;margin:0 auto}
.rezepte-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.rezept-card{background:white;border-radius:22px;overflow:hidden;border:1.5px solid var(--border);cursor:pointer;display:flex;flex-direction:column;transition:transform .3s,box-shadow .3s}
.rezept-card:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.rezept-img{height:220px;overflow:hidden;position:relative}
.rezept-img img{width:100%;height:100%;object-fit:cover;transition:transform .4s}
.rezept-card:hover .rezept-img img{transform:scale(1.05)}
.rezept-badge{position:absolute;top:14px;left:14px;background:var(--strawberry);color:white;border-radius:50px;padding:4px 12px;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.06em}
.rezept-saison-badge{position:absolute;top:14px;right:14px;background:rgba(255,255,255,.9);color:var(--dark);border-radius:50px;padding:4px 10px;font-size:10px;font-weight:700}
.rezept-body{padding:22px 22px 24px;flex:1;display:flex;flex-direction:column;gap:10px}
.rezept-body h3{font-family:'Lora',serif;font-size:1.15rem;color:var(--dark);line-height:1.3}
.rezept-body p{font-size:13.5px;color:var(--mid);line-height:1.6;flex:1}
.rezept-meta{display:flex;gap:14px;flex-wrap:wrap;padding-top:14px;border-top:1.5px solid var(--border)}
.rezept-meta-item{display:flex;align-items:center;gap:5px;font-size:12px;color:var(--mid);font-weight:600}
.rezept-meta-item i{color:var(--strawberry);font-size:13px}
.rezept-footer{display:flex;align-items:center;justify-content:space-between;margin-top:8px}
.rezept-schwierigkeit{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--waldviertel);background:var(--waldviertel-bg);padding:4px 10px;border-radius:50px}
.rezept-cta{display:inline-flex;align-items:center;gap:5px;font-size:13px;font-weight:700;color:var(--strawberry);transition:gap .2s}
.rezept-card:hover .rezept-cta{gap:9px}

/* Popup Overlay */
.rezept-overlay{position:fixed;inset:0;background:rgba(20,10,8,.75);backdrop-filter:blur(4px);z-index:1000;opacity:0;visibility:hidden;transition:opacity .3s ease,visibility 0s linear .3s;display:flex;align-items:center;justify-content:center;padding:20px}
.rezept-overlay.open{opacity:1;visibility:visible;transition:opacity .3s ease,visibility 0s linear 0s}

/* Modal */
.rezept-modal{background:white;border-radius:28px;max-width:720px;width:100%;max-height:90vh;overflow-y:auto;position:relative;transform:translateY(30px) scale(.97);transition:transform .35s cubic-bezier(.4,0,.2,1);box-shadow:0 30px 80px rgba(0,0,0,.3)}
.rezept-overlay.open .rezept-modal{transform:translateY(0) scale(1)}
.modal-hero{position:relative;height:260px;overflow:hidden;border-radius:28px 28px 0 0}
.modal-hero img{width:100%;height:100%;object-fit:cover}
.modal-hero::after{content:'';position:absolute;inset:0;background:linear-gradient(to bottom,transparent 40%,rgba(20,10,8,.7) 100%)}
.modal-hero-text{position:absolute;bottom:0;left:0;right:0;padding:24px 28px;z-index:2}
.modal-hero-text h2{font-family:'Lora',serif;font-size:clamp(1.4rem,3vw,1.9rem);color:white;line-height:1.2;margin-bottom:8px}
.modal-hero-meta{display:flex;gap:16px;flex-wrap:wrap}
.modal-hero-meta span{display:flex;align-items:center;gap:5px;font-size:12px;font-weight:700;color:rgba(255,255,255,.85)}
.modal-close{position:absolute;top:16px;right:16px;z-index:10;width:40px;height:40px;border-radius:50%;background:rgba(30,24,16,.6);backdrop-filter:blur(8px);border:1px solid rgba(255,255,255,.2);color:white;font-size:16px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background .2s;-webkit-tap-highlight-color:transparent}
.modal-close:hover,.modal-close:focus,.modal-close:active{background:rgba(30,24,16,.85);outline:none}
.modal-body{padding:28px 28px 36px}
.modal-intro{font-size:15px;color:var(--mid);line-height:1.8;margin-bottom:28px;padding-bottom:24px;border-bottom:1.5px solid var(--border)}
.modal-section-title{font-family:'Lora',serif;font-size:1.2rem;color:var(--dark);margin-bottom:16px}
.modal-zutaten{background:var(--strawberry-bg);border-radius:16px;padding:20px 22px;margin-bottom:24px}
.modal-zutaten ul{list-style:none;display:flex;flex-direction:column;gap:8px}
.modal-zutaten ul li{font-size:14.5px;color:var(--dark);display:flex;align-items:center;gap:8px;line-height:1.5}
.modal-zutaten ul li::before{content:'';width:6px;height:6px;border-radius:50%;background:var(--strawberry);flex-shrink:0}
.modal-schritte{display:flex;flex-direction:column;gap:16px}
.modal-schritt{display:flex;gap:16px;align-items:flex-start}
.schritt-num{width:32px;height:32px;border-radius:50%;background:var(--strawberry);color:white;font-size:13px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:2px}
.schritt-text{font-size:14.5px;color:var(--mid);line-height:1.75}
.schritt-tip{background:var(--waldviertel-bg);border-left:3px solid var(--waldviertel);border-radius:0 10px 10px 0;padding:10px 14px;margin-top:8px;font-size:13px;color:var(--waldviertel);font-weight:600}
.modal-tags{display:flex;flex-wrap:wrap;gap:8px;margin-top:24px;padding-top:20px;border-top:1.5px solid var(--border)}
.modal-tag{padding:5px 12px;border-radius:50px;background:var(--light);border:1.5px solid var(--border);font-size:12px;font-weight:600;color:var(--mid)}

/* Inspiration */
.rezepte-inspiration{background:var(--strawberry-bg);padding:80px 32px;text-align:center}
.rezepte-inspiration-inner{max-width:600px;margin:0 auto}
.rezepte-inspiration h2{font-family:'Lora',serif;font-size:clamp(1.8rem,3vw,2.4rem);color:var(--dark);margin-bottom:14px}
.rezepte-inspiration h2 i{font-style:italic;color:var(--strawberry)}
.rezepte-inspiration p{font-size:15px;color:var(--mid);line-height:1.7;margin-bottom:28px}

/* Responsive */
@media(max-width:960px){.rezepte-grid{grid-template-columns:1fr 1fr}}
@media(max-width:640px){
  .rezepte-grid{grid-template-columns:1fr}
  .modal-hero{height:200px}
  .modal-body{padding:20px 20px 28px}
  .modal-hero-text{padding:16px 20px}
}

.rezept-badge,
.rezept-saison-badge {
  z-index: 2;
  position: absolute;
}

.rezept-img {
  height: 220px;
  overflow: hidden;
  position: relative;
}

/* Badges aus dem overflow-hidden rausnehmen */
.rezept-img .rezept-badge,
.rezept-img .rezept-saison-badge {
  position: absolute;
  z-index: 3;
  transform: translateZ(0); /* verhindert dass sie beim Scale verschwinden */
}




.mob-header {
  display: flex; align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding: 24px 0 24px 0;
  border-bottom: 1.5px solid var(--border);
  margin-bottom: 20px;
}
.mob-header-title {
   font-family: 'Lora', serif;
  font-size: 1.25rem;
  color: var(--dark);
  line-height: 1.4;
  flex: 1;
	font-weight: bold;
}
.mob-header-title i {
 
  font-style: italic;
  color: var(--strawberry);
  font-size: 1.35rem;
}

.bc-bauernhof .box-card-img { background: linear-gradient(145deg, #D4E8B0, #F0F7EA); }
.bc-bauernhof .box-card-badge { background: var(--waldviertel); }
.bc-bauernhof .box-card-link { background: var(--waldviertel); color: white; }

.bc-special .box-card-img { background: linear-gradient(145deg, #FFE4B0, #FFF8E8); }
.bc-special .box-card-badge { background: #B8860B; }
.bc-special .box-card-link { background: #B8860B; color: white; }

@media(min-width:960px){
  .boxen-grid { grid-template-columns: 1fr 1fr 1fr 1fr; }
}







/* ════════════════════════════════
   FEIERN – PDF MODAL & BUTTON
════════════════════════════════ */

/* Hero Actions */
.feiern-hero-actions { display:flex; gap:12px; flex-wrap:wrap; animation:fadeUp .5s .3s ease both; }
.btn-feiern-info {
  display:inline-flex; align-items:center; gap:8px;
  padding:13px 28px; border-radius:50px;
  font-family:'DM Sans',sans-serif; font-size:15px; font-weight:700;
  background:white; color:var(--strawberry);
  border:2px solid var(--strawberry);
  cursor:pointer; transition:transform .2s,box-shadow .2s,background .2s,color .2s;
}
.btn-feiern-info:hover {
  background:var(--strawberry); color:white;
  transform:translateY(-3px); box-shadow:0 8px 28px rgba(217,58,82,.25);
}

/* Modal Overlay */
.feiern-modal-overlay {
  position:fixed; inset:0; z-index:99999;
  background:rgba(30,24,16,.6); backdrop-filter:blur(8px);
  display:flex; align-items:center; justify-content:center;
  padding:20px;
  opacity:0; pointer-events:none;
  transition:opacity .3s ease;
}
.feiern-modal-overlay.open {
  opacity:1; pointer-events:all;
}

/* Modal Box */
.feiern-modal {
  background:white; border-radius:24px;
  width:100%; max-width:480px;
  padding:44px 40px;
  position:relative;
  box-shadow:0 24px 80px rgba(30,24,16,.2);
  transform:translateY(20px) scale(.97);
  transition:transform .35s cubic-bezier(.34,1.56,.64,1);
}
.feiern-modal-overlay.open .feiern-modal {
  transform:translateY(0) scale(1);
}

/* Close Button */
.feiern-modal-close {
  position:absolute; top:16px; right:16px;
  width:36px; height:36px; border-radius:50%;
  background:var(--light); border:1.5px solid var(--border);
  display:flex; align-items:center; justify-content:center;
  cursor:pointer; font-size:14px; color:var(--mid);
  transition:background .2s, color .2s;
}
.feiern-modal-close:hover { background:var(--dark); color:white; }

/* Modal Step */
.feiern-modal-step {
  display:flex; flex-direction:column; align-items:center;
  text-align:center; gap:14px;
}
.feiern-modal-icon { font-size:48px; line-height:1; }
.feiern-modal h3 {
  font-family:'Lora',serif; font-size:1.5rem;
  color:var(--dark); line-height:1.2;
}
.feiern-modal p { font-size:14.5px; color:var(--mid); line-height:1.7; }

/* Form */
.feiern-modal-form { width:100%; display:flex; flex-direction:column; gap:14px; margin-top:6px; }
.feiern-modal-field { display:flex; flex-direction:column; gap:6px; text-align:left; }
.feiern-modal-field label { font-size:13px; font-weight:700; color:var(--dark); }
.feiern-modal-field input[type="email"] {
  width:100%; padding:12px 16px; border-radius:12px;
  border:1.5px solid var(--border); font-family:'DM Sans',sans-serif;
  font-size:15px; color:var(--dark); outline:none;
  transition:border-color .2s;
}
.feiern-modal-field input[type="email"]:focus { border-color:var(--strawberry); }

/* Privacy checkbox */
.feiern-modal-privacy {
  display:flex; align-items:flex-start; gap:10px;
  text-align:left;
}
.feiern-modal-privacy input[type="checkbox"] {
  margin-top:3px; flex-shrink:0;
  width:16px; height:16px; cursor:pointer;
  accent-color:var(--strawberry);
}
.feiern-modal-privacy label { font-size:12px; color:var(--mid); line-height:1.5; cursor:pointer; }

/* Submit Button */
.feiern-modal-submit {
  display:flex; align-items:center; justify-content:center; gap:8px;
  width:100%; padding:14px; border-radius:50px;
  background:var(--strawberry); color:white;
  font-family:'DM Sans',sans-serif; font-size:15px; font-weight:700;
  border:none; cursor:pointer;
  transition:transform .2s, box-shadow .2s, opacity .2s;
  box-shadow:0 4px 20px rgba(217,58,82,.3);
}
.feiern-modal-submit:hover { transform:translateY(-2px); box-shadow:0 8px 28px rgba(217,58,82,.4); }
.feiern-modal-submit:disabled { opacity:.6; cursor:not-allowed; transform:none; }

/* Error */
.feiern-modal-error { font-size:13px; color:#C0392B; font-weight:600; min-height:18px; }

/* Download Button */
.feiern-modal-download {
  display:inline-flex; align-items:center; gap:10px;
  padding:14px 32px; border-radius:50px;
  background:var(--strawberry); color:white;
  font-size:15px; font-weight:700; text-decoration:none;
  transition:transform .2s, box-shadow .2s;
  box-shadow:0 4px 20px rgba(217,58,82,.3);
}
.feiern-modal-download:hover { transform:translateY(-2px); box-shadow:0 8px 28px rgba(217,58,82,.4); }
.feiern-modal-note { font-size:13px; color:var(--mid); }

@media(max-width:480px){
  .feiern-modal { padding:32px 24px; }
  .feiern-hero-actions { flex-direction:column; align-items:flex-start; }
}









/* ════════════════════════════════
   WOOCOMMERCE SHOP
════════════════════════════════ */

/* Hero */
.shop-hero{background:linear-gradient(145deg,#EEF7F3 0%,var(--light) 55%,#FFF0F2 100%);padding:100px 32px 70px;text-align:center;position:relative;overflow:hidden}
.shop-hero .blob-a{width:400px;height:400px;background:#B8E4D0;top:-100px;right:-60px;animation:blobFloat 11s ease-in-out infinite}
.shop-hero .blob-b{width:280px;height:280px;background:#FFD6DE;bottom:-60px;left:-50px;animation:blobFloat 13s ease-in-out infinite reverse}
.shop-hero-inner{position:relative;z-index:2;max-width:640px;margin:0 auto}
.shop-eyebrow{display:inline-flex;align-items:center;gap:8px;background:white;border:1.5px solid var(--border);border-radius:50px;padding:6px 18px;font-size:12px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--breakfast);margin-bottom:24px;box-shadow:0 2px 10px rgba(0,0,0,.05);animation:fadeUp .5s ease both}
.shop-hero h1{font-family:'Lora',serif;font-size:clamp(2.4rem,5vw,3.6rem);line-height:1.1;color:var(--dark);margin-bottom:16px;animation:fadeUp .5s .1s ease both}
.shop-hero h1 i{font-style:italic;color:var(--breakfast)}
.shop-hero p{font-size:1.05rem;color:var(--mid);line-height:1.8;animation:fadeUp .5s .2s ease both}

/* Kategorie Tabs */
.shop-cats{background:white;border-bottom:1.5px solid var(--border);padding:0 32px;top:0;z-index:100;box-shadow:0 2px 12px rgba(0,0,0,.04)}
.shop-cats-inner{max-width:1260px;margin:0 auto;display:flex;gap:0;overflow-x:auto;scrollbar-width:none}
.shop-cats-inner::-webkit-scrollbar{display:none}
.shop-cat-btn{padding:18px 24px;font-family:'DM Sans',sans-serif;font-size:14px;font-weight:700;color:var(--mid);background:none;border:none;border-bottom:3px solid transparent;cursor:pointer;white-space:nowrap;transition:color .2s,border-color .2s;display:flex;align-items:center;gap:7px;text-decoration:none}
.shop-cat-btn:hover{color:var(--dark)}
.shop-cat-btn.active{color:var(--breakfast);border-bottom-color:var(--breakfast)}

/* Section */
.shop-section{padding:70px 32px;max-width:1260px;margin:0 auto}
.shop-section-head{display:flex;align-items:flex-end;justify-content:space-between;flex-wrap:wrap;gap:16px;margin-bottom:40px}
.shop-section-head h2{font-family:'Lora',serif;font-size:clamp(1.8rem,3vw,2.4rem);color:var(--dark)}
.shop-section-head h2 i{font-style:italic;color:var(--breakfast)}
.shop-section-head p{font-size:15px;color:var(--mid);margin-top:6px}
.shop-count{font-size:13px;color:var(--mid);font-weight:600;background:var(--light);border:1.5px solid var(--border);border-radius:50px;padding:6px 16px}

/* Shop Hero – allgemein (überschreibt breakfast Farbe) */
.shop-hero .blob-a { background: #FFD6DE !important; }
.shop-hero .blob-b { background: #C8E6A0 !important; }
.shop-eyebrow { color: var(--strawberry) !important; }
.shop-hero h1 i { color: var(--strawberry) !important; }
.shop-cats .shop-cat-btn.active {
  color: var(--strawberry) !important;
  border-bottom-color: var(--strawberry) !important;
}
.shop-section-head h2 i { color: var(--strawberry) !important; }

/* Info Band – Saisonerlebnisse Variante */
.shop-info-saison {
  background: var(--strawberry-bg) !important;
  border-top: 1.5px solid rgba(217,58,82,.12) !important;
}

/* Product Grid – override WooCommerce ul.products */
.woocommerce .products-grid,
ul.products.columns-3,
ul.products.columns-4 {
  display:grid!important;
  grid-template-columns:repeat(3,1fr)!important;
  gap:24px!important;
  margin:0!important;
  padding:0!important;
  list-style:none!important;
}

/* Product Card */
.product-card{background:white;border-radius:22px;border:1.5px solid var(--border);overflow:hidden;display:flex;flex-direction:column;transition:transform .3s,box-shadow .3s;cursor:pointer;text-decoration:none;color:inherit}
.product-card:hover{transform:translateY(-6px);box-shadow:var(--shadow);border-color:transparent}
.product-img{height:280px;position:relative;overflow:hidden;display:flex;align-items:center;justify-content:center}
.product-img img,.product-card-img{width:100%;height:100%;object-fit:cover;transition:transform .4s;inset:0}
.product-card:hover .product-img img,.product-card:hover .product-card-img{transform:scale(1.05)}
.product-img-emoji{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-size:80px;z-index:1;filter:drop-shadow(0 6px 16px rgba(0,0,0,.15))}
.product-badge{position:absolute;top:14px;left:14px;z-index:2;padding:5px 12px;border-radius:50px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:white}
.product-badge-sale{position:absolute;top:14px;right:14px;z-index:2;background:var(--strawberry);color:white;padding:5px 12px;border-radius:50px;font-size:11px;font-weight:700}
.product-body{padding:22px 22px 26px;flex:1;display:flex;flex-direction:column;gap:10px}
.product-cat{font-size:11px;font-weight:700;letter-spacing:.08em;text-transform:uppercase}
.product-body h3{font-family:'Lora',serif;font-size:1.2rem;color:var(--dark);line-height:1.25}
.product-body p{font-size:13.5px;color:var(--mid);line-height:1.65;flex:1}
.product-footer{display:flex;align-items:center;justify-content:space-between;margin-top:auto;padding-top:14px;border-top:1.5px solid var(--border)}
.product-price{font-family:'Lora',serif;font-size:1.35rem;font-weight:700;color:var(--dark)}
.product-price .price-from{font-size:12px;color:var(--mid);font-family:'DM Sans',sans-serif;font-weight:600;display:block;margin-bottom:2px}

/* WooCommerce Preis überschreiben */
.product-price .woocommerce-Price-amount{font-family:'Lora',serif;font-size:1.35rem;font-weight:700;color:var(--dark)}
.product-price del .woocommerce-Price-amount{font-size:.9rem;color:var(--mid);font-family:'DM Sans',sans-serif;font-weight:400}
.product-price ins{text-decoration:none}

/* Add to Cart Buttons */
.btn-add{display:inline-flex;align-items:center;gap:7px;padding:10px 20px;border-radius:50px;font-family:'DM Sans',sans-serif;font-size:13px;font-weight:700;border:none;cursor:pointer;transition:transform .2s,box-shadow .2s;text-decoration:none}
.btn-add:hover{transform:translateY(-2px);box-shadow:0 6px 20px rgba(0,0,0,.12)}
.btn-add-breakfast{background:var(--breakfast);color:white}
.btn-add-pumpkin{background:var(--pumpkin);color:white}
.btn-add-strawberry{background:var(--strawberry);color:white}
.btn-add-wv{background:var(--waldviertel);color:white}

/* Empty State */
.shop-empty{text-align:center;padding:80px 32px;display:flex;flex-direction:column;align-items:center;gap:16px}
.shop-empty-icon{font-size:64px}
.shop-empty h3{font-family:'Lora',serif;font-size:1.8rem;color:var(--dark)}
.shop-empty p{font-size:15px;color:var(--mid)}

/* Info Band */
.shop-info{background:var(--breakfast-bg);border-top:1.5px solid rgba(46,125,94,.12);padding:40px 32px}
.shop-info-inner{max-width:1260px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr 1fr 1fr; gap:24px}
.shop-info-item{display:flex;align-items:flex-start;gap:14px}
.shop-info-icon{width:42px;height:42px;border-radius:12px;background:white;display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0;box-shadow:0 2px 8px rgba(0,0,0,.06)}
.shop-info-item h4{font-size:14px;font-weight:700;color:var(--dark);margin-bottom:3px}
.shop-info-item p{font-size:12.5px;color:var(--mid);line-height:1.5}

/* WooCommerce Pagination */
.woocommerce-pagination{margin-top:48px;text-align:center}
.woocommerce-pagination ul{display:inline-flex;gap:8px;list-style:none;padding:0}
.woocommerce-pagination ul li a,
.woocommerce-pagination ul li span{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:50%;background:white;border:1.5px solid var(--border);font-weight:700;font-size:14px;color:var(--dark);text-decoration:none;transition:background .2s,color .2s,border-color .2s}
.woocommerce-pagination ul li span.current{background:var(--breakfast);color:white;border-color:var(--breakfast)}
.woocommerce-pagination ul li a:hover{background:var(--dark);color:white;border-color:var(--dark)}

/* Responsive */
@media(max-width:960px){
  .woocommerce .products-grid,ul.products.columns-3,ul.products.columns-4{grid-template-columns:1fr 1fr!important}
  .shop-info-inner{grid-template-columns:1fr !important;}
}
@media(max-width:640px){
  .woocommerce .products-grid,ul.products.columns-3,ul.products.columns-4{grid-template-columns:1fr!important}
  .shop-info-inner{grid-template-columns:1fr !important;}
  .shop-section-head{flex-direction:column;align-items:flex-start}
}



.woocommerce ul.products,
.woocommerce-page ul.products {
  display: grid !important;
  grid-template-columns: repeat(3, 1fr) !important;
  gap: 24px !important;
  width: 100% !important;
  margin: 0 !important;
  padding: 0 !important;
  list-style: none !important;
  float: none !important;
}

.woocommerce ul.products li.product,
.woocommerce-page ul.products li.product {
  width: 100% !important;
  margin: 0 !important;
  padding: 0 !important;
  float: none !important;
  clear: none !important;
}

@media(max-width:960px){
  .woocommerce ul.products,
  .woocommerce-page ul.products {
    grid-template-columns: repeat(2, 1fr) !important;
  }
}
@media(max-width:640px){
  .woocommerce ul.products,
  .woocommerce-page ul.products {
    grid-template-columns: 1fr !important;
  }
}


.woocommerce ul.products,
.woocommerce-page ul.products {
  display: grid !important;
	grid-template-columns: repeat(auto-fill, minmax(300px, 1fr)) !important;
 
  justify-content: start !important;
  gap: 24px !important;
  width: 100% !important;
  margin: 0 !important;
  padding: 0 !important;
  list-style: none !important;
  float: none !important;
}
.woocommerce ul.products::before,
.woocommerce ul.products::after,
.woocommerce-page ul.products::before,
.woocommerce-page ul.products::after {
  display: none !important;
  content: none !important;
}






/* ════════════════════════════════
   WOOCOMMERCE SINGLE PRODUCT
════════════════════════════════ */

/* Breadcrumb */
.product-breadcrumb{padding:20px 32px;max-width:1260px;margin:0 auto;font-size:13px;color:var(--mid);display:flex;align-items:center;gap:8px}
.product-breadcrumb a{color:var(--mid);text-decoration:none;transition:color .2s}
.product-breadcrumb a:hover{color:var(--dark)}
.product-breadcrumb i{font-size:10px;opacity:.5}

/* Layout */
.product-layout{max-width:1260px;margin:0 auto;padding:20px 32px 80px;display:grid;grid-template-columns:1fr 1fr;gap:70px;align-items:start}

/* Gallery */
.product-gallery-main{border-radius:24px;overflow:hidden;border:1.5px solid var(--border);aspect-ratio:4/3;display:flex;align-items:center;justify-content:center;font-size:120px;position:relative;box-shadow:0 8px 32px rgba(30,24,16,.08)}
.product-gallery-main img{width:100%;height:100%;object-fit:cover;inset:0;transition:transform .4s}
.product-gallery-thumbs{display:flex;gap:10px;margin-top:12px;flex-wrap:wrap}
.product-thumb{width:80px;height:80px;border-radius:12px;overflow:hidden;border:2px solid var(--border);cursor:pointer;transition:border-color .2s;display:flex;align-items:center;justify-content:center;font-size:32px;position:relative;flex-shrink:0}
.product-thumb img{width:100%;height:100%;object-fit:cover;position:absolute;inset:0}
.product-thumb.active{border-color:var(--breakfast)}
.product-thumb:hover{border-color:var(--breakfast)}

/* Details */
.product-details{position:sticky;top:100px}
.product-cat-badge{display:inline-flex;align-items:center;gap:6px;border-radius:50px;padding:5px 14px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;margin-bottom:16px;border:1.5px solid}
.product-details h1{font-family:'Lora',serif;font-size:clamp(1.9rem,3vw,2.6rem);line-height:1.15;color:var(--dark);margin-bottom:12px}
.product-details h1 i{font-style:italic;color:var(--breakfast)}
.product-short-desc{font-size:15px;color:var(--mid);line-height:1.8;margin-bottom:20px}
.product-price-wrap{padding:20px 0;border-top:1.5px solid var(--border);border-bottom:1.5px solid var(--border);margin-bottom:28px}
.product-price-label{font-size:12px;font-weight:700;color:var(--mid);text-transform:uppercase;letter-spacing:.08em;margin-bottom:6px}
.product-price-amount{font-family:'Lora',serif;font-size:2.2rem;font-weight:700;color:var(--dark)}
.product-price-amount .woocommerce-Price-amount{font-family:'Lora',serif;font-size:2.2rem;font-weight:700;color:var(--dark)}
.product-price-note{font-size:13px;color:var(--mid);margin-top:4px}

//* ── YITH WAPO Add-ons ── */
.yith-wapo-container { margin-top: 22px !important; }

.yith-wapo-addon {
  background: transparent !important;
  margin-bottom: 18px !important;
  padding: 0 !important;
  border: none !important;
}

/* Titel */
.wapo-addon-title {
  font-family: 'DM Sans', sans-serif !important;
  font-size: 13px !important;
  font-weight: 700 !important;
  color: var(--dark) !important;
  margin-bottom: 7px !important;
  display: flex !important;
  align-items: center !important;
  gap: 4px !important;
  text-transform: none !important;
}
.wapo-addon-title .required {
  color: var(--strawberry) !important;
}

/* Beschreibung */
.wapo-addon-description {
  font-size: 12px !important;
  color: var(--mid) !important;
  margin-bottom: 8px !important;
}

/* Options Container */
.yith-wapo-addon .options-container {
  padding: 0 !important;
}

/* Selects – Datum & Uhrzeit */
.yith-wapo-addon select.yith-wapo-option-value {
  width: 100% !important;
  padding: 13px 16px !important;
  border-radius: 14px !important;
  border: 1.5px solid var(--border) !important;
  font-family: 'DM Sans', sans-serif !important;
  font-size: 15px !important;
  color: var(--dark) !important;
  background: white !important;
  outline: none !important;
  appearance: none !important;
  -webkit-appearance: none !important;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 16 16'%3E%3Cpath fill='%235a4a40' d='M7.247 11.14 2.451 5.658C1.885 5.013 2.345 4 3.204 4h9.592a1 1 0 0 1 .753 1.659l-4.796 5.48a1 1 0 0 1-1.506 0z'/%3E%3C/svg%3E") !important;
  background-repeat: no-repeat !important;
  background-position: right 16px center !important;
  cursor: pointer !important;
  transition: border-color .2s, box-shadow .2s !important;
}
.yith-wapo-addon select.yith-wapo-option-value:focus {
  border-color: var(--breakfast) !important;
  box-shadow: 0 0 0 3px rgba(46,125,94,.1) !important;
}

/* Text Input – Sonstiges */
.yith-wapo-addon input[type="text"].yith-wapo-option-value {
  width: 100% !important;
  padding: 13px 16px !important;
  border-radius: 14px !important;
  border: 1.5px solid var(--border) !important;
  font-family: 'DM Sans', sans-serif !important;
  font-size: 15px !important;
  color: var(--dark) !important;
  background: white !important;
  outline: none !important;
  transition: border-color .2s, box-shadow .2s !important;
}
.yith-wapo-addon input[type="text"].yith-wapo-option-value:focus {
  border-color: var(--breakfast) !important;
  box-shadow: 0 0 0 3px rgba(46,125,94,.1) !important;
}

/* Label für Textfeld */
.yith-wapo-option .label label {
  font-size: 13px !important;
  font-weight: 400 !important;
  color: var(--dark) !important;
  display: block !important;

}

/* Addon Header */
.yith-wapo-addon .addon-header {
  margin-bottom: 6px !important;
  border: none !important;
  background: none !important;
  padding: 0 !important;
}

/* Menge + Button nebeneinander */
.woocommerce form.cart {
  display: flex !important;
  gap: 12px !important;
  align-items: center !important;
  flex-wrap: nowrap !important;
  margin-bottom: 0 !important;
}
.woocommerce div.quantity,
.woocommerce form.cart .quantity {
  display: flex !important;
  align-items: center !important;
}
.woocommerce form.cart .qty {
  width: 72px !important;
  height: 52px !important;
  text-align: center !important;
  border: 1.5px solid var(--border) !important;
  border-radius: 14px !important;
  font-family: 'DM Sans', sans-serif !important;
  font-size: 16px !important;
  font-weight: 700 !important;
  color: var(--dark) !important;
  background: white !important;
}
.woocommerce form.cart .single_add_to_cart_button {
  flex: 1 !important;
  padding: 15px 28px !important;
  border-radius: 50px !important;
  
  color: white !important;
  font-family: 'DM Sans', sans-serif !important;
  font-size: 16px !important;
  font-weight: 700 !important;
  border: none !important;
  cursor: pointer !important;
  transition: transform .2s, box-shadow .2s !important;
  box-shadow: 0 4px 20px rgba(46,125,94,.3) !important;
  text-transform: none !important;
  letter-spacing: normal !important;
  white-space: nowrap !important;
}
.woocommerce form.cart .single_add_to_cart_button:hover {
  transform: translateY(-2px) !important;
  box-shadow: 0 8px 28px rgba(46,125,94,.4) !important;
}

/* Inline style width:75% von YITH überschreiben */
.yith-wapo-addon .options,
.yith-wapo-addon .options-container .options {
  width: 100% !important;
}

@media(max-width:640px){
  .woocommerce form.cart { flex-wrap: wrap !important; }
  .woocommerce form.cart .qty { width: 100% !important; }
}
/* Trust Badges */
.product-trust{display:flex;flex-wrap:wrap;gap:10px;margin-top:5px; margin-bottom: 20px; }
.trust-badge{display:flex;align-items:center;gap:6px;font-size:12px;font-weight:600;color:var(--mid)}
.trust-badge i{color:var(--breakfast);font-size:14px}

/* ════════ PRODUKT TABS – Pill Style ════════ */
.product-tabs-section { max-width: 1260px; margin: 0 auto; padding: 0 32px 80px; }

.product-tabs {
  display: flex;
  gap: 8px;
  margin-bottom: 32px;
  background: var(--light);
  border-radius: 50px;
  padding: 6px;
  width: fit-content;
  border: 1.5px solid var(--border);
}

.product-tab {
  padding: 10px 24px;
  font-size: 14px;
  font-weight: 700;
  color: var(--mid);
  background: none;
  border: none;
  border-radius: 50px;
  cursor: pointer;
  transition: all .2s;
  font-family: 'DM Sans', sans-serif;
  white-space: nowrap;
}
.product-tab:hover { color: var(--dark); background: white; }
.product-tab.active {
  background: white;
  color: var(--dark);
  box-shadow: 0 2px 10px rgba(30,24,16,.08);
}

/* Aktive Farbe dynamisch per JS – Tab-Color CSS Variable */
.product-tabs-section .product-tab.active {
  color: var(--tab-color, var(--strawberry)) !important;
}

.product-tab-content { display: none; }
.product-tab-content.active { display: block; }

/* Beschreibung */
.tab-beschreibung h3 {
  font-family: 'Lora', serif;
  font-size: 1.4rem;
  color: var(--dark);
  margin-bottom: 14px;
}
.tab-beschreibung p {
  font-size: 15px;
  color: var(--mid);
  line-height: 1.85;
  margin-bottom: 16px;
}
.tab-beschreibung ul {
  padding-left: 0;
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 10px;
  margin-bottom: 16px;
	margin-top: 16px;
}
.tab-beschreibung ul li {
  font-size: 15px;
  color: var(--mid);
  line-height: 1.6;
  display: flex;
  align-items: flex-start;
  gap: 10px;
}
.tab-beschreibung ul li::before {
  content: '🍓';
  font-size: 14px;
  flex-shrink: 0;
  margin-top: 2px;
}

/* Infos Tabelle */
.tab-infos table { width: 100%; border-collapse: collapse; }
.tab-infos tr { border-bottom: 1.5px solid var(--border); }
.tab-infos tr:first-child { border-top: 1.5px solid var(--border); }
.tab-infos th {
  padding: 16px 0;
  font-size: 13px;
  font-weight: 700;
  color: var(--mid);
  text-align: left;
  width: 40%;
  text-transform: uppercase;
  letter-spacing: .06em;
}
.tab-infos td {
  padding: 16px 0;
  font-size: 15px;
  font-weight: 600;
  color: var(--dark);
}

@media(max-width:640px){
  .product-tabs { width: 100%; justify-content: center; }
  .product-tab { padding: 10px 16px; font-size: 13px; }
  .product-tabs-section { padding: 0 20px 60px; }
}

/* Related */
.related-section{background:var(--breakfast-bg);padding:70px 32px}
.related-inner{max-width:1260px;margin:0 auto}
.related-inner h2{font-family:'Lora',serif;font-size:clamp(1.8rem,3vw,2.4rem);color:var(--dark);margin-bottom:36px}
.related-inner h2 i{font-style:italic;color:var(--breakfast)}
.related-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:20px}
.related-card{background:white;border-radius:18px;overflow:hidden;border:1.5px solid var(--border);text-decoration:none;color:inherit;transition:transform .3s,box-shadow .3s}
.related-card:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.related-card-img{height:300px;display:flex;align-items:center;justify-content:center;font-size:56px;position:relative;overflow:hidden}
.related-card-body{padding:16px 18px 20px}
.related-card-body h4{font-family:'Lora',serif;font-size:1rem;color:var(--dark);margin-bottom:6px}
.related-card-body p{font-size:13px;color:var(--mid);line-height:1.5}
.related-card-price{font-family:'Lora',serif;font-size:1.1rem;font-weight:700;color:var(--dark);margin-top:10px}
.related-card-price .woocommerce-Price-amount{font-family:'Lora',serif;font-size:1.1rem;font-weight:700;color:var(--dark)}

/* Responsive */
@media(max-width:960px){
  .product-layout{grid-template-columns:1fr;gap:40px;padding:20px 32px 60px}
  .product-details{position:static}
  .related-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:640px){
  .product-layout{padding:20px 20px 60px}
  .product-tabs-section{padding:0 20px 60px}
  .related-section{padding:60px 20px}
  .related-grid{grid-template-columns:1fr}
  .woocommerce form.cart{flex-direction:column;align-items:stretch}
  .woocommerce form.cart .qty{width:100% !important}
}


/* Menge + Button nebeneinander – über YITH Container */
.woocommerce form.cart .quantity,
.woocommerce form.cart div.quantity {
  display: inline-flex !important;
  flex-shrink: 0 !important;
}

/* YITH Container kommt nach dem Button – wir reordnen per Flexbox */
.woocommerce form.cart {
  display: flex !important;
  flex-wrap: wrap !important;
  align-items: center !important;
  gap: 12px !important;
}

/* Quantity und Button in eine Zeile zwingen */
.woocommerce form.cart .quantity { order: 1 !important; }
.woocommerce form.cart .single_add_to_cart_button { order: 2 !important; }
.woocommerce form.cart #yith-wapo-container { 
  order: 3 !important; 
  width: 100% !important;
  flex-basis: 100% !important;
}

#yith-wapo-container .yith-wapo-block {
	margin-top: 20px !important;
}

/* Out of Stock – wie Feld-Status */
.stock.out-of-stock {
  display: inline-flex !important;
  align-items: center !important;
  gap: 6px !important;
  padding: 6px 14px !important;
  border-radius: 50px !important;
  background: #FFF0F0 !important;
  border: 1.5px solid rgba(192,57,43,.2) !important;
  font-size: 12px !important;
  font-weight: 700 !important;
  color: #C0392B !important;
  text-transform: uppercase !important;
  letter-spacing: .08em !important;
}
.stock.out-of-stock::before {
  content: '●' !important;
  font-size: 8px !important;
  color: #C0392B !important;
}





/* ════════ FEIERN MODAL – AUSWAHL (3 Steps) ════════ */
.feiern-step-indicator{display:flex;align-items:center;gap:8px;margin-bottom:4px}
.feiern-step-dot{width:8px;height:8px;border-radius:50%;background:var(--border);transition:background .3s}
.feiern-step-dot.active{background:var(--strawberry)}
.feiern-step-dot.done{background:rgba(217,58,82,.3)}

.feiern-selection-cards{display:flex;flex-direction:column;gap:12px;width:100%}
.feiern-selection-card{display:flex;align-items:center;gap:16px;padding:16px 20px;border-radius:16px;border:2px solid var(--border);background:white;cursor:pointer;transition:all .25s;text-align:left;width:100%}
.feiern-selection-card:hover{border-color:rgba(217,58,82,.3);background:var(--strawberry-bg);transform:translateY(-2px);box-shadow:0 6px 20px rgba(217,58,82,.1)}
.feiern-selection-card.selected{border-color:var(--strawberry);background:var(--strawberry-bg);box-shadow:0 4px 16px rgba(217,58,82,.15)}
.feiern-selection-icon{width:48px;height:48px;border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:26px;flex-shrink:0;background:white;box-shadow:0 2px 8px rgba(0,0,0,.06)}
.feiern-selection-text h4{font-size:15px;font-weight:700;color:var(--dark);margin-bottom:2px}
.feiern-selection-text p{font-size:12.5px;color:var(--mid);line-height:1.4}
.feiern-selection-check{margin-left:auto;width:22px;height:22px;border-radius:50%;border:2px solid var(--border);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all .2s;font-size:12px;color:white}
.feiern-selection-card.selected .feiern-selection-check{background:var(--strawberry);border-color:var(--strawberry)}
.feiern-selection-card.selected .feiern-selection-check::after{content:'✓'}

.feiern-btn-next{width:100%;padding:14px;border-radius:50px;background:var(--strawberry);color:white;font-family:'DM Sans',sans-serif;font-size:15px;font-weight:700;border:none;cursor:pointer;box-shadow:0 4px 20px rgba(217,58,82,.3);transition:transform .2s,box-shadow .2s,opacity .2s;opacity:.4;pointer-events:none}
.feiern-btn-next.enabled{opacity:1;pointer-events:all}
.feiern-btn-next.enabled:hover{transform:translateY(-2px);box-shadow:0 8px 28px rgba(217,58,82,.45)}

.feiern-selected-badge{display:inline-flex;align-items:center;gap:8px;background:var(--strawberry-bg);color:var(--strawberry);border:1.5px solid rgba(217,58,82,.2);border-radius:50px;padding:6px 14px;font-size:13px;font-weight:700;width:fit-content;margin-bottom:4px}

.feiern-btn-back{background:none;border:none;color:var(--mid);font-family:'DM Sans',sans-serif;font-size:13px;font-weight:600;cursor:pointer;display:flex;align-items:center;gap:4px;padding:0;transition:color .2s;margin-top:4px}
.feiern-btn-back:hover{color:var(--dark)}




/* ════════ ROUTE FINDER FAB ════════ */
.route-fab-wrap {
  position: fixed;
  bottom: 36px;
  right: 36px;
  z-index: 9999;
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 12px;
  animation: slideInRight .6s cubic-bezier(.34,1.56,.64,1) .5s both;
}
@keyframes slideInRight{from{opacity:0;transform:translateX(20px) scale(.9)}to{opacity:1;transform:translateX(0) scale(1)}}

/* Panel */
.route-panel{background:white;border-radius:22px;border:1.5px solid var(--border);box-shadow:0 16px 48px rgba(30,24,16,.16);overflow:hidden;width:300px;transform:scale(0.9) translateY(20px);transform-origin:bottom right;opacity:0;pointer-events:none;transition:all .35s cubic-bezier(.34,1.56,.64,1)}
.route-panel.open{transform:scale(1) translateY(0);opacity:1;pointer-events:all}
.route-panel-header{padding:16px 18px 12px;border-bottom:1.5px solid var(--border);background:var(--waldviertel-bg)}
.route-panel-header h4{font-family:'Lora',serif;font-size:1rem;color:var(--dark)}
.route-panel-header h4 i{font-style:italic;color:var(--waldviertel)}
.route-panel-header p{font-size:12px;color:var(--mid);margin-top:3px}
.route-field-list{padding:10px;display:flex;flex-direction:column;gap:6px}
.route-field-card{display:flex;align-items:center;gap:12px;padding:12px 14px;border-radius:14px;border:1.5px solid var(--border);text-decoration:none;color:inherit;transition:background .2s,border-color .2s;background:white;position:relative;overflow:hidden}
.route-field-card::before{content:'';position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--waldviertel);transform:scaleY(0);transition:transform .2s}
.route-field-card:hover{background:var(--waldviertel-bg);border-color:rgba(92,140,58,.3)}
.route-field-card:hover::before{transform:scaleY(1)}
.rfc-icon{width:38px;height:38px;border-radius:10px;background:var(--waldviertel-bg);display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0}
.rfc-text{flex:1}
.rfc-text strong{font-size:13.5px;font-weight:700;color:var(--dark);display:block}
.rfc-text span{font-size:11.5px;color:var(--mid)}
.rfc-arrow{width:28px;height:28px;border-radius:50%;background:var(--waldviertel);color:white;display:flex;align-items:center;justify-content:center;font-size:12px;flex-shrink:0}
.rfc-status{width:7px;height:7px;border-radius:50%;position:absolute;top:10px;right:10px}
.status-open{background:#27AE60}
.status-closed-s{background:#E74C3C}
.route-panel-footer{padding:10px 18px 14px;border-top:1.5px solid var(--border);text-align:center}
.route-panel-footer a{font-size:12px;font-weight:700;color:var(--waldviertel);text-decoration:none;display:inline-flex;align-items:center;gap:5px}
.route-panel-footer a:hover{text-decoration:underline}

/* Row: Label NUR beim Hover direkt über den Button */
.route-fab-row {
  display: flex;
  align-items: center;
  gap: 10px;
  /* Breite nur so groß wie der Inhalt */
  width: fit-content;
}
.route-fab-label {
  background: var(--dark);
  color: white;
  font-size: 12px;
  font-weight: 700;
  padding: 6px 12px;
  border-radius: 8px;
  white-space: nowrap;
  opacity: 0;
  transition: opacity .2s;
  pointer-events: none;
  position: relative;
}
.route-fab-label::after {
  content: '';
  position: absolute;
  left: 100%; top: 50%;
  transform: translateY(-50%);
  border: 6px solid transparent;
  border-left-color: var(--dark);
}
/* Hover NUR auf der Row, nicht auf dem ganzen Wrap */
.route-fab-row:hover .route-fab-label { opacity: 1; }

/* ════════ ROUTE FINDER FAB ════════ */
.route-fab-wrap{position:fixed;bottom:36px;right:36px;z-index:9999;display:flex;flex-direction:column;align-items:flex-end;gap:12px;animation:slideInRight .6s cubic-bezier(.34,1.56,.64,1) .5s both;width:auto;pointer-events:none}
@keyframes slideInRight{from{opacity:0;transform:translateX(20px) scale(.9)}to{opacity:1;transform:translateX(0) scale(1)}}
.route-panel{background:white;border-radius:22px;border:1.5px solid var(--border);box-shadow:0 16px 48px rgba(30,24,16,.16);overflow:hidden;width:300px;transform:scale(0.9) translateY(20px);transform-origin:bottom right;opacity:0;pointer-events:none;transition:all .35s cubic-bezier(.34,1.56,.64,1)}
.route-panel.open{transform:scale(1) translateY(0);opacity:1;pointer-events:all}
.route-panel-header{padding:16px 18px 12px;border-bottom:1.5px solid var(--border);background:var(--waldviertel-bg)}
.route-panel-header h4{font-family:'Lora',serif;font-size:1rem;color:var(--dark)}
.route-panel-header h4 i{font-style:italic;color:var(--waldviertel)}
.route-panel-header p{font-size:12px;color:var(--mid);margin-top:3px}
.route-field-list{padding:10px;display:flex;flex-direction:column;gap:6px}
.route-field-card{display:flex;align-items:center;gap:12px;padding:12px 14px;border-radius:14px;border:1.5px solid var(--border);text-decoration:none;color:inherit;transition:background .2s,border-color .2s;background:white;position:relative;overflow:hidden}
.route-field-card::before{content:'';position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--waldviertel);transform:scaleY(0);transition:transform .2s}
.route-field-card:hover{background:var(--waldviertel-bg);border-color:rgba(92,140,58,.3)}
.route-field-card:hover::before{transform:scaleY(1)}
.rfc-icon{width:38px;height:38px;border-radius:10px;background:var(--waldviertel-bg);display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0}
.rfc-text{flex:1}
.rfc-text strong{font-size:13.5px;font-weight:700;color:var(--dark);display:block}
.rfc-text span{font-size:11.5px;color:var(--mid)}
.rfc-arrow{width:28px;height:28px;border-radius:50%;background:var(--waldviertel);color:white;display:flex;align-items:center;justify-content:center;font-size:12px;flex-shrink:0}
.rfc-status{width:7px;height:7px;border-radius:50%;position:absolute;top:10px;right:10px}
.status-open{background:#27AE60}
.status-closed-s{background:#E74C3C}
.route-panel-footer{padding:10px 18px 14px;border-top:1.5px solid var(--border);text-align:center}
.route-panel-footer a{font-size:12px;font-weight:700;color:var(--waldviertel);text-decoration:none;display:inline-flex;align-items:center;gap:5px}
.route-panel-footer a:hover{text-decoration:underline}
.route-fab{width:58px;height:58px;border-radius:50%;background:var(--waldviertel);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 6px 24px rgba(92,140,58,.4);transition:transform .3s cubic-bezier(.34,1.56,.64,1),box-shadow .3s,background .3s;position:relative;pointer-events:all;animation:fabPulse 2.8s ease-in-out infinite}
.route-fab.is-open{animation:none;transform:scale(1.05) rotate(45deg);background:var(--dark);box-shadow:0 6px 24px rgba(30,24,16,.3)}
.route-fab:hover{animation:none;transform:scale(1.1) translateY(-2px);box-shadow:0 10px 32px rgba(92,140,58,.5)}
.route-fab.is-open:hover{transform:scale(1.1) rotate(45deg)}
.route-fab-icon{font-size:22px;color:white}
.route-fab-ring{position:absolute;inset:-3px;border-radius:50%;border:2px solid rgba(92,140,58,.35);animation:ringPulse 2.8s ease-out infinite;pointer-events:none}
@media(max-width:640px){
  .route-fab-wrap{bottom:24px;right:24px}
  .route-panel{width:calc(100vw - 48px)}
}


/* Warenkorb Badge im Nav */
.nav-cta { position: relative; }
.nav-cart-count {
  position: absolute;
  top: -6px;
  right: -8px;
  width: 18px;
  height: 18px;
  border-radius: 50%;
  background: white;
  color: var(--strawberry);
  font-size: 10px;
  font-weight: 800;
  display: flex;
  align-items: center;
  justify-content: center;
  border: 1.5px solid var(--strawberry);
  line-height: 1;
}

/* ════════ NAV CART DROPDOWN ════════ */
.nav-cart-wrap { position: relative; }
.nav-cta { position: relative; }
.nav-cart-count {
  position: absolute; top: -6px; right: -8px;
  width: 18px; height: 18px; border-radius: 50%;
  background: white; color: var(--strawberry);
  font-size: 10px; font-weight: 800;
  display: flex; align-items: center; justify-content: center;
  border: 1.5px solid var(--strawberry); line-height: 1;
}

.nav-cart-dropdown {
  position: absolute; top: calc(100% + 12px); right: 0;
  width: 300px; background: white;
  border-radius: 18px; border: 1.5px solid var(--border);
  box-shadow: 0 16px 48px rgba(30,24,16,.16);
  opacity: 0; pointer-events: none;
  transform: translateY(8px) scale(.97);
  transform-origin: top right;
  transition: all .25s cubic-bezier(.34,1.56,.64,1);
  z-index: 9999;
}
.nav-cart-wrap:hover .nav-cart-dropdown,
.nav-cart-dropdown.open {
  opacity: 1; pointer-events: all;
  transform: translateY(0) scale(1);
}

.ncd-inner { padding: 16px; display: flex; flex-direction: column; gap: 12px; }

.ncd-items { display: flex; flex-direction: column; gap: 8px; }
.ncd-item {
  display: flex; align-items: center; gap: 10px;
  padding: 8px 10px; border-radius: 12px;
  background: var(--light); border: 1.5px solid var(--border);
}
.ncd-item-img {
  width: 40px; height: 40px; border-radius: 8px;
  overflow: hidden; flex-shrink: 0; background: var(--strawberry-bg);
  display: flex; align-items: center; justify-content: center;
}
.ncd-item-img img { width: 100%; height: 100%; object-fit: cover; }
.ncd-item-text { flex: 1; }
.ncd-item-name { font-size: 13px; font-weight: 700; color: var(--dark); display: block; }
.ncd-item-qty { font-size: 12px; color: var(--mid); }

.ncd-total {
  display: flex; justify-content: space-between; align-items: center;
  padding: 10px 0; border-top: 1.5px solid var(--border);
  font-size: 14px; color: var(--mid);
}
.ncd-total strong { font-family: 'Lora', serif; font-size: 1.1rem; color: var(--dark); }

.ncd-actions { display: flex; flex-direction: column; gap: 8px; }
.ncd-btn-checkout {
  display: flex; align-items: center; justify-content: center; gap: 8px;
  padding: 12px; border-radius: 50px;
  background: var(--strawberry); color: white;
  font-size: 14px; font-weight: 700; text-decoration: none;
  transition: transform .2s, box-shadow .2s;
  box-shadow: 0 4px 16px rgba(217,58,82,.3);
}
.ncd-btn-checkout:hover { transform: translateY(-2px); box-shadow: 0 6px 20px rgba(217,58,82,.4); }
.ncd-btn-cart {
  display: flex; align-items: center; justify-content: center;
  padding: 10px; border-radius: 50px;
  background: var(--light); color: var(--mid);
  font-size: 13px; font-weight: 600; text-decoration: none;
  border: 1.5px solid var(--border);
  transition: background .2s, color .2s;
}
.ncd-btn-cart:hover { background: var(--dark); color: white; border-color: var(--dark); }

@media(max-width:960px) {
  .nav-cart-dropdown { display: none; }
}





/* ════════════════════════════════
   PW GIFT CARDS STYLING
════════════════════════════════ */

/* Variations – Betrag wählen */
.variations { width:100% !important; border-collapse:collapse !important; margin-bottom:20px !important; }




.variations td.value { padding:0 !important; }
.variations select {
  width: 100% !important;
  padding: 13px 16px !important;
  border-radius: 14px !important;
  border: 1.5px solid var(--border) !important;
  font-family: 'DM Sans', sans-serif !important;
  font-size: 15px !important;
  color: var(--dark) !important;
  background: white !important;
  outline: none !important;
  appearance: none !important;
  -webkit-appearance: none !important;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 16 16'%3E%3Cpath fill='%235a4a40' d='M7.247 11.14 2.451 5.658C1.885 5.013 2.345 4 3.204 4h9.592a1 1 0 0 1 .753 1.659l-4.796 5.48a1 1 0 0 1-1.506 0z'/%3E%3C/svg%3E") !important;
  background-repeat: no-repeat !important;
  background-position: right 16px center !important;
  cursor: pointer !important;
  transition: border-color .2s, box-shadow .2s !important;
}
.variations select:focus {
  border-color: var(--pumpkin) !important;
  box-shadow: 0 0 0 3px rgba(217,107,10,.1) !important;
}


.sp-accent-tickets .woocommerce-variation-price .woocommerce-Price-amount {
  font-family: 'Lora', serif !important;
  font-size: 1.8rem !important;
  font-weight: 700 !important;
  color: var(--strawberry) !important;
}
/* Reset link */
.reset_variations {
  display: inline-block !important;
  font-size: 12px !important;
  color: var(--mid) !important;
  margin-top: 6px !important;
  text-decoration: none !important;
}
.reset_variations:hover { color: var(--dark) !important; }

/* PW Gift Cards Felder */
#pwgc-purchase-container {
  width: 100% !important;
  margin-bottom: 20px !important;
}
.pwgc-field-container {
  margin-bottom: 16px !important;
}
.pwgc-label {
  font-size: 13px !important;
  font-weight: 700 !important;
  color: var(--dark) !important;
  display: block !important;
  margin-bottom: 7px !important;
}
.pwgc-subtitle {
  font-size: 11.5px !important;
  color: var(--mid) !important;
  margin-top: 5px !important;
  line-height: 1.5 !important;
}
.pwgc-input-text,
#pwgc-message {
  width: 100% !important;
  padding: 13px 16px !important;
  border-radius: 14px !important;
  border: 1.5px solid var(--border) !important;
  font-family: 'DM Sans', sans-serif !important;
  font-size: 15px !important;
  color: var(--dark) !important;
  background: white !important;
  outline: none !important;
  transition: border-color .2s, box-shadow .2s !important;
  box-sizing: border-box !important;
}
.pwgc-input-text:focus,
#pwgc-message:focus {
  border-color: var(--pumpkin) !important;
  box-shadow: 0 0 0 3px rgba(217,107,10,.1) !important;
}
#pwgc-message {
  height: 100px !important;
  resize: vertical !important;
  display: block !important;
}
#pwgc-message-characters-remaining {
  font-weight: 700 !important;
  color: var(--dark) !important;
}

/* Variationen Button Reihenfolge */
.woocommerce-variation-add-to-cart {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 12px !important;
  align-items: center !important;
}
.woocommerce-variation-add-to-cart .quantity { order: 1 !important; }
.woocommerce-variation-add-to-cart .single_add_to_cart_button { order: 2 !important; flex: 1 !important; }
.woocommerce-variation-add-to-cart #yith-wapo-container { order: 3 !important; width: 100% !important; }

/* Produkt-Tabs – dynamische Farbe via CSS Variable */
.product-tabs-section .product-tab.active {
  color: var(--tab-color, var(--strawberry)) !important;
  border-color: var(--tab-color, var(--strawberry)) !important;
}




.product-checkout-btn {
  display: flex; align-items: center; justify-content: center; gap: 8px;
  width: 100%; padding: 14px; border-radius: 50px;
  color: white; font-family: 'DM Sans', sans-serif;
  font-size: 15px; font-weight: 700; text-decoration: none;
  transition: transform .2s, box-shadow .2s;
  margin-top: 4px;
	background: var(--dark) !important;
}
.product-checkout-btn:hover { transform: translateY(-2px); opacity: .9; }

/* Mobil: Menge + Warenkorb + Kasse untereinander, alle 100% */
@media(max-width:640px){
  .woocommerce form.cart {
    flex-direction: column !important;
    align-items: stretch !important;
  }
  .woocommerce form.cart .quantity,
  .woocommerce form.cart div.quantity {
    width: 100% !important;
  }
  .woocommerce form.cart .qty {
    width: 100% !important;
  }
  .woocommerce form.cart .single_add_to_cart_button {
    width: 100% !important;
	  margin-top: 10px !important;
  }
  #feierCheckoutWrap {
    margin-top: 8px !important;
  }
  .product-checkout-btn {
    width: 100% !important;
    box-sizing: border-box !important;
	  margin-top: 10px !important;
  }
}





.pswp {
	display: none !important;
}







/* ════════ TULPEN ERLEBNISSE ════════ */
.tulip-experiences {
  display: flex;
  flex-direction: column;
  gap: 12px;
  margin: 20px 0 24px;
}
.tulip-experience-card {
  display: flex;
  gap: 14px;
  align-items: flex-start;
  background: var(--tulip-bg);
  border: 1.5px solid rgba(192,85,154,.15);
  border-radius: 14px;
  padding: 16px 18px;
}
.tec-icon { font-size: 22px; flex-shrink: 0; margin-top: 2px; }
.tec-body strong {
  font-size: 15px;
  font-weight: 700;
  color: var(--dark);
  display: block;
  margin-bottom: 5px;
}
.tec-body p {
  font-size: 14px;
  color: var(--mid);
  line-height: 1.7;
  margin: 0;
}

/* Hinweis Banner */
.tulip-notice {
  display: flex;
  gap: 12px;
  align-items: flex-start;
  background: #FFF8EC;
  border: 1.5px solid rgba(201,149,42,.25);
  border-radius: 14px;
  padding: 16px 18px;
  margin-bottom: 20px;
  font-size: 14px;
  color: var(--dark);
  line-height: 1.7;
}
.tulip-notice-icon { font-size: 18px; flex-shrink: 0; margin-top: 2px; }
.tulip-notice strong { font-weight: 700; margin-right: 4px; }

/* Farbige Highlights */
.intro-highlight--gold {
  background: #FFF8EC !important;
  border-color: rgba(201,149,42,.2) !important;
  color: #8B6914 !important;
  font-weight: 700 !important;
}
.intro-highlight--tulip {
  background: var(--tulip-bg) !important;
  border-color: rgba(192,85,154,.2) !important;
  color: var(--tulip) !important;
  font-weight: 700 !important;
}

.tec-hours {
  display: inline-block;
  font-size: 12px;
  font-weight: 700;
  color: var(--tulip);
  background: white;
  border: 1.5px solid rgba(192,85,154,.2);
  border-radius: 50px;
  padding: 3px 10px;
  margin-bottom: 8px;
}



.firma-anfrage-btn {
  width: 100%;
  padding: 13px;
  margin-top: 10px;
  border-radius: 50px;
  background: white;
  color: var(--breakfast);
  border: 1.5px solid var(--breakfast);
  font-family: 'DM Sans', sans-serif;
  font-size: 15px;
  font-weight: 700;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  transition: background .2s, color .2s;
}
.firma-anfrage-btn:hover {
  background: var(--breakfast);
  color: white;
}

/* ════════ FIRMEN MODAL FELDER ════════ */
#firmaForm .feiern-modal-field {
  display: flex;
  flex-direction: column;
  gap: 6px;
  margin-bottom: 14px;
}
#firmaForm .feiern-modal-field label {
  font-size: 13px;
  font-weight: 700;
  color: var(--mid);
}
#firmaForm .feiern-modal-field input {
  width: 100%;
  padding: 13px 16px;
  border: 1.5px solid var(--border);
  border-radius: 12px;
  font-family: 'DM Sans', sans-serif;
  font-size: 15px;
  color: var(--dark);
  background: #FAFAFA;
  transition: border-color .2s, box-shadow .2s;
  box-sizing: border-box;
}
#firmaForm .feiern-modal-field input:focus {
  border-color: var(--breakfast);
  box-shadow: 0 0 0 3px rgba(46,125,94,.1);
  background: white;
  outline: none;
}
.feiern-modal-overlay {
  position: fixed;
  inset: 0;
  background: rgba(30,24,16,.5);
  z-index: 99998;
  display: flex;
  align-items: center;
  justify-content: center;

  box-sizing: border-box;
  opacity: 0;
  pointer-events: none;
  transition: opacity .3s ease;
  backdrop-filter: blur(4px);
}
.feiern-modal-overlay.open {
  opacity: 1;
  pointer-events: all;
}
.feiern-modal {
  position: relative;
  background: white;
  border-radius: 24px;
  padding: 40px 32px 32px;
  width: 100%;
  max-width: 480px;
  max-height: calc(100vh - 100px);
  overflow-y: auto;
  box-shadow: 0 24px 64px rgba(30,24,16,.2);
}




/* ════════ WARENKORB BLOCK ════════ */

/* Layout */
.wc-block-cart .wc-block-components-sidebar-layout { gap: 40px !important; }

/* Tabelle Header */
.wc-block-cart-items__header th {
  font-family: 'DM Sans', sans-serif !important;
  font-size: 12px !important;
  font-weight: 700 !important;
  text-transform: uppercase !important;
  letter-spacing: .06em !important;
  color: var(--mid) !important;
  padding-bottom: 14px !important;
}

/* Produkt Links */
.wc-block-components-product-name {
  font-family: 'Lora', serif !important;
  font-size: 1rem !important;
  font-weight: 700 !important;
  color: var(--dark) !important;
  text-decoration: none !important;
}
.wc-block-components-product-name:hover { color: var(--strawberry) !important; }

/* Produkt Bild */
.wc-block-cart-item__image img {
  border-radius: 12px !important;
  border: 1.5px solid var(--border) !important;
}

/* Preis */
.wc-block-components-product-price__value {
  font-family: 'Lora', serif !important;
  font-size: 1rem !important;
  font-weight: 700 !important;
  color: var(--dark) !important;
}

/* Meta – Datum etc. */
.wc-block-components-product-details__name {
  font-size: 12px !important;
  font-weight: 700 !important;
  color: var(--mid) !important;
}
.wc-block-components-product-details__value {
  font-size: 12px !important;
  color: var(--dark) !important;
  font-weight: 600 !important;
}
.wc-block-components-product-metadata__description p {
  font-size: 12px !important;
  color: var(--mid) !important;
  line-height: 1.5 !important;
}

/* Mengen Selector */
.wc-block-components-quantity-selector {
  border: 1.5px solid var(--border) !important;
  border-radius: 50px !important;
  overflow: hidden !important;
}
.wc-block-components-quantity-selector__input {
  font-family: 'DM Sans', sans-serif !important;
  font-size: 15px !important;
  font-weight: 700 !important;
  color: var(--dark) !important;
  border: none !important;
}
.wc-block-components-quantity-selector__button {
  background: var(--light) !important;
  color: var(--dark) !important;
  border: none !important;
  font-size: 16px !important;
  transition: background .2s !important;
}
.wc-block-components-quantity-selector__button:hover {
  background: var(--border) !important;
}

/* Entfernen Link */
.wc-block-cart-item__remove-link {
  color: var(--mid) !important;
  transition: color .2s !important;
}
.wc-block-cart-item__remove-link:hover { color: var(--strawberry) !important; }
.wc-block-cart-item__remove-link svg { width: 16px !important; height: 16px !important; }

/* ── Sidebar ── */
.wc-block-cart__sidebar {
  background: white !important;
  border-radius: 20px !important;
  border: 1.5px solid var(--border) !important;
  padding: 24px !important;
}

/* Titel */
.wc-block-cart__totals-title {
  font-family: 'Lora', serif !important;
  font-size: 1.2rem !important;
  font-weight: 700 !important;
  color: var(--dark) !important;
 
}

/* Summen */
.wc-block-components-totals-item__label {
  font-family: 'DM Sans', sans-serif !important;
  font-size: 14px !important;
  color: var(--mid) !important;
}
.wc-block-components-totals-item__value {
  font-family: 'DM Sans', sans-serif !important;
  font-size: 14px !important;
  font-weight: 700 !important;
  color: var(--dark) !important;
}
.wc-block-components-totals-footer-item .wc-block-components-totals-item__label {
  font-family: 'Lora', serif !important;
  font-size: 1rem !important;
  font-weight: 700 !important;
  color: var(--dark) !important;
}
.wc-block-components-totals-footer-item-tax-value {
  font-family: 'Lora', serif !important;
  font-size: 1.25rem !important;
  font-weight: 700 !important;
  color: var(--dark) !important;
}
.wc-block-components-totals-footer-item-tax {
  font-size: 12px !important;
  color: var(--mid) !important;
}

/* Express Payment Trenner */
.wc-block-components-express-payment-continue-rule {
  font-family: 'DM Sans', sans-serif !important;
  font-size: 13px !important;
  color: var(--mid) !important;
}

/* ── Weiter zur Kasse Button ── */
.wc-block-cart__submit-button {
  background: var(--strawberry) !important;
  color: white !important;
  border: none !important;
  border-radius: 50px !important;
  padding: 16px !important;
  font-family: 'DM Sans', sans-serif !important;
  font-size: 16px !important;
  font-weight: 700 !important;
  text-decoration: none !important;
  transition: transform .2s, box-shadow .2s !important;
  box-shadow: 0 4px 20px rgba(217,58,82,.3) !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
}
.wc-block-cart__submit-button:hover {
  transform: translateY(-2px) !important;
  box-shadow: 0 8px 28px rgba(217,58,82,.4) !important;
  background: var(--strawberry) !important;
  color: white !important;
}

@media(max-width:768px){
  .wc-block-cart .wc-block-components-sidebar-layout { flex-direction: column !important; }
	.wc-block-cart .wc-block-components-sidebar .wc-block-cart__totals-title {
		display: block !important;
	}
}

/* ════════ PWGC GESCHENKKARTE WARENKORB ════════ */

#pwgc-redeem-gift-card-form label {
  font-family: 'DM Sans', sans-serif !important;
  font-size: 13px !important;
  font-weight: 700 !important;
  color: var(--mid) !important;
  display: block !important;
  margin-bottom: 8px !important;
}

#pwgc-redeem-gift-card-number {
  width: 100% !important;
  padding: 13px 16px !important;
  border: 1.5px solid var(--border) !important;
  border-radius: 12px !important;
  font-family: 'DM Sans', sans-serif !important;
  font-size: 15px !important;
  color: var(--dark) !important;
  background: #FAFAFA !important;
  box-sizing: border-box !important;
  margin-bottom: 10px !important;
  transition: border-color .2s, box-shadow .2s !important;
}
#pwgc-redeem-gift-card-number:focus {
  border-color: var(--pumpkin) !important;
  box-shadow: 0 0 0 3px rgba(217,107,10,.1) !important;
  background: white !important;
  outline: none !important;
}

.pwgc-apply-gift-card-button {
  width: 100% !important;
  padding: 13px !important;
  border-radius: 50px !important;
  background: var(--dark) !important;
  color: white !important;
  font-family: 'DM Sans', sans-serif !important;
  font-size: 14px !important;
  font-weight: 700 !important;
  border: none !important;
  cursor: pointer !important;
  transition: background .2s, transform .2s !important;
}
.pwgc-apply-gift-card-button:hover {
  background: var(--pumpkin) !important;
  transform: translateY(-1px) !important;
}

/* Weiter zur Kasse – kein sticky/fixed auf Mobil */
.wc-block-cart__submit-container {
  position: static !important;
  bottom: auto !important;
  left: auto !important;
  right: auto !important;
  z-index: auto !important;
  box-shadow: none !important;
  padding: 0 !important;
  background: transparent !important;
}

.wc-block-cart__submit {
  position: static !important;
  bottom: auto !important;
  z-index: auto !important;
}

/* ════════ BESTELLUNG AUFGEBEN BUTTON ════════ */
.wc-block-components-checkout-place-order-button {
  width: 100% !important;
  padding: 16px !important;
  border-radius: 50px !important;
  background: var(--strawberry) !important;
  color: white !important;
  border: none !important;
  font-family: 'DM Sans', sans-serif !important;
  font-size: 16px !important;
  font-weight: 700 !important;
  cursor: pointer !important;
  transition: transform .2s, box-shadow .2s !important;
  box-shadow: 0 4px 20px rgba(217,58,82,.3) !important;
  text-transform: none !important;
  letter-spacing: normal !important;
}
.wc-block-components-checkout-place-order-button:hover {
  transform: translateY(-2px) !important;
  box-shadow: 0 8px 28px rgba(217,58,82,.4) !important;
  background: var(--strawberry) !important;
}
.wc-block-components-checkout-place-order-button .wc-block-components-button__text {
  font-family: 'DM Sans', sans-serif !important;
  font-size: 16px !important;
  font-weight: 700 !important;
}



/* ════════ CART FAB ════════ */
.cart-fab-wrap {
  position: fixed;
  bottom: 32px;
  left: 32px;
  z-index: 9998;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 12px;
}

.cart-panel {
  background: white;
  border-radius: 22px;
  border: 1.5px solid var(--border);
  box-shadow: 0 16px 48px rgba(30,24,16,.16);
  overflow: hidden;
  width: 300px;
  transform: scale(0.9) translateY(20px);
  transform-origin: bottom left;
  opacity: 0;
  pointer-events: none;
  transition: all .35s cubic-bezier(.34,1.56,.64,1);
}
.cart-panel.open {
  transform: scale(1) translateY(0);
  opacity: 1;
  pointer-events: all;
}

.cart-panel-header {
  padding: 14px 18px 12px;
  border-bottom: 1.5px solid var(--border);
  background: var(--strawberry-bg);
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.cart-panel-header h4 {
  font-family: 'Lora', serif;
  font-size: 1rem;
  color: var(--dark);
  margin: 0;
}
.cart-panel-header span {
  font-size: 12px;
  color: var(--mid);
}

.cart-items { padding: 10px; display: flex; flex-direction: column; gap: 6px; }
.cart-fab-item {
  display: flex; align-items: center; gap: 10px;
  padding: 10px 12px; border-radius: 12px;
  border: 1.5px solid var(--border); background: white;
}
.cart-fab-item-img {
  width: 40px; height: 40px; border-radius: 8px;
  background: var(--strawberry-bg);
  display: flex; align-items: center; justify-content: center;
  font-size: 20px; flex-shrink: 0; overflow: hidden;
}
.cart-fab-item-img img { width: 100%; height: 100%; object-fit: cover; }
.cart-fab-item-name { font-size: 13px; font-weight: 700; color: var(--dark); display: block; }
.cart-fab-item-meta { font-size: 11.5px; color: var(--mid); display: block; }

.cart-fab-total {
  display: flex; justify-content: space-between; align-items: center;
  padding: 10px 18px; border-top: 1.5px solid var(--border);
  font-size: 13px; color: var(--mid);
}
.cart-fab-total strong {
  font-family: 'Lora', serif;
  font-size: 1.1rem;
  color: var(--dark);
}

.cart-fab-actions { padding: 10px; display: flex; flex-direction: column; gap: 8px; }
.cart-fab-btn-checkout {
  display: flex; align-items: center; justify-content: center; gap: 8px;
  padding: 12px; border-radius: 50px;
  background: var(--strawberry); color: white;
  font-family: 'DM Sans', sans-serif; font-size: 14px; font-weight: 700;
  text-decoration: none; transition: transform .2s, box-shadow .2s;
  box-shadow: 0 4px 16px rgba(217,58,82,.3);
}
.cart-fab-btn-checkout:hover { transform: translateY(-2px); box-shadow: 0 6px 20px rgba(217,58,82,.4); }
.cart-fab-btn-view {
  display: flex; align-items: center; justify-content: center;
  padding: 10px; border-radius: 50px;
  background: var(--light); color: var(--mid);
  font-family: 'DM Sans', sans-serif; font-size: 13px; font-weight: 600;
  text-decoration: none; border: 1.5px solid var(--border);
  transition: background .2s, color .2s;
}
.cart-fab-btn-view:hover { background: var(--dark); color: white; border-color: var(--dark); }

/* FAB Button */
.cart-fab {
  width: 58px; height: 58px; border-radius: 50%;
  background: var(--strawberry); border: none; cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  box-shadow: 0 6px 24px rgba(217,58,82,.4);
  transition: transform .3s cubic-bezier(.34,1.56,.64,1), box-shadow .3s, background .3s;
  position: relative;
  animation: cartFabPulse 2.8s ease-in-out infinite;
}
.cart-fab.open {
  animation: none;
  background: var(--dark);
  box-shadow: 0 6px 24px rgba(30,24,16,.3);
}
.cart-fab:hover {
  animation: none;
  transform: scale(1.1) translateY(-2px);
  box-shadow: 0 10px 32px rgba(217,58,82,.5);
}
@keyframes cartFabPulse {
  0%,100%{transform:scale(1)}
  50%{transform:scale(1.07)}
}
.cart-fab-icon { font-size: 22px; color: white; }
.cart-fab-badge {
  position: absolute; top: -4px; right: -4px;
  width: 20px; height: 20px; border-radius: 50%;
  background: white; color: var(--strawberry);
  font-size: 11px; font-weight: 800;
  display: flex; align-items: center; justify-content: center;
  border: 2px solid var(--strawberry);
}
.cart-fab-ring {
  position: absolute; inset: -3px; border-radius: 50%;
  border: 2px solid rgba(217,58,82,.35);
  animation: cartRingPulse 2.8s ease-out infinite;
  pointer-events: none;
}
@keyframes cartRingPulse {
  0%{transform:scale(1);opacity:.7}
  100%{transform:scale(1.7);opacity:0}
}

@media(max-width:640px){
  .cart-fab-wrap {
    bottom: 24px;
    left: 24px;
    right: 24px;
    transform: none;
    align-items: center;
  }
  .cart-panel {
    width: 100%;
  }
}
.cart-fab-wrap {
  position: fixed;
  bottom: 32px;
  left: 32px;
  z-index: 9998;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 12px;
  pointer-events: none; /* Wrap selbst nicht klickbar */
}

.cart-panel { pointer-events: none; } /* wird durch .open überschrieben */
.cart-panel.open { pointer-events: all; }
.cart-fab { pointer-events: all; } /* nur der Button klickbar */








/* FooEvents Datum Dropdown */
.fooevents-bookings-date label {
  font-family: 'DM Sans', sans-serif !important;
  font-size: 13px !important;
  font-weight: 700 !important;
  color: var(--mid) !important;
  text-transform: uppercase !important;
  letter-spacing: .06em !important;
  display: block !important;
  margin-bottom: 8px !important;
}
.fooevents-bookings-date select,
#fooevents_bookings_date_val__trans {
  width: 100% !important;
  padding: 13px 16px !important;
  border: 1.5px solid var(--border) !important;
  border-radius: 12px !important;
  font-family: 'DM Sans', sans-serif !important;
  font-size: 15px !important;
  color: var(--dark) !important;
  background: white !important;
  appearance: auto !important;
  margin-bottom: 12px !important;
  transition: border-color .2s !important;
}
.fooevents-bookings-date select:focus,
#fooevents_bookings_date_val__trans:focus {
  border-color: var(--strawberry) !important;
  outline: none !important;
	 box-shadow: 0 0 0 3px rgba(217,107,10,.1) !important;
}

/* Reset Variations Link ausblenden */
.sp-accent-tickets .reset_variations {
  display: none !important;
}



/* ════════ TICKETS – VARIATIONS STYLING ════════ */

/* Preis bei variablen Produkten – gleicher Stil wie Frühstück */
.sp-accent-tickets .woocommerce-variation-price {
  padding: 20px 0 !important;
  border-top: 1.5px solid var(--border) !important;
  border-bottom: 1.5px solid var(--border) !important;
 
}
.sp-accent-tickets .woocommerce-variation-price .woocommerce-Price-amount {
  font-family: 'Lora', serif !important;
  font-size: 2.2rem !important;
  font-weight: 700 !important;
  color: var(--dark) !important;
}
.sp-accent-tickets .woocommerce-variation-price::before {
  content: 'Preis';
  display: block;
  font-size: 12px;
  font-weight: 700;
  color: var(--mid);
  text-transform: uppercase;
  letter-spacing: .08em;
  margin-bottom: 6px;
}
.sp-accent-tickets .woocommerce-variation-price .price {
  display: block;
}

/* Varianten Tabelle – Kategorie Dropdown */
.sp-accent-tickets .variations {
  width: 100% !important;
  border-collapse: collapse !important;
  margin-bottom: 16px !important;
}
.sp-accent-tickets .variations tr {
  display: flex !important;
  flex-direction: column !important;
  gap: 6px !important;
	align-items: flex-start;
}
.sp-accent-tickets .variations th.label label {
  font-family: 'DM Sans', sans-serif !important;
  font-size: 12px !important;
  font-weight: 700 !important;
  color: var(--mid) !important;
  text-transform: uppercase !important;
  letter-spacing: .08em !important;
  display: block !important;
}
.sp-accent-tickets .variations td.value {
  display: block !important;
  width: 100% !important;
}

.sp-accent-tickets .variations td.value select:focus {
  border-color: var(--strawberry) !important;
  outline: none !important;
}
.sp-accent-tickets .reset_variations { display: none !important; }

/* FooEvents Datum Dropdown */
.sp-accent-tickets .fooevents-bookings-date {
  margin-bottom: 16px !important;
}
.sp-accent-tickets .fooevents-bookings-date label {
  font-family: 'DM Sans', sans-serif !important;
  font-size: 12px !important;
  font-weight: 700 !important;
  color: var(--mid) !important;
  text-transform: uppercase !important;
  letter-spacing: .08em !important;
  display: block !important;
  margin-bottom: 6px !important;
}
.sp-accent-tickets .fooevents-bookings-date label .required {
  color: var(--strawberry) !important;
}

.sp-accent-tickets #fooevents_bookings_date_val__trans:focus {
  border-color: var(--strawberry) !important;
  outline: none !important;
}

/* Menge + Button nebeneinander */
.sp-accent-tickets .woocommerce-variation-add-to-cart {
  display: flex !important;
  align-items: center !important;
  gap: 12px !important;
  margin-top: 20px !important;
}
.sp-accent-tickets .woocommerce-variation-add-to-cart .quantity {
  flex-shrink: 0 !important;
}
.sp-accent-tickets .woocommerce-variation-add-to-cart .quantity input {
  width: 72px !important;
  padding: 13px 12px !important;
  border: 1.5px solid var(--border) !important;
  border-radius: 12px !important;
  font-family: 'DM Sans', sans-serif !important;
  font-size: 15px !important;
  font-weight: 700 !important;
  color: var(--dark) !important;
  text-align: center !important;
}
.sp-accent-tickets .woocommerce-variation-add-to-cart .single_add_to_cart_button {
  flex: 1 !important;
  border-radius: 50px !important;
  padding: 14px 24px !important;
  font-family: 'DM Sans', sans-serif !important;
  font-size: 15px !important;
  font-weight: 700 !important;
  border: none !important;
  cursor: pointer !important;
  transition: transform .2s, box-shadow .2s !important;
}

/* single_variation_wrap – anfangs kein Sprung */
.sp-accent-tickets .single_variation_wrap {
  margin-top: 0 !important;
	width: 100%;
}
.sp-accent-tickets .woocommerce-variation.single_variation {
  margin-bottom: 0 !important;
}
.woocommerce form .form-row {
	padding: 0 !important;
}
.fooevents-bookings-date {
	width: 100%;
}


.mob-divider {
	display: none;
}



.footer-links {
  flex-wrap: wrap !important;
  gap: 8px 16px !important;
}


/* ════════ PAGINATION ════════ */
.woocommerce-pagination { text-align: center; margin: 48px 0 0; }

.woocommerce-pagination ul.page-numbers {
  display: inline-flex !important;
  flex-direction: row !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 8px !important;
  list-style: none !important;
  margin: 0 !important;
  padding: 0 !important;
}

.woocommerce-pagination ul.page-numbers li {
  display: flex !important;
  float: none !important;
  margin: 0 !important;
  padding: 0 !important;
}

.woocommerce-pagination ul.page-numbers li .page-numbers {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 42px !important;
  height: 42px !important;
  border-radius: 50% !important;
  font-size: 14px !important;
  font-weight: 700 !important;
  font-family: 'DM Sans', sans-serif !important;
  text-decoration: none !important;
  transition: all .2s !important;
  border: 1.5px solid var(--border) !important;
  background: white !important;
  color: var(--mid) !important;
  box-shadow: none !important;
  line-height: 1 !important;
}

.woocommerce-pagination ul.page-numbers li .page-numbers:hover {
  background: var(--strawberry-bg) !important;
  border-color: rgba(217,58,82,.25) !important;
  color: var(--strawberry) !important;
}

.woocommerce-pagination ul.page-numbers li .page-numbers.current {
  background: var(--strawberry) !important;
  border-color: var(--strawberry) !important;
  color: white !important;
  box-shadow: none !important;
}

.woocommerce-pagination ul.page-numbers li .page-numbers.next,
.woocommerce-pagination ul.page-numbers li .page-numbers.prev {
  font-size: 18px !important;
  color: var(--dark) !important;
}

.woocommerce-pagination ul.page-numbers li .page-numbers.next:hover,
.woocommerce-pagination ul.page-numbers li .page-numbers.prev:hover {
  background: var(--strawberry) !important;
  border-color: var(--strawberry) !important;
  color: white !important;
}
.woocommerce nav.woocommerce-pagination ul, .woocommerce nav.woocommerce-pagination ul li {
	border: none !important;
}





.product-img {
  aspect-ratio: 3 / 4 !important;
  overflow: hidden !important;
}

.product-img .product-card-img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  object-position: center !important;
}












/* ════════════════════════════════
   SHOP LAYOUT V2
   Einfach ans Ende der style.css hängen
   ════════════════════════════════ */


/* ════════ HERO V2 (neu, linksbündig) ════════ */

.shop-hero-v2 {
  background: linear-gradient(145deg, #EEF7F3 0%, var(--light) 55%, #FFF0F2 100%);
  border-bottom: 1.5px solid var(--border);
  position: relative;
  overflow: hidden;
}

/* Blobs wie im Original-Hero */
.shop-hero-v2 .blob-a {
  width: 400px; height: 400px;
  background: #B8E4D0;
  top: -100px; right: -60px;
  animation: blobFloat 11s ease-in-out infinite;
}
.shop-hero-v2 .blob-b {
  width: 280px; height: 280px;
  background: #FFD6DE;
  bottom: -60px; left: -50px;
  animation: blobFloat 13s ease-in-out infinite reverse;
}

/* Dot-Grid entfällt – Gradient + Blobs reichen */
.shv2-bg-dots { display: none; }

/* Akzentstreifen entfernt */
.shop-hero-v2::before { display: none; }

.shv2-inner {
  position: relative;
  z-index: 1;
  max-width: 1260px;
  margin: 0 auto;
  padding: 48px 32px 44px;
  display: grid;
  grid-template-columns: 1fr auto;
  align-items: end;
  gap: 40px;
}

.shv2-left {}

/* Eyebrow */
.shop-hero-v2 .shop-eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: 12px;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--strawberry);
  margin-bottom: 16px;
  /* Überschreibt alten shop-hero Stil (kein weißes Pill mehr) */
  background: none;
  border: none;
  border-radius: 0;
  padding: 0;
  box-shadow: none;
  animation: fadeUp .4s ease both;
}
.shv2-eyebrow-dot {
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: var(--strawberry);
  display: inline-block;
  flex-shrink: 0;
}

.shop-hero-v2 h1 {
  font-family: 'Lora', serif;
  font-size: clamp(2rem, 3.5vw, 3rem);
  line-height: 1.1;
  color: var(--dark);
  margin-bottom: 14px;
  animation: fadeUp .4s .08s ease both;
}
.shop-hero-v2 h1 i {
  font-style: italic;
  color: var(--strawberry);
}

.shop-hero-v2 > .shv2-inner > .shv2-left > p {
  font-size: 15px;
  color: var(--mid);
  line-height: 1.75;
  max-width: 480px;
  margin-bottom: 22px;
  animation: fadeUp .4s .14s ease both;
}

/* Kleine Tag-Chips im Hero */
.shv2-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  animation: fadeUp .4s .2s ease both;
}
.shv2-tag {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  font-size: 12px;
  font-weight: 600;
  color: var(--mid);
  background: var(--light);
  border: 1.5px solid var(--border);
  border-radius: 50px;
  padding: 5px 13px;
}

/* Stats-Block rechts */
.shv2-right {
  display: flex;
  flex-direction: column;
  gap: 12px;
  align-items: flex-end;
  flex-shrink: 0;
  animation: fadeUp .4s .1s ease both;
}
.shv2-stat {
  text-align: right;
}
.shv2-stat-num {
  font-family: 'Lora', serif;
  font-size: 2.2rem;
  font-weight: 700;
  color: var(--dark);
  display: block;
  line-height: 1;
}
.shv2-stat-label {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--mid);
  display: block;
  margin-top: 2px;
}

@media(max-width:768px) {
  .shv2-inner {
    grid-template-columns: 1fr;
    gap: 24px;
    padding: 36px 32px;
  }
  .shv2-right {
    flex-direction: row;
    align-items: flex-start;
    gap: 24px;
  }
  .shv2-stat { text-align: left; }
}


/* ════════ LAYOUT WRAPPER ════════ */

/* Wrapper läuft volle Breite durch – kein padding links/rechts */
.shop-layout-wrap {
  background: var(--light);
}

/* Grid direkt ohne max-width Beschränkung –
   Sidebar links bündig, Main mit eigenem padding */
.shop-layout-inner {
  display: grid;
  grid-template-columns: 260px 1fr;
  align-items: start;
  min-height: 60vh;
}

@media(max-width:1060px) {
  .shop-layout-inner {
    grid-template-columns: 220px 1fr;
  }
}
@media(max-width:768px) {
  .shop-layout-inner {
    grid-template-columns: 1fr;
  }
}


/* ════════ SIDEBAR – fixer Streifen ════════ */

.shop-sidebar {
  background: var(--white);
  border-right: 1.5px solid var(--border);
  border-radius: 0;
  box-shadow: none;
  align-self: stretch;
}

/* Scrollbar dezent stylen */
.shop-sidebar::-webkit-scrollbar { width: 4px; }
.shop-sidebar::-webkit-scrollbar-track { background: transparent; }
.shop-sidebar::-webkit-scrollbar-thumb { background: var(--border); border-radius: 2px; }

/* Mobile Toggle */
.shop-sidebar-toggle {
  display: none;
  width: 100%;
  padding: 15px 18px;
  background: none;
  border: none;
  font-family: 'DM Sans', sans-serif;
  font-size: 14px;
  font-weight: 700;
  color: var(--dark);
  cursor: pointer;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
}
.shop-sidebar-toggle svg {
  width: 16px; height: 16px;
  stroke: var(--mid); fill: none;
  stroke-width: 2.5; stroke-linecap: round; stroke-linejoin: round;
  flex-shrink: 0;
  transition: transform .3s;
}
.shop-sidebar-toggle.open svg { transform: rotate(180deg); }

@media(max-width:768px) {
  .shop-sidebar {
    position: static;
    height: auto;
    border-right: none;
    border-bottom: 1.5px solid var(--border);
    overflow: visible;
  }
  .shop-sidebar-toggle { display: flex; }
  .shop-sidebar-body { display: none; }
  .shop-sidebar-body.open { display: block; border-top: 1.5px solid var(--border); }
}

/* Sidebar Blöcke */
.sb-block {
  padding: 18px 18px 14px;
}
/* Erster Block etwas mehr Abstand nach oben */
.sb-block:first-child {
  padding-top: 24px;
}
.sb-label {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: var(--mid);
  margin-bottom: 11px;
}
.sb-divider {
  height: 1.5px;
  background: var(--border);
}

/* Kategorien */
.sb-cat-list {
  display: flex;
  flex-direction: column;
  gap: 1px;
}
.sb-cat-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  padding: 8px 10px;
  border-radius: 11px;
  font-size: 13.5px;
  font-weight: 600;
  color: var(--mid);
  text-decoration: none;
  transition: background .18s, color .18s;
}
.sb-cat-item:hover {
  background: var(--light);
  color: var(--dark);
}
.sb-cat-item.active {
  background: var(--strawberry-bg);
  color: var(--strawberry);
  font-weight: 700;
}
.sb-cat-count {
  font-size: 10.5px;
  font-weight: 700;
  padding: 2px 8px;
  border-radius: 50px;
  background: var(--light);
  border: 1.5px solid var(--border);
  color: var(--mid);
  flex-shrink: 0;
  line-height: 1.6;
}
.sb-cat-item.active .sb-cat-count {
  background: white;
  border-color: rgba(217,58,82,.2);
  color: var(--strawberry);
}

/* Checkboxen */
.sb-check-list {
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.sb-check-item {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 7px 10px;
  border-radius: 10px;
  font-size: 13px;
  font-weight: 600;
  color: var(--mid);
  text-decoration: none;
  transition: background .18s, color .18s;
  cursor: pointer;
}
.sb-check-item:hover {
  background: var(--light);
  color: var(--dark);
}
.sb-check-item.on {
  color: var(--dark);
}
.sb-checkbox {
  width: 17px;
  height: 17px;
  border-radius: 5px;
  border: 1.5px solid var(--border);
  background: white;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  transition: background .18s, border-color .18s;
}
.sb-check-item.on .sb-checkbox {
  background: var(--strawberry);
  border-color: var(--strawberry);
}
.sb-checkbox svg {
  width: 10px;
  height: 10px;
}

/* Pills */
.sb-pill-cloud {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}
.sb-pill {
  font-size: 12px;
  font-weight: 600;
  padding: 5px 12px;
  border-radius: 50px;
  border: 1.5px solid var(--border);
  color: var(--mid);
  background: transparent;
  text-decoration: none;
  transition: background .18s, color .18s, border-color .18s;
}
.sb-pill:hover {
  background: var(--light);
  color: var(--dark);
}
.sb-pill.active {
  background: var(--strawberry-bg);
  border-color: rgba(217,58,82,.25);
  color: var(--strawberry);
  font-weight: 700;
}

/* Reset Button */
.sb-reset-btn {
  display: block;
  width: 100%;
  text-align: center;
  padding: 10px;
  font-size: 12.5px;
  font-weight: 700;
  color: var(--mid);
  text-decoration: none;
  border-radius: 10px;
  transition: color .2s, background .2s;
}
.sb-reset-btn:hover {
  color: var(--strawberry);
  background: var(--strawberry-bg);
}


/* ════════ SHOP MAIN ════════ */

.shop-main {
  padding: 70px 32px;
}

.shop-main .shop-section-head {
  margin-bottom: 20px;
}
.shop-main .shop-section-head h2 {
  font-size: clamp(1.5rem, 2.2vw, 1.9rem);
  margin-top: 4px;
}

/* Aktive Filter Chips */
.shop-active-filters {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 7px;
  margin-bottom: 20px;
}
.saf-label {
  font-size: 11.5px;
  font-weight: 700;
  color: var(--mid);
  text-transform: uppercase;
  letter-spacing: .07em;
  flex-shrink: 0;
}
.saf-chip {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 12px;
  font-weight: 700;
  padding: 5px 11px;
  border-radius: 50px;
  background: var(--strawberry-bg);
  border: 1.5px solid rgba(217,58,82,.2);
  color: var(--strawberry);
  text-decoration: none;
  transition: background .18s;
}
.saf-chip:hover { background: #FFD6DE; }
.saf-chip-x {
  font-size: 13px;
  line-height: 1;
  color: var(--strawberry);
  opacity: .7;
}
.saf-reset {
  font-size: 12px;
  font-weight: 700;
  color: var(--mid);
  text-decoration: none;
  margin-left: 4px;
  transition: color .2s;
}
.saf-reset:hover { color: var(--strawberry); }

/* Produktgrid – 3-spaltig im Sidebar-Kontext */
.shop-main .woocommerce ul.products,
.shop-main .woocommerce-page ul.products {
  grid-template-columns: repeat(3, 1fr) !important;
}

@media(max-width:1060px) {
  .shop-main .woocommerce ul.products,
  .shop-main .woocommerce-page ul.products {
    grid-template-columns: repeat(2, 1fr) !important;
  }
}
@media(max-width:768px) {
  .shop-main .woocommerce ul.products,
  .shop-main .woocommerce-page ul.products {
    grid-template-columns: repeat(2, 1fr) !important;
  }
	
}
@media(max-width:480px) {
  .shop-main .woocommerce ul.products,
  .shop-main .woocommerce-page ul.products {
    grid-template-columns: 1fr !important;
  }
}


.sp-accent-tickets .variations tr:first-child {
	margin-bottom: 20px;
}



@media(max-width: 768px) {
  .product-tabs {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    background: none !important;
    border: none !important;
    border-radius: 0 !important;
    padding: 0 !important;
  }

  .product-tab {
    flex: 1 1 calc(50% - 4px);
    text-align: center;
    font-size: 12px !important;
    font-weight: 700 !important;
    padding: 10px 12px !important;
    border: 1.5px solid var(--border) !important;
    border-radius: 50px !important;
    background: white !important;
    color: var(--mid) !important;
    white-space: normal !important;
    line-height: 1.3 !important;
    cursor: pointer;
  }

  .product-tab.active {
    border-color: var(--strawberry) !important;
    background: var(--strawberry-bg) !important;
    color: var(--strawberry) !important;
  }

  /* Container ohne Border */
  .product-tabs-section {
    padding: 24px 20px !important;
  }
}


.ds-local-pickup {
	display: none;
}




.sb-sort-wrap .woocommerce-ordering {
  width: 100%;
}

.sb-sort-wrap .woocommerce-ordering select {
  font-family: 'DM Sans', sans-serif;
  font-size: 13px;
  color: var(--dark);
  background: var(--light);
  border: 1.5px solid var(--border);
  border-radius: 10px;
  padding: 9px 36px 9px 14px;
  width: 100%;
  outline: none;
  cursor: pointer;
  -webkit-appearance: none;
  appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 16 16'%3E%3Cpolyline points='4,6 8,10 12,6' fill='none' stroke='%235a4a40' stroke-width='2' stroke-linecap='round'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 12px center;
  transition: border-color .2s;
}

.sb-sort-wrap .woocommerce-ordering select:focus {
  border-color: var(--strawberry);
  background-color: #fff;
}