*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --red:#C0392B;--red-dark:#96281B;--red-light:#F8EEEC;--red-mid:#E8C5C0;
  --black:#111;--dark:#1C1C1C;--mid:#5A5A5A;--light:#F5F2F0;--white:#FFFFFF;
  --border:rgba(192,57,43,0.15);
  --nav-h:68px;
  --maxw:1400px;
}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:'DM Sans',sans-serif;background:var(--white);color:var(--dark);font-weight:300;line-height:1.7;overflow-x:hidden;-webkit-font-smoothing:antialiased}
img{max-width:100%;display:block}
a{-webkit-tap-highlight-color:transparent}
button{-webkit-tap-highlight-color:transparent}

/* anchors not hidden behind sticky nav */
section[id], div[id]{scroll-margin-top:calc(var(--nav-h) + 12px)}

.reveal{opacity:0;transform:translateY(28px);transition:opacity 0.65s ease,transform 0.65s ease}
.reveal.visible{opacity:1;transform:none}
@media (prefers-reduced-motion: reduce){
  .reveal{opacity:1;transform:none;transition:none}
  html{scroll-behavior:auto}
}

/* ── NAV ── */
nav{position:fixed;top:0;left:0;right:0;z-index:200;padding:0.9rem 5vw;display:flex;align-items:center;justify-content:space-between;gap:1rem;background:#FBF9F6;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border-bottom:1px solid var(--border);min-height:var(--nav-h);box-shadow:0 4px 24px rgba(192,57,43,0.06)}

/* Subpages: nav scrollt mit (kein fixed) damit nichts überlappt */
body.subpage nav{position:static;background:#FBF9F6;border-bottom:1px solid var(--red-light);box-shadow:0 2px 12px rgba(192,57,43,0.05)}
body.subpage .breadcrumbs{padding-top:1.2rem}
body.subpage section[id]{scroll-margin-top:1rem}
.logo{font-family:'Playfair Display',serif;font-size:1.15rem;font-weight:700;color:var(--red);text-decoration:none;letter-spacing:0.02em;line-height:1.2;flex-shrink:1;min-width:0;display:inline-block}
.logo span{display:block;font-size:0.6rem;font-family:'DM Sans',sans-serif;font-weight:300;letter-spacing:0.22em;text-transform:uppercase;color:var(--mid)}
.nav-links{display:flex;gap:1.6rem;list-style:none}
.nav-links a{font-size:0.72rem;letter-spacing:0.16em;text-transform:uppercase;color:var(--mid);text-decoration:none;transition:color 0.2s;white-space:nowrap}
.nav-links a:hover{color:var(--red)}
.nav-cta{font-size:0.7rem;letter-spacing:0.13em;text-transform:uppercase;padding:0.7rem 1.3rem;background:var(--red);color:var(--white);border:none;cursor:pointer;transition:background 0.2s;font-family:'DM Sans',sans-serif;font-weight:500;text-decoration:none;white-space:nowrap}
.nav-cta:hover{background:var(--red-dark)}

/* hamburger */
.nav-toggle{display:none;width:44px;height:44px;background:none;border:1px solid var(--border);cursor:pointer;align-items:center;justify-content:center;flex-direction:column;gap:5px;flex-shrink:0}
.nav-toggle span{display:block;width:18px;height:1.5px;background:var(--dark);transition:transform 0.25s,opacity 0.25s}
body.menu-open .nav-toggle span:nth-child(1){transform:translateY(6.5px) rotate(45deg)}
body.menu-open .nav-toggle span:nth-child(2){opacity:0}
body.menu-open .nav-toggle span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}

/* mobile drawer */
.mobile-drawer{position:fixed;top:0;right:0;bottom:0;width:min(85vw,360px);background:var(--white);z-index:199;padding:calc(var(--nav-h) + 1.5rem) 2rem 2rem;transform:translateX(100%);transition:transform 0.3s ease;display:flex;flex-direction:column;gap:0;border-left:1px solid var(--border);overflow-y:auto;-webkit-overflow-scrolling:touch}
.mobile-drawer a{display:block;font-family:'Playfair Display',serif;font-size:1.4rem;color:var(--dark);text-decoration:none;padding:0.95rem 0;border-bottom:1px solid var(--border);transition:color 0.2s}
.mobile-drawer a:hover{color:var(--red)}
.mobile-drawer a.drawer-cta{margin-top:1.3rem;background:var(--red);color:var(--white);text-align:center;font-family:'DM Sans',sans-serif;font-size:0.78rem;letter-spacing:0.16em;text-transform:uppercase;font-weight:500;padding:1rem 1.2rem;border:none}
.mobile-drawer-meta{margin-top:1.5rem;font-size:0.75rem;color:var(--mid);line-height:1.7}
.mobile-drawer-meta strong{color:var(--dark);font-weight:500;display:block;font-family:'Playfair Display',serif;font-size:0.95rem;margin-bottom:0.4rem}
body.menu-open .mobile-drawer{transform:translateX(0)}
.drawer-backdrop{position:fixed;inset:0;background:rgba(0,0,0,0.45);z-index:198;opacity:0;pointer-events:none;transition:opacity 0.3s}
body.menu-open .drawer-backdrop{opacity:1;pointer-events:auto}
body.menu-open{overflow:hidden}

/* ── HERO ── */
.hero{min-height:100vh;display:grid;grid-template-columns:55% 45%;padding-top:var(--nav-h);background:var(--white)}
.hero-left{display:flex;flex-direction:column;justify-content:center;padding:4.5rem 5vw 4rem 7vw}
.hero-tag{font-size:0.66rem;letter-spacing:0.35em;text-transform:uppercase;color:var(--red);margin-bottom:1.2rem;font-weight:500}
.hero-title{font-family:'Playfair Display',serif;font-size:clamp(2.2rem,4.2vw,4rem);font-weight:700;line-height:1.08;color:var(--black);margin-bottom:1.1rem;text-wrap:balance}
.hero-title em{font-style:italic;color:var(--red)}
.hero-body{font-size:0.95rem;color:var(--mid);max-width:440px;line-height:1.85;margin-bottom:2rem}
.hero-actions{display:flex;gap:1rem;align-items:center;flex-wrap:wrap}
.btn-red{font-size:0.72rem;letter-spacing:0.13em;text-transform:uppercase;padding:1rem 1.9rem;background:var(--red);color:var(--white);border:none;cursor:pointer;transition:background 0.2s,transform 0.15s;font-family:'DM Sans',sans-serif;font-weight:500;text-decoration:none;display:inline-block;min-height:44px;line-height:1.2}
.btn-red:hover{background:var(--red-dark)}
.btn-red:active{transform:translateY(1px)}
.btn-ghost{font-size:0.72rem;letter-spacing:0.13em;text-transform:uppercase;color:var(--mid);text-decoration:none;transition:color 0.2s;padding:1rem 0.4rem;min-height:44px;display:inline-flex;align-items:center}
.btn-ghost:hover{color:var(--red)}
.hero-badges{display:flex;gap:1.8rem;margin-top:2.2rem;padding-top:1.8rem;border-top:1px solid var(--border);flex-wrap:wrap}
.badge-num{font-family:'Playfair Display',serif;font-size:1.7rem;font-weight:700;color:var(--red);line-height:1}
.badge-label{font-size:0.63rem;letter-spacing:0.12em;text-transform:uppercase;color:var(--mid);margin-top:0.2rem}
.hero-right{position:relative;overflow:hidden;background:#1a1413;min-height:420px;display:block}
.hero-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block;opacity:0;transform:scale(1.06);transition:opacity 1.6s cubic-bezier(.45,.05,.25,1);will-change:opacity,transform}
.hero-img.slide-active{opacity:1;z-index:1}
.hero-right::after{content:"";position:absolute;inset:auto 0 0 0;height:35%;background:linear-gradient(to top,rgba(20,16,15,0.35),transparent);pointer-events:none;z-index:2}
.hero-right .hero-img:nth-child(1).slide-active{animation:kb1 7s ease-out forwards}
.hero-right .hero-img:nth-child(2).slide-active{animation:kb2 7s ease-out forwards}
.hero-right .hero-img:nth-child(3).slide-active{animation:kb3 7s ease-out forwards}
@keyframes kb1{0%{transform:scale(1.02) translate(0,0)}100%{transform:scale(1.16) translate(-2%,-1.5%)}}
@keyframes kb2{0%{transform:scale(1.16) translate(-2%,0)}100%{transform:scale(1.04) translate(1%,-1%)}}
@keyframes kb3{0%{transform:scale(1.04) translate(1%,-1%)}100%{transform:scale(1.18) translate(-1%,1.5%)}}

/* ── INTRO BAND ── */
.intro-band{background:var(--red);color:var(--white);padding:1.3rem 6vw;display:flex;align-items:center;justify-content:center;gap:1.5rem;flex-wrap:wrap}
.intro-item{font-size:0.75rem;letter-spacing:0.12em;text-transform:uppercase}
.intro-dot{width:4px;height:4px;background:rgba(255,255,255,0.4);border-radius:50%;flex-shrink:0}

/* ── SHARED SECTION STYLES ── */
.section-eyebrow{font-size:0.66rem;letter-spacing:0.35em;text-transform:uppercase;color:var(--red);margin-bottom:0.7rem;font-weight:500}
.section-title{font-family:'Playfair Display',serif;font-size:clamp(1.9rem,3.2vw,2.7rem);font-weight:700;line-height:1.2;color:var(--black);text-wrap:balance}
.section-title em{font-style:italic;color:var(--red)}

/* ── SERVICES ── */
.services{padding:5.5rem 8vw}
.services-header{display:grid;grid-template-columns:1fr 1fr;gap:2.5rem;margin-bottom:3.5rem;align-items:end}
.services-intro{font-size:0.92rem;color:var(--mid);line-height:1.9;max-width:440px}
.services-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:0;border:1px solid var(--border)}
.svc{padding:2.2rem;border-right:1px solid var(--border);border-bottom:1px solid var(--border);transition:background 0.2s;cursor:default}
.svc:nth-child(3n){border-right:none}
.svc:nth-last-child(-n+3){border-bottom:none}
.svc:hover{background:var(--red-light)}
.svc-icon{width:36px;height:36px;background:var(--red-light);display:flex;align-items:center;justify-content:center;margin-bottom:1.3rem}
.svc-icon svg{width:18px;height:18px;stroke:var(--red);fill:none;stroke-width:1.5}
.svc-name{font-family:'Playfair Display',serif;font-size:1.15rem;font-weight:700;margin-bottom:0.55rem;color:var(--black);line-height:1.3}
.svc-desc{font-size:0.85rem;color:var(--mid);line-height:1.8}
.svc-highlight{background:var(--red);color:var(--white);padding:2.2rem}
.svc-highlight .svc-name{color:var(--white)}
.svc-highlight .svc-desc{color:rgba(255,255,255,0.85)}
.svc-highlight .svc-icon{background:rgba(255,255,255,0.15)}
.svc-highlight .svc-icon svg{stroke:var(--white)}
.svc-badge{display:inline-block;font-size:0.58rem;letter-spacing:0.18em;text-transform:uppercase;background:rgba(255,255,255,0.2);color:var(--white);padding:0.3rem 0.6rem;border-radius:2px;margin-bottom:0.8rem}

