﻿:root{--cream:#FAF7F2;--warm-white:#FFFDF9;--gold:#C49A2A;--gold-light:#E8D28A;--gold-dark:#8A6B1A;--charcoal:#6B6860;--charcoal-soft:#6B6860;--stone:#6B6860;--stone-light:#A8A59E;--border:#E0D9CC;--border-gold:#C49A2A40;--slate:#3A4A5C;--slate-light:#EEF2F7;}
*{box-sizing:border-box;margin:0;padding:0;}
body{font-family:'REM',sans-serif;background:var(--cream);color:var(--charcoal);line-height:1.6;}
html{scroll-behavior:smooth;}

/* Aktualitäten-Streifen (unter Hauptmenü) */
.news-banner{position:relative;background:linear-gradient(90deg,var(--gold) 0%,var(--gold-light) 50%,var(--gold) 100%);color:var(--charcoal);font-family:'REM',sans-serif;font-size:13px;border-top:1px solid rgba(0,0,0,0.08);border-bottom:1px solid rgba(0,0,0,0.12);box-shadow:0 2px 6px rgba(0,0,0,0.08);}
.news-banner-inner{max-width:1200px;margin:0 auto;padding:8px 48px 8px 40px;display:flex;align-items:center;gap:14px;flex-wrap:wrap;}
.news-banner-tag{display:inline-flex;align-items:center;gap:6px;font-size:10px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:#fff;background:var(--slate);padding:3px 9px;border-radius:2px;flex-shrink:0;}
.news-banner-tag::before{content:'';width:6px;height:6px;border-radius:50%;background:#FF5555;animation:newsBannerPulse 1.6s ease-in-out infinite;}
.news-banner-text{flex:1;min-width:200px;font-weight:600;color:var(--charcoal);}
.news-banner-cta{color:var(--charcoal);text-decoration:none;font-weight:700;white-space:nowrap;border-bottom:1px solid rgba(0,0,0,0.35);padding-bottom:1px;}
.news-banner-cta:hover{border-color:var(--charcoal);}
.news-banner-close{position:absolute;right:10px;top:50%;transform:translateY(-50%);width:26px;height:26px;background:transparent;border:none;color:var(--charcoal);font-size:20px;line-height:1;cursor:pointer;opacity:0.7;}
.news-banner-close:hover{opacity:1;}
@keyframes newsBannerPulse{0%,100%{opacity:1;transform:scale(1);}50%{opacity:0.35;transform:scale(0.7);}}
@media (prefers-reduced-motion: reduce){.news-banner-tag::before{animation:none;}}
@media (max-width:720px){.news-banner-inner{padding:8px 40px 8px 16px;}}

/* Aktuelles-Sektion */
.news-section{padding-top:60px;padding-bottom:60px;}
.news-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:8px;}
.news-card{background:var(--warm-white);border:1px solid var(--border);display:flex;flex-direction:column;transition:transform 0.2s ease,box-shadow 0.2s ease;}
.news-card:hover{transform:translateY(-3px);box-shadow:0 12px 24px rgba(58,74,92,0.10);}
.news-card-img{height:160px;background:var(--slate-light) center/cover no-repeat;border-bottom:1px solid var(--border);}
.news-card-body{padding:20px;display:flex;flex-direction:column;gap:8px;flex:1;}
.news-card-meta{font-size:11px;font-weight:600;letter-spacing:1.5px;text-transform:uppercase;color:var(--gold-dark);}
.news-card-title{font-size:18px;font-weight:700;color:var(--charcoal);line-height:1.35;}
.news-card-text{font-size:14px;color:var(--stone);line-height:1.6;flex:1;}
.news-card-link{font-size:13px;font-weight:600;color:var(--gold-dark);text-decoration:none;align-self:flex-start;border-bottom:1px solid rgba(196,154,42,0.35);padding-bottom:1px;}
.news-card-link:hover{color:var(--gold);}
@media (max-width:900px){.news-grid{grid-template-columns:1fr;}}

/* Scroll-Cue (Chevron unten im Viewport) */
.scroll-cue{position:fixed;left:50%;bottom:22px;transform:translateX(-50%);z-index:50;display:inline-flex;align-items:center;gap:10px;padding:8px 16px;color:#fff;text-decoration:none;font-family:'REM',sans-serif;font-size:11px;font-weight:600;letter-spacing:2px;text-transform:uppercase;background:rgba(26,26,24,0.55);border:1px solid rgba(232,210,138,0.55);border-radius:999px;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);box-shadow:0 6px 18px rgba(0,0,0,0.25);opacity:0.95;transition:opacity 0.8s ease,transform 0.4s ease;animation:scrollCueFade 0.6s ease-out 0.4s both;}
.scroll-cue:hover{opacity:1;border-color:var(--gold-light);}
.scroll-cue-arrow{display:inline-flex;align-items:center;justify-content:center;font-size:14px;line-height:1;color:var(--gold-light);animation:scrollCueBounce 1.8s ease-in-out infinite;}
.scroll-cue.is-hidden{opacity:0 !important;pointer-events:none;transform:translate(-50%,12px);animation:none !important;}
@keyframes scrollCueBounce{0%,100%{transform:translateY(0);}50%{transform:translateY(4px);}}
@keyframes scrollCueFade{from{opacity:0;transform:translate(-50%,16px);}to{opacity:0.95;transform:translate(-50%,0);}}
@media (prefers-reduced-motion: reduce){.scroll-cue-arrow{animation:none;}.scroll-cue{animation:none;}}

/* NAV */
.top-bar{background:var(--slate);color:#E8D28A;font-size:13px;padding:8px 40px;display:flex;justify-content:space-between;align-items:center;gap:16px;flex-wrap:wrap;}
.top-bar a{color:#C49A2A;text-decoration:none;}
.topbar-wa{display:inline-flex;align-items:center;gap:5px;color:#25D366 !important;font-weight:600;transition:color 0.2s;}
.topbar-wa:hover{color:#1ebd58 !important;}
.topbar-wa svg{display:block;}
.top-bar-right{display:inline-flex;align-items:center;gap:18px;flex-wrap:wrap;}
.lang-switcher{position:relative;display:inline-block;}
/* Mobile-only Header-Elemente: am Desktop ausgeblendet */
.lang-mobile{display:none;}
.nav-phone-mobile{display:none;}
.lang-toggle{display:inline-flex;align-items:center;gap:8px;background:rgba(255,255,255,0.04);border:1px solid rgba(232,210,138,0.25);color:#E8D28A;font-family:'REM',sans-serif;font-size:12px;font-weight:600;letter-spacing:0.4px;padding:5px 10px;cursor:pointer;border-radius:4px;transition:background .15s,border-color .15s;}
.lang-toggle:hover,.lang-toggle[aria-expanded="true"]{background:rgba(232,210,138,0.12);border-color:rgba(232,210,138,0.55);}
.lang-caret{font-size:10px;line-height:1;}
.lang-menu{position:absolute;top:calc(100% + 6px);right:0;width:240px;max-height:360px;overflow:hidden;background:#1A1A18;border:1px solid rgba(232,210,138,0.35);border-radius:4px;box-shadow:0 12px 28px rgba(0,0,0,0.4);display:none;z-index:9100;flex-direction:column;}
.lang-menu.open{display:flex;}
.lang-search{margin:6px 6px 4px;padding:7px 9px;background:rgba(255,255,255,0.05);border:1px solid rgba(232,210,138,0.2);border-radius:3px;color:#E8D28A;font-family:'REM',sans-serif;font-size:12px;}
.lang-search::placeholder{color:rgba(232,210,138,0.45);}
.lang-list{list-style:none;margin:0;padding:4px;overflow-y:auto;flex:1;}
.lang-list li{margin:0;padding:0;}
.lang-option{width:100%;display:flex;align-items:center;gap:10px;background:transparent;border:0;color:#E8D28A;font-family:'REM',sans-serif;font-size:13px;font-weight:600;letter-spacing:0.3px;padding:7px 10px;cursor:pointer;border-radius:3px;text-align:left;transition:background .15s,color .15s;}
.lang-option:hover{background:rgba(232,210,138,0.12);}
.lang-option.active{background:#C49A2A;color:var(--charcoal);}
.lang-option .lang-name{flex:1;font-weight:500;font-size:12.5px;}
.lang-flag{width:18px;height:18px;border-radius:50%;display:inline-block;flex-shrink:0;object-fit:cover;background:#222;}
.lang-code{font-size:12px;opacity:0.7;}
.lang-option.active .lang-code{opacity:1;}
/* Google Translate hide chrome */
#google_translate_element{position:fixed !important;left:-9999px !important;top:-9999px !important;width:1px !important;height:1px !important;overflow:hidden !important;opacity:0 !important;pointer-events:none !important;}
/* verhindert, dass ein position:fixed-Icon aus dem off-screen-Container ausbricht */
#google_translate_element *{position:static !important;}
.goog-te-banner-frame,.goog-te-banner-frame.skiptranslate,iframe.goog-te-banner-frame,.goog-te-gadget,.goog-te-gadget-icon,.goog-te-gadget-simple,.goog-te-balloon-frame,#goog-gt-tt,.goog-te-spinner-pos,.goog-logo-link{display:none !important;visibility:hidden !important;}
/* neuere Google-Translate-Widget-Klassen (Icon/Leiste/Feedback) */
.VIpgJd-ZVi9od-ORHb-OEVmcd,.VIpgJd-ZVi9od-l4eHX-hSRGPd,.VIpgJd-ZVi9od-aZ2wEe-wOHMyf,.VIpgJd-ZVi9od-aZ2wEe-OiiCO,.VIpgJd-ZVi9od-xl07Ob-OEVmcd{display:none !important;visibility:hidden !important;}
/* Sicherheitsnetz: fixierte Google-Iframes (Banner/Tooltip) ausblenden */
body > iframe.skiptranslate,iframe.VIpgJd-ZVi9od-ORHb-OEVmcd{display:none !important;}
html,body{top:0 !important;position:static !important;}
.goog-tooltip,.goog-tooltip:hover{display:none !important;}
.goog-text-highlight{background:none !important;box-shadow:none !important;}
.i18n-notice{position:fixed;bottom:18px;right:18px;z-index:9000;max-width:320px;background:#1A1A18;color:#E8D28A;border:1px solid rgba(232,210,138,0.35);padding:12px 36px 12px 14px;font-family:'REM',sans-serif;font-size:12px;line-height:1.5;border-radius:4px;box-shadow:0 8px 24px rgba(0,0,0,0.35);display:none;}
.i18n-notice.visible{display:block;}
.i18n-notice-close{position:absolute;top:6px;right:8px;background:transparent;border:0;color:#E8D28A;font-size:16px;cursor:pointer;line-height:1;}
.main-nav{background:var(--warm-white);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:100;}
.nav-inner{max-width:1200px;margin:0 auto;padding:0 40px;display:grid;grid-template-columns:auto minmax(0,1fr) auto;align-items:center;height:64px;column-gap:10px;}
.logo{font-family:'REM',sans-serif;font-size:18px;font-weight:700;color:var(--charcoal);letter-spacing:1px;display:flex;align-items:center;gap:16px;background:none;border:none;cursor:pointer;padding:0;flex-shrink:0;white-space:nowrap;}
.logo-mark{width:40px;height:40px;display:block;object-fit:contain;flex-shrink:0;filter:contrast(1.45) saturate(1.1) brightness(0.92) drop-shadow(0.35px 0 0 rgba(107,104,96,0.8)) drop-shadow(-0.35px 0 0 rgba(107,104,96,0.8)) drop-shadow(0 0.35px 0 rgba(107,104,96,0.8)) drop-shadow(0 -0.35px 0 rgba(107,104,96,0.8));image-rendering:auto;}
.logo-text{font:inherit;letter-spacing:inherit;color:inherit;}
.nav-links{display:flex;gap:0;justify-content:safe center;min-width:0;overflow-x:auto;overflow-y:hidden;scrollbar-width:none;-ms-overflow-style:none;}
.nav-links::-webkit-scrollbar{display:none;}
.nav-links-track{display:flex;align-items:center;justify-content:center;gap:0;flex-shrink:0;}
.nav-links button{background:none;border:none;font-family:'REM',sans-serif;font-size:var(--nav-fs,16px) !important;font-weight:400;letter-spacing:0;text-transform:none;color:#4b4b48;cursor:pointer;padding:2px 7px;line-height:1;transition:color 0.2s;border-bottom:2px solid transparent;white-space:nowrap;flex-shrink:0;}
.nav-links button:hover,.nav-links button.active{color:var(--charcoal);}
.nav-links button.active{border-bottom-color:var(--gold);}
.nav-dropdown{position:relative;display:flex;align-items:center;}
.nav-dropdown-menu{position:absolute;top:100%;left:0;min-width:210px;background:var(--warm-white);border:1px solid var(--border);box-shadow:0 16px 32px rgba(26,26,24,0.12);padding:8px 0;display:none;z-index:120;}
.nav-dropdown:hover .nav-dropdown-menu,.nav-dropdown:focus-within .nav-dropdown-menu{display:block;}
.nav-dropdown-menu button{display:block;width:100%;text-align:left;border-bottom:none;padding:10px 16px;white-space:nowrap;}
.nav-dropdown-menu button:hover{background:var(--cream);color:var(--charcoal);}
.nav-actions{display:flex;align-items:center;gap:8px;flex-shrink:0;}
.nav-cart-btn{display:inline-flex;align-items:center;gap:6px;background:#fff;border:1px solid var(--border);color:var(--stone);font-family:'REM',sans-serif;font-size:11px !important;font-weight:600;padding:4px 7px;cursor:pointer;line-height:1;white-space:nowrap;}
.nav-cart-btn span{font-size:11px !important;}
.nav-cart-btn:hover,.nav-cart-btn.active{color:var(--charcoal);border-color:rgba(196,154,42,0.45);}
.nav-cart-btn svg{width:14px;height:14px;stroke:currentColor;fill:none;stroke-width:2;}
.nav-cart-count{display:inline-flex;align-items:center;justify-content:center;min-width:16px;height:16px;padding:0 4px;border-radius:999px;background:var(--gold);color:#fff;font-size:10px;font-weight:700;line-height:1;}
.nav-cta{background:var(--gold);color:white;border:none;font-family:'REM',sans-serif;font-size:11px !important;font-weight:600;padding:4px 8px;cursor:pointer;letter-spacing:0.2px;transition:background 0.2s;white-space:nowrap;flex-shrink:0;}
.nav-cta:hover{background:var(--gold-dark);}

/* Page-Level-Scrollen: ganze Seite wird scrollbar, wenn Inhalt breiter ist als das Fenster.
   Kein explizites overflow-x setzen – sonst wird body zum eigenen Scroll-Container und
   der Browser zeigt keine Page-Scrollbar mehr. */
/* Body wächst mit dem breitesten Kind mit, damit Section-Hintergründe die volle Breite einnehmen */
body{min-width:max-content;}
/* Sections sollen ihre Hintergründe über die volle Body-Breite ziehen, auch wenn diese > Viewport ist */
body > section,body > footer,body > nav,body > div,body > header{min-width:100%;}

@media (max-width:1100px){
  .nav-inner{height:60px;padding:0 20px;column-gap:8px;}
  .nav-links button{font-size:var(--nav-fs,16px);padding:2px 7px;}
}
@media (max-width:820px){
  .nav-inner{display:flex;justify-content:space-between;height:44px;padding:0 14px;}
  .nav-cta{font-size:11px;padding:4px 8px;}
}

/* PAGE TABS */
.page-tabs{background:var(--slate);display:none;justify-content:center;flex-wrap:wrap;gap:0;border-bottom:3px solid var(--gold);}
.page-tabs button{background:none;border:none;color:var(--stone-light);font-family:'REM',sans-serif;font-size:11px;font-weight:500;letter-spacing:1px;text-transform:uppercase;padding:11px 18px;cursor:pointer;transition:all 0.2s;}
.page-tabs button:hover{color:#E8D28A;}
.page-tabs button.active{color:var(--gold);background:rgba(196,154,42,0.1);}
.page{display:none;} .page.active{display:block;}

/* HERO SLIDER - pure image carousel, no text on images */
/* Niedrigerer Slider (~70%): feste, begrenzte Höhe + background-size:contain,
   damit das ganze breite Bild sichtbar bleibt. Auf breiten Monitoren entstehen
   dezente seitliche Ränder in Slate (passt zum dunklen Hero darunter). */
.hero-slider{position:relative;width:100%;height:50vh;min-height:340px;max-height:560px;overflow:hidden;background:var(--slate);}
.slide{position:absolute;inset:0;opacity:0;transition:opacity 1.4s ease;background-size:contain;background-repeat:no-repeat;background-position:center center;}
.slide.active{opacity:1;}
/* dots */
.slider-dots{position:absolute;bottom:22px;left:50%;transform:translateX(-50%);display:flex;gap:10px;z-index:10;}
.dot{width:9px;height:9px;border-radius:50%;background:rgba(255,255,255,0.4);border:none;cursor:pointer;transition:all 0.3s;padding:0;}
.dot.active{background:var(--gold);width:30px;border-radius:5px;}
/* arrows */
.slider-arrow{position:absolute;top:50%;transform:translateY(-50%);z-index:10;background:rgba(0,0,0,0.28);border:1px solid rgba(255,255,255,0.18);color:white;width:50px;height:50px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all 0.2s;font-size:22px;line-height:1;}
.slider-arrow:hover{background:var(--gold);border-color:var(--gold);}
.slider-arrow.left{left:20px;}
.slider-arrow.right{right:20px;}
/* prominent badge top-left: communicates "Stuckateur-Meisterbetrieb" at first glance */
.slide-badge{position:absolute;top:22px;left:24px;background:rgba(0,0,0,0.58);border-left:3px solid var(--gold);padding:10px 18px;font-family:'REM',sans-serif;font-size:12px;font-weight:500;color:rgba(255,255,255,0.92);letter-spacing:2px;text-transform:uppercase;z-index:5;backdrop-filter:blur(2px);}
.slide-badge-strong{color:var(--gold-light);font-weight:700;}
@media (max-width:600px){.slide-badge{top:14px;left:14px;font-size:10px;padding:8px 12px;letter-spacing:1.4px;max-width:calc(100% - 28px);}}
/* small caption bottom-right */
.slide-caption{position:absolute;bottom:22px;right:24px;background:rgba(0,0,0,0.52);border-left:3px solid var(--gold);padding:8px 16px;font-size:11px;color:rgba(255,255,255,0.8);letter-spacing:1px;text-transform:uppercase;z-index:5;}
@media (max-width:600px){
  /* Handy: Bild randlos über volle Breite (12:5 = exakt Bildformat -> kein
     Beschnitt, keine Ränder); der Slider ist hier ohnehin niedrig. */
  .hero-slider{height:auto;aspect-ratio:12/5;min-height:0;max-height:none;}
  .slide{background-size:cover;}
  .slider-arrow{width:42px;height:42px;font-size:18px;}
  /* Overlays wuerden das schmale Bild verdecken -> ausblenden. Branding steht
     ohnehin direkt darunter im Hero-Text. */
  .slide-badge,.slide-caption{display:none;}
}
/* headline section BELOW the slider */
.hero-text{background:var(--slate);padding:52px 40px 48px;}
.hero-text-inner{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:1.2fr 0.8fr;gap:80px;align-items:center;}
.hero-tag{display:inline-block;font-size:11px;font-weight:600;letter-spacing:2px;text-transform:uppercase;color:var(--gold);border:1px solid var(--gold);padding:5px 14px;margin-bottom:22px;}
.hero-h1{font-family:'REM',sans-serif;font-size:48px;font-weight:700;color:white;line-height:1.15;margin-bottom:10px;}
.hero-h1 em{color:var(--gold-light);font-style:italic;}
.hero-subline{font-family:'REM',sans-serif;font-size:19px;font-style:italic;font-weight:400;color:var(--gold-light);letter-spacing:0.3px;margin-bottom:20px;opacity:0.92;}
.hero-lead{color:#A8A59E;font-size:17px;line-height:1.7;margin-bottom:30px;}
.hero-btns{display:flex;gap:14px;}
.btn-gold{background:var(--gold);color:white;border:none;font-family:'REM',sans-serif;font-size:14px;font-weight:600;padding:14px 28px;cursor:pointer;letter-spacing:0.5px;transition:background 0.2s;}
.btn-gold:hover{background:var(--gold-dark);}
.btn-outline{background:none;border:1px solid rgba(255,255,255,0.25);color:#A8A59E;font-family:'REM',sans-serif;font-size:14px;font-weight:500;padding:14px 28px;cursor:pointer;transition:all 0.2s;}
.btn-outline:hover{border-color:var(--gold);color:var(--gold);}
/* stats bar */
.hero-stats-bar{background:var(--slate);border-top:1px solid rgba(255,255,255,0.07);display:grid;grid-template-columns:repeat(6,1fr);}
.hero-stat{border-right:1px solid rgba(255,255,255,0.06);padding:20px 14px;text-align:center;}
.hero-stat:last-child{border-right:none;}
.hero-stat .num{font-family:'REM',sans-serif;font-size:26px;font-weight:700;color:var(--gold-light);}
.hero-stat .label{font-size:10px;color:var(--stone-light);text-transform:uppercase;letter-spacing:1px;margin-top:3px;}
.hero-stats-right{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:rgba(255,255,255,0.06);}

/* SECTION */
.section{max-width:1200px;margin:0 auto;padding:80px 40px;}
.section-tag{font-size:11px;font-weight:600;letter-spacing:2px;text-transform:uppercase;color:var(--gold);margin-bottom:12px;}
.section h2{font-family:'REM',sans-serif;font-size:38px;font-weight:700;color:var(--charcoal);margin-bottom:16px;line-height:1.2;}
.section h2 em{font-style:italic;color:var(--gold-dark);}
.section-lead{font-size:17px;color:var(--stone);max-width:600px;line-height:1.7;}
.divider{width:60px;height:2px;background:var(--gold);margin:20px 0 40px;}

/* SERVICES */
.services-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:1px;background:var(--border);margin-top:50px;}
.service-card{background:var(--warm-white);padding:36px 28px;transition:all 0.3s;cursor:pointer;}
.service-card:hover{background:var(--slate);}
.service-card:hover .service-title{color:white;}
.service-card:hover .service-desc{color:var(--stone-light);}
.service-card:hover .service-icon{background:var(--gold);}
.service-card[data-action]{cursor:pointer;}
.service-icon{width:48px;height:48px;background:var(--cream);display:flex;align-items:center;justify-content:center;margin-bottom:20px;}
.service-icon svg{width:24px;height:24px;stroke:var(--gold);fill:none;stroke-width:1.5;}
.service-title{font-family:'REM',sans-serif;font-size:18px;font-weight:600;color:var(--charcoal);margin-bottom:12px;}
.service-desc{font-size:14px;color:var(--stone);line-height:1.6;}

/* PRODUCTS */
.products-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:50px;}
.product-card{background:var(--warm-white);border:1px solid var(--border);overflow:hidden;}
.product-img{height:160px;background:var(--cream);display:flex;align-items:center;justify-content:center;}
.product-info{padding:20px;}
.product-cat{font-size:11px;font-weight:600;letter-spacing:1.5px;text-transform:uppercase;color:var(--gold);margin-bottom:6px;}
.product-name{font-family:'REM',sans-serif;font-size:18px;font-weight:600;color:var(--charcoal);margin-bottom:8px;}
.product-desc{font-size:13px;color:var(--stone);line-height:1.5;margin-bottom:16px;}
.product-price{font-size:20px;font-weight:700;color:var(--charcoal);}
.product-price span{font-size:13px;color:var(--stone);font-weight:400;}
.product-actions{display:flex;gap:10px;margin-top:14px;}
.btn-sm{font-family:'REM',sans-serif;font-size:12px;font-weight:600;padding:8px 16px;cursor:pointer;border:none;letter-spacing:0.5px;transition:background 0.18s,border-color 0.18s,color 0.18s;}
.btn-sm-gold{background:var(--gold);color:white;}
.btn-sm-gold:hover{background:var(--gold-dark);}
.btn-sm-outline{background:none;border:1px solid var(--border);color:var(--stone);}
.btn-sm-outline:hover{border-color:var(--gold);color:var(--gold);background:rgba(196,154,42,0.06);}

/* B2B PARTNER STRIP */
.b2b-strip{background:var(--slate);padding:30px 40px;}
.b2b-inner{max-width:1200px;margin:0 auto;}
.b2b-header{display:grid;grid-template-columns:1fr 1fr;gap:50px;align-items:start;margin-bottom:20px;}
.b2b-header h2{font-family:'REM',sans-serif;font-size:38px;font-weight:700;color:white;line-height:1.2;}
.b2b-header h2 em{color:var(--gold-light);font-style:italic;}
.b2b-header p{color:#B0BCCA;font-size:16px;line-height:1.55;padding-top:0;}
.b2b-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:rgba(255,255,255,0.08);}
.b2b-card{background:rgba(0,0,0,0.2);padding:18px 18px;}
.b2b-card-icon{width:40px;height:40px;border:1px solid rgba(196,154,42,0.4);display:flex;align-items:center;justify-content:center;margin-bottom:10px;}
.b2b-card-icon svg{width:22px;height:22px;stroke:var(--gold);fill:none;stroke-width:1.5;}
.b2b-card h3{font-size:16px;font-weight:600;color:white;margin-bottom:6px;}
.b2b-card p{font-size:14px;color:#9AAAB8;line-height:1.45;}
.b2b-bottom{display:flex;align-items:flex-start;justify-content:space-between;margin-top:14px;padding-top:12px;border-top:1px solid rgba(255,255,255,0.1);}
.b2b-logos{display:flex;gap:16px;align-items:center;}
.b2b-logo-pill{border:1px solid rgba(255,255,255,0.15);color:#9AAAB8;font-size:12px;font-weight:600;letter-spacing:0.5px;padding:5px 12px;text-transform:uppercase;}
.b2b-cta-text{color:#B0BCCA;font-size:14px;max-width:300px;text-align:right;}

@media (max-width:900px){
  .b2b-bottom{align-items:flex-start;}
}

/* Nav mit dezenter Stuckelemente-Lasur als Hintergrund (nur leicht erkennbar) */
.main-nav{overflow:hidden;}
.main-nav::before{content:'';position:absolute;inset:0;background:url('../assets/images/home/stuckelemente-strecke.webp') center / auto 100% repeat-x;opacity:0.30;pointer-events:none;z-index:0;filter:invert(1) brightness(0.85) contrast(1.05);}
.main-nav .nav-inner{position:relative;z-index:1;}
@media (max-width:600px){.main-nav::before{opacity:0.22;}}

/* TRUST BAR */
.trust-bar{background:var(--warm-white);border-top:1px solid var(--border);border-bottom:1px solid var(--border);padding:20px 40px;}
.trust-inner{max-width:1200px;margin:0 auto;display:flex;justify-content:space-between;align-items:center;}
.trust-item{display:flex;align-items:center;gap:10px;font-size:13px;color:var(--stone);}
.trust-item svg{width:20px;height:20px;stroke:var(--gold);fill:none;stroke-width:2;}

/* QUOTE BANNER */
.quote-banner{background:#FAF0D7;border-top:1px solid #E8D28A;border-bottom:1px solid #E8D28A;padding:48px 40px;text-align:center;}
.quote-banner blockquote{font-family:'REM',sans-serif;font-size:26px;font-style:italic;color:var(--charcoal);max-width:700px;margin:0 auto;line-height:1.5;}
.quote-banner cite{display:block;font-style:normal;font-family:'REM',sans-serif;font-size:13px;color:var(--gold-dark);margin-top:16px;letter-spacing:1px;text-transform:uppercase;}

/* CONTACT STRIP */
.contact-strip{background:var(--slate);padding:30px 40px 0;text-align:center;}
.contact-strip-inner{max-width:800px;margin:0 auto;}
.contact-strip-inner-md{max-width:760px;}
.contact-strip-inner-sm{max-width:700px;}
.contact-strip-tag{display:flex;justify-content:center;margin-bottom:10px;}
.contact-strip-title{font-family:'REM',sans-serif;font-size:36px;font-weight:700;color:white;margin-bottom:8px;}
.contact-strip-title-md{font-size:34px;}
.contact-strip-title-sm{font-size:32px;}
.contact-strip-copy{color:#A8A59E;font-size:16px;margin-bottom:18px;}
.contact-strip-copy-sm{font-size:15px;}
.contact-strip-actions{display:flex;justify-content:center;gap:14px;flex-wrap:wrap;}
.contact-info{display:flex;justify-content:center;gap:50px;margin-top:14px;}

/* Reduce the visual gap between the contact strip and the following footer. */
.contact-strip + footer{padding-top:2px;}
.contact-item .label{font-size:11px;color:var(--stone-light);text-transform:uppercase;letter-spacing:1px;margin-bottom:6px;}
.contact-item .value{font-size:17px;color:var(--gold-light);font-weight:500;}

.btn-lg{font-size:15px;padding:14px 32px;}
.btn-callout{padding:16px 40px;font-size:15px;}
.btn-link-inline{display:inline-flex;align-items:center;text-decoration:none;}
.btn-outline-neutral{color:var(--stone);border-color:var(--border);}
.btn-outline-neutral:hover{border-color:var(--gold);color:var(--gold);background:rgba(196,154,42,0.06);}
.btn-disabled{opacity:0.65;cursor:not-allowed;}

.page-footer-simple .footer-bottom{padding:24px 40px;max-width:100%;}

/* FOOTER */
footer{background:var(--slate);padding:20px 40px 14px;}
.footer-inner{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:30px;margin-bottom:18px;}
.footer-logo{font-family:'REM',sans-serif;font-size:20px;color:white;font-weight:700;margin-bottom:14px;}
.footer-desc{font-size:14px;color:var(--stone);line-height:1.7;}
.footer-col h4{font-size:11px;font-weight:600;letter-spacing:1.5px;text-transform:uppercase;color:var(--gold);margin-bottom:10px;}
.footer-col ul{list-style:none;}
.footer-col ul li{margin-bottom:5px;}
.footer-col ul li a{font-size:14px;color:var(--stone);text-decoration:none;cursor:pointer;}
.footer-col ul li a:hover{color:var(--gold-light);}
.footer-bottom{border-top:1px solid #2A2A28;padding-top:10px;max-width:1200px;margin:0 auto;display:flex;justify-content:space-between;align-items:center;}
.footer-copy{font-size:13px;color:var(--stone);}
.footer-badges{display:flex;gap:8px;}
.badge{font-size:11px;color:var(--stone);border:1px solid #2A2A28;padding:3px 10px;}
.new-tag{background:var(--gold);color:white;font-size:9px;font-weight:700;letter-spacing:1px;padding:2px 6px;text-transform:uppercase;vertical-align:middle;margin-left:6px;}

/* REFERENZEN & BEWERTUNGEN */
.ref-hero{background:var(--slate);padding:72px 40px;position:relative;overflow:hidden;}
.ref-hero-compact{padding:64px 40px;}
.ref-hero-pattern{display:none;}
.ref-hero-inner{position:relative;max-width:1200px;margin:0 auto;display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center;}
.ref-hero-inner-single{grid-template-columns:1fr;gap:24px;}
.ref-hero h1{font-family:'REM',sans-serif;font-size:48px;font-weight:700;color:white;line-height:1.2;margin-bottom:16px;}
.ref-hero h1 em{color:var(--gold-light);font-style:italic;}
.ref-hero p{color:#A8A59E;font-size:16px;line-height:1.7;}
.ref-hero-copy{color:#A8A59E;font-size:16px;line-height:1.8;margin-top:16px;max-width:860px;}
.ref-hero-copy-wide{max-width:900px;}
.ref-hero-stats{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;background:rgba(255,255,255,0.08);}
.ref-hero-stat{background:rgba(0,0,0,0.25);padding:28px 20px;text-align:center;}
.ref-hero-stat .num{font-family:'REM',sans-serif;font-size:42px;font-weight:700;color:var(--gold-light);}
.ref-hero-stat .lbl{font-size:12px;color:var(--stone-light);text-transform:uppercase;letter-spacing:1px;margin-top:6px;}

.section-tight-bottom{padding-bottom:0;}
.section-shell{background:var(--warm-white);border:1px solid var(--border);}
.section-shell-divider-top{border-top:1px solid var(--border);}
.section-shell-divider-bottom{border-bottom:1px solid var(--border);}
.section-shell-cream{background:var(--cream);}
.section-shell-padded{padding:26px;}
.section-shell-padded-lg{padding:30px;}
.section-shell-padded-xl{padding:38px;}
.section-grid-two{display:grid;grid-template-columns:1fr 1fr;gap:28px;}
.section-grid-two-wide{display:grid;grid-template-columns:1fr 1fr;gap:40px;margin-top:20px;}
.section-grid-three{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:10px;}
.stack-sm{display:grid;gap:10px;}
.stack-md{display:grid;gap:12px;}
.stack-lg{display:grid;gap:14px;}
.content-copy{font-size:16px;color:var(--stone);line-height:1.8;}
.content-copy + .content-copy{margin-top:16px;}
.info-title{font-size:30px;line-height:1.2;}
.mini-kicker{font-size:11px;font-weight:600;letter-spacing:1.4px;text-transform:uppercase;color:var(--gold);margin-bottom:10px;}
.list-plain{list-style:none;}
.list-plain-spacious{list-style:none;font-size:14px;color:var(--stone);line-height:2;}
.note-banner{border:1px solid var(--border-gold);background:#FFF9ED;padding:14px 16px;margin-bottom:24px;font-size:13px;color:var(--gold-dark);line-height:1.7;display:flex;justify-content:space-between;gap:16px;align-items:center;flex-wrap:wrap;}

.form-stack{display:grid;gap:12px;}
.form-control,.form-textarea,.mock-field{border:1px solid var(--border);padding:12px 14px;font-family:'REM',sans-serif;font-size:14px;}
.form-textarea{min-height:120px;resize:vertical;}
.mock-field{background:#F5F1E9;color:#8D887E;}
.form-note{font-size:12px;color:var(--stone-light);line-height:1.5;}
.form-note-relaxed{line-height:1.6;}
.form-status{font-size:12px;color:#8A6D3B;line-height:1.5;}
.form-success{display:none;font-size:13px;color:#2F6B1A;background:#EAF3DE;border:1px solid #C8DDB8;padding:10px 12px;}
.form-consent{font-size:13px;color:var(--stone);display:flex;align-items:flex-start;gap:8px;}
.form-consent input{margin-top:3px;}

.action-row{display:flex;gap:12px;flex-wrap:wrap;margin-top:22px;}
.hero-actions{display:flex;gap:14px;margin-top:32px;flex-wrap:wrap;}

.map-box{margin-top:20px;}
.map-label{font-size:12px;font-weight:600;letter-spacing:1px;text-transform:uppercase;color:var(--stone);margin-bottom:8px;}
.map-frame{position:relative;border:1px solid var(--border);overflow:hidden;background:#EFE9DE;}
.map-frame iframe{width:100%;height:220px;border:0;}
.map-overlay-btn{position:absolute;inset:0;background:rgba(26,26,24,0.22);border:none;cursor:pointer;color:white;font-family:'REM',sans-serif;font-size:14px;font-weight:600;letter-spacing:0.5px;}

.metric-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;}
.metric-card{background:var(--cream);border:1px solid var(--border);padding:20px;}
.metric-value{font-size:28px;font-family:'REM',sans-serif;font-weight:700;color:var(--gold-dark);}
.metric-label{font-size:13px;color:var(--stone);margin-top:6px;line-height:1.5;}

.dark-panel{background:var(--slate);padding:60px 40px;}
.dark-panel-inner{max-width:1200px;margin:0 auto;}
.dark-panel-title{font-family:'REM',sans-serif;font-size:34px;color:white;margin-bottom:8px;}
.dark-panel-title em{color:var(--gold-light);font-style:italic;}
.dark-panel-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:rgba(255,255,255,0.08);margin-top:10px;}
.dark-panel-card{background:rgba(0,0,0,0.2);padding:28px 22px;}

/* ABOUT */
.about-stage{position:relative;}
.about-stage-tight{padding-top:0;}
.about-pillars{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:24px;}
.about-pillar{background:linear-gradient(180deg,#FFFDF9 0%,#F8F3EA 100%);border:1px solid var(--border);padding:30px;box-shadow:0 18px 36px rgba(26,26,24,0.05);position:relative;overflow:hidden;}
.about-pillar::before{content:'';position:absolute;top:0;left:0;width:100%;height:4px;background:linear-gradient(90deg,var(--gold) 0%,rgba(196,154,42,0.15) 100%);}
.about-pillar .divider{margin-bottom:28px;}
.about-pillar-text{font-size:15px;color:var(--stone);line-height:1.85;}

.about-profile-grid{display:grid;grid-template-columns:minmax(0,1.08fr) minmax(320px,0.92fr);gap:28px;align-items:stretch;}
.about-profile-card{background:var(--warm-white);border:1px solid var(--border);padding:38px;box-shadow:0 20px 42px rgba(26,26,24,0.05);position:relative;}
.about-profile-card::after{content:'';position:absolute;right:32px;top:32px;width:86px;height:86px;border:1px solid rgba(196,154,42,0.22);border-radius:50%;}
.about-profile-text{font-size:15px;color:var(--stone);line-height:1.9;margin-bottom:16px;max-width:62ch;position:relative;z-index:1;}
.about-profile-text-last{margin-bottom:0;}

.about-summary-card{background:linear-gradient(180deg,#F7F0E2 0%,#EEE3CF 100%);border:1px solid rgba(196,154,42,0.26);padding:34px 32px;box-shadow:0 20px 42px rgba(138,107,26,0.09);}
.about-summary-list{display:grid;gap:14px;}
.about-summary-item{padding:16px 0;border-bottom:1px solid rgba(107,104,96,0.14);}
.about-summary-item:last-child{border-bottom:none;padding-bottom:0;}
.about-summary-label{font-size:11px;font-weight:600;letter-spacing:1.2px;text-transform:uppercase;color:var(--stone-light);margin-bottom:8px;}
.about-summary-value{font-family:'REM',sans-serif;font-size:26px;font-weight:700;line-height:1.25;color:var(--charcoal);max-width:16ch;}

.about-history-shell{background:linear-gradient(180deg,#FCFAF5 0%,#F3EBDD 100%);border:1px solid var(--border);padding:38px;display:grid;grid-template-columns:minmax(280px,0.8fr) minmax(0,1.2fr);gap:32px;box-shadow:0 20px 42px rgba(26,26,24,0.05);}
.about-history-lead{font-size:16px;color:var(--stone);line-height:1.85;max-width:34ch;}
.about-history-list{display:grid;gap:18px;position:relative;}
.about-history-list::before{content:'';position:absolute;left:14px;top:6px;bottom:6px;width:1px;background:rgba(196,154,42,0.3);}
.about-history-item{position:relative;background:rgba(255,253,249,0.84);border:1px solid rgba(224,217,204,0.9);padding:20px 22px 20px 36px;}
.about-history-item::before{content:'';position:absolute;left:9px;top:24px;width:10px;height:10px;border-radius:50%;background:var(--gold);box-shadow:0 0 0 6px rgba(196,154,42,0.14);}
.about-history-kicker{font-size:11px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:var(--gold-dark);margin-bottom:10px;}
.about-history-text{font-size:15px;color:var(--stone);line-height:1.85;}

/* WHOLESALE */
.wholesale-hero-inner{grid-template-columns:minmax(0,1.05fr) minmax(320px,0.95fr);}
.wholesale-stage{position:relative;}
.wholesale-stage-tight{padding-top:0;}
.service-subnav-section{padding-top:28px;padding-bottom:12px;}
.service-subnav-wrap{background:var(--warm-white);border:1px solid var(--border);padding:24px;box-shadow:0 16px 32px rgba(26,26,24,0.04);}
.service-subnav-grid{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:14px;}
.service-subnav-item{background:linear-gradient(180deg,#FFFDF9 0%,#F7F1E7 100%);border:1px solid var(--border);padding:18px;text-align:left;cursor:pointer;font-family:'REM',sans-serif;transition:all 0.2s;color:var(--charcoal);}
.service-subnav-item:hover{border-color:rgba(196,154,42,0.45);transform:translateY(-1px);}
.service-subnav-item.active{background:var(--slate);border-color:var(--slate);}
.service-subnav-item.active .service-subnav-label{color:white;}
.service-subnav-item.active .service-subnav-meta{color:var(--gold-light);}
.service-subnav-label{display:block;font-size:15px;font-weight:700;line-height:1.35;margin-bottom:8px;color:var(--charcoal);}
.service-subnav-meta{display:block;font-size:12px;line-height:1.6;color:var(--stone);}
.wholesale-grid{display:grid;grid-template-columns:minmax(0,1.08fr) minmax(320px,0.92fr);gap:28px;align-items:stretch;}
.wholesale-copy-card{background:var(--warm-white);border:1px solid var(--border);padding:38px;box-shadow:0 20px 42px rgba(26,26,24,0.05);}
.wholesale-copy{font-size:15px;color:var(--stone);line-height:1.9;margin-bottom:16px;max-width:64ch;}
.wholesale-copy-last{margin-bottom:0;}
.wholesale-actions{display:flex;gap:14px;flex-wrap:wrap;margin-top:28px;}
.wholesale-outline{color:var(--stone);border-color:var(--border);}

.wholesale-facts-card{background:linear-gradient(180deg,#F7F0E2 0%,#EEE3CF 100%);border:1px solid rgba(196,154,42,0.26);padding:34px 32px;box-shadow:0 20px 42px rgba(138,107,26,0.09);}
.wholesale-facts{display:grid;gap:14px;}
.wholesale-fact-item{padding:16px 0;border-bottom:1px solid rgba(107,104,96,0.14);}
.wholesale-fact-item:last-child{border-bottom:none;padding-bottom:0;}
.wholesale-fact-label{font-size:11px;font-weight:600;letter-spacing:1.2px;text-transform:uppercase;color:var(--stone-light);margin-bottom:8px;}
.wholesale-fact-value{font-family:'REM',sans-serif;font-size:24px;font-weight:700;line-height:1.3;color:var(--charcoal);max-width:16ch;}
.wholesale-facts-title{font-family:'REM',sans-serif;font-size:22px;font-weight:700;color:var(--charcoal);margin:8px 0 18px;line-height:1.3;}
.wholesale-fact-list{list-style:none;padding:0;margin:0 0 18px;}
.wholesale-fact-list li{padding:14px 0;border-bottom:1px solid rgba(107,104,96,0.14);display:flex;flex-direction:column;gap:4px;}
.wholesale-fact-list li:last-child{border-bottom:none;padding-bottom:0;}
.wholesale-fact-list strong{font-family:'REM',sans-serif;font-size:15px;font-weight:600;color:var(--charcoal);letter-spacing:0.2px;}
.wholesale-fact-list span{font-size:13px;color:var(--stone);line-height:1.55;}
.wholesale-fact-note{font-size:13px;color:var(--stone);line-height:1.6;margin-top:18px;padding-top:14px;border-top:1px solid rgba(107,104,96,0.14);}
/* Komplettsanierungs-Banner: dunkler USP-Streifen ueber die volle Breite */
.komplett-banner{background:var(--slate);padding:44px 24px;}
.komplett-banner-inner{max-width:1200px;margin:0 auto;display:grid;grid-template-columns:0.95fr 1.3fr;gap:48px;align-items:start;}
.komplett-banner-tag{display:inline-block;font-size:11px;font-weight:600;letter-spacing:2px;text-transform:uppercase;color:var(--gold-light);border:1px solid var(--gold-light);padding:5px 14px;margin-bottom:18px;}
.komplett-banner-title{font-family:'REM',sans-serif;font-size:34px;font-weight:700;color:#fff;line-height:1.2;margin:0 0 14px;}
.komplett-banner-title em{color:var(--gold-light);font-style:italic;}
.komplett-banner-copy{color:#C8C0B0;font-size:15px;line-height:1.7;margin:0;}
.komplett-banner-list{list-style:none;padding:0;margin:0;display:grid;grid-template-columns:1fr 1fr;gap:14px 24px;}
.komplett-banner-list li{padding:14px 18px;border-left:2px solid var(--gold);background:rgba(255,255,255,0.04);}
.komplett-banner-list strong{display:block;font-family:'REM',sans-serif;font-size:15px;font-weight:600;color:#fff;letter-spacing:0.3px;margin-bottom:4px;}
.komplett-banner-list span{font-size:13px;color:#A8A59E;line-height:1.55;}

/* Hub-Auswahlkarten (Stuckelemente -> Innenstuck/Fassadenstuck) */
.hub-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px;max-width:1100px;margin:0 auto;}
.hub-card{display:flex;flex-direction:column;gap:10px;background:var(--warm-white);border:1px solid var(--border);padding:36px 32px;text-align:left;cursor:pointer;font:inherit;color:inherit;transition:border-color 0.2s,transform 0.2s,box-shadow 0.2s,background 0.2s;}
.hub-card:hover{border-color:var(--gold);background:#FFF9ED;transform:translateY(-2px);box-shadow:0 12px 28px rgba(58,58,40,0.08);}
.hub-card:focus-visible{outline:2px solid var(--gold);outline-offset:3px;}
.hub-card-tag{font-size:11px;font-weight:600;letter-spacing:1.5px;text-transform:uppercase;color:var(--gold);}
.hub-card-title{font-family:'REM',sans-serif;font-size:22px;font-weight:700;color:var(--charcoal);line-height:1.3;margin-bottom:4px;}
.hub-card-desc{font-size:14px;color:var(--stone);line-height:1.7;flex:1;}
.hub-card-cta{margin-top:14px;font-size:13px;font-weight:600;letter-spacing:0.5px;color:var(--gold);display:inline-flex;align-items:center;gap:6px;}
.hub-card:hover .hub-card-cta{color:var(--gold-dark);}
@media (max-width:720px){.hub-grid{grid-template-columns:1fr;}}

/* Ratgeber: Stilrichtungen-Hub */
.ratgeber-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:40px;max-width:1200px;margin-left:auto;margin-right:auto;}
.ratgeber-card{display:flex;flex-direction:column;gap:8px;background:var(--warm-white);border:1px solid var(--border);padding:28px 26px;text-align:left;cursor:pointer;font:inherit;color:inherit;transition:border-color 0.2s,transform 0.2s,box-shadow 0.2s,background 0.2s;}
.ratgeber-card:hover{border-color:var(--gold);background:#FFF9ED;transform:translateY(-2px);box-shadow:0 12px 28px rgba(58,58,40,0.08);}
.ratgeber-card:focus-visible{outline:2px solid var(--gold);outline-offset:3px;}
.ratgeber-card-coming{cursor:default;opacity:0.78;background:var(--cream);}
.ratgeber-card-coming:hover{border-color:var(--border);background:var(--cream);transform:none;box-shadow:none;}
.ratgeber-card-period{font-size:11px;font-weight:600;letter-spacing:1.5px;text-transform:uppercase;color:var(--gold);}
.ratgeber-card-title{font-family:'REM',sans-serif;font-size:24px;font-weight:700;color:var(--charcoal);line-height:1.2;margin:2px 0 6px;}
.ratgeber-card-desc{font-size:14px;color:var(--stone);line-height:1.7;flex:1;}
.ratgeber-card-cta{margin-top:14px;font-size:13px;font-weight:600;letter-spacing:0.5px;color:var(--gold);display:inline-flex;align-items:center;gap:6px;}
.ratgeber-card:hover .ratgeber-card-cta{color:var(--gold-dark);}
@media (max-width:1100px){.ratgeber-grid{grid-template-columns:1fr 1fr;}}
@media (max-width:720px){.ratgeber-grid{grid-template-columns:1fr;}}

/* Ratgeber: Artikel-Layout (Stilseiten) */
.ratgeber-article{max-width:780px;margin:0 auto;}
.ratgeber-article h2{font-family:'REM',sans-serif;font-size:26px;font-weight:700;color:var(--charcoal);margin:36px 0 14px;line-height:1.3;}
.ratgeber-article h2:first-of-type{margin-top:14px;}
.ratgeber-article h3{font-family:'REM',sans-serif;font-size:20px;font-weight:600;color:var(--charcoal);margin:24px 0 10px;}
.ratgeber-article p{font-size:16px;color:var(--stone);line-height:1.85;margin-bottom:18px;}
.ratgeber-lead{font-size:18px !important;line-height:1.8 !important;color:var(--charcoal) !important;border-left:3px solid var(--gold);padding-left:18px;margin-bottom:28px !important;}
.ratgeber-list{list-style:none;padding:0;margin:0 0 22px;display:grid;gap:8px;}
.ratgeber-list li{position:relative;padding-left:24px;font-size:15px;color:var(--stone);line-height:1.7;}
.ratgeber-list li::before{content:'';position:absolute;left:0;top:13px;width:8px;height:1px;background:var(--gold);}
.ratgeber-height-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin:14px 0 26px;}
.ratgeber-height-grid > div{background:var(--warm-white);border:1px solid var(--border);border-left:3px solid var(--gold);padding:16px 18px;display:flex;flex-direction:column;gap:4px;}
.ratgeber-height-grid strong{font-family:'REM',sans-serif;font-size:15px;font-weight:600;color:var(--charcoal);}
.ratgeber-height-grid span{font-size:13px;color:var(--stone);line-height:1.55;}
@media (max-width:720px){.ratgeber-height-grid{grid-template-columns:1fr;}}

/* Ratgeber: CTA-Box im Artikel */
.ratgeber-cta{background:var(--slate);color:#fff;padding:32px 28px;margin:40px 0;text-align:center;}
.ratgeber-cta h3{font-family:'REM',sans-serif;font-size:22px;font-weight:700;color:#fff;margin-bottom:8px;line-height:1.3;}
.ratgeber-cta p{font-size:15px;color:#C8C0B0;line-height:1.7;margin-bottom:18px;max-width:520px;margin-left:auto;margin-right:auto;}
.ratgeber-cta-actions{display:inline-flex;flex-wrap:wrap;gap:10px;justify-content:center;}

/* Ratgeber: FAQ-Block */
.ratgeber-faq{margin:40px 0;}
.ratgeber-faq h2{font-family:'REM',sans-serif;font-size:24px;font-weight:700;color:var(--charcoal);margin-bottom:14px;}
.ratgeber-faq details{background:var(--warm-white);border:1px solid var(--border);border-radius:0;padding:14px 18px;margin-bottom:10px;}
.ratgeber-faq details[open]{border-color:var(--gold);}
.ratgeber-faq summary{font-family:'REM',sans-serif;font-size:15px;font-weight:600;color:var(--charcoal);cursor:pointer;list-style:none;display:flex;align-items:center;justify-content:space-between;gap:14px;}
.ratgeber-faq summary::-webkit-details-marker{display:none;}
.ratgeber-faq summary::after{content:'+';font-size:22px;font-weight:300;color:var(--gold);line-height:1;transition:transform 0.2s;}
.ratgeber-faq details[open] summary::after{content:'−';}
.ratgeber-faq details p{margin:12px 0 0;font-size:14px;color:var(--stone);line-height:1.75;}

/* Ratgeber: verwandte Stile */
.ratgeber-related{margin:40px 0 24px;padding-top:32px;border-top:1px solid var(--border);}
.ratgeber-related h3{font-family:'REM',sans-serif;font-size:20px;font-weight:700;color:var(--charcoal);margin:4px 0 18px;}
.ratgeber-related-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;}
.ratgeber-related-card{display:flex;flex-direction:column;gap:6px;background:var(--warm-white);border:1px solid var(--border);padding:18px 20px;text-align:left;cursor:pointer;font:inherit;color:inherit;transition:border-color 0.2s,background 0.2s;}
.ratgeber-related-card:hover{border-color:var(--gold);background:#FFF9ED;}
.ratgeber-related-card .ratgeber-card-title{font-size:18px;margin:0;}
.ratgeber-related-card .ratgeber-card-desc{font-size:13px;}
@media (max-width:720px){.ratgeber-related-grid{grid-template-columns:1fr;}}

/* Ratgeber-Hinweis-Streifen (im Shop-Hub und auf Innenstuck-Seite) */
.ratgeber-hint{display:grid;grid-template-columns:auto 1fr auto;gap:20px;align-items:center;width:100%;max-width:1100px;margin:24px auto 0;background:#FFF9ED;border:1px solid var(--border-gold);padding:20px 24px;text-align:left;cursor:pointer;font:inherit;color:inherit;transition:border-color 0.2s,background 0.2s,transform 0.2s;}
.ratgeber-hint:hover{border-color:var(--gold);background:#FFF5E0;transform:translateY(-1px);}
.ratgeber-hint:focus-visible{outline:2px solid var(--gold);outline-offset:3px;}
.ratgeber-hint-icon{width:44px;height:44px;border-radius:50%;background:var(--gold);color:#fff;display:flex;align-items:center;justify-content:center;flex-shrink:0;}
.ratgeber-hint-icon svg{width:24px;height:24px;}
.ratgeber-hint-body{display:flex;flex-direction:column;gap:4px;}
.ratgeber-hint-tag{font-size:11px;font-weight:600;letter-spacing:1.5px;text-transform:uppercase;color:var(--gold);}
.ratgeber-hint-title{font-family:'REM',sans-serif;font-size:17px;font-weight:600;color:var(--charcoal);line-height:1.3;}
.ratgeber-hint-desc{font-size:13.5px;color:var(--stone);line-height:1.65;}
.ratgeber-hint-cta{flex-shrink:0;font-size:13px;font-weight:600;letter-spacing:0.5px;color:var(--gold);display:inline-flex;align-items:center;gap:6px;white-space:nowrap;}
.ratgeber-hint:hover .ratgeber-hint-cta{color:var(--gold-dark);}
.ratgeber-hint-slim{max-width:none;margin:0 0 24px;}
@media (max-width:720px){
  .ratgeber-hint{grid-template-columns:auto 1fr;gap:14px;padding:16px 18px;}
  .ratgeber-hint-cta{grid-column:1 / -1;justify-content:flex-end;margin-top:4px;}
  .ratgeber-hint-icon{width:36px;height:36px;}
  .ratgeber-hint-icon svg{width:20px;height:20px;}
  .ratgeber-hint-title{font-size:15px;}
}

/* Mobile: Lange Texte sollen die volle nutzbare Breite einnehmen
   (Sektion-Padding 14px liefert minimalen Atem-Raum am Rand) */
@media (max-width:720px){
  .section-lead,
  .wholesale-copy,
  .about-history-text,
  .ref-hero-copy,
  .contact-strip-copy,
  .hub-card-desc,
  .catalog-pdf-desc,
  .baus-desc{ max-width:none; }
  /* Inline-max-widths in Beschreibungs-<p>-Tags ueberschreiben (Hero/Rechtliches/Partner-Bereich) */
  .baustoffe-hero p[style*="max-width"],
  .ref-hero p[style*="max-width"],
  .ref-hero-inner p[style*="max-width"]{ max-width:none !important; }
  /* Footer-Spalten auf Mobile mittig zentriert untereinander */
  footer .footer-inner{ text-align:center; }
  footer .footer-col h4{ text-align:center; }
  footer .footer-col ul{ padding:0; }
  footer .footer-col ul li{ text-align:center; }
  footer .footer-desc{ text-align:center; }
  footer .footer-logo{ text-align:center; }
}

/* PDF-Katalog-Card (ueber dem Innenstuck-Filter) */
.catalog-pdf-card{display:grid;grid-template-columns:220px 1fr;gap:24px;align-items:stretch;background:var(--warm-white);border:1px solid var(--border);padding:20px;margin-bottom:28px;}
.catalog-pdf-cover{display:block;border:1px solid var(--border);overflow:hidden;background:#F2EEE3;transition:border-color 0.2s,transform 0.2s,box-shadow 0.2s;align-self:center;}
.catalog-pdf-cover:hover{border-color:var(--gold);transform:scale(1.02);box-shadow:0 8px 20px rgba(58,58,40,0.12);}
.catalog-pdf-cover img{display:block;width:100%;height:auto;aspect-ratio:1/1.414;object-fit:cover;}
.catalog-pdf-body{display:flex;flex-direction:column;gap:8px;justify-content:center;}
.catalog-pdf-tag{font-size:11px;font-weight:600;letter-spacing:1.5px;text-transform:uppercase;color:var(--gold);}
.catalog-pdf-title{font-family:'REM',sans-serif;font-size:22px;font-weight:700;color:var(--charcoal);line-height:1.3;margin:0;}
.catalog-pdf-desc{font-size:14px;color:var(--stone);line-height:1.7;margin:6px 0 14px;}
.catalog-pdf-actions{display:flex;gap:12px;flex-wrap:wrap;}
@media (max-width:720px){
  .catalog-pdf-card{grid-template-columns:1fr;gap:18px;}
  .catalog-pdf-cover{max-width:200px;margin:0 auto;}
}
@media (max-width:900px){
  .komplett-banner{padding:32px 18px;}
  .komplett-banner-inner{grid-template-columns:1fr;gap:24px;}
  .komplett-banner-list{grid-template-columns:1fr;}
  .komplett-banner-title{font-size:26px;}
}

.service-thumbs-card .section-tag{margin-bottom:16px;}
.service-thumbs-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;}
.service-thumb{border:1px solid var(--border);background:var(--warm-white);padding:6px;display:block;cursor:pointer;transition:border-color 0.2s,transform 0.2s;width:100%;text-align:left;font:inherit;color:inherit;}
.service-thumb:hover{border-color:rgba(196,154,42,0.7);transform:translateY(-1px);}
.service-thumb:focus-visible{outline:2px solid var(--gold);outline-offset:2px;}
.service-thumb img{cursor:pointer;}
.service-thumb img{width:100%;aspect-ratio:4 / 3;object-fit:cover;display:block;margin-bottom:6px;}
.service-thumb-label{font-size:13px;font-weight:600;color:var(--charcoal);line-height:1.4;text-align:center;}
.service-thumbs-hint{margin:14px 0 0;font-size:12px;color:var(--stone);line-height:1.5;text-align:center;}
body.lightbox-open{overflow:hidden;}

.image-lightbox{position:fixed;inset:0;display:none;z-index:1200;padding:28px;}
.image-lightbox.open{display:grid;place-items:center;}
.image-lightbox-backdrop{position:absolute;inset:0;background:rgba(26,33,42,0.72);backdrop-filter:blur(2px);}
.image-lightbox-dialog{position:relative;z-index:1;width:min(1280px,96vw);max-height:96vh;background:var(--slate);display:grid;grid-template-rows:1fr auto;gap:0;box-shadow:0 30px 70px rgba(0,0,0,0.45);animation:lightboxPopIn 0.2s ease-out;}
.image-lightbox-stage{position:relative;background:var(--slate);display:flex;align-items:center;justify-content:center;min-height:0;}
.image-lightbox-stage img{width:100%;max-height:88vh;object-fit:contain;background:var(--slate);display:block;}
.image-lightbox-half{position:absolute;top:0;bottom:0;width:50%;border:0;background:transparent;padding:0;margin:0;cursor:default;z-index:2;outline:none;}
.image-lightbox-half-prev{left:0;}
.image-lightbox-half-next{right:0;}
.image-lightbox:not(.lightbox-multi) .image-lightbox-half{pointer-events:none;}
.image-lightbox-nav{position:absolute;top:50%;transform:translateY(-50%);width:48px;height:64px;border:none;background:rgba(26,33,42,0.62);color:#fff;font-size:38px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;z-index:4;transition:background 0.15s;}
.image-lightbox-nav:hover{background:rgba(26,33,42,0.88);}
.image-lightbox-nav-prev{left:8px;}
.image-lightbox-nav-next{right:8px;}
.image-lightbox-nav[hidden]{display:none;}
.image-lightbox-footer{display:flex;justify-content:space-between;align-items:center;gap:16px;background:#2C3849;padding:12px 16px;}
.image-lightbox-caption{color:#E8E4DA;font-size:14px;line-height:1.6;flex:1;min-width:0;}
.image-lightbox-counter{color:#A8A59E;font-size:13px;font-variant-numeric:tabular-nums;white-space:nowrap;}
.image-lightbox-close{position:absolute;top:8px;right:8px;width:38px;height:38px;border:none;background:rgba(26,33,42,0.72);color:#fff;font-size:26px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;}
body.lightbox-open{overflow:hidden;}

@keyframes lightboxPopIn{
  from{opacity:0;transform:scale(0.96);}
  to{opacity:1;transform:scale(1);}
}

.wholesale-gallery-shell{background:linear-gradient(180deg,#FCFAF5 0%,#F3EBDD 100%);border:1px solid var(--border);padding:38px;display:grid;grid-template-columns:minmax(280px,0.78fr) minmax(0,1.22fr);gap:32px;box-shadow:0 20px 42px rgba(26,26,24,0.05);}
.wholesale-gallery-lead{font-size:16px;color:var(--stone);line-height:1.85;max-width:34ch;}
.wholesale-gallery-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:18px;grid-auto-rows:minmax(180px,1fr);}
.wholesale-image-slot{background:var(--warm-white);border:1px dashed rgba(196,154,42,0.45);padding:24px;display:flex;flex-direction:column;justify-content:flex-end;min-height:220px;}
.wholesale-image-slot-tall{grid-row:span 2;min-height:458px;}
.wholesale-image-label{font-size:11px;font-weight:700;letter-spacing:1.5px;text-transform:uppercase;color:var(--gold-dark);margin-bottom:8px;}
.wholesale-image-note{font-size:15px;color:var(--stone);line-height:1.7;max-width:24ch;}

@media (max-width:1100px){
  .about-pillars{grid-template-columns:1fr;}
  .about-profile-grid,.about-history-shell{grid-template-columns:1fr;}
  .about-summary-value{max-width:none;}
  .services-grid{grid-template-columns:repeat(3,1fr);}
  .service-subnav-grid{grid-template-columns:repeat(3,minmax(0,1fr));}
  .wholesale-hero-inner,.wholesale-grid,.wholesale-gallery-shell{grid-template-columns:1fr;}
  .wholesale-fact-value{max-width:none;}
  .section-grid-two,.section-grid-two-wide,.section-grid-three{grid-template-columns:1fr;}
  .metric-grid{grid-template-columns:1fr 1fr;}
  .dark-panel-grid{grid-template-columns:1fr 1fr;}
}

@media (max-width:700px){
  .about-pillar,.about-profile-card,.about-summary-card,.about-history-shell{padding:24px;}
  .about-profile-card::after{display:none;}
  .about-history-item{padding:18px 18px 18px 32px;}
  .service-subnav-wrap{padding:18px;}
  .service-subnav-grid{grid-template-columns:1fr;}
  .wholesale-copy-card,.wholesale-facts-card,.wholesale-gallery-shell{padding:24px;}
  .wholesale-gallery-grid{grid-template-columns:1fr;grid-auto-rows:minmax(180px,1fr);}
  .wholesale-image-slot-tall{grid-row:auto;min-height:220px;}
  .service-thumb img{aspect-ratio:4 / 3;}
  .contact-strip,.dark-panel{padding:48px 24px;}
  .contact-strip-title,.contact-strip-title-md,.contact-strip-title-sm,.dark-panel-title{font-size:28px;}
  .page-footer-simple .footer-bottom{padding:24px 24px;}
  .note-banner,.hero-actions,.action-row,.contact-strip-actions{align-items:stretch;}
  .contact-info{flex-direction:column;gap:18px;}
  .metric-grid,.dark-panel-grid{grid-template-columns:1fr;}
  .image-lightbox{padding:14px;}
  .image-lightbox-dialog{width:98vw;max-height:96vh;}
  .image-lightbox-stage img{max-height:78vh;}
  .image-lightbox-nav{width:40px;height:54px;font-size:30px;}
}

/* STAR RATING */
.stars{color:var(--gold);font-size:18px;letter-spacing:2px;margin-bottom:10px;}
.overall-rating{display:flex;align-items:center;gap:24px;background:var(--warm-white);border:1px solid var(--border);padding:24px 28px;margin-bottom:40px;}
.rating-big{font-family:'REM',sans-serif;font-size:64px;font-weight:700;color:var(--charcoal);line-height:1;}
.rating-info{flex:1;}
.rating-info .stars-lg{font-size:24px;color:var(--gold);letter-spacing:3px;}
.rating-info p{font-size:14px;color:var(--stone);margin-top:6px;}
.rating-bars{flex:2;}
.rbar{display:flex;align-items:center;gap:10px;margin-bottom:6px;}
.rbar-label{font-size:12px;color:var(--stone);width:20px;text-align:right;}
.rbar-track{flex:1;height:6px;background:var(--border);}
.rbar-fill{height:100%;background:var(--gold);}
.rbar-count{font-size:12px;color:var(--stone);width:24px;}

/* TESTIMONIAL CARDS */
.testimonials-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:40px;}
.testimonial-card{background:var(--warm-white);border:1px solid var(--border);padding:30px;position:relative;}
.testimonial-card.featured{border-color:var(--gold);border-width:2px;}
.testimonial-card.featured::before{content:'Empfohlen';position:absolute;top:-1px;right:20px;background:var(--gold);color:white;font-size:10px;font-weight:700;letter-spacing:1px;padding:3px 10px;text-transform:uppercase;}
.t-quote{font-size:48px;color:var(--gold-light);font-family:'REM',sans-serif;line-height:0.6;margin-bottom:16px;}
.t-text{font-size:15px;color:var(--charcoal-soft);line-height:1.7;margin-bottom:20px;font-style:italic;}
.t-divider{width:40px;height:1px;background:var(--border);margin-bottom:16px;}
.t-author{display:flex;align-items:center;gap:12px;}
.t-avatar{width:44px;height:44px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:'REM',sans-serif;font-size:15px;font-weight:600;flex-shrink:0;}
.t-name{font-size:14px;font-weight:600;color:var(--charcoal);}
.t-role{font-size:12px;color:var(--stone);margin-top:2px;}
.t-source{font-size:11px;color:var(--stone-light);margin-top:3px;font-weight:500;letter-spacing:0.5px;text-transform:uppercase;}
.t-stars{color:var(--gold);font-size:14px;margin-bottom:8px;}

/* CASE STUDIES */
.case-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px;margin-top:40px;}
.case-card{background:var(--warm-white);border:1px solid var(--border);overflow:hidden;}
.case-img{height:200px;background:var(--slate);display:flex;align-items:center;justify-content:center;position:relative;}
.case-img-label{position:absolute;bottom:0;left:0;right:0;background:rgba(0,0,0,0.6);padding:10px 16px;}
.case-img-label span{font-size:11px;color:var(--gold-light);font-weight:600;letter-spacing:1px;text-transform:uppercase;}
.case-body{padding:24px;}
.case-tag{font-size:11px;font-weight:600;letter-spacing:1.5px;text-transform:uppercase;color:var(--gold);margin-bottom:8px;}
.case-title{font-family:'REM',sans-serif;font-size:20px;font-weight:600;color:var(--charcoal);margin-bottom:10px;}
.case-meta{display:flex;gap:20px;margin-bottom:12px;}
.case-meta-item{font-size:12px;color:var(--stone);}
.case-meta-item strong{color:var(--charcoal);display:block;font-size:13px;}
.case-desc{font-size:14px;color:var(--stone);line-height:1.6;}
.case-tags{display:flex;gap:6px;margin-top:14px;flex-wrap:wrap;}
.case-pill{font-size:11px;background:var(--cream);border:1px solid var(--border);color:var(--stone);padding:3px 10px;}

/* PLATFORM REVIEWS */
.platform-grid{display:flex;flex-wrap:wrap;justify-content:center;gap:20px;margin-top:40px;}
.platform-grid .platform-card{flex:0 1 360px;}
.platform-card{background:var(--warm-white);border:1px solid var(--border);padding:24px;text-align:center;}
.platform-name{font-size:13px;font-weight:600;color:var(--stone);text-transform:uppercase;letter-spacing:1px;margin-bottom:12px;}
.platform-score{font-family:'REM',sans-serif;font-size:44px;font-weight:700;color:var(--charcoal);}
.platform-stars{color:var(--gold);font-size:20px;letter-spacing:2px;margin:6px 0;}
.platform-count{font-size:13px;color:var(--stone);}
.platform-cta{display:inline-block;margin-top:14px;font-size:12px;font-weight:600;color:var(--gold);text-decoration:none;border:1px solid var(--border-gold);padding:6px 14px;cursor:pointer;}
/* Plattform-Karten sind klickbare Links (oeffnen Bewertungsseite im neuen Tab) */
a.platform-card{display:block;text-decoration:none;color:inherit;cursor:pointer;transition:border-color 0.15s, box-shadow 0.15s, transform 0.15s;}
a.platform-card:hover{border-color:var(--gold);box-shadow:0 8px 22px rgba(26,26,24,0.10);transform:translateY(-2px);}
a.platform-card:hover .platform-cta{background:var(--gold);color:#fff;border-color:var(--gold);}

/* ANALYZE */
.analysis-grid{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin-top:40px;}
.issue-card{background:var(--warm-white);border:1px solid var(--border);padding:24px;}
.issue-card.critical{border-left:4px solid #A32D2D;}
.issue-card.warning{border-left:4px solid #854F0B;}
.issue-card.ok{border-left:4px solid #3B6D11;}
.issue-badge{display:inline-flex;align-items:center;gap:5px;font-size:11px;font-weight:600;letter-spacing:1px;text-transform:uppercase;padding:3px 10px;margin-bottom:12px;}
.badge-critical{background:#FCEBEB;color:#A32D2D;}
.badge-warning{background:#FAEEDA;color:#854F0B;}
.badge-ok{background:#EAF3DE;color:#3B6D11;}
.issue-title{font-family:'REM',sans-serif;font-size:17px;font-weight:600;color:var(--charcoal);margin-bottom:8px;}
.issue-desc{font-size:14px;color:var(--stone);line-height:1.6;}
.fix-box{background:var(--cream);border:1px solid var(--border-gold);padding:12px 14px;margin-top:12px;font-size:13px;color:var(--gold-dark);}
.fix-box strong{color:var(--charcoal);}

/* SEO */
.seo-score{display:flex;align-items:center;justify-content:center;gap:40px;padding:48px 40px;background:var(--slate);margin-bottom:40px;}
.score-circle{width:120px;height:120px;border-radius:50%;border:6px solid var(--gold);display:flex;flex-direction:column;align-items:center;justify-content:center;}
.score-num{font-family:'REM',sans-serif;font-size:38px;font-weight:700;color:var(--gold-light);line-height:1;}
.score-label{font-size:11px;color:var(--stone-light);letter-spacing:1px;text-transform:uppercase;}
.score-info{color:white;}
.score-info h2{font-family:'REM',sans-serif;font-size:28px;font-weight:700;margin-bottom:8px;}
.score-info p{color:var(--stone-light);font-size:15px;}
.seo-list{list-style:none;}
.seo-item{display:flex;gap:16px;padding:18px 0;border-bottom:1px solid var(--border);}
.seo-item:last-child{border-bottom:none;}
.seo-num{width:28px;height:28px;background:var(--gold);color:white;font-size:13px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:2px;}
.seo-item-title{font-weight:600;color:var(--charcoal);font-size:15px;margin-bottom:5px;}
.seo-item-desc{font-size:14px;color:var(--stone);line-height:1.6;}
.seo-code{background:var(--cream);border:1px solid var(--border);font-family:'REM',sans-serif;font-size:12px;padding:10px 14px;margin-top:10px;color:var(--charcoal-soft);word-break:break-all;line-height:1.5;}

/* BAUSTOFFE */
.baustoffe-hero{background:var(--slate);padding:64px 40px;text-align:center;border-bottom:3px solid var(--gold);}
.baustoffe-hero h1{font-family:'REM',sans-serif;font-size:48px;font-weight:700;color:white;margin-bottom:16px;}
.baustoffe-hero p{color:var(--stone-light);font-size:17px;max-width:560px;margin:0 auto 28px;}
.baustoffe-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;}
.baus-card{background:var(--warm-white);border:1px solid var(--border);padding:28px;}
.baus-icon{width:52px;height:52px;background:var(--cream);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;margin-bottom:18px;}
.baus-icon svg{width:26px;height:26px;stroke:var(--gold-dark);fill:none;stroke-width:1.5;}
.baus-icon-image{width:96px;height:96px;background:transparent;border:0;padding:0;}
.baus-icon-image img{width:100%;height:100%;object-fit:contain;display:block;}
.baus-cat{font-size:11px;font-weight:600;letter-spacing:1.5px;text-transform:uppercase;color:var(--gold);margin-bottom:8px;}
.baus-name{font-family:'REM',sans-serif;font-size:20px;font-weight:600;color:var(--charcoal);margin-bottom:10px;}
.baus-desc{font-size:14px;color:var(--stone);line-height:1.6;margin-bottom:18px;}
.baus-items{list-style:none;border-top:1px solid var(--border);padding-top:14px;}
.baus-items li{font-size:13px;color:var(--stone);padding:5px 0;display:flex;justify-content:space-between;border-bottom:1px solid var(--border);}
.baus-items li:last-child{border-bottom:none;}
.baus-price{font-weight:600;color:var(--charcoal);}
.shop-catalog-section{padding-top:24px;}
.shop-catalog-toolbar{background:var(--warm-white);border:1px solid var(--border);padding:18px;display:grid;gap:14px;margin-top:28px;}
.shop-filter-row{display:flex;gap:10px;flex-wrap:wrap;}
.shop-filter-btn{border:1px solid var(--border);background:#fff;padding:9px 14px;font-family:'REM',sans-serif;font-size:12px;font-weight:600;color:var(--stone);letter-spacing:0.4px;cursor:pointer;}
.shop-filter-btn.active,.shop-filter-btn:hover{border-color:rgba(196,154,42,0.55);color:var(--charcoal);background:#F9F5EC;}
.shop-search-row{display:grid;grid-template-columns:minmax(0,1fr) 240px;gap:10px;}
.shop-search-input,.shop-sort-select{border:1px solid var(--border);padding:11px 12px;font-family:'REM',sans-serif;font-size:14px;color:var(--charcoal);background:#fff;}
.shop-catalog-meta{display:flex;justify-content:space-between;align-items:center;gap:12px;font-size:13px;color:var(--stone);}
.shop-reset-btn{background:none;border:none;color:var(--gold-dark);font-family:'REM',sans-serif;font-size:13px;font-weight:600;cursor:pointer;padding:0;}
.shop-item-grid{margin-top:24px;display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px;}
.shop-item-card{background:var(--warm-white);border:1px solid var(--border);padding:20px;display:grid;gap:10px;align-content:start;}
.shop-item-kicker{font-size:11px;font-weight:700;letter-spacing:1.3px;text-transform:uppercase;color:var(--gold-dark);}
.shop-item-card h3{font-family:'REM',sans-serif;font-size:19px;line-height:1.3;color:var(--charcoal);}
.shop-item-card p{font-size:14px;color:var(--stone);line-height:1.7;}
.shop-item-footer{display:flex;justify-content:space-between;align-items:center;gap:10px;padding-top:8px;}
.shop-item-price{font-size:22px;font-weight:700;color:var(--charcoal);line-height:1;}
.shop-visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0;}
.stuck-catalog-status{margin-top:16px;color:var(--stone);font-size:14px;}
.shop-pagination{display:flex;flex-wrap:wrap;justify-content:center;align-items:center;gap:6px;margin:28px 0 8px;}
.shop-pagination-btn{min-width:36px;height:36px;padding:0 10px;background:var(--warm-white);border:1px solid var(--border);color:var(--charcoal);font-family:'REM',sans-serif;font-size:14px;font-weight:500;cursor:pointer;transition:border-color 0.15s,color 0.15s,background 0.15s;}
.shop-pagination-btn:hover:not(:disabled){border-color:var(--gold);color:var(--gold);}
.shop-pagination-btn.active{background:var(--gold);border-color:var(--gold);color:#fff;font-weight:700;}
.shop-pagination-btn.nav{font-weight:600;}
.shop-pagination-btn:disabled{opacity:0.4;cursor:not-allowed;}
.shop-pagination-ellipsis{padding:0 4px;color:var(--stone);font-size:14px;line-height:36px;}
.shop-pagination-info{flex-basis:100%;text-align:center;font-size:12px;color:var(--stone);margin-top:8px;}
.stuck-item-grid{grid-template-columns:repeat(3,minmax(0,1fr));}
.stuck-item-card{padding:0;overflow:hidden;display:flex;flex-direction:column;}
.stuck-item-media{background:var(--slate);border-bottom:1px solid var(--border);aspect-ratio:4 / 3;overflow:hidden;display:flex;align-items:center;justify-content:center;padding:12px;}
.stuck-item-media-btn{border:0;width:100%;cursor:zoom-in;text-align:inherit;}
.stuck-item-media-btn:focus-visible{outline:2px solid var(--gold);outline-offset:-2px;}
.stuck-item-media img{max-width:100%;max-height:100%;width:auto;height:auto;object-fit:contain;display:block;}
.stuck-item-body{padding:16px;display:grid;gap:10px;align-content:start;}
.stuck-item-meta{display:flex;flex-wrap:wrap;gap:8px;font-size:12px;color:var(--stone);}
.stuck-item-chip{padding:4px 8px;border:1px solid var(--border);background:#fff;}
.stuck-item-dims{font-size:13px;color:var(--stone);line-height:1.5;}
.stuck-item-actions{display:flex;flex-direction:column;align-items:stretch;gap:10px;border-top:1px solid var(--border);padding-top:10px;}
.stuck-item-actions .btn-sm{white-space:nowrap;}
/* Kauf-Zeile: Mengen-Stepper + Warenkorb-Icon-Button */
.stuck-buy{display:flex;align-items:center;justify-content:space-between;gap:10px;}
.qty-stepper{display:inline-flex;align-items:center;border:1px solid var(--border);border-radius:7px;overflow:hidden;background:#fff;}
.qty-btn{width:32px;height:36px;border:none;background:#fff;color:var(--charcoal);font-size:16px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0;-webkit-tap-highlight-color:transparent;}
.qty-btn:hover{background:var(--cream);color:var(--gold-dark);}
.qty-btn:active{background:var(--border);}
.qty-val{min-width:30px;text-align:center;font-size:14px;font-weight:700;color:var(--charcoal);user-select:none;}
.add-cart-btn{flex:1;min-width:0;height:36px;border:none;border-radius:7px;background:var(--gold);color:#fff;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;transition:background 0.2s;-webkit-tap-highlight-color:transparent;}
.add-cart-btn:hover{background:var(--gold-dark);}
.add-cart-btn:active{transform:translateY(1px);}
.add-cart-btn svg{width:21px;height:21px;stroke:#fff;fill:none;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round;}

/* ROUTE / KARTEN-APP AUSWAHL-MODAL */
.route-modal{position:fixed;inset:0;z-index:1000;display:flex;align-items:center;justify-content:center;padding:20px;}
.route-modal[hidden]{display:none;}
.route-modal-backdrop{position:absolute;inset:0;background:rgba(26,26,24,0.55);-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);}
.route-modal-card{position:relative;background:var(--warm-white);border:1px solid var(--border);border-radius:14px;max-width:380px;width:100%;padding:26px 22px 22px;box-shadow:0 20px 55px rgba(0,0,0,0.32);}
.route-modal-x{position:absolute;top:10px;right:12px;background:none;border:none;font-size:24px;line-height:1;color:var(--stone);cursor:pointer;padding:4px 8px;}
.route-modal-x:hover{color:var(--charcoal);}
.route-modal-title{font-family:'REM',sans-serif;color:var(--charcoal);margin-bottom:6px;}
.route-modal-sub{font-size:14px;color:var(--stone);line-height:1.5;margin-bottom:16px;}
.route-loc-toggle{display:flex;align-items:flex-start;gap:10px;font-size:14px;color:var(--charcoal);cursor:pointer;margin-bottom:18px;line-height:1.45;}
.route-loc-toggle input{margin-top:2px;width:18px;height:18px;accent-color:var(--gold);flex-shrink:0;cursor:pointer;}
.route-loc-toggle em{font-style:normal;color:var(--stone);font-size:12px;display:block;margin-top:2px;}
.route-modal-apps{display:grid;gap:10px;}
.route-app-btn{display:inline-flex;align-items:center;justify-content:center;gap:10px;width:100%;min-height:50px;border:1px solid var(--border);border-radius:10px;background:#fff;color:var(--charcoal);font-family:'REM',sans-serif;font-weight:600;cursor:pointer;transition:all 0.15s;}
.route-app-btn:hover{border-color:var(--gold);background:var(--cream);}
.route-app-btn svg{width:22px;height:22px;stroke:var(--gold);fill:none;stroke-width:1.8;flex-shrink:0;}
.route-modal-cancel{margin-top:14px;width:100%;background:none;border:none;color:var(--stone);font-size:14px;cursor:pointer;padding:8px;text-decoration:underline;}
.route-modal-cancel:hover{color:var(--charcoal);}

/* BESTELLFORMULAR (Checkout-Modal) */
.route-modal-card{max-height:90vh;overflow-y:auto;}
.order-form{display:grid;gap:12px;text-align:left;}
.order-form label{font-size:13px;font-weight:600;color:var(--charcoal);display:block;margin-bottom:4px;}
.order-form input,.order-form textarea{width:100%;box-sizing:border-box;border:1px solid var(--border);border-radius:8px;padding:10px 12px;font-family:'REM',sans-serif;font-size:14px;color:var(--charcoal);background:#fff;}
.order-form input:focus,.order-form textarea:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 3px rgba(196,154,42,0.12);}
.order-form textarea{min-height:62px;resize:vertical;line-height:1.5;}
.order-consent{display:flex;gap:9px;align-items:flex-start;font-size:12px;color:var(--stone);line-height:1.45;cursor:pointer;margin-top:2px;}
.order-consent input{width:18px;height:18px;margin-top:1px;accent-color:var(--gold);flex-shrink:0;}
.order-hp{position:absolute !important;left:-9999px !important;width:1px !important;height:1px !important;overflow:hidden;opacity:0;}
.order-error{color:#C0392B;font-size:13px;background:#FDEDEC;border:1px solid #F5B7B1;border-radius:6px;padding:8px 10px;}
.order-error[hidden]{display:none;}
#orderSubmitBtn[disabled]{opacity:0.6;cursor:wait;}

/* Datei-Upload im Kontaktformular */
.contact-upload-block{display:grid;gap:8px;}
.contact-upload-label{font-size:13px;color:var(--stone);font-weight:600;}
.contact-upload-label span{font-weight:400;color:var(--stone-light);}
.contact-upload-zone{display:flex;align-items:center;gap:14px;border:1.5px dashed var(--border);background:#FAFAF7;padding:18px 16px;cursor:pointer;transition:border-color 0.15s,background 0.15s;color:var(--stone);}
.contact-upload-zone:hover,.contact-upload-zone:focus-within{border-color:var(--gold);background:#FFF9ED;color:var(--charcoal);}
.contact-upload-zone.drag-over{border-color:var(--gold);background:#FFF9ED;border-style:solid;}
.contact-upload-zone svg{width:30px;height:30px;flex-shrink:0;color:var(--gold-dark);}
.contact-upload-zone-text{display:flex;flex-direction:column;gap:2px;font-family:'REM',sans-serif;}
.contact-upload-zone-text strong{font-size:14px;font-weight:600;color:inherit;}
.contact-upload-zone-text span{font-size:12px;color:var(--stone-light);line-height:1.4;}
.contact-upload-list{list-style:none;padding:0;margin:0;display:grid;gap:6px;}
.contact-upload-list li{display:flex;align-items:center;gap:10px;background:var(--warm-white);border:1px solid var(--border);padding:8px 12px;font-size:13px;color:var(--charcoal);}
.contact-upload-list .file-name{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.contact-upload-list .file-size{font-size:11px;color:var(--stone-light);flex-shrink:0;}
.contact-upload-list .file-remove{background:none;border:none;color:var(--stone);font-size:18px;cursor:pointer;line-height:1;padding:0 4px;}
.contact-upload-list .file-remove:hover{color:#C0392B;}
.contact-upload-meter{display:grid;gap:6px;margin-top:2px;}
.contact-upload-meter-bar{height:6px;background:#EEE9DD;overflow:hidden;border-radius:3px;}
.contact-upload-meter-bar span{display:block;height:100%;width:0%;background:linear-gradient(90deg,#5BAA4A 0%,#5BAA4A 100%);transition:width 0.25s ease,background 0.25s ease;}
.contact-upload-meter.warn .contact-upload-meter-bar span{background:linear-gradient(90deg,#E0A03A 0%,#E0A03A 100%);}
.contact-upload-meter.full .contact-upload-meter-bar span{background:linear-gradient(90deg,#C0392B 0%,#C0392B 100%);}
.contact-upload-meter-text{font-size:12px;color:var(--stone);}
.contact-upload-meter-text strong{color:var(--charcoal);font-weight:600;}

/* CART */
.cart-layout{display:grid;grid-template-columns:minmax(0,1fr) 320px;gap:24px;align-items:start;}
.cart-panel{border:1px solid var(--border);background:var(--warm-white);padding:18px;}
.cart-head{display:flex;align-items:baseline;justify-content:space-between;gap:12px;padding-bottom:10px;border-bottom:1px solid var(--border);}
.cart-empty{padding:22px 6px;color:var(--stone);}
.cart-items{display:grid;gap:12px;margin-top:12px;}
.cart-row{display:grid;grid-template-columns:84px minmax(0,1fr) auto;gap:12px;padding:10px;border:1px solid var(--border);background:#fff;align-items:center;}
.cart-row img{width:84px;height:62px;object-fit:contain;background:var(--cream);border:1px solid var(--border);}
.cart-row-name{font-weight:700;color:var(--charcoal);margin-bottom:2px;}
.cart-row-meta{font-size:13px;color:var(--stone);}
.cart-row-right{display:grid;justify-items:end;gap:8px;}
.cart-qty{display:inline-flex;align-items:center;border:1px solid var(--border);}
.cart-qty button{border:0;background:#fff;color:var(--charcoal);width:28px;height:28px;cursor:pointer;font-size:16px;line-height:1;}
.cart-qty span{min-width:28px;text-align:center;font-size:13px;}
.cart-remove{border:0;background:none;color:var(--stone);font-size:12px;cursor:pointer;text-decoration:underline;}
.cart-summary{border:1px solid var(--border);background:var(--warm-white);padding:16px;display:grid;gap:10px;position:sticky;top:70px;}
.cart-summary h3{font-size:20px;color:var(--charcoal);margin-bottom:4px;}
.cart-summary-row,.cart-summary-total{display:flex;justify-content:space-between;align-items:center;gap:10px;}
.cart-summary-total{padding-top:10px;border-top:1px solid var(--border);font-size:18px;}
.cart-checkout-btn,.cart-back-btn{width:100%;justify-content:center;display:inline-flex;align-items:center;}

@media (max-width:980px){
  .cart-layout{grid-template-columns:1fr;}
  .cart-summary{position:static;}
  .cart-row{grid-template-columns:70px minmax(0,1fr);}
  .cart-row img{width:70px;height:54px;}
  .cart-row-right{grid-column:1 / -1;justify-items:start;}
}
/* ADMIN PANEL */
.admin-wrap{display:flex;min-height:calc(100vh - 120px);background:#F0F2F5;}
.admin-sidebar{width:230px;background:#1A1A18;flex-shrink:0;display:flex;flex-direction:column;}
.admin-logo{padding:22px 20px;border-bottom:1px solid rgba(255,255,255,0.07);}
.admin-logo-title{font-family:'REM',sans-serif;font-size:15px;color:white;font-weight:700;}
.admin-logo-sub{font-size:11px;color:#6B6860;margin-top:2px;}
.admin-nav{padding:12px 0;flex:1;}
.admin-nav-section{font-size:10px;font-weight:600;letter-spacing:1.5px;text-transform:uppercase;color:#4A4840;padding:12px 20px 5px;}
.admin-nav-item{display:flex;align-items:center;gap:10px;padding:9px 20px;font-size:13px;color:#A8A59E;cursor:pointer;transition:all 0.15s;border-left:3px solid transparent;background:none;border-top:none;border-right:none;border-bottom:none;width:100%;text-align:left;font-family:'REM',sans-serif;}
.admin-nav-item:hover{background:rgba(255,255,255,0.04);color:white;}
.admin-nav-item.active{background:rgba(196,154,42,0.1);color:#C49A2A;border-left-color:#C49A2A;}
.admin-nav-item svg{width:15px;height:15px;stroke:currentColor;fill:none;stroke-width:1.8;flex-shrink:0;}
.admin-nav-badge{margin-left:auto;background:#C49A2A;color:white;font-size:10px;font-weight:700;padding:1px 7px;border-radius:10px;}
.admin-main{flex:1;overflow:auto;}
.admin-topbar{background:white;border-bottom:1px solid #E5E7EB;padding:0 28px;height:56px;display:flex;align-items:center;justify-content:space-between;}
.admin-topbar-title{font-size:15px;font-weight:600;color:#111;}
.admin-avatar{width:34px;height:34px;border-radius:50%;background:#1A1A18;display:flex;align-items:center;justify-content:center;color:#C49A2A;font-size:13px;font-weight:700;}
.admin-content{padding:24px 28px;}
.admin-section{display:none;} .admin-section.active{display:block;}
.admin-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:24px;}
.admin-stat-card{background:white;border:1px solid #E5E7EB;border-radius:8px;padding:18px;}
.admin-stat-icon{width:38px;height:38px;border-radius:8px;display:flex;align-items:center;justify-content:center;margin-bottom:12px;}
.admin-stat-icon svg{width:18px;height:18px;stroke:white;fill:none;stroke-width:2;}
.admin-stat-num{font-size:24px;font-weight:700;color:#111;line-height:1;}
.admin-stat-label{font-size:12px;color:#6B7280;margin-top:3px;}
.admin-card{background:white;border:1px solid #E5E7EB;border-radius:8px;margin-bottom:18px;}
.admin-card-header{padding:14px 18px;border-bottom:1px solid #F3F4F6;display:flex;align-items:center;justify-content:space-between;}
.admin-card-title{font-size:13px;font-weight:600;color:#111;}
.admin-card-body{padding:18px;}
.slider-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;}
.slider-item{border:2px solid #E5E7EB;border-radius:6px;overflow:hidden;position:relative;background:#F9FAFB;}
.slider-item.slot-active{border-color:#C49A2A;}
.slider-thumb{height:120px;background-size:cover;background-position:center;position:relative;}
.slider-thumb-overlay{position:absolute;inset:0;background:rgba(0,0,0,0);transition:background 0.2s;display:flex;align-items:center;justify-content:center;gap:8px;}
.slider-item:hover .slider-thumb-overlay{background:rgba(0,0,0,0.45);}
.slider-thumb-btn{background:white;border:none;border-radius:4px;width:30px;height:30px;display:flex;align-items:center;justify-content:center;cursor:pointer;opacity:0;transition:opacity 0.15s;}
.slider-item:hover .slider-thumb-btn{opacity:1;}
.slider-thumb-btn svg{width:14px;height:14px;stroke:#111;fill:none;stroke-width:2;}
.slider-meta{padding:9px 11px;border-top:1px solid #F3F4F6;}
.slider-meta-name{font-size:12px;font-weight:600;color:#111;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.status-active{color:#10B981;font-size:11px;font-weight:600;}
.status-hidden{color:#9CA3AF;font-size:11px;font-weight:600;}
.slider-order{position:absolute;top:6px;left:6px;background:rgba(0,0,0,0.6);border-radius:4px;padding:3px 8px;font-size:11px;color:white;font-weight:700;}
.upload-zone{border:2px dashed #D1D5DB;border-radius:8px;padding:36px 20px;text-align:center;cursor:pointer;transition:all 0.2s;background:#FAFAFA;}
.upload-zone:hover{border-color:#C49A2A;background:#FFFDF5;}
.upload-zone svg{width:36px;height:36px;stroke:#9CA3AF;fill:none;stroke-width:1.2;margin:0 auto 10px;display:block;}
.upload-zone p{font-size:14px;color:#6B7280;}
.upload-zone .file-types{font-size:11px;color:#9CA3AF;margin-top:4px;}
.admin-label{font-size:11px;font-weight:600;color:#374151;display:block;margin-bottom:5px;text-transform:uppercase;letter-spacing:0.5px;}
.admin-input{width:100%;border:1px solid #D1D5DB;border-radius:6px;padding:8px 11px;font-size:13px;font-family:'REM',sans-serif;color:#111;background:white;outline:none;}
.admin-input:focus{border-color:#C49A2A;box-shadow:0 0 0 3px rgba(196,154,42,0.1);}
.admin-textarea{width:100%;border:1px solid #D1D5DB;border-radius:6px;padding:8px 11px;font-size:13px;font-family:'REM',sans-serif;color:#111;min-height:70px;resize:vertical;outline:none;}
.admin-select{width:100%;border:1px solid #D1D5DB;border-radius:6px;padding:8px 11px;font-size:13px;font-family:'REM',sans-serif;color:#111;background:white;outline:none;cursor:pointer;}
.admin-btn{font-family:'REM',sans-serif;font-size:12px;font-weight:600;padding:8px 16px;border-radius:6px;cursor:pointer;border:none;transition:all 0.15s;}
.admin-btn-primary{background:#C49A2A;color:white;}
.admin-btn-primary:hover{background:#8A6B1A;}
.admin-btn-secondary{background:white;color:#374151;border:1px solid #D1D5DB;}
.admin-btn-secondary:hover{background:#F9FAFB;}
.admin-btn-danger{background:#FEE2E2;color:#DC2626;border:none;}
.admin-form-row{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:14px;}
.admin-form-group{margin-bottom:14px;}
.admin-table{width:100%;border-collapse:collapse;}
.admin-table th{text-align:left;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:0.5px;color:#6B7280;padding:9px 12px;border-bottom:1px solid #F3F4F6;background:#F9FAFB;}
.admin-table td{padding:11px 12px;border-bottom:1px solid #F9FAFB;font-size:13px;color:#374151;vertical-align:middle;}
.admin-table tr:last-child td{border-bottom:none;}
.tag-pill{display:inline-block;font-size:10px;padding:2px 9px;border-radius:20px;font-weight:600;}
.tag-new{background:#DCFCE7;color:#16A34A;}
.tag-pending{background:#FEF3C7;color:#D97706;}
.tag-done{background:#F3F4F6;color:#6B7280;}
.admin-toast{position:fixed;bottom:24px;left:50%;right:auto;transform:translateX(-50%);width:max-content;min-width:0;max-width:min(420px,calc(100vw - 32px));box-sizing:border-box;background:#1A1A18;color:white;padding:12px 22px;border-radius:8px;font-size:13px;border-left:4px solid #C49A2A;display:none;z-index:999;font-family:'REM',sans-serif;text-align:center;overflow-wrap:break-word;}
.admin-toast.show{display:block;}


/* === GLOBAL FONT SIZE CAP (Stil wie b2b-card 'CAD-Planung & Vorabansicht') === */
.font-cap h1, body h1{font-size:18px !important;line-height:1.3 !important;}
body h2{font-size:16px !important;line-height:1.3 !important;}
body h3, body h4, body h5{font-size:16px !important;line-height:1.3 !important;}
body p, body li, body td, body th, body label, body button, body input, body textarea, body select, body a, body span, body div, body cite, body blockquote, body em, body strong, body small{font-size:14px !important;line-height:1.6 !important;}
body .section-tag{font-size:11px !important;}
body .hero-stat .num, body .ref-hero-stat .num, body .admin-stat-num, body .product-price{font-size:16px !important;line-height:1.3 !important;}
body svg, body svg *{font-size:inherit;}
body .image-lightbox-close{font-size:26px !important;}
body .image-lightbox-nav{font-size:30px !important;}

@media (max-width: 1200px){
  .stuck-item-grid{grid-template-columns:repeat(2,minmax(0,1fr));}
}

@media (max-width: 980px){
  .stuck-item-grid{grid-template-columns:1fr;}
}

/* ============================================================
   MOBILE APP SHELL  –  Handy & Tablet-Hochformat (<=900px)
   Behebt "Desktop-Layout auf dem Handy" + native App-Optik
   ============================================================ */
:root{ --tabbar-h:58px; --appbar-h:54px; }
.mobile-tabbar{ display:none; }
.wa-float{ display:none; }

@media (max-width:900px){
  /* 1) KERN-FIX: erzwungene Desktop-Breite aufheben (statt min-width:max-content) */
  html{ overflow-x:hidden; }
  body{ min-width:0 !important; overflow-x:hidden;
        padding-top:calc(var(--appbar-h) + var(--tabbar-h) + env(safe-area-inset-top)); }
  body > section, body > footer, body > nav, body > div, body > header{ min-width:0 !important; }
  img, svg, video, iframe{ max-width:100%; height:auto; }

  /* 2) Desktop-Navigation aus, schlanke App-Kopfzeile */
  .top-bar{ display:none; }
  .nav-links{ display:none; }
  .nav-actions{ display:none; }
  .page-tabs{ display:none !important; }
  /* Schwebender WhatsApp-Button (unten rechts, über der Mobile-Tabbar) */
  .wa-float{
    display:inline-flex; align-items:center; justify-content:center;
    position:fixed; right:16px;
    bottom:calc(var(--tabbar-h) + 16px + env(safe-area-inset-bottom));
    width:56px; height:56px; border-radius:50%;
    background:#25D366; color:#fff; text-decoration:none;
    box-shadow:0 8px 22px rgba(0,0,0,0.28), 0 2px 6px rgba(0,0,0,0.18);
    z-index:300;
    transition:transform 0.2s, background 0.2s;
  }
  .wa-float:hover, .wa-float:active{ background:#1ebd58; transform:scale(1.05); }
  .wa-float svg{ display:block; }
  /* "Noch mehr zu entdecken"-Scrollhinweis nur am Desktop, nicht auf dem Handy */
  .scroll-cue{ display:none !important; }
  /* Gekuerzte Unternehmens-Sektion auf der Startseite: am Handy ausblenden (Desktop behaelt sie) */
  .home-company-recap{ display:none !important; }
  .main-nav{ position:fixed; top:0; left:0; right:0; z-index:200; padding-top:env(safe-area-inset-top); }
  .nav-inner{ display:flex; justify-content:flex-start; align-items:center; height:54px; padding:0 16px; }

  /* 1-Tap-Telefon im App-Header (links neben der Sprachwahl), nur Mobile.
     Schiebt sich per margin-left:auto nach rechts; die Sprachwahl folgt mit Gap. */
  .nav-phone-mobile{
    display:inline-flex; align-items:center; justify-content:center;
    margin-left:auto; flex:none;
    width:40px; height:42px; border-radius:6px;
    background:var(--slate); border:1px solid var(--gold);
    color:#E8D28A; text-decoration:none; touch-action:manipulation;
  }
  .nav-phone-mobile svg{ width:20px; height:20px; stroke:currentColor; fill:none; stroke-width:1.8; stroke-linecap:round; stroke-linejoin:round; }

  /* Sprachwahl auf Mobile: sichtbarer Button (runde Flagge + Kürzel + Pfeil)
     im gewohnten Design, darueber ein transparentes natives <select>. Das
     Aufklappen macht das OS – maximal zuverlaessig auf iOS/Android. */
  .lang-mobile{
    display:inline-flex; align-items:center; gap:6px; position:relative;
    margin-left:6px;
    background:var(--slate); color:#E8D28A;
    border:1px solid var(--gold); border-radius:6px;
    padding:8px 9px; min-height:42px;
  }
  .lang-mobile-flag{ width:18px; height:18px; border-radius:50%; display:block; flex:none; }
  .lang-mobile-code{ font-family:'REM',sans-serif; font-size:13px; font-weight:700; letter-spacing:0.5px; color:#E8D28A; }
  .lang-mobile-caret{ color:#E8D28A; font-size:11px; line-height:1; }
  /* Transparentes Select ueber dem ganzen Button – faengt den Tap ab und
     oeffnet den nativen OS-Picker. font-size:16px verhindert iOS-Zoom. */
  .lang-mobile .lang-native{
    position:absolute; inset:0; width:100%; height:100%;
    margin:0; padding:0; border:0; background:transparent;
    opacity:0; font-size:16px; cursor:pointer;
    -webkit-appearance:none; appearance:none;
  }

  /* 3) Layout-Raster mobil zusammenklappen */
  .hero-text{ padding:30px 18px; }
  .hero-text-inner{ grid-template-columns:1fr; gap:26px; }
  .hero-stats-bar{ grid-template-columns:repeat(3,1fr); }
  .hero-stats-right{ grid-template-columns:1fr 1fr; }
  .section{ padding:46px 18px; }
  .services-grid{ grid-template-columns:1fr 1fr; }
  .products-grid{ grid-template-columns:1fr; }
  .b2b-strip{ padding:26px 18px; }
  .b2b-header{ grid-template-columns:1fr; gap:16px; }
  .b2b-cards{ grid-template-columns:1fr; }
  .b2b-bottom{ flex-direction:column; gap:12px; }
  .b2b-cta-text{ text-align:left; max-width:none; }
  .trust-bar{ padding:18px; }
  .trust-inner{ flex-wrap:wrap; gap:14px 22px; justify-content:flex-start; }
  .quote-banner{ padding:36px 18px; }
  .contact-strip{ padding:28px 18px 0; }
  .contact-strip-actions{ flex-direction:column; }
  .contact-info{ flex-direction:column; gap:16px; }
  .stuck-item-grid{ grid-template-columns:1fr 1fr !important; gap:12px; }

  /* 4) Touch-Targets */
  .btn-gold, .btn-outline, .btn-lg, .btn-callout, .nav-cart-btn{ min-height:46px; }

  /* 5) FESTE OBERE TAB-LEISTE (App-Optik) – direkt unter dem Logo-Header */
  .mobile-tabbar{
    display:flex; position:fixed; left:0; right:0; z-index:190;
    top:calc(var(--appbar-h) + env(safe-area-inset-top));
    height:var(--tabbar-h);
    background:var(--slate);
    /* feine goldene Linien: oben sehr dezent, unten etwas praesenter */
    border-top:1px solid rgba(196,154,42,0.35);
    border-bottom:1px solid rgba(196,154,42,0.70);
    box-shadow:0 2px 10px rgba(0,0,0,0.18);
  }
  .mtab{
    flex:1; display:flex; flex-direction:column; align-items:center; justify-content:center; gap:3px;
    background:none; border:none; cursor:pointer; position:relative;
    color:#A8A59E; font-family:'REM',sans-serif; padding:7px 2px 5px;
    -webkit-tap-highlight-color:transparent;
  }
  .mtab svg{ width:23px; height:23px; stroke:currentColor; fill:none; stroke-width:1.7; stroke-linecap:round; stroke-linejoin:round; }
  .mtab span{ font-size:10px !important; line-height:1 !important; letter-spacing:0.2px; font-weight:600; }
  .mtab.active{ color:var(--gold-light); }
  .mtab.active::before{ content:""; position:absolute; bottom:0; width:30px; height:3px; background:var(--gold); border-radius:4px 4px 0 0; }
  .mtab-badge{
    position:absolute; top:5px; left:calc(50% + 7px);
    min-width:16px; height:16px; padding:0 4px;
    background:var(--gold); color:#fff; font-size:9px !important; font-weight:700;
    border-radius:9px; display:none; align-items:center; justify-content:center; line-height:1;
  }
  .mtab-badge.has-items{ display:flex; }
}

/* Tablet-Hochformat etwas dichter: Shop 3-spaltig */
@media (min-width:601px) and (max-width:900px){
  .stuck-item-grid{ grid-template-columns:repeat(3,minmax(0,1fr)) !important; }
  .products-grid{ grid-template-columns:1fr 1fr; }
}

/* ------------------------------------------------------------
   MOBIL: ALLE mehrspaltigen Layouts auf 1 Spalte klappen
   (verhindert abgeschnittene/fehlende Texte durch off-screen Spalten)
   ------------------------------------------------------------ */
@media (max-width:900px){
  /* Inline-Grids direkt im HTML (style="display:grid;grid-template-columns:..") */
  [style*="grid-template-columns"]{ grid-template-columns:1fr !important; }

  /* Klassenbasierte Content-Grids -> 1 Spalte */
  .news-grid, .services-grid, .products-grid, .b2b-header, .b2b-cards,
  .footer-inner, .ref-hero-inner, .section-grid-two, .section-grid-two-wide,
  .section-grid-three, .about-pillars, .testimonials-grid, .case-grid,
  .platform-grid, .analysis-grid, .baustoffe-grid{
    grid-template-columns:1fr !important;
  }

  /* Diese 4er/3er-Raster auf 2 Spalten (kompakte Kacheln) */
  .dark-panel-grid, .service-subnav-grid, .shop-item-grid, .metric-grid{
    grid-template-columns:1fr 1fr !important;
  }

  /* Flex-Reihen umbrechen statt ueberlaufen */
  .b2b-logos, .case-meta, .footer-bottom, .b2b-bottom, .hero-btns,
  .product-actions, .stuck-item-actions, .contact-strip-actions{ flex-wrap:wrap; }

  /* Formularfelder volle Breite, nie ueber den Rand */
  input, select, textarea, .admin-input, .admin-select, .admin-textarea{
    max-width:100%; box-sizing:border-box;
  }
  .admin-form-row{ grid-template-columns:1fr !important; }

  /* Sicherheitsnetz: nichts schiebt sich aus dem Viewport */
  .section, .b2b-inner, .b2b-strip, .ref-hero-inner, .contact-strip-inner{ max-width:100%; }
}

/* Tablet (601-900): einige Raster duerfen 2-spaltig bleiben */
@media (min-width:601px) and (max-width:900px){
  .services-grid, .section-grid-two, .section-grid-two-wide, .testimonials-grid,
  .case-grid, .platform-grid, .baustoffe-grid, .about-pillars{ grid-template-columns:1fr 1fr !important; }
}

/* Letzte Ueberlauf-Quellen: Inline-Flex-Reihen umbrechen, Inline-min-width neutralisieren */
@media (max-width:900px){
  [style*="display:flex"]{ flex-wrap:wrap; }
  [style*="min-width"]{ min-width:0 !important; }
  .ref-hero-stat, .platform-card, .ref-hero-stats{ min-width:0 !important; }

  /* Stat-Kacheln: kompakter, damit lange Uppercase-Woerter (z. B. EMPFEHLUNGEN,
     BRANDENBURG) nicht aus der Kachel ragen */
  .ref-hero-stat{ padding:18px 8px !important; overflow:hidden; }
  body .ref-hero-stat .num{ overflow-wrap:anywhere; word-break:break-word; }
  body .ref-hero-stat .lbl{ font-size:10px !important; letter-spacing:0.3px !important; overflow-wrap:anywhere; word-break:break-word; }

  /* Bewertungs-Block (Referenzen): 3 Spalten untereinander, Trennraender weg */
  .overall-rating{ flex-direction:column; align-items:stretch; gap:16px; }
  .overall-rating > div{ border:0 !important; padding-left:0 !important; padding-right:0 !important; }
}

/* ============================================================
   KONTRAST – gedaempfter Text auf dunklen Slate-Flaechen lesbarer
   (Footer, B2B, Hero-Text, Kontakt, Heros). #CCD3DC ~5.8:1 = WCAG AA.
   ============================================================ */
.hero-text .hero-lead,
.contact-strip p,
.contact-strip-copy,
.contact-item .label,
.hero-stats-bar .hero-stat .label,
.b2b-strip p,
.b2b-strip .b2b-header p,
.b2b-strip .b2b-card p,
.b2b-strip .b2b-cta-text,
.b2b-strip .b2b-logo-pill,
.ref-hero p,
.baustoffe-hero p,
.dark-panel p,
footer .footer-desc,
footer .footer-col ul li a,
footer .footer-copy{
  color:#CCD3DC !important;
}
footer .footer-col ul li a:hover{ color:var(--gold-light) !important; }
/* Gold-Ueberschriften auf Slate etwas heller fuer mehr Kontrast */
.footer-col h4{ color:var(--gold-light) !important; }

/* ===== Mobil: Shop-Kategorie-Filter einklappbar (spart Platz) ===== */
.shop-filter-toggle{ display:none; }
@media (max-width:900px){
  .shop-filter-toggle{
    display:flex; align-items:center; justify-content:space-between; gap:10px; width:100%;
    background:#fff; border:1px solid var(--border); border-radius:8px; padding:11px 14px;
    cursor:pointer; font-family:'REM',sans-serif; color:var(--charcoal); text-align:left;
  }
  .shop-filter-toggle-text{ color:var(--stone); }
  .shop-filter-toggle-text strong{ color:var(--gold-dark); font-weight:600; }
  .shop-filter-toggle-caret{ color:var(--stone); transition:transform 0.2s; }
  .shop-filter-toggle[aria-expanded="true"] .shop-filter-toggle-caret{ transform:rotate(180deg); }
  /* Kategorie-Pillen standardmaessig eingeklappt; nur bei geoeffnetem Toggle zeigen */
  .shop-filter-row{ display:none; }
  .shop-catalog-toolbar.filter-open .shop-filter-row{ display:flex; margin-top:4px; }
  /* Suche + Sortierung untereinander statt nebeneinander */
  .shop-search-row{ grid-template-columns:1fr; }
}

/* ===== Mobil: Bild-Lightbox als vollbreites Band (oben/unten frei) ===== */
@media (max-width:900px){
  .image-lightbox{ z-index:3000; padding:0; bottom:auto; height:100vh; height:100dvh; }
  /* Oben/unten NICHT abdunkeln: Backdrop transparent. Nur das Bildband ist dunkel.
     backdrop-filter entfernt (iOS). Tippen ausserhalb schliesst weiterhin. */
  .image-lightbox-backdrop{ background:transparent; -webkit-backdrop-filter:none; backdrop-filter:none; }
  /* Vollbreites, vertikal zentriertes Band; oben/unten bleibt die Seite sichtbar */
  .image-lightbox-dialog{ width:100vw; max-width:100vw; max-height:84vh; }
  .image-lightbox-stage img{ width:100%; max-height:70vh; }
}

/* ===== Startseite: Produktkacheln (direkter Einstieg in die Kategorien) ===== */
.home-products{ padding-top:56px; padding-bottom:8px; }
.prod-tile-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:18px; margin-top:32px; }
.prod-tile{
  display:flex; flex-direction:column; text-align:left;
  background:var(--warm-white); border:1px solid var(--border);
  padding:0; overflow:hidden; cursor:pointer; font-family:inherit;
  transition:border-color .15s, transform .15s, box-shadow .15s;
}
.prod-tile:hover{ border-color:var(--gold); transform:translateY(-2px); box-shadow:0 10px 24px rgba(0,0,0,0.08); }
.prod-tile-img{
  aspect-ratio:4/3; background:var(--slate); border-bottom:1px solid var(--border);
  padding:9%; overflow:hidden;
}
.prod-tile-img img{ width:100%; height:100%; object-fit:contain; display:block; }
.prod-tile-body{ display:flex; align-items:center; justify-content:space-between; gap:10px; padding:16px 18px; }
.prod-tile-name{ font-family:'REM',sans-serif; font-size:17px; font-weight:600; color:var(--charcoal); }
.prod-tile-cta{ font-size:13px; font-weight:600; color:var(--gold); white-space:nowrap; }
@media (max-width:900px){
  .home-products{ padding-top:36px; }
  .prod-tile-grid{ grid-template-columns:1fr 1fr; gap:12px; margin-top:22px; }
  .prod-tile-name{ font-size:15px; }
  /* Name und CTA untereinander, damit auf schmalen Kacheln nichts abschneidet */
  .prod-tile-body{ flex-direction:column; align-items:flex-start; gap:3px; padding:12px 14px; }
}

/* ===== Startseite: "Warum Stuckdiscount" (Trust-/Benefit-Kacheln) ===== */
.why-us{ padding-top:48px; padding-bottom:8px; }
.why-grid{ display:grid; grid-template-columns:repeat(3,1fr); gap:18px; margin-top:32px; }
.why-card{ background:var(--warm-white); border:1px solid var(--border); padding:28px 26px; }
.why-icon{ width:44px; height:44px; display:flex; align-items:center; justify-content:center; border:1px solid var(--gold); border-radius:50%; margin-bottom:16px; }
.why-icon svg{ width:22px; height:22px; stroke:var(--gold-dark); fill:none; stroke-width:1.6; stroke-linecap:round; stroke-linejoin:round; }
.why-card h3{ font-family:'REM',sans-serif; font-size:18px; font-weight:600; color:var(--charcoal); margin:0 0 8px; }
.why-card p{ color:var(--stone); line-height:1.7; margin:0; }
@media (max-width:900px){
  .why-us{ padding-top:34px; }
  .why-grid{ grid-template-columns:1fr; gap:12px; margin-top:22px; }
  .why-card{ padding:20px 18px; }
}
@media (min-width:601px) and (max-width:900px){
  .why-grid{ grid-template-columns:1fr 1fr; }
}

/* Produktkarte: schlanker Beratungs-/Anfrage-CTA unter der Kauf-Zeile */
.stuck-inquiry-btn{
  display:inline-flex; align-items:center; gap:7px; align-self:flex-start;
  background:none; border:0; padding:2px 0; margin:0; cursor:pointer;
  font-family:'REM',sans-serif; font-size:12.5px; font-weight:600;
  color:var(--gold-dark); text-align:left; transition:color .15s;
}
.stuck-inquiry-btn:hover{ color:var(--gold); }
.stuck-inquiry-btn svg{ width:15px; height:15px; stroke:currentColor; fill:none; stroke-width:1.7; stroke-linecap:round; stroke-linejoin:round; flex:none; }

/* Mobile "Wissen & Mehr"-Sheet (klappt ueber der unteren Tab-Leiste auf) */
.mobile-more-sheet{ display:none; }
@media (max-width:900px){
  .mobile-more-sheet{
    position:fixed; left:0; right:0; z-index:195;
    bottom:calc(var(--tabbar-h) + env(safe-area-inset-bottom));
    background:var(--slate);
    border-top:1px solid rgba(196,154,42,0.70);
    box-shadow:0 -8px 22px rgba(0,0,0,0.28);
    display:flex; flex-direction:column;
  }
  .mobile-more-sheet[hidden]{ display:none; }
  .mobile-more-link{
    display:block; width:100%; text-align:left; cursor:pointer;
    background:none; border:0; border-bottom:1px solid rgba(255,255,255,0.08);
    color:#E8D28A; font-family:'REM',sans-serif; font-size:15px; font-weight:600;
    padding:16px 20px; -webkit-tap-highlight-color:transparent;
  }
  .mobile-more-link:last-child{ border-bottom:0; }
  .mobile-more-link:active{ background:rgba(232,210,138,0.12); }
}

/* Startseite: rotierende Bilderwand (ersetzt den Hero-Slider). Kacheln fuellen
   per flex:1 immer die volle Breite -> keine grauen Raender; Anzahl steuert JS. */
.image-wall{ display:flex; gap:8px; width:100%; height:clamp(190px,22vw,300px); overflow:hidden; background:var(--slate); }
.image-wall-tile{ flex:1 1 0; min-width:0; position:relative; overflow:hidden; }
.image-wall-tile img{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; opacity:1; transition:opacity .5s ease; }
