@font-face {
	font-weight: normal;
	font-style: normal;
	font-family: "woodmart-font";
	src: url("//protrocknung.de/wp-content/themes/woodmart/fonts/woodmart-font-1-400.woff2?v=8.3.5") format("woff2");
}

:root {
	--wd-text-font: "Lato", Arial, Helvetica, sans-serif;
	--wd-text-font-weight: 400;
	--wd-text-color: rgb(43,43,43);
	--wd-text-font-size: 14px;
	--wd-title-font: "Poppins", Arial, Helvetica, sans-serif;
	--wd-title-font-weight: 600;
	--wd-title-color: #242424;
	--wd-entities-title-font: "Poppins", Arial, Helvetica, sans-serif;
	--wd-entities-title-font-weight: 500;
	--wd-entities-title-color: rgb(0,0,0);
	--wd-entities-title-color-hover: rgb(135, 139, 142);
	--wd-alternative-font: "Lato", Arial, Helvetica, sans-serif;
	--wd-widget-title-font: "Poppins", Arial, Helvetica, sans-serif;
	--wd-widget-title-font-weight: 600;
	--wd-widget-title-transform: uppercase;
	--wd-widget-title-color: rgb(0,0,0);
	--wd-widget-title-font-size: 16px;
	--wd-header-el-font: "Lato", Arial, Helvetica, sans-serif;
	--wd-header-el-font-weight: 700;
	--wd-header-el-transform: uppercase;
	--wd-header-el-font-size: 13px;
	--wd-otl-style: dotted;
	--wd-otl-width: 2px;
	--wd-primary-color: rgb(30,115,190);
	--wd-alternative-color: rgb(0,75,188);
	--btn-default-bgcolor: rgb(255,255,255);
	--btn-default-bgcolor-hover: rgb(239,239,239);
	--btn-accented-bgcolor: rgb(129,215,66);
	--btn-accented-bgcolor-hover: #74a32f;
	--wd-form-brd-width: 2px;
	--notices-success-bg: #459647;
	--notices-success-color: #fff;
	--notices-warning-bg: #E0B252;
	--notices-warning-color: #fff;
	--wd-link-color: rgb(30,115,190);
	--wd-link-color-hover: rgb(30,84,191);
}
.wd-age-verify-wrap {
	--wd-popup-width: 500px;
}
.wd-popup.wd-promo-popup {
	background-color: #111111;
	background-image: none;
	background-repeat: no-repeat;
	background-size: contain;
	background-position: left center;
}
.wd-promo-popup-wrap {
	--wd-popup-width: 800px;
}
:is(.woodmart-woocommerce-layered-nav, .wd-product-category-filter) .wd-scroll-content {
	max-height: 223px;
}
.wd-page-title .wd-page-title-bg img {
	object-fit: cover;
	object-position: center center;
}
.wd-footer {
	background-color: rgb(55,123,191);
	background-image: none;
}
html .wd-nav.wd-nav-main > li > a {
	font-size: 16px;
	color: rgb(0,0,0);
}
html .wd-nav.wd-nav-main > li:hover > a, html .wd-nav.wd-nav-main > li.current-menu-item > a {
	color: rgb(30,115,190);
}
 {
	background: rgb(255,255,255);
}
.page .wd-page-content {
	background-color: rgb(249,249,249);
	background-image: none;
}
body, [class*=color-scheme-light], [class*=color-scheme-dark], .wd-search-form[class*="wd-header-search-form"] form.searchform, .wd-el-search .searchform {
	--wd-form-color: rgb(255,255,255);
}
.mfp-wrap.wd-popup-quick-view-wrap {
	--wd-popup-width: 920px;
}
:root{
--wd-container-w: 1222px;
--wd-form-brd-radius: 0px;
--btn-default-color: #fff;
--btn-default-color-hover: #fff;
--btn-accented-color: #fff;
--btn-accented-color-hover: #fff;
--btn-default-brd-radius: 35px;
--btn-default-box-shadow: none;
--btn-default-box-shadow-hover: none;
--btn-accented-brd-radius: 35px;
--btn-accented-box-shadow: none;
--btn-accented-box-shadow-hover: none;
--wd-brd-radius: 12px;
}

@media (min-width: 1222px) {
[data-vc-full-width]:not([data-vc-stretch-content]),
:is(.vc_section, .vc_row).wd-section-stretch {
padding-left: calc((100vw - 1222px - var(--wd-sticky-nav-w) - var(--wd-scroll-w)) / 2);
padding-right: calc((100vw - 1222px - var(--wd-sticky-nav-w) - var(--wd-scroll-w)) / 2);
}
}