/* ── SPECIAL OCCASIONS ── */
.occasions{padding:5.5rem 8vw;background:var(--light)}
.occasions-grid{display:grid;grid-template-columns:1fr 1fr;gap:3px;margin-top:3rem}
.occ-card{position:relative;overflow:hidden;aspect-ratio:3/4}
.occ-card img{width:100%;height:100%;object-fit:cover;transition:transform 0.6s ease;display:block}
.occ-card:hover img{transform:scale(1.04)}
.occ-overlay{position:absolute;bottom:0;left:0;right:0;padding:2rem;background:linear-gradient(to top,rgba(0,0,0,0.78) 0%,transparent 100%);color:var(--white)}
.occ-title{font-family:'Playfair Display',serif;font-size:1.4rem;font-weight:700;margin-bottom:0.4rem}
.occ-sub{font-size:0.78rem;color:rgba(255,255,255,0.85);letter-spacing:0.1em}

/* ── GALLERY ── */
.gallery{padding:0 0 5.5rem}
.gallery-header{padding:3.5rem 8vw 2rem}
.gallery-scroll{display:grid;grid-template-columns:repeat(5,1fr);gap:3px;margin:0 8vw}
.gallery-item{overflow:hidden;aspect-ratio:3/4;position:relative}
.gallery-item img{width:100%;height:100%;object-fit:cover;transition:transform 0.5s ease;display:block}
.gallery-item:hover img{transform:scale(1.06)}
.gallery-item.wide{grid-column:span 2}

