/* ===== Variante A – Subpage components (Sommerfrisch) ===== */
.subhero{position:relative;overflow:hidden;background:var(--cream-2);padding:54px 0 70px;border-bottom:1px solid var(--line)}
.subhero .blobx{position:absolute;border-radius:48% 52% 57% 43%/47% 45% 55% 53%;background:var(--cream-3);width:460px;height:460px;right:-130px;top:-120px;z-index:0}
.subhero .wrap{position:relative;z-index:2;max-width:880px}
.breadcrumb{display:flex;align-items:center;gap:10px;font-family:"Fredoka",sans-serif;font-weight:500;font-size:.9rem;color:var(--ink-soft);margin-bottom:20px}
.breadcrumb a:hover{color:var(--brand)}
.breadcrumb b{color:var(--ink)}
.breadcrumb span{opacity:.5}
.subhero h1{font-size:clamp(2.4rem,5vw,3.8rem);font-weight:700;margin:14px 0 16px}
.subhero h1 .pop{color:var(--brand)}
.subhero .lead{font-size:1.2rem;color:var(--ink-soft);max-width:54ch}
.subhero .hero-cta{display:flex;gap:14px;flex-wrap:wrap;margin-top:26px}

/* split text + media */
.split{display:grid;grid-template-columns:1fr 1fr;gap:56px;align-items:center}
.split.rev .split-media{order:2}
.split-media{border-radius:30px;overflow:hidden;aspect-ratio:4/3;box-shadow:var(--shadow);border:8px solid #fff}
.split-media img{width:100%;height:100%;object-fit:cover}
.split h2{font-size:clamp(1.9rem,3.4vw,2.6rem);margin:12px 0 16px}
.split p{color:var(--ink-soft);margin-bottom:14px}
.ticklist{list-style:none;margin-top:18px;display:grid;gap:12px}
.ticklist li{display:flex;gap:12px;align-items:flex-start;font-weight:600}
.ticklist li::before{content:"✓";flex:0 0 26px;width:26px;height:26px;border-radius:50%;background:var(--brand);color:#fff;display:grid;place-content:center;font-size:.8rem;font-family:"Fredoka",sans-serif}

/* neutral feature cards */
.fcards{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.fcard{background:var(--cream);border:1px solid var(--line);border-radius:26px;padding:30px 26px;transition:transform .2s,box-shadow .2s}
.fcard:hover{transform:translateY(-5px);box-shadow:var(--shadow)}
.fcard .ic{width:54px;height:54px;border-radius:16px;background:var(--cream-2);color:var(--brand);display:grid;place-content:center;font-size:1.5rem;margin-bottom:18px}
.fcard h3{font-size:1.35rem;margin-bottom:10px}
.fcard p{color:var(--ink-soft);font-size:.98rem}

/* menu / offer list */
.offer{display:grid;gap:4px;max-width:760px;margin:0 auto}
.offer .row{display:flex;align-items:baseline;gap:14px;padding:16px 4px;border-bottom:1px dashed var(--line)}
.offer .row .nm{font-family:"Fredoka",sans-serif;font-weight:600;font-size:1.15rem;white-space:nowrap}
.offer .row .dt{flex:1;border-bottom:2px dotted var(--cream-3);transform:translateY(-4px)}
.offer .row .ds{color:var(--ink-soft);font-size:.92rem;flex:1}
.offer .row .pr{font-family:"Fredoka",sans-serif;font-weight:700;color:var(--brand);white-space:nowrap}
.pill-row{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;margin-top:8px}
.pill-row .pill{background:var(--cream-2);color:var(--ink);border-radius:999px;padding:.5em 1.1em;font-weight:700;font-size:.95rem}

/* location cards */
.locs{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.loc{background:#fff;border:1px solid var(--line);border-radius:26px;overflow:hidden;box-shadow:var(--shadow-sm)}
.loc .map{height:170px;background:repeating-linear-gradient(45deg,var(--cream-2),var(--cream-2) 14px,var(--cream) 14px,var(--cream) 28px);display:grid;place-content:center;color:var(--ink-soft);font-family:"Fredoka",sans-serif;font-weight:600}
.loc .lc{padding:26px}
.loc h3{font-size:1.5rem;margin-bottom:10px;color:var(--brand)}
.loc .lrow{display:flex;gap:10px;align-items:flex-start;margin-bottom:8px;color:var(--ink-soft);font-size:.98rem}
.loc .lrow b{color:var(--ink);font-family:"Fredoka",sans-serif;font-weight:600}

/* FAQ */
.faq{max-width:780px;margin:0 auto;display:grid;gap:14px}
.faq details{background:var(--cream);border:1px solid var(--line);border-radius:18px;padding:4px 22px}
.faq summary{cursor:pointer;list-style:none;font-family:"Fredoka",sans-serif;font-weight:600;font-size:1.1rem;padding:16px 0;display:flex;justify-content:space-between;align-items:center;gap:14px}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";color:var(--brand);font-size:1.5rem;transition:transform .2s}
.faq details[open] summary::after{transform:rotate(45deg)}
.faq details p{color:var(--ink-soft);padding:0 0 18px}

/* gallery */
.gallery{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}
.gallery .g{border-radius:20px;overflow:hidden;aspect-ratio:1;border:6px solid #fff;box-shadow:var(--shadow-sm)}
.gallery .g img{width:100%;height:100%;object-fit:cover}
.gallery .g:nth-child(1){grid-row:span 2;aspect-ratio:auto}
.gallery.flat{grid-auto-rows:1fr}
.gallery.flat .g:nth-child(1){grid-row:auto;aspect-ratio:1}

/* location text cards (Eis – no maps) */
.loccards{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.loccard{background:var(--cream);border:1px solid var(--line);border-radius:26px;padding:30px 28px;position:relative;overflow:hidden}
.loccard::before{content:"";position:absolute;top:0;left:0;width:100%;height:6px;background:var(--brand)}
.loccard .pin{display:inline-flex;align-items:center;gap:8px;font-family:"Fredoka",sans-serif;font-weight:600;color:var(--brand);font-size:.82rem;letter-spacing:.05em;text-transform:uppercase;margin-bottom:10px}
.loccard h3{font-size:1.55rem;margin-bottom:14px}
.loccard .lrow{display:flex;gap:10px;align-items:flex-start;margin-bottom:9px;color:var(--ink-soft);font-size:.98rem}
.loccard .lrow b{color:var(--ink);font-family:"Fredoka",sans-serif;font-weight:600;min-width:88px;display:inline-block}
.loccard .hours{margin-top:14px;border-top:1px dashed var(--line);padding-top:14px}

/* team row */
.team-row{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:8px}
.team-card{border-radius:22px;overflow:hidden;border:1px solid var(--line);background:#fff;box-shadow:var(--shadow-sm)}
.team-card .tphoto{aspect-ratio:4/3;overflow:hidden}
.team-card .tphoto img{width:100%;height:100%;object-fit:cover}
.team-card .tcap{padding:16px 18px}
.team-card .tcap b{font-family:"Fredoka",sans-serif;font-weight:600;display:block}
.team-card .tcap span{font-size:.9rem;color:var(--ink-soft)}
@media(max-width:980px){.loccards{grid-template-columns:1fr}.team-row{grid-template-columns:1fr}}

/* prose (legal) */
.prose{max-width:780px;margin:0 auto}
.prose h2{font-size:1.6rem;margin:34px 0 12px}
.prose h2:first-child{margin-top:0}
.prose h3{font-size:1.2rem;margin:22px 0 8px}
.prose p,.prose li{color:var(--ink-soft);margin-bottom:12px}
.prose ul{padding-left:22px;margin-bottom:14px}
.prose a{color:var(--brand);text-decoration:underline}
.prose .placeholder{background:var(--cream-2);border:1px dashed var(--brand);border-radius:14px;padding:14px 18px;color:var(--ink);font-family:"Fredoka",sans-serif;font-size:.92rem;margin:8px 0 18px}

@media(max-width:980px){
  .split{grid-template-columns:1fr;gap:34px}
  .split.rev .split-media{order:0}
  .fcards{grid-template-columns:1fr}
  .locs{grid-template-columns:1fr}
  .gallery{grid-template-columns:1fr 1fr}
  .gallery .g:nth-child(1){grid-row:auto;aspect-ratio:1}
}