.wd-page-title {
background-color: rgb(10,10,10);
}

#ueberuns {
  position: relative;
  border-radius: 12px;

  /* Immer gleich → Text bewegt sich nie */
  padding-left: 12px;
  border-left: 3px solid transparent;

  transition: box-shadow 0.5s ease, border-color 0.5s ease;
}

#ueberuns.highlight {
  border-left-color: #ffd700; /* nur Farbe ändern → kein Ruckeln */

  /* Weicher runder Glow */
  box-shadow:
    0 0 25px 10px rgba(255, 215, 0, 0.45),
    0 0 45px 18px rgba(255, 215, 0, 0.25);

  background-color: transparent;
}

body.single-post .wd-entities-title.wd-post-title.title,
body.single-post .wd-post-meta {
    display: none !important;
}


.single-post .single-post-top-shape-row {
	margin-top: -60px !important;
	margin-bottom: 0 !important;
	line-height: 0;
	position: relative;
	z-index: 30;
	overflow: visible;
}

.single-post .single-post-top-shape-row + .vc_row-full-width {
	margin: 0 !important;
}

.single-post .single-post-top-shape-row > .single-post-top-shape-col,
.single-post .single-post-top-shape-row > .single-post-top-shape-col > .vc_column-inner,
.single-post .single-post-top-shape-row > .single-post-top-shape-col > .vc_column-inner > .wpb_wrapper {
	margin: 0 !important;
	padding: 0 !important;
}

.single-post .single-post-top-shape-row .woodmart-row-gradient {
	position: absolute;
	inset: 0;
}

.single-post #wd-6970486ed0aa8 {
	margin: 0 !important;
	line-height: 0;
}

.single-post #wd-6970486ed0aa8 svg {
	display: block;
	width: 100%;
	height: 50px;
}

.single-post #wd-6970486ed0aa8 path {
	fill: #ffffff !important;
}

.single-post article.post-single-page,
.single-post .wd-single-post-header,
.single-post .wd-single-post-header .wd-post-image,
.single-post .wd-entry-content {
	margin-top: 0 !important;
	padding-top: 0 !important;
}


/* Mobile: Timeline (primary + secondary)
   - Bild unter Text
   - KEINE Punkte
   - KEINE vertikale Linie
   - Horizontale Linie NUR unter dem Titel
*/
@media (max-width: 768px) {

  /* Für beide Spalten: primary + secondary */
  .timeline-col.timeline-col-primary,
  .timeline-col.timeline-col-secondary {
    display: flex;
    flex-direction: column;
  }

  /* Reihenfolge: Titel -> Content -> Bild */
  .timeline-col.timeline-col-primary .wd-timeline-title,
  .timeline-col.timeline-col-secondary .wd-timeline-title {
    order: 1;
    position: relative; /* nötig für ::after */
  }

  .timeline-col.timeline-col-primary .wd-timeline-content,
  .timeline-col.timeline-col-secondary .wd-timeline-content {
    order: 2;
  }

  .timeline-col.timeline-col-primary .wd-timeline-image,
  .timeline-col.timeline-col-secondary .wd-timeline-image {
    order: 3;
    margin-top: 20px;
  }

  /* Original Woodmart Timeline (Linie + Punkte) komplett weg */
  .woodmart-timeline-line,
  .woodmart-timeline-line *,
  .woodmart-timeline-dot,
  .woodmart-timeline-dot::before,
  .woodmart-timeline-dot::after,
  .wd-timeline-dot,
  .wd-timeline-dot::before,
  .wd-timeline-dot::after,
  .line-dot,
  .line-dot::before,
  .line-dot::after,
  .timeline-arrow,
  .timeline-arrow::before,
  .timeline-arrow::after,
  .timeline-col::before,
  .timeline-col::after {
    display: none !important;
    content: none !important;
  }

  /* Eigene Linie NUR unter dem Titel (mittig) */
  .timeline-col.timeline-col-primary .wd-timeline-title::after,
  .timeline-col.timeline-col-secondary .wd-timeline-title::after {
    content: "";
    display: block;
    width: 100%;
    max-width: 180px;          /* Länge */
    height: 3px;               /* Dicke */
    background: rgba(0,0,0,0.15);
    margin: 12px auto 16px;    /* mittig */
    border-radius: 3px;
  }

}

============================================================
TEIL 1: CSS — IM WORDPRESS CUSTOMIZER EINFÜGEN
(Design → Customizer → Zusätzliches CSS → Veröffentlichen)
============================================================