/* ── TAMARA ── */
.tamara{display:grid;grid-template-columns:1fr 1fr;background:var(--dark);color:var(--white)}
.tamara-img{overflow:hidden;position:relative;min-height:500px}
.tamara-img img{width:100%;height:100%;object-fit:cover;object-position:center top;filter:brightness(0.85)}
.tamara-content{padding:5rem 6vw;display:flex;flex-direction:column;justify-content:center}
.tamara-content .section-eyebrow{color:var(--red-mid)}
.tamara-content .section-title{color:var(--white)}
.tamara-body{font-size:0.92rem;color:rgba(255,255,255,0.7);line-height:1.9;margin-top:1.4rem;max-width:440px}
.tamara-stats{display:flex;gap:2.5rem;margin-top:2.2rem;padding-top:1.8rem;border-top:1px solid rgba(192,57,43,0.3);flex-wrap:wrap}
.tstat-n{font-family:'Playfair Display',serif;font-size:1.9rem;font-weight:700;color:var(--red-mid);line-height:1}
.tstat-l{font-size:0.63rem;letter-spacing:0.15em;text-transform:uppercase;color:rgba(255,255,255,0.5);margin-top:0.3rem}

/* ── FAQ (accordion) ── */
.faq{padding:5.5rem 8vw;background:var(--red-light)}
.faq-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-top:3rem}
.faq-item{background:var(--white);border-left:3px solid var(--red);overflow:hidden}
.faq-q{font-family:'Playfair Display',serif;font-size:1rem;font-weight:700;color:var(--black);padding:1.4rem 1.6rem;cursor:pointer;display:flex;justify-content:space-between;align-items:center;gap:1rem;background:none;border:none;width:100%;text-align:left;font-family:'Playfair Display',serif;line-height:1.35}
.faq-q::after{content:'+';font-family:'DM Sans',sans-serif;font-size:1.4rem;font-weight:300;color:var(--red);flex-shrink:0;transition:transform 0.25s}
.faq-item.open .faq-q::after{content:'−'}
.faq-a{font-size:0.86rem;color:var(--mid);line-height:1.85;padding:0 1.6rem;max-height:0;overflow:hidden;transition:max-height 0.3s ease,padding 0.3s ease}
.faq-item.open .faq-a{max-height:500px;padding:0 1.6rem 1.4rem}

/* ── PREISE ── */
.preise{padding:5.5rem 8vw}
.preise-tabs{display:flex;gap:0;margin:2.2rem 0 2.5rem;border:1px solid var(--border)}
.tab-btn{flex:1;padding:1rem;font-size:0.72rem;letter-spacing:0.18em;text-transform:uppercase;background:var(--white);border:none;cursor:pointer;color:var(--mid);font-family:'DM Sans',sans-serif;font-weight:500;transition:all 0.2s;border-right:1px solid var(--border);min-height:44px}
.tab-btn:last-child{border-right:none}
.tab-btn.active{background:var(--red);color:var(--white)}
.price-table{display:none}
.price-table.active{display:block}
.price-grid{display:grid;grid-template-columns:1fr 1fr;gap:4px}
.price-row{display:flex;justify-content:space-between;align-items:baseline;padding:0.95rem 1.1rem;border:1px solid var(--border);background:var(--white);transition:background 0.2s;gap:1rem}
.price-row:hover{background:var(--red-light)}
.price-item{font-size:0.86rem;color:var(--dark);font-weight:500;flex:1;min-width:0}
.price-item span{font-weight:300;color:var(--mid);font-size:0.78rem;margin-left:0.3rem}
.price-val{font-family:'Playfair Display',serif;font-size:0.95rem;font-weight:700;color:var(--red);white-space:nowrap;flex-shrink:0}
.price-note{font-size:0.78rem;color:var(--mid);margin-top:1.2rem;font-style:italic}

