:root{
  --teal:#0a9d90; --teal-d:#077a70; --teal-l:#e7f4f2;
  --grey:#8a8a8a; --grey-d:#6b6b6b;
  --ink:#16302e; --muted:#5d6b6a; --line:#e2eae9;
  --bg:#fff; --soft:#f4f8f8; --shadow:0 6px 24px rgba(16,48,46,.08); --shadow-lg:0 16px 44px rgba(16,48,46,.16);
}
*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}
html{scroll-behavior:smooth}
/* 100dvh statt 100vh — kein iOS-Safari-Bottom-Bar-Lag */
html,body{min-height:100dvh}
body{font-family:-apple-system,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;color:var(--ink);background:var(--bg);line-height:1.6;-webkit-font-smoothing:antialiased;overscroll-behavior-y:contain}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
svg{display:block}
.wrap{max-width:1180px;margin:0 auto;padding:0 24px}
.ico{width:18px;height:18px;flex:0 0 auto}
.btn{display:inline-flex;align-items:center;gap:9px;font-weight:700;font-size:.95rem;padding:13px 22px;border-radius:10px;border:0;cursor:pointer;transition:transform .15s,opacity .15s,background .18s,border-color .18s;min-height:44px}
.btn:active{transform:scale(0.97);opacity:.88}
.btn .ico{width:17px;height:17px}
.btn-teal{background:var(--teal);color:#fff}.btn-teal:hover{background:var(--teal-d);transform:translateY(-1px)}
.btn-ghost{background:#fff;color:var(--ink);border:1.5px solid var(--line)}.btn-ghost:hover{border-color:var(--teal);color:var(--teal-d)}
.btn-white{background:#fff;color:var(--teal-d)}.btn-white:hover{transform:translateY(-1px)}
.eyebrow{color:#056059;font-weight:800;text-transform:uppercase;letter-spacing:.08em;font-size:.78rem;display:inline-block;margin-bottom:6px}
h2.section-title{font-size:clamp(1.65rem,5vw,2.15rem);line-height:1.1;margin:0 0 14px;letter-spacing:-.03em;font-weight:700}
.section{padding:96px 0}
.section + .section{padding-top:0}
.muted{color:var(--muted);line-height:1.65}
/* Klarer Lead-Text unter section-title */
.section-lead{color:var(--muted);font-size:1.05rem;line-height:1.65;max-width:62ch;margin:0 auto}
@media(max-width:880px){.section{padding:64px 0}}
@media(max-width:560px){.section{padding:52px 0}}

/* Topbar */
.topbar{background:var(--teal-d);color:#dff3f0;font-size:.84rem}
.topbar .wrap{display:flex;justify-content:space-between;align-items:center;height:42px;gap:16px}
.topbar .left{display:flex;align-items:center;gap:18px}
.topbar .social{display:flex;gap:12px}
/* Social-Icon Touch-Targets: 17px Icon in 44px Tap-Flaeche einbetten */
.topbar .social a{color:#cdeae6;display:flex;align-items:center;justify-content:center;min-width:44px;min-height:44px;margin:-13px -6px;touch-action:manipulation;-webkit-tap-highlight-color:rgba(255,255,255,.15)}.topbar .social a:hover{color:#fff}
.topbar .social a svg{pointer-events:none}
.topbar .tel{touch-action:manipulation}
.topbar .tel .ico,.topbar .tel span{pointer-events:none}
.topbar .social .ico{width:17px;height:17px}
/* Telefon-Link Touch-Target */
.topbar .tel{display:flex;align-items:center;gap:7px;color:#eafaf8;font-weight:600;min-height:44px}
.topbar .tel .ico{width:15px;height:15px}
.langdrop{position:relative}
/* Sprach-Dropdown-Button: min 44px hoch (WCAG 2.5.8) */
.langdrop>button{background:rgba(255,255,255,.14);color:#eafaf8;border:0;padding:10px 12px;border-radius:7px;font-family:inherit;font-size:.83rem;font-weight:600;cursor:pointer;display:inline-flex;gap:7px;align-items:center;min-height:44px}
.langdrop>button:hover{background:rgba(255,255,255,.24)}
.langdrop>button .ico{width:15px;height:15px}
.langdrop .menu{position:absolute;right:0;top:calc(100% + 4px);background:#fff;color:var(--ink);border:1px solid var(--line);border-radius:11px;box-shadow:var(--shadow-lg);min-width:170px;padding:6px;display:none;z-index:60}
.langdrop.open .menu{display:block}
/* Dropdown-Items: 44px min-height */
.langdrop .menu a{display:flex;align-items:center;min-height:44px;padding:0 13px;border-radius:8px;font-weight:600;font-size:.92rem;cursor:pointer}
.langdrop .menu a:hover{background:var(--teal-l);color:var(--teal-d)}
.langdrop .menu a.active{color:var(--teal-d);background:var(--teal-l)}

/* Header */
header.site{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.97);backdrop-filter:saturate(180%) blur(8px);border-bottom:1px solid var(--line)}
header.site .wrap{display:flex;align-items:center;justify-content:space-between;height:72px;gap:24px}
/* Logo etwas kleiner damit Kontakt-Button und Hamburger mehr Luft haben */
header.site img.logo{height:50px;width:auto}
header.site .header-cta{margin-left:6px}
/* Mobile: Header schlanker — Kontakt-Button raus (im Burger-Menue eh erreichbar), Logo etwas grosser */
@media(max-width:880px){header.site .header-cta{display:none}}
@media(max-width:880px){header.site .wrap{gap:12px;height:64px} header.site img.logo{height:42px}}
nav.main{display:flex;gap:26px;margin-left:auto}
nav.main a{font-weight:600;font-size:.96rem;padding:6px 0;position:relative;color:#2b403e}
nav.main a:hover,nav.main a.active{color:var(--teal-d)}
nav.main a::after{content:"";position:absolute;left:0;bottom:-2px;height:2px;width:0;background:var(--teal);transition:.2s}
nav.main a:hover::after,nav.main a.active::after{width:100%}
/* Hamburger: 44px Touch-Target (Apple HIG) */
.menu-btn{display:none;background:none;border:0;cursor:pointer;color:var(--ink);min-width:44px;min-height:44px;align-items:center;justify-content:center}.menu-btn .ico{width:28px;height:28px}

/* Hero — dvh statt vh damit iOS-Safari-URL-Bar nicht Hoehe aufblaest */
.hero{position:relative;height:min(82dvh,640px);overflow:hidden;background:#0c2b29}
.hero .slide{position:absolute;inset:0;opacity:0;transition:opacity 1s ease;background-size:cover;background-position:center}
.hero .slide.on{opacity:1}
.hero::after{content:"";position:absolute;inset:0;background:linear-gradient(100deg,rgba(7,42,40,.86) 0%,rgba(7,42,40,.55) 45%,rgba(10,157,144,.18) 100%)}
.hero .content{position:absolute;inset:0;z-index:3;display:flex;align-items:center}
.hero h1{color:#fff;font-size:clamp(2rem,4.6vw,3.5rem);line-height:1.08;letter-spacing:-.02em;max-width:760px;text-shadow:0 2px 20px rgba(0,0,0,.25)}
.hero p.sub{color:#dff3f0;font-size:1.2rem;max-width:600px;margin:18px 0 28px}
.hero .cta{display:flex;gap:12px;flex-wrap:wrap}
.dots{position:absolute;bottom:18px;left:0;right:0;z-index:4;display:flex;gap:8px;justify-content:center;padding:0 20px}
.dots button{box-sizing:border-box;width:6px;height:6px;border-radius:50%;border:0;background:rgba(255,255,255,.42);cursor:pointer;padding:0;transition:background .25s, transform .25s;flex:0 0 auto}
.dots button:hover{background:rgba(255,255,255,.7)}
.dots button.on{background:rgba(255,255,255,.95);transform:scale(1.25)}
@media(max-width:880px){
  .dots{gap:7px}
  .dots button{width:5px;height:5px}
}

/* Page hero (Unterseiten) */
.phero{background:linear-gradient(120deg,var(--teal-d),var(--teal));color:#fff;padding:54px 0 48px}
.phero .crumb{font-size:.82rem;color:#bdeee8;margin-bottom:10px}
.phero .crumb a{color:#dff3f0}
.phero h1{font-size:clamp(1.8rem,3.6vw,2.7rem);letter-spacing:-.01em}
.phero p{color:#dff3f0;max-width:680px;margin-top:8px;font-size:1.08rem}

/* Bereiche / Karten */
.grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.card{background:#fff;border:1px solid var(--line);border-radius:16px;overflow:hidden;box-shadow:var(--shadow);transition:transform .2s,box-shadow .2s,border-color .2s;display:flex;flex-direction:column}
.card:active{transform:scale(0.985);box-shadow:var(--shadow)}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:#cfe6e3}
.card .pic{height:220px;display:flex;align-items:center;justify-content:center;background:var(--soft);border-bottom:1px solid var(--line);transition:.4s;overflow:hidden}
/* Foto-Variante (Bereich-Cards mit Header-Bild): cover statt contain */
.card .pic.photo{background-size:cover;background-position:center;background-repeat:no-repeat}
.card:hover .pic.photo{transform:scale(1.03)}
/* Icon-Variante (Fallback fuer kleine CAD-PNGs) */
.card .pic img{max-height:140px;width:auto;transition:transform .35s ease}
.card:hover .pic:not(.photo){background:var(--teal-l)}
.card:hover .pic img{transform:scale(1.04)}
@media(max-width:880px){.card .pic{height:200px}.card .pic img{max-height:120px}}
@media(max-width:560px){.card .pic{height:180px}}
.card .body{padding:26px 24px 24px;display:flex;flex-direction:column;flex:1;gap:8px}
.card h3{font-size:1.22rem;margin:0;letter-spacing:-.015em;line-height:1.25}
.card p{color:var(--muted);font-size:.94rem;flex:1;line-height:1.6;margin:0}
.card .more{margin-top:14px;color:var(--teal-d);font-weight:700;font-size:.86rem;letter-spacing:.02em;display:inline-flex;align-items:center;gap:4px;transition:gap .2s}
.card:hover .more{gap:8px}
.card .more{margin-top:14px;color:var(--teal-d);font-weight:700;font-size:.92rem}

/* USP */
.usp-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:38px}
.usp{display:flex;flex-direction:column;gap:12px}
.usp .ic{width:52px;height:52px;border-radius:14px;background:var(--soft);display:flex;align-items:center;justify-content:center;color:var(--grey-d);border:1px solid var(--line)}
.usp .ic .ico{width:24px;height:24px}
.usp b{font-size:1.05rem;letter-spacing:-.01em}
.usp span{color:var(--muted);font-size:.93rem;line-height:1.6}

/* Service band */
.band{background:linear-gradient(120deg,var(--teal-d),var(--teal));color:#fff;padding:92px 0}
@media(max-width:880px){.band{padding:64px 0}}
.band .wrap{padding:60px 24px}
.band .head{text-align:center;max-width:660px;margin:0 auto 48px}
.band .head h2{font-size:clamp(1.75rem,4.2vw,2.15rem);letter-spacing:-.025em;line-height:1.1}
.band .head .eyebrow{color:#bdeee8}
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.svc{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.16);border-radius:16px;padding:28px 26px;text-decoration:none;color:inherit;display:block;transition:.25s;position:relative}
.svc:hover{background:rgba(255,255,255,.18);border-color:rgba(255,255,255,.35);transform:translateY(-3px)}
.svc:active{transform:scale(0.97)}
.svc .ic{width:42px;height:42px;border-radius:11px;background:rgba(255,255,255,.16);display:flex;align-items:center;justify-content:center;margin-bottom:14px;transition:.2s}
.svc:hover .ic{background:rgba(255,255,255,.28)}
.svc .ic .ico{width:22px;height:22px;color:#fff}
.svc h4{font-size:1.1rem;margin-bottom:5px;color:#fff}
.svc p{color:#dff3f0;font-size:.92rem;margin-bottom:14px}
.svc .svc-more{font-size:.85rem;font-weight:700;color:#a8e4dc;display:inline-flex;align-items:center;gap:4px;transition:gap .2s}
.svc:hover .svc-more{gap:8px;color:#fff}
/* Light-Variante auf der Service-Übersichtsseite (über soft-Hintergrund) */
.svc.light{background:var(--soft);border-color:var(--line)}
.svc.light:hover{background:#fff;border-color:var(--teal-l);box-shadow:var(--shadow)}
.svc.light .ic{background:var(--teal-l)}
.svc.light .ic .ico{color:var(--teal-d)}
.svc.light h4{color:var(--ink)}
.svc.light p{color:var(--muted)}
.svc.light .svc-more{color:var(--teal-d)}

/* News */
.news{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.news .item{border:1px solid var(--line);border-radius:14px;overflow:hidden;background:#fff;transition:.2s}
.news .item:hover{box-shadow:var(--shadow);transform:translateY(-3px)}
.news .item:active{transform:scale(0.985)}
.news .item .pic{height:150px;background:var(--soft) center/cover}
.news .item .tx{padding:18px}
.news .date{color:var(--teal-d);font-weight:700;font-size:.8rem;text-transform:uppercase;letter-spacing:.05em}
.news h4{margin:5px 0 6px;font-size:1.06rem}

/* Produkt-Detail / Prose */
.split{display:grid;grid-template-columns:1.2fr .8fr;gap:48px;align-items:start}
.prose p{margin-bottom:14px;color:#33433f}
.prose ul{margin:0 0 16px 20px;color:#33433f}
.prose li{margin-bottom:6px}
.prose h3{margin:22px 0 8px;font-size:1.25rem}
.aside{background:var(--soft);border:1px solid var(--line);border-radius:16px;padding:24px;position:sticky;top:108px}
.aside h4{font-size:1.05rem;margin-bottom:10px}
.aside .b{display:block;margin-top:10px}
.gallery{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:12px;margin-top:18px}
.gallery img{border-radius:12px;border:1px solid var(--line);background:var(--soft);width:100%;height:120px;object-fit:contain;padding:8px}

/* Listen (Downloads/Partner) */
.list{border:1px solid var(--line);border-radius:14px;overflow:hidden}
.list .row{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:16px 20px;border-bottom:1px solid var(--line);min-height:56px}
.list .row:last-child{border-bottom:0}
.list .row:hover{background:var(--soft)}
.list .row:active{background:var(--teal-l)}
.list .row .ico{color:var(--teal-d)}
/* Karriere-Bewerben-Link: eigener Touch-Target */
.list .row a{min-height:44px;display:inline-flex;align-items:center}

/* Kontaktformular */
.kontakt{display:grid;grid-template-columns:.9fr 1.1fr;gap:48px;align-items:start}
.kontakt .info .line{display:flex;align-items:center;gap:10px;color:var(--muted);margin-top:8px;min-height:44px}
.kontakt .info .line .ico{width:18px;height:18px;color:var(--grey-d)}
.cform{background:#fff;border:1px solid var(--line);border-radius:16px;padding:26px;box-shadow:var(--shadow)}
.cform .r2{display:grid;grid-template-columns:1fr 1fr;gap:12px}
/* font-size:16px verhindert iOS-Auto-Zoom beim Fokus (KRITISCH) */
/* min-height:44px auf select/input sichert WCAG 2.5.8 Touch-Target */
.cform input,.cform select,.cform textarea{width:100%;padding:12px 14px;border:1.5px solid var(--line);border-radius:9px;font-family:inherit;font-size:16px;margin-bottom:12px;background:#fff;color:var(--ink);min-height:44px}
/* WebKit rendert <select> nativ — appearance:none + padding erzwingt 44px Hoehe */
.cform select{-webkit-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%238a8a8a' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:38px}
.cform input:focus,.cform select:focus,.cform textarea:focus{outline:0;border-color:var(--teal)}
.cform textarea{min-height:120px;resize:vertical}
/* Checkbox-Zeile: min-height:44px damit Checkbox leicht antippbar */
.cform .chk{display:flex;gap:9px;align-items:flex-start;font-size:.85rem;color:var(--muted);margin-bottom:14px;min-height:44px;padding:4px 0}
.cform .chk input[type=checkbox]{width:20px;height:20px;min-width:20px;margin:2px 0 0;cursor:pointer;accent-color:var(--teal)}
.cform .file{border:1.5px dashed var(--line);border-radius:9px;padding:16px;text-align:center;color:var(--muted);margin-bottom:12px;overflow:hidden}
.cform .file label{display:block;max-width:100%;white-space:normal;word-break:break-word}

/* Footer */
footer{background:#0e2624;color:#bcd4d1;padding:76px 0 30px;font-size:.93rem}
footer .cols{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:48px}
footer h5{color:#fff;font-size:.74rem;text-transform:uppercase;letter-spacing:.12em;margin-bottom:18px;font-weight:700;opacity:.85}
/* Footer-Links: min-height 44px fuer sicheres Antippen */
footer a{display:flex;align-items:center;min-height:44px;padding:0;color:#bcd4d1;line-height:1.3}footer a:hover{color:var(--teal)}
footer .logo-f{height:42px;margin-bottom:16px;background:#fff;padding:9px 13px;border-radius:10px}
footer .fline{display:flex;align-items:center;gap:9px;padding:4px 0;min-height:44px}
footer .fline .ico{width:16px;height:16px;color:var(--teal);flex:0 0 auto}
footer .bottom{border-top:1px solid rgba(255,255,255,.1);margin-top:40px;padding-top:18px;display:flex;justify-content:space-between;gap:14px;flex-wrap:wrap;color:#8fb0ac;font-size:.85rem}

@media(max-width:880px){
  nav.main{display:none}
  /* Hamburger: flex statt block damit align-items/justify-content greifen */
  .menu-btn{display:flex}
  /* Topbar auf Mobile: nur Social-Icons + Sprach-Dropdown, Telefon-Nummer weg (Platz) */
  .topbar .tel span{display:none}
  /* Topbar social-Abstands-Kompensation rueckgaengig fuer kleine Screens */
  .topbar .social a{min-width:40px;min-height:40px;margin:-10px -2px}
  /* Topbar muss Tap-Area-Overflow erlauben */
  .topbar{overflow:visible}
  .topbar .wrap{overflow:visible}
  .grid,.news,.usp-grid,.svc-grid,.kontakt,.split{grid-template-columns:1fr}
  .usp-grid{grid-template-columns:1fr 1fr}
  footer .cols{grid-template-columns:1fr 1fr;gap:20px}
  footer .cols > *{min-width:0}
  /* Section-Padding mobil kompakter */
  .section{padding:42px 0}
  .phero{padding:36px 0 30px}
  .aside{position:static}
  /* Kontaktformular: 2-spaltige Eingabe-Zeile auf Mobile 1-spaltig */
  .cform .r2{grid-template-columns:1fr}
  /* Hero auf Mobile: Split-Layout — Bild oben (ganze Maschine sichtbar), Text darunter */
  .hero{height:auto;min-height:0;display:flex;flex-direction:column;background:#0c2b29}
  .hero .slide{position:relative;inset:auto;width:100%;height:260px;background-size:cover;background-position:center;flex:0 0 auto}
  .hero .slide.on{opacity:1}
  .hero .slide:not(.on){display:none}
  .hero::after{display:none}
  .hero .content{position:relative;inset:auto;background:#0c2b29;padding:24px 0 28px;display:block;align-items:initial}
  .hero h1{font-size:clamp(1.65rem,6.8vw,2.3rem);line-height:1.14;letter-spacing:-.015em}
  .hero p.sub{font-size:.94rem;margin:10px 0 18px;line-height:1.5;max-width:none}
  .hero .eyebrow{font-size:.72rem;letter-spacing:.12em;color:#7fe0d6 !important}
  .hero .cta{gap:10px;flex-wrap:nowrap}
  .hero .cta .btn{flex:1 1 0;justify-content:center;padding:13px 14px;font-size:.92rem}
  /* Dots am Slide-Unterrand (innerhalb des Bildes) */
  .dots{bottom:auto;top:236px;padding:0 16px}
  /* Karriere: "Jetzt bewerben"-Spans sollen klickbar wirken */
  .list .row{flex-wrap:wrap;gap:8px}
  /* Footer-Links kompakter auf Mobile */
  footer a{min-height:40px}
  footer .fline{min-height:40px}
}

/* Topbar auf sehr kleinen Screens (375px): Social ausblenden, nur Tel+Lang */
@media(max-width:480px){
  .topbar .left{gap:8px}
  .topbar .social{gap:6px}
  /* Topbar kompakter auf kleinen Screens: 42px -> 36px */
  .topbar .wrap{height:36px}
  /* Social-Icons: negative margin kompensiert den kompakten topbar, echte Hit-Area 40px */
  .topbar .social a{min-width:36px;min-height:36px;margin:-6px -3px}
}

/* Focus-Ring fuer Keyboard/Switch-Nutzer (WCAG 2.4.7) */
a:focus-visible,button:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible{
  outline:3px solid var(--teal);outline-offset:2px;border-radius:4px
}

/* Reduced Motion (WCAG 2.3.3) */
@media(prefers-reduced-motion:reduce){
  *{animation-duration:.01ms !important;transition-duration:.01ms !important}
  html{scroll-behavior:auto}
}
/* Skip-Link */
.skip-link{position:absolute;left:12px;top:-120%;background:var(--teal-d);color:#fff;padding:10px 16px;border-radius:0 0 8px 8px;font-weight:700;z-index:9999}
.skip-link:focus{top:0}
/* Screen-reader-only */
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
/* Mobiles Menü: Hamburger öffnet die Navigation */
@media(max-width:880px){
  header.site.menu-open nav.main{display:flex;flex-direction:column;gap:2px;position:absolute;top:72px;left:0;right:0;background:#fff;padding:12px 24px 18px;border-bottom:1px solid var(--line);box-shadow:var(--shadow)}
  header.site.menu-open nav.main a{padding:12px 0;font-size:1.02rem}
  /* Breadcrumb: 44px min-height via padding (Apple HIG 44pt) */
  .phero .crumb a{display:inline-flex;align-items:center;min-height:44px;padding:0 4px 0 0}
  /* Sitemap: Links in Listen haben nur Zeilenhöhe — auf 44px Touch-Target aufweiten */
  .prose li a{display:inline-flex;align-items:center;min-height:44px}
}

/* ============ Phase 0: Produkt-Detail + Partner ============ */
/* Galerie */
.gmain{width:100%;aspect-ratio:16/10;object-fit:contain;background:var(--soft);border:1px solid var(--line);border-radius:16px;margin-bottom:14px;padding:18px;max-height:520px}
.gmain.solo{margin-bottom:22px}
/* Wenn echtes Foto (kein CAD-Icon): nutze cover statt contain */
.gmain[data-fit="cover"]{object-fit:cover;padding:0}
.pgallery{margin-bottom:22px}
.gthumbs{display:flex;gap:10px;overflow-x:auto;padding-bottom:4px;-webkit-overflow-scrolling:touch;touch-action:pan-x;scrollbar-width:none}
.gthumbs::-webkit-scrollbar{display:none}
.gthumb{flex:0 0 auto;width:72px;height:54px;padding:0;border:2px solid var(--line);border-radius:9px;overflow:hidden;background:var(--soft);cursor:pointer;transition:.15s}
.gthumb img{width:100%;height:100%;object-fit:contain}
.gthumb.on,.gthumb:hover{border-color:var(--teal)}
/* Produkt-Abschnitts-Überschriften */
.prose h3{font-size:1.2rem;margin:30px 0 12px;color:var(--ink)}
.prose ul{margin:0 0 6px;padding-left:20px}.prose li{margin-bottom:6px;color:#33433f}
/* Specs-Tabelle */
.spectable{border:1px solid var(--line);border-radius:12px;overflow:hidden}
.specrow{display:flex;justify-content:space-between;gap:16px;padding:11px 15px;border-bottom:1px solid var(--line);font-size:.95rem}
.specrow:last-child{border-bottom:0}
.specrow:nth-child(odd){background:var(--soft)}
.specl{color:var(--muted);flex:0 0 auto;max-width:48%}
.specv{font-weight:600;text-align:right}
/* Varianten-Accordion */
.accordion{border:1px solid var(--line);border-radius:12px;overflow:hidden}
.acc-item{border-bottom:1px solid var(--line)}.acc-item:last-child{border-bottom:0}
.acc-head{width:100%;display:flex;align-items:center;justify-content:space-between;gap:12px;padding:15px 16px;background:#fff;border:0;cursor:pointer;font-weight:700;font-size:1rem;color:var(--ink);text-align:left;min-height:52px}
.acc-head:hover{background:var(--soft)}
.acc-ic{flex:0 0 auto;width:24px;height:24px;border-radius:50%;background:var(--teal-l);color:var(--teal-d);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1.2rem;line-height:1}
.acc-ic::before{content:"+"}
.acc-item.open .acc-ic{background:var(--teal);color:#fff}
.acc-item.open .acc-ic::before{content:"–"}
.acc-body{max-height:0;overflow:hidden;transition:max-height .25s ease}
.acc-item.open .acc-body{max-height:600px}
.acc-body .spectable{border:0;border-radius:0;border-top:1px solid var(--line)}
/* Produkt-Video */
.pvideo{position:relative;width:100%;padding-bottom:56.25%;border-radius:16px;overflow:hidden;background:var(--soft)}
.pvideo iframe{position:absolute;inset:0;width:100%;height:100%;border:0}
/* Referenzen-Grid */
.refgrid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:14px}
.refcard{display:flex;flex-direction:column;border:1px solid var(--line);border-radius:12px;overflow:hidden;background:#fff;transition:.18s}
.refcard:hover{box-shadow:var(--shadow);transform:translateY(-2px);border-color:#cfe6e3}
.refcard:active{transform:scale(0.97)}
.refcard .pic{display:block;height:96px;background:var(--soft) center/cover}
.refcard .rt{padding:10px 12px;font-size:.9rem;font-weight:600;color:var(--ink)}
/* Demo-Hinweis */
.demo-note{margin-top:24px;padding:11px 14px;background:var(--soft);border-left:3px solid var(--teal);border-radius:8px;font-size:.86rem;color:var(--muted);font-style:italic}
/* Vertriebspartner-Karten */
.pgrid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:20px}
.pcard{background:#fff;border:1px solid var(--line);border-radius:16px;padding:20px;box-shadow:var(--shadow)}
.pcard.gesucht{background:var(--soft);border-style:dashed}
.phead{display:flex;align-items:center;gap:12px;margin-bottom:14px}
.plogo{flex:0 0 auto;width:46px;height:46px;border-radius:11px;background:var(--teal);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:1rem;letter-spacing:.02em}
.pcard.gesucht .plogo{background:var(--grey)}
.pland{font-weight:800;font-size:1.08rem}
.pbadge{font-size:.72rem;text-transform:uppercase;letter-spacing:.05em;font-weight:700;color:var(--teal-d)}
.pcard.gesucht .pbadge{color:var(--grey-d)}
.pname{font-weight:600;margin-bottom:10px}
.pmeta{display:flex;align-items:center;gap:9px;color:var(--muted);font-size:.9rem;margin-bottom:7px}
.pmeta .ico{color:var(--teal-d);flex:0 0 auto}
.pcontacts{display:flex;flex-direction:column;gap:7px;margin-top:13px;padding-top:13px;border-top:1px solid var(--line)}
.pcontact{display:flex;align-items:center;gap:9px;color:var(--teal-d);font-weight:700;font-size:.92rem;min-height:44px}
.pcontact .ico{flex:0 0 auto}
.pcta{display:flex;align-items:center;justify-content:space-between;gap:18px;flex-wrap:wrap;margin-top:30px;padding:22px 24px;background:var(--teal-l);border-radius:16px}
.pcta .btn{flex:0 0 auto}

/* ============ Phase 0b: Service/Referenzen/Aktuelles ============ */
/* Zwei Formulare nebeneinander, mobil gestapelt */
.form2{display:grid;grid-template-columns:1fr 1fr;gap:24px}
@media(max-width:880px){.form2{grid-template-columns:1fr}}
/* Referenz-Karten: Kategorie-Tag + Meta-Zeilen */
.reftag{display:inline-block;background:var(--teal-l);color:var(--teal-d);font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em;padding:3px 9px;border-radius:999px}
.refmeta{display:flex;align-items:center;gap:8px;color:var(--muted);font-size:.88rem;margin-top:5px}
.refmeta .ico{width:16px;height:16px;color:var(--teal-d);flex:0 0 auto}
/* Messetermine */
.messe-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:16px}
.messe{display:flex;align-items:center;gap:13px;background:var(--soft);border:1px solid var(--line);border-radius:12px;padding:16px 18px}
.messe .md{flex:0 0 auto;width:40px;height:40px;border-radius:10px;background:var(--teal-l);display:flex;align-items:center;justify-content:center}
.messe .md .ico{color:var(--teal-d)}

/* Nav-Start-Icon (Home in der Tab-Bar) */
nav.main a.nav-home{display:inline-flex;align-items:center;gap:6px}
nav.main a.nav-home svg{width:16px;height:16px;flex:0 0 16px}

/* Cookie-Banner (DSGVO) */
.cookie-banner{position:fixed;left:0;right:0;bottom:0;background:rgba(14,38,36,.97);color:#fff;padding:14px 16px;z-index:1000;box-shadow:0 -4px 24px rgba(0,0,0,.18);backdrop-filter:blur(8px)}
.cookie-banner .wrap{max-width:1200px;margin:0 auto}
.cookie-banner p{color:#e8faf8}
.cookie-banner a{color:#7fe0d6;text-decoration:underline}
/* btn-teal im Cookie-Banner: min-height:44px — WCAG 2.5.8 */
.cookie-banner .btn-teal{background:var(--teal-l);color:var(--teal-d);min-height:44px}
.cookie-banner .btn-teal:hover{background:#fff}
@media(max-width:560px){
  .cookie-banner{padding:10px 12px}
  .cookie-banner .wrap{flex-direction:row !important;flex-wrap:nowrap !important;align-items:center !important;gap:10px;text-align:left}
  .cookie-banner p{font-size:.8rem;line-height:1.35;flex:1;min-width:0}
  .cookie-banner .btn-teal{flex:0 0 auto;white-space:nowrap;padding:10px 14px;font-size:.85rem;min-height:40px}
}

/* Footer-Social-Icons: 44x44 Touch-Target (Apple HIG) */
.social-foot a{display:inline-flex;align-items:center;justify-content:center;min-width:44px;min-height:44px;border-radius:7px;background:rgba(255,255,255,.08);color:#cfd8d6;transition:background .15s}
.social-foot a:hover{background:rgba(255,255,255,.18);color:#fff}