/* === WICHTIG: Damit der CTA volle Breite erreicht === */
.vc_row {
  overflow: visible !important;
}

/* Padding der Spalte entfernen wo CTA ist */
.vc_column_container > .vc_column-inner:has(> .wpb_wrapper > .pt-cta-end) {
  padding-left: 0 !important;
  padding-right: 0 !important;
}
.vc_column_container:has(> .vc_column-inner > .wpb_wrapper > .pt-cta-end) {
  padding-left: 0 !important;
  padding-right: 0 !important;
}

.pt-cta-end {
  font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
  overflow: hidden;
  margin-bottom: -20px;
  /* Breakout aus WPBakery Spalte */
  position: relative;
  left: 50%;
  transform: translateX(-50%);
  width: 100vw;
  max-width: 100vw;
}

/* === BLAUE BOX — Welle + Gradient als ein Hintergrund === */
.pt-blue-end {
  /* Zwei Layer: SVG-Welle (oben) + blauer Gradient (darunter) */
  background-image: 
    url("data:image/svg+xml,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20viewBox%3D%220%200%201440%2060%22%20preserveAspectRatio%3D%22none%22%3E%3Cpath%20fill%3D%22%23f9f9f9%22%20d%3D%22M0%2C0%20L0%2C12%20Q360%2C38%20720%2C12%20T1440%2C12%20L1440%2C0%20Z%22%2F%3E%3C%2Fsvg%3E"),
    linear-gradient(to right, rgba(29, 28, 44, 0.737) 0%, rgb(55, 123, 191) 25%, rgb(55, 123, 191) 74%, rgba(29, 28, 44, 0.737) 100%);
  background-position: top center, top center;
  background-size: 100% 60px, 100%;
  background-repeat: no-repeat, no-repeat;
  /* 45px + 60px für Welle = 105px padding oben */
  padding: 105px 20px 80px;
  text-align: center;
  width: 100%;
  box-sizing: border-box;
  margin: 0;
  /* WICHTIG: Einziger GPU-Layer — eliminiert sub-pixel Naht */
  will-change: transform;
}

/* Inhalt */
.pt-in-end {
  max-width: 900px;
  margin: 0 auto;
}

/* === BAUTROCKNER === */
.pt-dev-end {
  position: relative;
  width: 90px;
  height: 85px;
  margin: 0 auto 20px;
}
.pt-dev-end::before {
  content: '';
  position: absolute;
  width: 120px;
  height: 120px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(255,255,255,0.12), transparent 65%);
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}
.pt-dev-end::after {
  content: '';
  position: absolute;
  width: 140px;
  height: 140px;
  border: 1px solid rgba(255,255,255,0.15);
  border-radius: 50%;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  animation: pt-ring-end 20s linear infinite;
}
@keyframes pt-ring-end {
  0% { transform: translate(-50%, -50%) rotate(0deg); }
  100% { transform: translate(-50%, -50%) rotate(360deg); }
}

/* Animation auf ganzen Bautrockner — alles bewegt sich zusammen */
.pt-dev-end {
  animation: pt-bob-end 3.5s ease-in-out infinite;
}
@keyframes pt-bob-end {
  0%, 100% { transform: translateY(0); }
  50% { transform: translateY(-6px); }
}

.pt-koerper-end {
  position: relative;
  z-index: 2;
  width: 65px;
  height: 55px;
  background: linear-gradient(145deg, #f5c518, #e5b517);
  border-radius: 8px;
  margin: 18px auto 0;
  box-shadow: 0 6px 20px rgba(0,0,0,0.35);
}

.pt-griff-end {
  position: absolute;
  width: 34px;
  height: 12px;
  border: 3px solid #222;
  border-bottom: none;
  border-radius: 10px 10px 0 0;
  top: -10px;
  left: 50%;
  transform: translateX(-50%);
  z-index: 3;
}

.pt-vent-end {
  position: absolute;
  width: 44px;
  height: 30px;
  background: #1a1a2e;
  border-radius: 4px;
  top: 8px;
  left: 50%;
  transform: translateX(-50%);
  overflow: hidden;
}
.pt-vent-end::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(255,255,255,0.06) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,0.06) 1px, transparent 1px);
  background-size: 8px 8px;
}

.pt-panel-end {
  position: absolute;
  width: 30px;
  height: 6px;
  background: rgba(0,0,0,0.3);
  border-radius: 3px;
  bottom: 4px;
  left: 50%;
  transform: translateX(-50%);
}