/* ── REVIEWS ── */
.reviews{padding:5.5rem 8vw;background:var(--light)}
.reviews-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem;margin-top:3rem}
.review-card{background:var(--white);padding:1.7rem;border-top:3px solid var(--red)}
.review-stars{color:var(--red);font-size:0.8rem;letter-spacing:0.08em;margin-bottom:0.7rem}
.review-text{font-size:0.86rem;color:var(--mid);line-height:1.8;font-style:italic;margin-bottom:0.95rem}
.review-author{font-size:0.7rem;letter-spacing:0.13em;text-transform:uppercase;color:var(--dark);font-weight:500}
.review-date{font-size:0.67rem;color:var(--mid);margin-top:0.15rem}

/* ── MAP ── */
.map-section{padding:5.5rem 8vw}
.map-wrap{margin-top:2.5rem;border:1px solid var(--border);overflow:hidden}
.map-wrap iframe{display:block;width:100%;height:420px;border:none}
.map-cta{margin-top:1.2rem;display:flex;align-items:center;gap:1rem;flex-wrap:wrap}
.map-addr{font-size:0.88rem;color:var(--mid);flex:1;min-width:220px}
.map-addr strong{color:var(--dark);font-weight:500;display:block;margin-bottom:0.2rem}

/* ── CTA ── */
.cta{padding:6rem 8vw;text-align:center;background:var(--red);color:var(--white)}
.cta-title{font-family:'Playfair Display',serif;font-size:clamp(1.9rem,3.8vw,2.9rem);font-weight:700;line-height:1.15;margin-bottom:1.1rem;text-wrap:balance}
.cta-sub{font-size:0.92rem;color:rgba(255,255,255,0.8);margin-bottom:2.2rem;max-width:520px;margin-left:auto;margin-right:auto;line-height:1.8}
.btn-white{font-size:0.78rem;letter-spacing:0.13em;text-transform:uppercase;padding:1rem 2.2rem;background:var(--white);color:var(--red);border:none;cursor:pointer;transition:all 0.2s;font-family:'DM Sans',sans-serif;font-weight:700;text-decoration:none;display:inline-block;min-height:44px}
.btn-white:hover{background:var(--black);color:var(--white)}

/* ── FOOTER ── */
footer{background:var(--dark);padding:2.8rem 8vw;display:grid;grid-template-columns:1fr auto 1fr;gap:2rem;align-items:center;border-top:3px solid var(--red)}
.footer-logo{font-family:'Playfair Display',serif;font-size:1.05rem;font-weight:700;color:var(--white)}
.footer-logo span{display:block;font-size:0.6rem;font-family:'DM Sans',sans-serif;font-weight:300;letter-spacing:0.18em;text-transform:uppercase;color:rgba(255,255,255,0.4);margin-top:0.2rem}
.footer-center{text-align:center;font-size:0.76rem;color:rgba(255,255,255,0.5);line-height:2}
.footer-center a{color:inherit;text-decoration:none}
.footer-right{text-align:right;display:flex;flex-direction:column;align-items:flex-end;gap:0.5rem}
.footer-link{font-size:0.74rem;color:rgba(255,255,255,0.6);cursor:pointer;text-decoration:none;background:none;border:none;font-family:'DM Sans',sans-serif;transition:color 0.2s;letter-spacing:0.05em;padding:0.25rem 0}
.footer-link:hover{color:var(--red)}

/* ── MODAL OVERLAY ── */
.modal-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,0.55);z-index:1000;align-items:center;justify-content:center;padding:1.2rem}
.modal-overlay.open{display:flex}
.modal-box{background:var(--white);max-width:600px;width:100%;max-height:85vh;overflow-y:auto;-webkit-overflow-scrolling:touch;padding:2.5rem;position:relative;border-top:4px solid var(--red)}
.modal-close{position:absolute;top:0.8rem;right:0.8rem;width:40px;height:40px;background:none;border:none;cursor:pointer;font-size:1.3rem;color:var(--mid);line-height:1;font-family:'DM Sans',sans-serif;transition:color 0.2s;display:flex;align-items:center;justify-content:center}
.modal-close:hover{color:var(--red)}
.modal-title{font-family:'Playfair Display',serif;font-size:1.5rem;font-weight:700;margin-bottom:1.5rem;color:var(--black)}
.modal-body{font-size:0.86rem;color:var(--mid);line-height:1.9}
.modal-body h3{font-family:'Playfair Display',serif;font-size:1rem;font-weight:700;color:var(--black);margin:1.2rem 0 0.4rem}
.modal-body p{margin-bottom:0.6rem}
.modal-body strong{color:var(--dark);font-weight:500}

/* ── MOBILE STICKY CTA ── */
.mobile-call{display:none;position:fixed;bottom:1rem;left:1rem;right:1rem;z-index:150;background:var(--red);color:var(--white);font-size:0.82rem;letter-spacing:0.13em;text-transform:uppercase;text-align:center;padding:1rem 1.2rem;font-family:'DM Sans',sans-serif;font-weight:500;text-decoration:none;border:none;box-shadow:0 6px 20px rgba(192,57,43,0.35);min-height:52px;align-items:center;justify-content:center;gap:0.6rem}
.mobile-call svg{width:16px;height:16px;flex-shrink:0}

