/* ========= Bäckerei Wannenmacher · Heritage Bakery & Café ========= */
@import url('https://fonts.googleapis.com/css2?family=Fraunces:ital,opsz,wght@0,9..144,400;0,9..144,500;0,9..144,600;0,9..144,700;1,9..144,400&family=Mulish:wght@400;500;600;700;800&display=swap');

:root{
  --carmine:#C30038; --carmine-d:#9C0029; --carmine-soft:#f6dfe5;
  --green:#00795F; --green-d:#0A5340;
  --cream:#FBF6EC; --cream2:#F4EAD7; --paper:#FFFFFF;
  --ink:#241B14; --ink-soft:#5e5044; --ink-mute:#8a7b6c;
  --bread:#b07a3c; --gold-soft:#E7D2A6;
  --line:rgba(36,27,20,.12); --line-2:rgba(36,27,20,.07);
  --shadow:0 18px 50px -22px rgba(36,27,20,.45);
  --shadow-sm:0 8px 26px -16px rgba(36,27,20,.5);
  --radius:18px; --radius-sm:12px;
  --serif:"Fraunces",Georgia,serif; --sans:"Mulish",system-ui,sans-serif;
  --wrap:1200px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;font-family:var(--sans);color:var(--ink);background:var(--cream);
  font-size:17px;line-height:1.65;-webkit-font-smoothing:antialiased;overflow-x:hidden}
img{max-width:100%;display:block}
a{color:var(--carmine);text-decoration:none}
h1,h2,h3{font-family:var(--serif);font-weight:600;line-height:1.08;margin:0;letter-spacing:-.01em}
.wrap{max-width:var(--wrap);margin:0 auto;padding:0 24px}
.eyebrow{font-family:var(--sans);font-weight:700;text-transform:uppercase;letter-spacing:.18em;
  font-size:12.5px;color:var(--carmine)}
.eyebrow.g{color:var(--green)}
section{position:relative}
.sec{padding:clamp(56px,8vw,108px) 0}
.center{text-align:center}
.lead{font-size:clamp(17px,2vw,19px);color:var(--ink-soft);max-width:62ch}
.center .lead{margin-left:auto;margin-right:auto}

/* ---------- buttons ---------- */
.btn{display:inline-flex;align-items:center;gap:.55em;font-family:var(--sans);font-weight:700;
  font-size:15px;padding:14px 26px;border-radius:999px;cursor:pointer;border:1.6px solid transparent;
  transition:transform .25s,box-shadow .25s,background .25s,color .25s;line-height:1}