.pt-led-end {
  position: absolute;
  width: 4px;
  height: 4px;
  border-radius: 50%;
  bottom: 6px;
}
.pt-led-end.a { background: #4a9eff; left: 18px; box-shadow: 0 0 4px #4a9eff; }
.pt-led-end.b { background: #4ade80; left: 50%; transform: translateX(-50%); }
.pt-led-end.c { background: #4a9eff; right: 18px; box-shadow: 0 0 4px #4a9eff; }

.pt-power-end {
  position: absolute;
  width: 5px;
  height: 5px;
  background: #4a9eff;
  border-radius: 50%;
  top: 14px;
  right: 6px;
  box-shadow: 0 0 6px rgba(74,158,255,0.7);
  animation: pt-pulse-end 2s ease-in-out infinite;
}
@keyframes pt-pulse-end {
  0%, 100% { opacity: 0.4; }
  50% { opacity: 1; }
}

.pt-rad-end {
  position: absolute;
  width: 12px;
  height: 12px;
  background: #222;
  border-radius: 50%;
  bottom: 16px;
  z-index: 4;
}
.pt-rad-end.l { left: 14px; }
.pt-rad-end.r { right: 14px; }
.pt-rad-end::after {
  content: '';
  position: absolute;
  width: 5px;
  height: 5px;
  background: #999;
  border-radius: 50%;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}

.pt-badge-end {
  display: inline-block;
  padding: 8px 22px;
  background: rgba(255,255,255,0.1);
  border: 1px solid rgba(255,255,255,0.2);
  border-radius: 50px;
  font-size: 13px;
  font-weight: 600;
  color: #fff;
  margin-bottom: 20px;
}

.pt-h2-end {
  font-size: clamp(28px, 4vw, 44px);
  font-weight: 800;
  color: #fff;
  line-height: 1.1;
  margin: 0 0 12px 0;
}
.pt-h2-end span {
  color: #f5c518;
}

.pt-text-end {
  font-size: 16px;
  color: rgba(255,255,255,0.85);
  line-height: 1.6;
  max-width: 500px;
  margin: 0 auto 25px auto;
}

.pt-btn-gelb-end,
.pt-btn-weiss-end {
  display: inline-block !important;
  padding: 15px 34px;
  font-size: 16px;
  font-weight: 700;
  text-decoration: none !important;
  border-radius: 8px;
  margin: 5px;
  cursor: pointer;
  border: 2px solid transparent;
  transition: all 0.3s ease;
}
.pt-btn-gelb-end {
  background: #f5c518;
  color: #111 !important;
  border-color: #f5c518;
  box-shadow: 0 5px 18px rgba(245,197,24,0.35);
}
.pt-btn-gelb-end:hover {
  background: #ffd93d;
  transform: translateY(-2px);
  box-shadow: 0 8px 25px rgba(245,197,24,0.5);
}
.pt-btn-weiss-end {
  background: transparent;
  color: #fff !important;
  border-color: rgba(255,255,255,0.35);
}
.pt-btn-weiss-end:hover {
  background: rgba(255,255,255,0.1);
  border-color: rgba(255,255,255,0.6);
  transform: translateY(-2px);
}

.pt-trust-end {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 28px;
  flex-wrap: wrap;
  padding-top: 25px;
  border-top: 1px solid rgba(255,255,255,0.1);
  max-width: 700px;
  margin: 30px auto 0;
}
.pt-trust-end > div {
  color: rgba(255,255,255,0.8);
  font-size: 14px;
}
.pt-trust-end > div .pt-hk {
  color: #4ade80;
  font-weight: 700;
}

@media(max-width: 600px) {
  .pt-blue-end {
    background-size: 100% 40px, 100%;
    padding: 75px 15px 60px;
  }
  .pt-h2-end { font-size: 24px; }
  .pt-dev-end { transform: scale(0.85); }
  .pt-in-end > div:nth-of-type(3) { display: block !important; }
  .pt-in-end > div:nth-of-type(3) > p { display: block !important; margin: 0 !important; }
  .pt-btn-gelb-end,
  .pt-btn-weiss-end { display: block !important; max-width: 280px; margin: 8px auto; text-align: center; }
  /* Desktop: Buttons nebeneinander — 3. div in .pt-in-end (nach Gerät + Badge) */
.pt-in-end > div:nth-of-type(3) {
  display: flex !important;
  flex-wrap: nowrap !important;
  justify-content: center;
  gap: 10px;
}
/* WPBakery <p>-Tags um Buttons herum neutralisieren */
.pt-in-end > div:nth-of-type(3) > p {
  display: inline !important;
  margin: 0 !important;
}
  .pt-trust-end { flex-direction: column; gap: 8px; }
}