/* ────────────────────────── */
/* TABLET                     */
/* ────────────────────────── */
@media(max-width:1100px){
  .services-grid{grid-template-columns:repeat(2,1fr)}
  .svc{border-right:1px solid var(--border);border-bottom:1px solid var(--border)}
  .svc:nth-child(3n){border-right:1px solid var(--border)}
  .svc:nth-child(2n){border-right:none}
  .svc:nth-last-child(-n+3){border-bottom:1px solid var(--border)}
  .svc:nth-last-child(-n+2){border-bottom:none}
  .reviews-grid{grid-template-columns:repeat(2,1fr)}
  .gallery-scroll{grid-template-columns:repeat(4,1fr)}
}

/* ────────────────────────── */
/* MOBILE                     */
/* ────────────────────────── */
@media(max-width:780px){
  :root{--nav-h:60px}

  /* nav */
  nav{padding:0.7rem 5vw}
  .nav-links{display:none}
  .nav-cta{display:none}
  .nav-toggle{display:flex}
  .logo{font-size:0.95rem}
  .logo span{font-size:0.55rem;letter-spacing:0.18em}

  /* hero */
  .hero{grid-template-columns:1fr;min-height:auto;padding-top:var(--nav-h)}
  .hero-left{padding:3rem 6vw 2.5rem;order:2}
  .hero-right{order:1;height:65vw;min-height:260px;max-height:440px}
  .hero-title{font-size:clamp(2rem,9vw,2.9rem);line-height:1.05}
  .hero-body{font-size:0.95rem;max-width:none}
  .hero-actions{flex-direction:column;align-items:stretch;gap:0.8rem}
  .hero-actions .btn-red{text-align:center;padding:1.1rem 1.6rem}
  .hero-actions .btn-ghost{text-align:center;justify-content:center;border:1px solid var(--border);padding:1.1rem 1.6rem}
  .hero-badges{gap:1.4rem;justify-content:space-between}
  .hero-badges>div{flex:1;min-width:90px}
  .badge-num{font-size:1.5rem}

  /* intro band */
  .intro-band{flex-direction:column;gap:0.6rem;padding:1.4rem 6vw;text-align:center}
  .intro-dot{display:none}
  .intro-item{font-size:0.7rem}

  /* services */
  .services{padding:4rem 6vw}
  .services-header{grid-template-columns:1fr;gap:1.2rem;margin-bottom:2.5rem}
  .services-grid{grid-template-columns:1fr;border:none;gap:0.6rem}
  .svc{border:1px solid var(--border)!important;padding:1.7rem 1.5rem}
  .svc-highlight{border:none!important}
  .svc-name{font-size:1.05rem}

  /* occasions */
  .occasions{padding:4rem 6vw}
  .occasions-grid{grid-template-columns:1fr;gap:0.6rem;margin-top:2.2rem}
  .occ-card{aspect-ratio:4/3}
  .occ-overlay{padding:1.3rem}
  .occ-title{font-size:1.2rem}

  /* gallery: horizontal scroll */
  .gallery{padding:0 0 4rem}
  .gallery-header{padding:3rem 6vw 1.5rem}
  .gallery-scroll{display:flex;grid-template-columns:none;gap:0.5rem;margin:0;padding:0 6vw 0.5rem;overflow-x:auto;-webkit-overflow-scrolling:touch;scroll-snap-type:x mandatory;scrollbar-width:none}
  .gallery-scroll::-webkit-scrollbar{display:none}
  .gallery-item{flex:0 0 70%;aspect-ratio:3/4;scroll-snap-align:start}
  .gallery-item.wide{flex:0 0 70%;grid-column:auto}

  /* tamara */
  .tamara{grid-template-columns:1fr}
  .tamara-img{min-height:340px;aspect-ratio:1/1}
  .tamara-content{padding:3.5rem 6vw}
  .tamara-stats{gap:1.4rem;justify-content:space-between}
  .tamara-stats>div{flex:1;min-width:80px}
  .tstat-n{font-size:1.6rem}

  /* faq */
  .faq{padding:4rem 6vw}
  .faq-grid{grid-template-columns:1fr;margin-top:2.2rem;gap:0.6rem}
  .faq-q{padding:1.2rem 1.3rem;font-size:0.95rem}
  .faq-a{font-size:0.85rem}
  .faq-item.open .faq-a{padding:0 1.3rem 1.2rem}

  /* preise */
  .preise{padding:4rem 6vw}
  .price-grid{grid-template-columns:1fr;gap:0.4rem}
  .price-row{padding:0.95rem 1rem}
  .tab-btn{padding:0.95rem 0.4rem;font-size:0.7rem;letter-spacing:0.14em}

  /* reviews */
  .reviews{padding:4rem 6vw}
  .reviews-grid{grid-template-columns:1fr;margin-top:2.2rem}

  /* map */
  .map-section{padding:4rem 6vw}
  .map-wrap iframe{height:320px}
  .map-cta{flex-direction:column;align-items:stretch}
  .map-cta .btn-red{text-align:center}
  .map-addr{text-align:center;min-width:0}

  /* cta */
  .cta{padding:4.5rem 6vw}
  .cta-sub{font-size:0.9rem}

  /* footer */
  footer{grid-template-columns:1fr;text-align:center;padding:2.5rem 6vw 5.5rem;gap:1.5rem}
  .footer-logo{text-align:center}
  .footer-right{align-items:center}

  /* modal */
  .modal-box{padding:2rem 1.5rem;max-height:90vh}
  .modal-title{font-size:1.3rem}

  /* sticky call */
  .mobile-call{display:flex}

  /* hide reveal slide-up on mobile to feel snappier */
  .reveal{transform:translateY(14px)}
}