.btn svg{width:18px;height:18px}
.btn-primary{background:var(--carmine);color:#fff;box-shadow:0 12px 26px -12px rgba(195,0,56,.7)}
.btn-primary:hover{background:var(--carmine-d);transform:translateY(-3px);box-shadow:0 18px 34px -12px rgba(195,0,56,.75)}
.btn-ghost{background:transparent;color:var(--ink);border-color:var(--line)}
.btn-ghost:hover{border-color:var(--ink);transform:translateY(-3px)}
.btn-light{background:rgba(255,255,255,.14);color:#fff;border-color:rgba(255,255,255,.5);backdrop-filter:blur(4px)}
.btn-light:hover{background:#fff;color:var(--ink);transform:translateY(-3px)}
.btn-green{background:var(--green);color:#fff}
.btn-green:hover{background:var(--green-d);transform:translateY(-3px)}

/* ---------- navbar ---------- */
header.nav{position:fixed;inset:0 0 auto 0;z-index:100;transition:background .35s,box-shadow .35s,padding .35s;padding:16px 0}
.nav-in{display:flex;align-items:center;justify-content:space-between;gap:20px}
.brand{display:flex;align-items:center;gap:12px}
.brand img{width:46px;height:46px;border-radius:50%;background:#fff;padding:3px;box-shadow:0 2px 10px rgba(0,0,0,.18)}
.brand .bt{display:flex;flex-direction:column;line-height:1}
.brand .bt b{font-family:var(--serif);font-weight:600;font-size:20px;letter-spacing:.01em;color:#fff;transition:color .35s}
.brand .bt span{font-size:10.5px;font-weight:700;letter-spacing:.22em;text-transform:uppercase;color:rgba(255,255,255,.82);transition:color .35s}
.nav-links{display:flex;align-items:center;gap:6px}
.nav-links a:not(.btn){color:rgba(255,255,255,.92);font-weight:600;font-size:15px;padding:9px 13px;border-radius:9px;transition:color .25s,background .25s}
.nav-links a:not(.btn):hover{background:rgba(255,255,255,.14)}
.nav.scrolled{background:rgba(251,246,236,.9);backdrop-filter:saturate(1.2) blur(12px);box-shadow:0 1px 0 var(--line),0 12px 30px -24px rgba(36,27,20,.6);padding:10px 0}
.nav.scrolled .brand .bt b{color:var(--ink)}
.nav.scrolled .brand .bt span{color:var(--carmine)}
.nav.scrolled .nav-links a:not(.btn){color:var(--ink)}
.nav.scrolled .nav-links a:not(.btn):hover{background:var(--cream2)}
.nav.solid{position:sticky}
.burger{display:none;background:none;border:0;cursor:pointer;padding:8px;flex-direction:column;gap:5px}
.burger span{width:26px;height:2.4px;background:#fff;border-radius:2px;transition:.3s}
.nav.scrolled .burger span,.nav.solid .burger span{background:var(--ink)}

/* ---------- hero ---------- */
.hero{position:relative;min-height:92vh;display:flex;align-items:flex-end;overflow:hidden;color:#fff}
.hero-bg{position:absolute;inset:-12% 0;background-size:cover;background-position:center 60%;will-change:transform;z-index:0}
.hero::after{content:"";position:absolute;inset:0;z-index:1;
  background:linear-gradient(180deg,rgba(20,12,8,.46) 0%,rgba(20,12,8,.18) 38%,rgba(20,12,8,.62) 78%,rgba(20,12,8,.86) 100%)}
.hero-in{position:relative;z-index:2;padding-bottom:clamp(54px,8vw,96px);padding-top:140px;max-width:860px}
.hero .eyebrow{color:#ffd9c2}
.hero h1{font-size:clamp(40px,7vw,82px);font-weight:600;margin:.18em 0 .32em;text-shadow:0 2px 30px rgba(0,0,0,.35)}
.hero h1 em{font-style:italic;color:#ffd2a6}
.hero p{font-size:clamp(17px,2.2vw,21px);max-width:54ch;color:rgba(255,255,255,.94);margin:0 0 30px}
.hero-cta{display:flex;gap:14px;flex-wrap:wrap}
.scroll-cue{position:absolute;left:50%;bottom:22px;transform:translateX(-50%);z-index:3;color:rgba(255,255,255,.8);font-size:12px;letter-spacing:.2em;text-transform:uppercase;display:flex;flex-direction:column;align-items:center;gap:8px}
.scroll-cue i{width:1px;height:34px;background:linear-gradient(rgba(255,255,255,.8),transparent);animation:cue 1.8s ease-in-out infinite}
@keyframes cue{0%,100%{transform:scaleY(.4);opacity:.4}50%{transform:scaleY(1);opacity:1}}

/* ---------- trust strip ---------- */
.trust{background:var(--ink);color:#fff}
.trust .wrap{display:flex;flex-wrap:wrap;justify-content:center;gap:clamp(20px,5vw,64px);padding:22px 24px}
.trust .t{display:flex;align-items:center;gap:12px}
.trust .t b{font-family:var(--serif);font-size:22px;color:#ffd2a6}
.trust .t span{font-size:13px;color:rgba(255,255,255,.74);line-height:1.25}
.trust .stars{color:#ffc857;letter-spacing:1px}

/* ---------- heritage ---------- */
.heritage{background:var(--cream)}
.h-head{display:grid;grid-template-columns:1.1fr 1fr;gap:clamp(30px,5vw,64px);align-items:center}
.h-num{font-family:var(--serif);font-size:clamp(86px,16vw,190px);font-weight:600;color:var(--carmine);line-height:.85;letter-spacing:-.04em}
.h-num small{display:block;font-size:15px;font-family:var(--sans);font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--green);margin-top:14px}
.h-head h2{font-size:clamp(28px,4vw,44px);margin-bottom:.5em}
.h-head p{color:var(--ink-soft);margin:0 0 1em}
.timeline{margin-top:clamp(40px,6vw,72px);display:grid;grid-template-columns:repeat(4,1fr);gap:22px;position:relative}
.timeline::before{content:"";position:absolute;top:17px;left:6%;right:6%;height:2px;background:linear-gradient(90deg,var(--carmine),var(--green));opacity:.4}
.tl{position:relative;padding-top:46px;text-align:center}
.tl .dot{position:absolute;top:8px;left:50%;transform:translateX(-50%);width:18px;height:18px;border-radius:50%;background:var(--carmine);border:4px solid var(--cream);box-shadow:0 0 0 2px var(--carmine)}
.tl:nth-child(even) .dot{background:var(--green);box-shadow:0 0 0 2px var(--green)}
.tl b{font-family:var(--serif);font-size:22px;display:block;color:var(--ink)}
.tl span{font-size:14px;color:var(--ink-soft)}
.facade-band{margin-top:clamp(40px,6vw,72px);border-radius:var(--radius);overflow:hidden;position:relative;box-shadow:var(--shadow)}
.facade-band img{width:100%;height:clamp(260px,42vw,460px);object-fit:cover}
.facade-band .cap{position:absolute;left:24px;bottom:20px;color:#fff;background:rgba(20,12,8,.5);backdrop-filter:blur(4px);padding:9px 16px;border-radius:999px;font-size:13.5px;font-weight:600}

/* ---------- signature ---------- */
.signature{background:var(--cream2)}
.sig-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(22px,3.5vw,36px);margin-top:clamp(34px,4vw,52px)}
.sig-card{background:var(--paper);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm);
  display:flex;flex-direction:column;transition:transform .35s,box-shadow .35s}
.sig-card:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.sig-card .ph{height:240px;overflow:hidden}
.sig-card .ph img{width:100%;height:100%;object-fit:cover;transition:transform .6s}
.sig-card:hover .ph img{transform:scale(1.06)}
.sig-card .bd{padding:26px 28px 30px}
.sig-card .tag{font-size:11.5px;font-weight:800;letter-spacing:.16em;text-transform:uppercase;color:var(--green)}
.sig-card h3{font-size:26px;margin:.35em 0 .4em}
.sig-card p{margin:0;color:var(--ink-soft);font-size:15.5px}

/* ---------- product grid (bento) ---------- */
.sortiment{background:var(--cream)}
.bento{display:grid;grid-template-columns:repeat(6,1fr);grid-auto-rows:200px;gap:16px;margin-top:clamp(34px,4vw,52px)}
.tile{position:relative;border-radius:var(--radius-sm);overflow:hidden;cursor:pointer;box-shadow:var(--shadow-sm);background:#000}
.tile img{width:100%;height:100%;object-fit:cover;transition:transform .7s,filter .4s}
.tile::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 45%,rgba(20,12,8,.72));opacity:.9;transition:opacity .4s}
.tile:hover img{transform:scale(1.07)}
.tile .lbl{position:absolute;left:16px;bottom:14px;z-index:2;color:#fff}
.tile .lbl b{font-family:var(--serif);font-size:19px;font-weight:600;display:block}
.tile .lbl span{font-size:12.5px;color:rgba(255,255,255,.85)}
.tile.big{grid-column:span 3;grid-row:span 2}
.tile.wide{grid-column:span 3}
.tile.std{grid-column:span 2}
.tile.sq{grid-column:span 2}

/* ---------- backstube strip ---------- */
.backstube{background:var(--ink);color:#fff;overflow:hidden}
.bs-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(30px,5vw,60px);align-items:center}
.backstube h2{color:#fff;font-size:clamp(28px,4vw,44px)}
.backstube .eyebrow{color:#ffd2a6}
.backstube p{color:rgba(255,255,255,.82)}
.bs-photos{display:grid;grid-template-columns:1fr 1fr;grid-template-rows:1fr 1fr;gap:14px;height:440px}
.bs-photos img{width:100%;height:100%;object-fit:cover;border-radius:12px}
.bs-photos img:first-child{grid-row:span 2;height:100%}
.feat-list{list-style:none;padding:0;margin:18px 0 28px;display:grid;gap:12px}
.feat-list li{display:flex;gap:12px;align-items:flex-start;color:rgba(255,255,255,.9);font-size:15.5px}
.feat-list svg{width:22px;height:22px;color:#ffd2a6;flex:0 0 auto;margin-top:1px}

/* ---------- café split ---------- */
.cafe{background:var(--cream2)}
.split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(26px,4vw,56px);align-items:center}
.split.rev .txt{order:2}
.split .img-stack{position:relative}
.split .img-stack img{border-radius:var(--radius);box-shadow:var(--shadow);width:100%;height:clamp(320px,40vw,460px);object-fit:cover}
.split .img-stack .badge{position:absolute;right:-14px;bottom:-14px;background:var(--green);color:#fff;border-radius:16px;padding:16px 20px;font-family:var(--serif);box-shadow:var(--shadow);max-width:200px}
.split .img-stack .badge b{font-size:30px;display:block;line-height:1}
.split .img-stack .badge span{font-size:13px;font-family:var(--sans);font-weight:600;opacity:.9}
.split h2{font-size:clamp(26px,3.6vw,40px);margin-bottom:.5em}
.split p{color:var(--ink-soft)}
.mini{display:flex;gap:26px;margin:20px 0 28px;flex-wrap:wrap}
.mini .m b{font-family:var(--serif);font-size:26px;color:var(--carmine);display:block}
.mini .m span{font-size:13px;color:var(--ink-soft)}

/* ---------- frühstück highlight ---------- */
.fruh{background:var(--cream)}
.fr-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:clamp(30px,4vw,48px)}
.fr-card{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius-sm);padding:24px;transition:transform .3s,box-shadow .3s,border-color .3s}
.fr-card:hover{transform:translateY(-5px);box-shadow:var(--shadow-sm);border-color:var(--gold-soft)}
.fr-card .pr{font-family:var(--serif);font-size:30px;color:var(--carmine);font-weight:600}
.fr-card h3{font-size:20px;margin:.3em 0 .4em}
.fr-card p{margin:0;font-size:14.5px;color:var(--ink-soft)}

/* ---------- reviews marquee ---------- */
.reviews{background:var(--green-d);color:#fff;overflow:hidden}
.reviews h2{color:#fff}
.reviews .eyebrow{color:#ffd2a6}
.marquee-wrap{overflow:hidden;margin-top:clamp(28px,4vw,44px);-webkit-mask-image:linear-gradient(90deg,transparent,#000 6%,#000 94%,transparent);mask-image:linear-gradient(90deg,transparent,#000 6%,#000 94%,transparent)}
.marquee{display:flex;gap:20px;width:max-content;animation:marquee 44s linear infinite}
.marquee:has(.review-card:hover){animation-play-state:paused}
@keyframes marquee{to{transform:translateX(-50%)}}
.review-card{flex:0 0 360px;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.16);border-radius:var(--radius-sm);
  padding:24px 26px;transition:border-color .25s,box-shadow .25s,transform .25s}
.review-card:hover{border-color:var(--gold-soft);box-shadow:0 0 0 2px var(--gold-soft);transform:translateY(-3px)}
.review-card .stars{color:#ffc857;letter-spacing:2px;font-size:15px}
.review-card p{font-size:15.5px;margin:12px 0 16px;color:rgba(255,255,255,.94);font-style:italic}
.review-card .who{font-size:13px;color:rgba(255,255,255,.7);font-weight:600}
.review-card .who b{color:#fff;font-weight:700;font-style:normal}

/* ---------- delivery band ---------- */
.delivery{background:var(--carmine);color:#fff}
.delivery .wrap{display:flex;align-items:center;justify-content:space-between;gap:30px;flex-wrap:wrap}
.delivery h2{color:#fff;font-size:clamp(26px,3.4vw,38px)}
.delivery p{color:rgba(255,255,255,.9);margin:.4em 0 0;max-width:52ch}
.delivery .ico{width:54px;height:54px;flex:0 0 auto}

/* ---------- contact / map ---------- */
.contact{background:var(--cream2)}
.c-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(26px,4vw,48px)}
.c-card{background:var(--paper);border-radius:var(--radius);padding:30px 32px;box-shadow:var(--shadow-sm)}
.c-card h3{font-size:22px;margin-bottom:.5em}
.c-row{display:flex;gap:13px;align-items:flex-start;margin:14px 0}
.c-row svg{width:21px;height:21px;color:var(--carmine);flex:0 0 auto;margin-top:3px}
.c-row b{display:block;font-size:15px}
.c-row span,.c-row a{font-size:14.5px;color:var(--ink-soft)}
.hours{list-style:none;padding:0;margin:6px 0 0}
.hours li{display:flex;justify-content:space-between;padding:7px 0;border-bottom:1px dashed var(--line);font-size:14.5px}
.hours li:last-child{border:0}
.hours .day{color:var(--ink-soft)}
.hours .tm{font-weight:600;font-variant-numeric:tabular-nums}
.map-card{border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm);min-height:360px}
.map-card iframe{width:100%;height:100%;min-height:360px;border:0;display:block}

/* ---------- footer ---------- */
footer{background:var(--ink);color:rgba(255,255,255,.72);font-size:14px}
.f-top{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:40px;padding:clamp(46px,6vw,72px) 0 40px}
.f-top img.flogo{width:210px;background:#fff;padding:8px 12px;border-radius:10px;margin-bottom:16px}
.footer h4{color:#fff;font-family:var(--sans);font-size:13px;letter-spacing:.14em;text-transform:uppercase;margin:0 0 14px}
.f-top a{color:rgba(255,255,255,.72);display:block;padding:5px 0}
.f-top a:hover{color:#ffd2a6}
.f-imp{font-size:12.5px;line-height:1.7;color:rgba(255,255,255,.55)}
.f-bot{border-top:1px solid rgba(255,255,255,.12);padding:20px 0;display:flex;justify-content:space-between;gap:14px;flex-wrap:wrap;font-size:12.5px;color:rgba(255,255,255,.5)}
.f-bot a{color:rgba(255,255,255,.6)}

/* ---------- reveal anim ---------- */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .7s cubic-bezier(.2,.7,.2,1),transform .7s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}
.reveal.d1{transition-delay:.08s}.reveal.d2{transition-delay:.16s}.reveal.d3{transition-delay:.24s}.reveal.d4{transition-delay:.32s}
@media (prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none}.marquee{animation:none}.hero-bg{transform:none!important}}

/* ---------- lightbox ---------- */
.lb{position:fixed;inset:0;z-index:200;background:rgba(15,9,5,.94);display:none;align-items:center;justify-content:center;padding:30px}
.lb.open{display:flex}
.lb img{max-width:92vw;max-height:84vh;border-radius:10px;box-shadow:0 30px 80px rgba(0,0,0,.6)}
.lb .x,.lb .ar{position:absolute;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.3);color:#fff;cursor:pointer;border-radius:50%;width:50px;height:50px;font-size:22px;display:flex;align-items:center;justify-content:center;transition:background .2s}
.lb .x:hover,.lb .ar:hover{background:rgba(255,255,255,.28)}
.lb .x{top:24px;right:24px}
.lb .prev{left:24px;top:50%;transform:translateY(-50%)}
.lb .next{right:24px;top:50%;transform:translateY(-50%)}
.lb .ct{position:absolute;bottom:26px;left:50%;transform:translateX(-50%);color:rgba(255,255,255,.8);font-size:13px}

/* ---------- page header (sub pages) ---------- */
.pagehead{position:relative;color:#fff;padding:150px 0 56px;overflow:hidden}
.pagehead .hero-bg{background-position:center 55%}
.pagehead::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(20,12,8,.55),rgba(20,12,8,.78));z-index:1}
.pagehead .wrap{position:relative;z-index:2}
.pagehead h1{font-size:clamp(34px,5.5vw,58px);margin:.2em 0 .25em}
.pagehead p{color:rgba(255,255,255,.9);max-width:56ch;margin:0}
.crumbs{font-size:13px;color:rgba(255,255,255,.7)}
.crumbs a{color:rgba(255,255,255,.85)}

/* ---------- menu (speisekarte) ---------- */
.menu-tabs{display:flex;gap:8px;flex-wrap:wrap;justify-content:center;margin:0 0 clamp(30px,4vw,46px)}
.menu-tab{font-family:var(--sans);font-weight:700;font-size:14.5px;padding:11px 20px;border-radius:999px;border:1.5px solid var(--line);background:var(--paper);color:var(--ink);cursor:pointer;transition:.25s}
.menu-tab:hover{border-color:var(--carmine)}
.menu-tab.active{background:var(--carmine);color:#fff;border-color:var(--carmine)}
.menu-panel{display:none}
.menu-panel.active{display:block;animation:fade .4s}
@keyframes fade{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}
.menu-cols{columns:2;column-gap:48px}
@media(max-width:760px){.menu-cols{columns:1}}
.mcat{break-inside:avoid;margin:0 0 34px}
.mcat h3{font-size:23px;color:var(--carmine);margin-bottom:4px}
.mcat .sub{font-size:13px;color:var(--ink-mute);margin:0 0 14px;font-style:italic}
.mitem{display:flex;gap:12px;align-items:baseline;padding:9px 0;border-bottom:1px dashed var(--line)}
.mitem .nm{font-weight:600;font-size:15.5px}
.mitem .ds{font-size:13px;color:var(--ink-soft);display:block;font-weight:400;margin-top:2px}
.mitem .dots{flex:1;border-bottom:1.5px dotted var(--line);transform:translateY(-4px);min-width:14px}
.mitem .pr{font-family:var(--serif);font-weight:600;color:var(--ink);font-variant-numeric:tabular-nums;white-space:nowrap}
.menu-note{background:var(--cream2);border-left:3px solid var(--green);padding:16px 20px;border-radius:0 12px 12px 0;font-size:14px;color:var(--ink-soft);margin-top:20px}
.tagesteller{background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);padding:clamp(24px,3vw,36px);box-shadow:var(--shadow-sm)}
.tt-list{list-style:none;padding:0;margin:14px 0 0;display:grid;gap:0}
.tt-list li{display:flex;gap:16px;padding:12px 0;border-bottom:1px dashed var(--line)}
.tt-list li:last-child{border:0}
.tt-list .dy{font-weight:700;color:var(--green);min-width:54px;font-size:14.5px}
.tt-list .ds{font-size:15px}

/* ---------- order (bestellen) ---------- */
.order-grid{display:grid;grid-template-columns:1.6fr 1fr;gap:34px;align-items:start}
.shop-cat{margin-bottom:34px}
.shop-cat h3{font-size:22px;color:var(--carmine);margin-bottom:14px;padding-bottom:8px;border-bottom:2px solid var(--line)}
.prod{display:flex;gap:16px;align-items:center;background:var(--paper);border:1px solid var(--line);border-radius:14px;padding:14px 16px;margin-bottom:12px;transition:border-color .2s,box-shadow .2s}
.prod:hover{border-color:var(--gold-soft);box-shadow:var(--shadow-sm)}
.prod .pimg{width:74px;height:74px;border-radius:10px;object-fit:cover;flex:0 0 auto}
.prod .pinfo{flex:1;min-width:0}
.prod .pinfo b{font-size:16px;display:block}
.prod .pinfo span{font-size:13px;color:var(--ink-soft);display:block;margin-top:2px}
.prod .pinfo .ppr{color:var(--carmine);font-family:var(--serif);font-weight:600;font-size:18px;margin-top:4px}
.prod .add{flex:0 0 auto}
.qty{display:inline-flex;align-items:center;border:1.5px solid var(--line);border-radius:999px;overflow:hidden}
.qty button{width:34px;height:34px;border:0;background:var(--cream2);color:var(--ink);font-size:18px;cursor:pointer;line-height:1}
.qty button:hover{background:var(--carmine);color:#fff}
.qty span{min-width:34px;text-align:center;font-weight:700;font-variant-numeric:tabular-nums}
.cart{position:sticky;top:90px;background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);padding:24px;box-shadow:var(--shadow-sm)}
.cart h3{font-size:21px;margin-bottom:14px}
.cart-items{list-style:none;padding:0;margin:0 0 14px;max-height:320px;overflow:auto}
.cart-items li{display:flex;justify-content:space-between;gap:10px;padding:10px 0;border-bottom:1px dashed var(--line);font-size:14.5px}
.cart-items .ci-rm{color:var(--ink-mute);cursor:pointer;border:0;background:none;font-size:16px}
.cart-items .ci-rm:hover{color:var(--carmine)}
.cart-empty{color:var(--ink-mute);font-size:14px;text-align:center;padding:18px 0}
.cart-tot{display:flex;justify-content:space-between;font-family:var(--serif);font-size:22px;font-weight:600;margin:6px 0 4px}
.cart-min{font-size:12.5px;color:var(--ink-mute);margin-bottom:14px}
.cart-min.ok{color:var(--green);font-weight:700}
.field{margin:12px 0}
.field label{display:block;font-size:13px;font-weight:700;margin-bottom:6px}
.field input,.field select,.field textarea{width:100%;padding:11px 13px;border:1.5px solid var(--line);border-radius:10px;font-family:var(--sans);font-size:15px;background:var(--cream);color:var(--ink)}
.field input:focus,.field select:focus,.field textarea:focus{outline:0;border-color:var(--carmine)}
.seg{display:flex;gap:8px}
.seg label{flex:1;text-align:center;padding:11px;border:1.5px solid var(--line);border-radius:10px;cursor:pointer;font-weight:600;font-size:14px}
.seg input{position:absolute;opacity:0}
.seg input:checked+label,.seg label.on{border-color:var(--carmine);background:var(--carmine-soft);color:var(--carmine-d)}
.toast{position:fixed;bottom:24px;left:50%;transform:translateX(-50%) translateY(120%);background:var(--ink);color:#fff;padding:13px 22px;border-radius:999px;font-weight:600;font-size:14px;z-index:300;transition:transform .4s;box-shadow:var(--shadow)}
.toast.show{transform:translateX(-50%) translateY(0)}
.cart-fab{position:fixed;right:18px;bottom:18px;z-index:90;background:var(--carmine);color:#fff;border:0;border-radius:999px;padding:14px 20px;font-weight:700;cursor:pointer;box-shadow:var(--shadow);display:none;align-items:center;gap:8px}
.cart-fab .cb{background:#fff;color:var(--carmine);border-radius:999px;padding:1px 8px;font-size:13px}

/* ---------- form page ---------- */
.formwrap{max-width:680px;margin:0 auto;background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);padding:clamp(26px,4vw,44px);box-shadow:var(--shadow-sm)}
.frow{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.note-card{background:var(--cream2);border-radius:14px;padding:18px 20px;font-size:14px;color:var(--ink-soft);margin-top:18px;border-left:3px solid var(--green)}

/* ---------- anleitung ---------- */
.guide{max-width:820px;margin:0 auto}
.gstep{display:flex;gap:20px;margin-bottom:26px;background:var(--paper);border:1px solid var(--line);border-radius:var(--radius);padding:24px 26px;box-shadow:var(--shadow-sm)}
.gstep .gn{flex:0 0 auto;width:46px;height:46px;border-radius:50%;background:var(--carmine);color:#fff;font-family:var(--serif);font-size:22px;display:flex;align-items:center;justify-content:center}
.gstep h3{font-size:20px;margin-bottom:.3em}
.gstep p{margin:0;color:var(--ink-soft);font-size:15px}
.callout{background:var(--green);color:#fff;border-radius:var(--radius);padding:28px 30px;margin:30px 0}
.callout h3{color:#fff;font-size:24px;margin-bottom:.4em}
.callout p{margin:0;color:rgba(255,255,255,.92)}

/* ---------- responsive ---------- */
@media(max-width:980px){
  .h-head,.bs-grid,.split,.c-grid,.order-grid{grid-template-columns:1fr}
  .split.rev .txt{order:0}
  .bs-photos{height:340px}
  .f-top{grid-template-columns:1fr 1fr}
  .cart{position:static}
  .cart-fab{display:inline-flex}
}
@media(max-width:760px){
  .nav-links{position:fixed;inset:0 0 0 auto;width:min(80vw,320px);background:var(--cream);flex-direction:column;
    align-items:stretch;padding:90px 22px 30px;gap:4px;transform:translateX(110%);transition:transform .35s;box-shadow:var(--shadow);z-index:99}
  .nav-links.open{transform:none}
  .nav-links a:not(.btn){color:var(--ink)!important;font-size:17px;padding:13px 14px;border-bottom:1px solid var(--line)}
  .nav-links .btn{margin-top:12px;justify-content:center}
  .burger{display:flex;z-index:101}
  .timeline{grid-template-columns:1fr 1fr;gap:30px 18px}
  .timeline::before{display:none}
  .sig-grid,.fr-grid,.bento{grid-template-columns:1fr!important}
  .bento{grid-auto-rows:200px}
  .tile.big,.tile.wide,.tile.std,.tile.sq{grid-column:span 1;grid-row:span 1}
  .frow{grid-template-columns:1fr}
  .f-top{grid-template-columns:1fr}
  .trust .wrap{gap:18px 28px}
}