@media(max-width:420px){
  .hero-left{padding:2.5rem 6vw 2rem}
  .hero-badges{padding-top:1.4rem;margin-top:1.6rem}
  .badge-num{font-size:1.35rem}
  .badge-label{font-size:0.58rem}
  .section-title{font-size:clamp(1.7rem,8vw,2.2rem)}
}

/* Made by link */
.madeby-link{color:rgba(255,255,255,0.35);font-size:0.65rem;letter-spacing:0.1em;text-decoration:none;transition:color 0.2s;border-bottom:1px solid rgba(255,255,255,0.15)}
.madeby-link:hover{color:var(--red);border-bottom-color:var(--red)}

/* focus states for keyboard users */
a:focus-visible,button:focus-visible{outline:2px solid var(--red);outline-offset:3px}

/* ═════════════════════════════════════════════════ */
/* SEO-FOOTER (Bezirks- & Leistungslinks)            */
/* ═════════════════════════════════════════════════ */
.seo-footer{background:var(--light);padding:4.5rem 8vw 3.5rem;border-top:1px solid var(--border)}
.seo-footer-grid{max-width:var(--maxw);margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:3.5rem}
.seo-col h3{font-family:'Playfair Display',serif;font-size:1.15rem;font-weight:700;color:var(--black);margin-bottom:0.4rem;letter-spacing:0.01em}
.seo-col .seo-eyebrow{font-size:0.62rem;letter-spacing:0.32em;text-transform:uppercase;color:var(--red);margin-bottom:0.8rem;font-weight:500}
.seo-col p.seo-intro{font-size:0.82rem;color:var(--mid);line-height:1.75;margin-bottom:1.5rem;max-width:480px}
.seo-list{list-style:none;display:grid;grid-template-columns:repeat(3,1fr);gap:0.45rem 1.5rem;padding:0;margin:0}
.seo-list.cols-2{grid-template-columns:repeat(2,1fr)}
.seo-list li{font-size:0}
.seo-list a{display:inline-block;font-size:0.78rem;color:var(--mid);text-decoration:none;padding:0.3rem 0;border-bottom:1px solid transparent;transition:color 0.2s,border-color 0.2s;line-height:1.4;letter-spacing:0.01em}
.seo-list a:hover{color:var(--red);border-bottom-color:var(--red-mid)}
.seo-footer-bottom{max-width:var(--maxw);margin:2.8rem auto 0;padding-top:2rem;border-top:1px solid var(--border);font-size:0.74rem;color:var(--mid);text-align:center;line-height:1.7}
.seo-footer-bottom a{color:var(--red);text-decoration:none}
.seo-footer-bottom a:hover{text-decoration:underline}

/* ═════════════════════════════════════════════════ */
/* BREADCRUMBS                                       */
/* ═════════════════════════════════════════════════ */
.breadcrumbs{padding:calc(var(--nav-h) + 1.6rem) 8vw 0.6rem;font-size:0.74rem;color:var(--mid);letter-spacing:0.04em;background:var(--white)}
.breadcrumbs ol{list-style:none;display:flex;flex-wrap:wrap;gap:0.4rem;padding:0;margin:0}
.breadcrumbs li{display:flex;align-items:center;gap:0.4rem}
.breadcrumbs li:not(:last-child)::after{content:"›";color:var(--red);margin-left:0.4rem;opacity:0.7}
.breadcrumbs a{color:var(--mid);text-decoration:none;transition:color 0.2s}
.breadcrumbs a:hover{color:var(--red)}
.breadcrumbs li:last-child{color:var(--dark);font-weight:500}

/* ═════════════════════════════════════════════════ */
/* SUBPAGE HERO (Bezirks- / Leistungsseiten)         */
/* ═════════════════════════════════════════════════ */
.page-hero{padding:3rem 8vw 4rem;background:linear-gradient(180deg,#FBF9F6 0%,#FFFFFF 100%);margin:0;border-bottom:1px solid var(--red-light);overflow:visible}
.page-hero-inner{max-width:var(--maxw);margin:0 auto}
.page-hero-eyebrow{font-size:0.7rem;letter-spacing:0.35em;text-transform:uppercase;color:var(--red);margin-bottom:1.2rem;font-weight:500;display:block}
.page-hero h1{font-family:'Playfair Display',serif;font-size:clamp(1.8rem,3vw,2.6rem);font-weight:700;line-height:1.2;color:var(--black);margin:0 0 1.4rem;max-width:900px;overflow-wrap:break-word;word-wrap:break-word;display:block}
.page-hero h1 em{font-style:italic;color:var(--red)}
.page-hero .page-lead{font-size:1.02rem;color:var(--mid);line-height:1.85;max-width:720px;margin-bottom:2rem;font-weight:300}
.page-hero-actions{display:flex;gap:1rem;align-items:center;flex-wrap:wrap;margin-bottom:2.4rem}
.page-hero-meta{display:flex;flex-wrap:wrap;gap:1.6rem 2.4rem;padding-top:1.8rem;border-top:1px solid var(--border);font-size:0.78rem;color:var(--mid);max-width:760px}
.page-hero-meta strong{display:block;color:var(--black);font-family:'Playfair Display',serif;font-size:0.95rem;font-weight:700;margin-bottom:0.2rem}

/* ═════════════════════════════════════════════════ */
/* CONTENT BLOCKS auf Sub-Seiten                     */
/* ═════════════════════════════════════════════════ */
.content-section{max-width:var(--maxw);margin:0 auto;padding:3rem 8vw;display:grid;grid-template-columns:minmax(0,1fr) 320px;gap:3.5rem;align-items:start}
.content-section.full{grid-template-columns:1fr}
.content-main h2{font-family:'Playfair Display',serif;font-size:clamp(1.5rem,2.6vw,2rem);font-weight:700;color:var(--black);margin:2.2rem 0 1rem;line-height:1.2;text-wrap:balance}
.content-main h2:first-child{margin-top:0}
.content-main h2 em{font-style:italic;color:var(--red)}
.content-main h3{font-family:'Playfair Display',serif;font-size:1.15rem;font-weight:700;color:var(--black);margin:1.6rem 0 0.6rem}
.content-main p{font-size:0.95rem;line-height:1.85;color:var(--mid);margin-bottom:1.1rem}
.content-main p strong{color:var(--dark);font-weight:500}
.content-main ul{padding-left:1.2rem;margin-bottom:1.4rem}
.content-main ul li{font-size:0.93rem;line-height:1.85;color:var(--mid);margin-bottom:0.4rem;list-style:none;position:relative;padding-left:1.1rem}
.content-main ul li::before{content:"›";position:absolute;left:0;color:var(--red);font-weight:700}
.content-main a:not(.btn-red):not(.btn-ghost){color:var(--red);text-decoration:none;border-bottom:1px solid var(--red-mid);transition:border-color 0.2s}
.content-main a:not(.btn-red):not(.btn-ghost):hover{border-bottom-color:var(--red)}
.content-cta-inline{margin:1.8rem 0;padding:1.3rem 1.6rem;background:var(--red-light);border-left:3px solid var(--red);font-size:0.9rem;color:var(--dark);line-height:1.7}
.content-cta-inline strong{display:block;font-family:'Playfair Display',serif;font-size:1.05rem;color:var(--black);margin-bottom:0.35rem;font-weight:700}
.content-cta-inline a{color:var(--red);font-weight:500}

/* Sidebar (sticky) */
.content-aside{position:sticky;top:calc(var(--nav-h) + 1rem);background:var(--light);padding:1.8rem;border-top:3px solid var(--red)}
.content-aside h4{font-family:'Playfair Display',serif;font-size:1.05rem;font-weight:700;color:var(--black);margin-bottom:0.4rem}
.content-aside .aside-eyebrow{font-size:0.6rem;letter-spacing:0.3em;text-transform:uppercase;color:var(--red);margin-bottom:0.5rem;font-weight:500}
.content-aside p{font-size:0.84rem;color:var(--mid);line-height:1.7;margin-bottom:1rem}
.content-aside .aside-block{margin-top:1.4rem;padding-top:1.4rem;border-top:1px solid var(--border)}
.content-aside ul{list-style:none;padding:0;margin:0}
.content-aside ul li{margin-bottom:0.4rem}
.content-aside ul li a{font-size:0.82rem;color:var(--mid);text-decoration:none;transition:color 0.2s}
.content-aside ul li a:hover{color:var(--red)}
.content-aside .btn-red{display:block;text-align:center;margin-top:0.8rem}
.content-aside .aside-meta{font-size:0.78rem;color:var(--mid);line-height:1.7}
.content-aside .aside-meta strong{color:var(--dark);font-weight:500;display:block;margin-bottom:0.2rem;font-family:'Playfair Display',serif;font-size:0.95rem}

/* Highlight-Karten Reihe */
.feature-row{max-width:var(--maxw);margin:0 auto;padding:2rem 8vw 3rem;display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem}
.feature-card{background:var(--light);padding:1.8rem 1.6rem;border-top:3px solid var(--red)}
.feature-card h3{font-family:'Playfair Display',serif;font-size:1.05rem;font-weight:700;color:var(--black);margin-bottom:0.5rem}
.feature-card p{font-size:0.86rem;color:var(--mid);line-height:1.75;margin:0}

/* FAQ auf Sub-Seiten – kompakt */
.subpage-faq{max-width:var(--maxw);margin:0 auto;padding:3rem 8vw;background:var(--white)}
.subpage-faq .section-eyebrow{margin-bottom:0.5rem}
.subpage-faq h2{font-family:'Playfair Display',serif;font-size:clamp(1.6rem,2.8vw,2.3rem);font-weight:700;color:var(--black);margin-bottom:1.6rem;line-height:1.2}
.subpage-faq h2 em{font-style:italic;color:var(--red)}
.subpage-faq .faq-list{display:grid;gap:0;max-width:880px;border-top:1px solid var(--border)}
.subpage-faq details{border-bottom:1px solid var(--border);padding:1.2rem 0}
.subpage-faq summary{cursor:pointer;font-family:'Playfair Display',serif;font-size:1.05rem;font-weight:700;color:var(--black);list-style:none;display:flex;justify-content:space-between;align-items:center;gap:1rem;line-height:1.4}
.subpage-faq summary::-webkit-details-marker{display:none}
.subpage-faq summary::after{content:"+";color:var(--red);font-size:1.3rem;font-weight:300;transition:transform 0.25s;flex-shrink:0;line-height:1}
.subpage-faq details[open] summary::after{transform:rotate(45deg)}
.subpage-faq details > p{font-size:0.92rem;line-height:1.85;color:var(--mid);margin-top:0.8rem;padding-right:2rem}

/* CTA-Block für Subseiten */
.subpage-cta{padding:4.5rem 8vw;text-align:center;background:var(--red);color:var(--white)}
.subpage-cta h2{font-family:'Playfair Display',serif;font-size:clamp(1.7rem,3.2vw,2.4rem);font-weight:700;line-height:1.2;margin-bottom:1rem;text-wrap:balance}
.subpage-cta p{font-size:0.92rem;color:rgba(255,255,255,0.85);margin-bottom:1.8rem;max-width:560px;margin-left:auto;margin-right:auto;line-height:1.8}
.subpage-cta .cta-actions{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}
.subpage-cta .btn-white{background:var(--white);color:var(--red)}
.subpage-cta .btn-outline{font-size:0.78rem;letter-spacing:0.13em;text-transform:uppercase;padding:1rem 2.2rem;background:transparent;color:var(--white);border:1px solid rgba(255,255,255,0.45);text-decoration:none;font-weight:500;display:inline-block;min-height:44px;transition:background 0.2s,border-color 0.2s}
.subpage-cta .btn-outline:hover{background:rgba(255,255,255,0.1);border-color:var(--white)}

/* Service-Grid (Seitenliste) */
.svc-list-section{max-width:var(--maxw);margin:0 auto;padding:3.5rem 8vw}
.svc-list-section .section-eyebrow{margin-bottom:0.5rem}
.svc-list-section h2{font-family:'Playfair Display',serif;font-size:clamp(1.7rem,3vw,2.4rem);font-weight:700;color:var(--black);margin-bottom:0.4rem;line-height:1.2}
.svc-list-section h2 em{font-style:italic;color:var(--red)}
.svc-list-section .lead{font-size:0.95rem;color:var(--mid);line-height:1.8;max-width:680px;margin-bottom:2.2rem}
.svc-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem}
.svc-card{background:var(--white);border:1px solid var(--border);padding:1.7rem 1.5rem;text-decoration:none;color:inherit;transition:border-color 0.2s,transform 0.2s,box-shadow 0.2s;display:flex;flex-direction:column;gap:0.5rem;min-height:160px}
.svc-card:hover{border-color:var(--red);transform:translateY(-3px);box-shadow:0 8px 26px rgba(192,57,43,0.08)}
.svc-card .svc-card-eyebrow{font-size:0.6rem;letter-spacing:0.28em;text-transform:uppercase;color:var(--red);font-weight:500}
.svc-card h3{font-family:'Playfair Display',serif;font-size:1.1rem;font-weight:700;color:var(--black);line-height:1.25;margin:0}
.svc-card p{font-size:0.84rem;color:var(--mid);line-height:1.7;margin:0}
.svc-card .svc-card-arrow{margin-top:auto;padding-top:0.6rem;font-size:0.74rem;letter-spacing:0.13em;text-transform:uppercase;color:var(--red);font-weight:500}

/* Sitemap-Seite */
.sitemap-section{max-width:var(--maxw);margin:0 auto;padding:3rem 8vw 5rem}
.sitemap-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:3rem}
.sitemap-block h3{font-family:'Playfair Display',serif;font-size:1.15rem;font-weight:700;color:var(--black);margin-bottom:1rem;padding-bottom:0.5rem;border-bottom:2px solid var(--red)}
.sitemap-block ul{list-style:none;padding:0;margin:0}
.sitemap-block li{margin-bottom:0.4rem}
.sitemap-block a{font-size:0.84rem;color:var(--mid);text-decoration:none;transition:color 0.2s;line-height:1.5;display:inline-block;padding:0.15rem 0}
.sitemap-block a:hover{color:var(--red)}

/* ─── Mobile Anpassungen ─── */
@media(max-width:1100px){
  .seo-list{grid-template-columns:repeat(2,1fr)}
  .feature-row{grid-template-columns:repeat(2,1fr)}
  .svc-cards{grid-template-columns:repeat(2,1fr)}
  .sitemap-grid{grid-template-columns:1fr 1fr}
  .content-section{grid-template-columns:1fr;gap:2rem}
  .content-aside{position:static;top:auto}
}
@media(max-width:780px){
  .seo-footer{padding:3rem 6vw 2.5rem}
  .seo-footer-grid{grid-template-columns:1fr;gap:2.4rem}
  .seo-list{grid-template-columns:repeat(2,1fr);gap:0.3rem 1rem}
  .breadcrumbs{padding:calc(var(--nav-h) + 1rem) 6vw 0.4rem;font-size:0.7rem}
  .page-hero{padding:1.4rem 6vw 2.6rem}
  .page-hero h1{font-size:clamp(1.7rem,8vw,2.5rem)}
  .page-hero .page-lead{font-size:0.95rem}
  .content-section{padding:2rem 6vw}
  .feature-row{grid-template-columns:1fr;padding:1rem 6vw 2.2rem;gap:1rem}
  .svc-list-section{padding:2.4rem 6vw}
  .svc-cards{grid-template-columns:1fr;gap:0.9rem}
  .svc-card{min-height:auto;padding:1.4rem 1.3rem}
  .subpage-faq{padding:2.4rem 6vw}
  .subpage-faq summary{font-size:0.95rem}
  .subpage-cta{padding:3.4rem 6vw}
  .sitemap-section{padding:2rem 6vw 3.4rem}
  .sitemap-grid{grid-template-columns:1fr;gap:2rem}
}
@media(max-width:480px){
  .seo-list{grid-template-columns:1fr}
}

/* prevent iOS auto-zoom on tap by ensuring inputs ≥16px (none here, but safe) */
