.elementor-kit-3784{--e-global-color-primary:#FFFFFF;--e-global-color-secondary:#FFF1DD;--e-global-color-text:#0F0E0EF5;--e-global-color-accent:#F8910C;--e-global-color-c696dce:#FFFFFF;--e-global-color-86b4fcd:#02010100;--e-global-color-57c8da2:#0F0E0EF5;--e-global-color-30e10f3:#F8910C;--e-global-color-cc75b7d:#FFF1DD;--e-global-color-3ea853c:#DBDBDB;--e-global-color-5b5f6bb:#333230;--e-global-typography-primary-font-family:"Poppins";--e-global-typography-primary-font-size:3.5rem;--e-global-typography-primary-font-weight:900;--e-global-typography-primary-font-style:normal;--e-global-typography-primary-text-decoration:none;--e-global-typography-primary-line-height:1.2em;--e-global-typography-primary-letter-spacing:0px;--e-global-typography-primary-word-spacing:0em;--e-global-typography-secondary-font-family:"Poppins";--e-global-typography-secondary-font-size:1.875rem;--e-global-typography-secondary-font-weight:600;--e-global-typography-secondary-font-style:normal;--e-global-typography-secondary-text-decoration:none;--e-global-typography-secondary-line-height:1.1em;--e-global-typography-secondary-letter-spacing:0px;--e-global-typography-text-font-family:"Poppins";--e-global-typography-text-font-size:1.25rem;--e-global-typography-text-font-weight:300;--e-global-typography-text-text-transform:none;--e-global-typography-text-font-style:normal;--e-global-typography-text-text-decoration:none;--e-global-typography-text-line-height:1.5em;--e-global-typography-text-letter-spacing:0px;--e-global-typography-accent-font-family:"Poppins";--e-global-typography-accent-font-size:1rem;--e-global-typography-accent-font-weight:400;--e-global-typography-accent-text-transform:capitalize;--e-global-typography-accent-font-style:normal;--e-global-typography-accent-text-decoration:none;--e-global-typography-accent-line-height:1em;--e-global-typography-accent-letter-spacing:0px;--e-global-typography-392b9e0-font-family:"Poppins";--e-global-typography-392b9e0-font-size:1.2rem;--e-global-typography-392b9e0-font-weight:600;--e-global-typography-392b9e0-text-transform:capitalize;--e-global-typography-392b9e0-font-style:normal;--e-global-typography-392b9e0-text-decoration:none;--e-global-typography-392b9e0-line-height:1.2em;--e-global-typography-392b9e0-letter-spacing:0px;--e-global-typography-c05b693-font-family:"Poppins";--e-global-typography-c05b693-font-size:1.2rem;--e-global-typography-c05b693-font-weight:300;--e-global-typography-c05b693-text-transform:none;--e-global-typography-c05b693-font-style:normal;--e-global-typography-c05b693-text-decoration:none;--e-global-typography-c05b693-line-height:1.5em;--e-global-typography-c05b693-letter-spacing:0px;--e-global-typography-6558fb1-font-family:"Poppins";--e-global-typography-6558fb1-font-size:1rem;--e-global-typography-6558fb1-font-weight:300;--e-global-typography-6558fb1-text-transform:uppercase;--e-global-typography-6558fb1-font-style:normal;--e-global-typography-6558fb1-text-decoration:none;--e-global-typography-6558fb1-line-height:1.5em;--e-global-typography-6558fb1-letter-spacing:10px;--e-global-typography-92bce3b-font-family:"Poppins";--e-global-typography-92bce3b-font-size:1rem;--e-global-typography-92bce3b-font-weight:400;--e-global-typography-92bce3b-text-transform:capitalize;--e-global-typography-92bce3b-font-style:italic;--e-global-typography-92bce3b-text-decoration:underline;--e-global-typography-92bce3b-line-height:1em;--e-global-typography-92bce3b-letter-spacing:0px;--e-global-typography-b2deeae-font-family:"Poppins";--e-global-typography-b2deeae-font-size:5.9rem;--e-global-typography-b2deeae-font-weight:600;--e-global-typography-b2deeae-text-transform:none;--e-global-typography-b2deeae-font-style:normal;--e-global-typography-b2deeae-text-decoration:none;--e-global-typography-b2deeae-line-height:1em;--e-global-typography-b2deeae-letter-spacing:0px;--e-global-typography-fb1a3e0-font-family:"Poppins";--e-global-typography-fb1a3e0-font-size:10em;--e-global-typography-fb1a3e0-font-weight:600;--e-global-typography-fb1a3e0-text-transform:none;--e-global-typography-fb1a3e0-font-style:normal;--e-global-typography-fb1a3e0-text-decoration:none;--e-global-typography-fb1a3e0-line-height:1.2em;--e-global-typography-fb1a3e0-letter-spacing:0px;--e-global-typography-397e168-font-family:"Poppins";--e-global-typography-397e168-font-size:1.2rem;--e-global-typography-397e168-font-weight:400;--e-global-typography-397e168-text-transform:capitalize;--e-global-typography-397e168-font-style:italic;--e-global-typography-397e168-text-decoration:none;--e-global-typography-397e168-line-height:1.3em;--e-global-typography-397e168-letter-spacing:0px;background-color:var( --e-global-color-c696dce );color:var( --e-global-color-57c8da2 );font-family:"Poppins", Sans-serif;font-weight:600;}.elementor-kit-3784 e-page-transition{background-color:var( --e-global-color-c696dce );}.site-footer{background-color:var( --e-global-color-primary );}.elementor-kit-3784 a{color:var( --e-global-color-30e10f3 );font-family:"Poppins", Sans-serif;}.elementor-kit-3784 a:hover{color:var( --e-global-color-accent );}.elementor-kit-3784 h1{color:var( --e-global-color-57c8da2 );font-family:var( --e-global-typography-primary-font-family ), Sans-serif;font-size:var( --e-global-typography-primary-font-size );font-weight:var( --e-global-typography-primary-font-weight );font-style:var( --e-global-typography-primary-font-style );text-decoration:var( --e-global-typography-primary-text-decoration );line-height:var( --e-global-typography-primary-line-height );letter-spacing:var( --e-global-typography-primary-letter-spacing );word-spacing:var( --e-global-typography-primary-word-spacing );}.elementor-kit-3784 h2{color:var( --e-global-color-57c8da2 );font-size:1.875rem;}.elementor-kit-3784 h3{color:var( --e-global-color-57c8da2 );font-family:"Poppins", Sans-serif;font-size:1.5rem;}.elementor-kit-3784 h4{color:var( --e-global-color-57c8da2 );font-family:var( --e-global-typography-392b9e0-font-family ), Sans-serif;font-size:var( --e-global-typography-392b9e0-font-size );font-weight:var( --e-global-typography-392b9e0-font-weight );text-transform:var( --e-global-typography-392b9e0-text-transform );font-style:var( --e-global-typography-392b9e0-font-style );text-decoration:var( --e-global-typography-392b9e0-text-decoration );line-height:var( --e-global-typography-392b9e0-line-height );letter-spacing:var( --e-global-typography-392b9e0-letter-spacing );}.elementor-kit-3784 h5{color:var( --e-global-color-57c8da2 );font-family:"Poppins", Sans-serif;font-size:1.25rem;}.elementor-kit-3784 h6{color:var( --e-global-color-57c8da2 );font-family:"Poppins", Sans-serif;font-size:1rem;}.elementor-kit-3784 button,.elementor-kit-3784 input[type="button"],.elementor-kit-3784 input[type="submit"],.elementor-kit-3784 .elementor-button{font-size:1rem;}.elementor-section.elementor-section-boxed > .elementor-container{max-width:85vw;}.e-con{--container-max-width:85vw;--container-default-padding-top:0px;--container-default-padding-right:0px;--container-default-padding-bottom:0px;--container-default-padding-left:0px;}.elementor-widget:not(:last-child){margin-block-end:0px;}.elementor-element{--widgets-spacing:0px 0px;--widgets-spacing-row:0px;--widgets-spacing-column:0px;}{}h1.entry-title{display:var(--page-title-display);}.site-header .header-inner{width:75vw;max-width:100%;}.site-header{padding-inline-end:0%;padding-inline-start:0%;}.site-footer .site-branding{flex-direction:column;align-items:stretch;gap:8px;}.site-footer .footer-inner{width:100%;max-width:100%;}.site-footer .site-branding .site-logo img{width:7vw;max-width:7vw;}.site-footer .copyright p{color:var( --e-global-color-accent );font-family:var( --e-global-typography-text-font-family ), Sans-serif;font-size:var( --e-global-typography-text-font-size );font-weight:var( --e-global-typography-text-font-weight );text-transform:var( --e-global-typography-text-text-transform );font-style:var( --e-global-typography-text-font-style );text-decoration:var( --e-global-typography-text-text-decoration );line-height:var( --e-global-typography-text-line-height );letter-spacing:var( --e-global-typography-text-letter-spacing );}@media(max-width:1024px){.elementor-kit-3784{--e-global-typography-primary-font-size:45px;--e-global-typography-secondary-font-size:25px;--e-global-typography-text-font-size:14px;--e-global-typography-accent-font-size:14px;--e-global-typography-c05b693-font-size:18px;--e-global-typography-c05b693-line-height:1.4em;--e-global-typography-6558fb1-font-size:14px;--e-global-typography-92bce3b-font-size:14px;--e-global-typography-b2deeae-font-size:65px;--e-global-typography-fb1a3e0-font-size:145px;--e-global-typography-397e168-font-size:14px;}.elementor-kit-3784 h1{font-size:var( --e-global-typography-primary-font-size );line-height:var( --e-global-typography-primary-line-height );letter-spacing:var( --e-global-typography-primary-letter-spacing );word-spacing:var( --e-global-typography-primary-word-spacing );}.elementor-kit-3784 h4{font-size:var( --e-global-typography-392b9e0-font-size );line-height:var( --e-global-typography-392b9e0-line-height );letter-spacing:var( --e-global-typography-392b9e0-letter-spacing );}.elementor-section.elementor-section-boxed > .elementor-container{max-width:1024px;}.e-con{--container-max-width:1024px;}.site-header{padding-inline-end:5%;padding-inline-start:5%;}.site-footer .copyright p{font-size:var( --e-global-typography-text-font-size );line-height:var( --e-global-typography-text-line-height );letter-spacing:var( --e-global-typography-text-letter-spacing );}}@media(max-width:767px){.elementor-kit-3784{--e-global-typography-primary-font-size:28px;--e-global-typography-primary-line-height:1.1em;--e-global-typography-secondary-font-size:20px;--e-global-typography-392b9e0-font-size:18px;--e-global-typography-c05b693-font-size:16px;--e-global-typography-b2deeae-font-size:42px;--e-global-typography-b2deeae-line-height:1em;--e-global-typography-fb1a3e0-font-size:100px;--e-global-typography-fb1a3e0-line-height:1em;}.elementor-kit-3784 h1{font-size:var( --e-global-typography-primary-font-size );line-height:var( --e-global-typography-primary-line-height );letter-spacing:var( --e-global-typography-primary-letter-spacing );word-spacing:var( --e-global-typography-primary-word-spacing );}.elementor-kit-3784 h4{font-size:var( --e-global-typography-392b9e0-font-size );line-height:var( --e-global-typography-392b9e0-line-height );letter-spacing:var( --e-global-typography-392b9e0-letter-spacing );}.elementor-section.elementor-section-boxed > .elementor-container{max-width:767px;}.e-con{--container-max-width:767px;}.site-header{padding-inline-end:8%;padding-inline-start:8%;}.site-footer .copyright p{font-size:var( --e-global-typography-text-font-size );line-height:var( --e-global-typography-text-line-height );letter-spacing:var( --e-global-typography-text-letter-spacing );}}
/* Start custom CSS *//* ════════════════════════════════════════════════════════════════
   acko eGbR — Custom CSS (v2 für Container-Template)
   ────────────────────────────────────────────────────────────────
   Einfügen unter: Site Settings → Custom CSS  (Elementor Pro)
   ODER: Theme Customizer → Zusätzliches CSS
   ════════════════════════════════════════════════════════════════ */

/* ─── 1. Design Tokens ─────────────────────────────────────── */
:root {
  --acko-amber:        #F5A623;
  --acko-amber-dark:   #E09010;
  --acko-amber-deeper: #C57A08;
  --acko-amber-soft:   #FFF3DC;
  --acko-near-black:   #141414;
  --acko-gray-900:     #1F1F1F;
  --acko-gray-700:     #3D3D3D;
  --acko-gray-500:     #6E6E6E;
  --acko-gray-400:     #8A8A8A;
  --acko-gray-300:     #C8C8C8;
  --acko-gray-200:     #E0E0E0;
  --acko-gray-100:     #F4F4F4;
  --acko-gray-50:      #FAFAFA;

  --acko-display: 'Barlow Condensed', 'Barlow', system-ui, sans-serif;
  --acko-sans:    'Barlow', system-ui, sans-serif;
}

/* ─── 2. Globale Typo-Polish ───────────────────────────────── */
body {
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
}
.elementor-widget-heading h1.elementor-heading-title,
.elementor-widget-heading h2.elementor-heading-title,
.elementor-widget-heading h3.elementor-heading-title {
  text-wrap: balance;
}
.elementor-widget-text-editor p {
  text-wrap: pretty;
}

/* ─── 3. Eyebrows (Section-Labels mit Strich) ──────────────── */
.acko-eyebrow .elementor-heading-title {
  display: inline-flex !important;
  align-items: center;
}
.acko-eyebrow .elementor-heading-title::before {
  content: "";
  display: inline-block;
  width: 24px;
  height: 2px;
  background: var(--acko-amber);
  margin-right: 12px;
  flex-shrink: 0;
}

/* ─── 4. HERO ───────────────────────────────────────────────── */
.acko-hero {
  position: relative;
  overflow: hidden;
  min-height: 760px;
}

/* Großes Doppel-Chevron im Hintergrund */
.acko-hero::before {
  content: "››";
  position: absolute;
  right: -40px;
  bottom: -160px;
  font-family: var(--acko-display);
  font-size: 720px;
  font-weight: 800;
  color: var(--acko-amber);
  opacity: 0.08;
  pointer-events: none;
  line-height: 1;
  z-index: 1;
}

/* Texturierung */
.acko-hero::after {
  content: "";
  position: absolute;
  inset: 0;
  background-image: radial-gradient(rgba(255,255,255,0.025) 1px, transparent 1px);
  background-size: 3px 3px;
  pointer-events: none;
  z-index: 1;
}
.acko-hero > .e-con-inner,
.acko-hero > .elementor-container {
  position: relative;
  z-index: 2;
}

/* Hero-Form-Card (Kontaktbox rechts) */
.acko-form-card {
  box-shadow: 0 32px 80px rgba(0,0,0,0.45);
  position: relative;
}
.acko-form-card::before {
  content: "";
  position: absolute;
  top: 0;
  left: 32px;
  right: 32px;
  height: 3px;
  background: var(--acko-amber);
}

/* ─── 5. USP-Strip ─────────────────────────────────────────── */
.acko-usp .e-con-inner > .e-con:not(:last-child),
.acko-usp .elementor-container > .e-con:not(:last-child) {
  border-right: 1px solid rgba(255,255,255,0.08);
}

/* ─── 6. Service-Cards (Bento-Grid) ─────────────────────────── */
.acko-svc-card {
  transition: transform 240ms ease, box-shadow 240ms ease !important;
  position: relative;
}
.acko-svc-card:hover {
  transform: translateY(-3px);
  box-shadow: 0 16px 48px rgba(0,0,0,0.15);
}

/* Die Service-Card-Nummer (oberste Heading) absolut positionieren */
.acko-svc-card > .elementor-element:first-child {
  position: absolute;
  top: 24px;
  right: 24px;
  z-index: 2;
}

/* ─── 7. Reasons-Liste (Warum acko) ─────────────────────────── */
.acko-reason {
  transition: padding 200ms ease;
}

/* ─── 8. Process-Steps (Ablauf) ─────────────────────────────── */
.acko-step {
  position: relative;
}
/* Pseudo-Chev neben der großen Step-Nummer */
.acko-step > .elementor-widget-heading:first-child .elementor-heading-title::after {
  content: " ››";
  font-size: 0.35em;
  vertical-align: super;
  opacity: 0.5;
  margin-left: 6px;
}

/* ─── 9. Stats-Strip ───────────────────────────────────────── */
.acko-stats .e-con-inner > .e-con:not(:last-child),
.acko-stats .elementor-container > .e-con:not(:last-child) {
  border-right: 1px solid rgba(255,255,255,0.08);
}

/* ─── 10. Testimonials ─────────────────────────────────────── */
.acko-testimonial {
  transition: border-color 200ms ease, box-shadow 200ms ease, transform 200ms ease;
}
.acko-testimonial:hover {
  border-color: var(--acko-amber) !important;
  box-shadow: 0 12px 32px rgba(245,166,35,0.10);
  transform: translateY(-2px);
}
.acko-avatar .elementor-heading-title {
  line-height: 40px !important;
}

/* ─── 11. Standorte – Chips ────────────────────────────────── */
.acko-stand-chip {
  transition: border-color 160ms ease, background 160ms ease, transform 160ms ease !important;
  cursor: pointer;
}
.acko-stand-chip:hover {
  border-color: var(--acko-amber) !important;
  background: var(--acko-amber-soft) !important;
  transform: translateX(2px);
}

/* ─── 12. Adress-Karte mit großem Chevron ──────────────────── */
.acko-addr-card {
  position: relative;
}
.acko-addr-card::after {
  content: "››";
  position: absolute;
  right: -10px;
  bottom: -50px;
  font-family: var(--acko-display);
  font-size: 240px;
  font-weight: 800;
  color: var(--acko-amber);
  opacity: 0.12;
  line-height: 1;
  pointer-events: none;
}

/* ─── 13. Über-uns-Foto mit Frame & Badge ──────────────────── */
.acko-about-photo {
  position: relative;
}
/* Outline-Frame */
.acko-about-photo::before {
  content: "";
  position: absolute;
  inset: -20px;
  border: 1px solid var(--acko-amber);
  border-radius: 12px;
  opacity: 0.4;
  pointer-events: none;
}
/* Badge unten links positionieren */
.acko-about-badge {
  position: absolute !important;
  left: 24px !important;
  bottom: 24px !important;
  z-index: 3;
  box-shadow: 0 12px 32px rgba(245,166,35,0.25);
  width: auto !important;
  flex-grow: 0 !important;
}
.acko-image-placeholder {
  position: relative;
  background: linear-gradient(135deg, var(--acko-gray-800) 0%, var(--acko-near-black) 100%) !important;
}

/* ─── 14. Final-CTA mit großem Chevron ─────────────────────── */
.acko-final-cta {
  position: relative;
  overflow: hidden;
}
.acko-final-cta::before {
  content: "››";
  position: absolute;
  right: -60px;
  top: 50%;
  transform: translateY(-50%);
  font-family: var(--acko-display);
  font-weight: 800;
  font-size: 480px;
  color: var(--acko-amber);
  opacity: 0.1;
  line-height: 0.8;
  pointer-events: none;
  z-index: 1;
}
.acko-final-cta > .e-con-inner,
.acko-final-cta > .elementor-container {
  position: relative;
  z-index: 2;
}

.acko-phone-card {
  transition: background 200ms ease;
}
.acko-phone-card:hover {
  background: rgba(255,255,255,0.08) !important;
}

/* ─── 15. Buttons – Hover-Polish ───────────────────────────── */
.elementor-button {
  transition: transform 180ms ease, box-shadow 180ms ease, background 180ms ease !important;
  letter-spacing: 0.01em;
}
.elementor-button:hover {
  transform: translateY(-1px);
}
/* Primärer (amber) Button mit Glow-Schatten beim Hover */
.elementor-button[style*="rgb(245, 166, 35)"]:hover,
.elementor-button[style*="#F5A623"]:hover {
  box-shadow: 0 12px 32px rgba(245,166,35,0.35);
}
/* Fokus-Sichtbarkeit (Accessibility) */
.elementor-button:focus-visible,
a:focus-visible {
  outline: 2px solid var(--acko-amber);
  outline-offset: 3px;
}

/* ─── 16. FAQ-Accordion ────────────────────────────────────── */
.acko-faq .elementor-accordion .elementor-accordion-item {
  border-left: none !important;
  border-right: none !important;
  border-top: 1px solid var(--acko-gray-200) !important;
  border-bottom: none !important;
}
.acko-faq .elementor-accordion .elementor-accordion-item:last-child {
  border-bottom: 1px solid var(--acko-gray-200) !important;
}
.acko-faq .elementor-accordion .elementor-tab-title {
  background: transparent !important;
  padding: 24px 0 !important;
  transition: color 160ms ease;
}
.acko-faq .elementor-accordion .elementor-tab-title:hover,
.acko-faq .elementor-accordion .elementor-tab-title.elementor-active {
  color: var(--acko-amber-dark) !important;
}
.acko-faq .elementor-accordion .elementor-tab-content {
  border-top: none !important;
  padding: 0 0 24px 0 !important;
}

/* ─── 17. Forms (falls Elementor-Form genutzt wird) ────────── */
.elementor-form .elementor-field-group label {
  font-size: 10px !important;
  font-weight: 800 !important;
  letter-spacing: 0.14em !important;
  text-transform: uppercase;
  color: var(--acko-gray-400) !important;
  margin-bottom: 6px !important;
}
.elementor-form .elementor-field {
  border: none !important;
  border-bottom: 1.5px solid var(--acko-gray-200) !important;
  border-radius: 0 !important;
  background: transparent !important;
  padding: 10px 0 !important;
  font-family: var(--acko-sans) !important;
  font-size: 15px !important;
  transition: border-color 180ms ease;
}
.elementor-form .elementor-field:focus {
  border-bottom-color: var(--acko-amber) !important;
  outline: none !important;
  box-shadow: none !important;
}

/* ─── 18. Mobile Responsive ────────────────────────────────── */
@media (max-width: 1024px) {
  .acko-hero {
    min-height: auto;
  }
  .acko-hero h1.elementor-heading-title,
  .acko-hero .elementor-widget-heading h1 {
    font-size: 64px !important;
    line-height: 0.96 !important;
  }
  .acko-hero::before {
    font-size: 480px;
    bottom: -100px;
  }
  .acko-final-cta::before {
    font-size: 320px;
  }
}

@media (max-width: 767px) {
  /* Hero-Headline */
  .acko-hero h1.elementor-heading-title,
  .acko-hero .elementor-widget-heading h1 {
    font-size: 44px !important;
    line-height: 0.98 !important;
    letter-spacing: -1px !important;
  }
  .acko-hero::before {
    font-size: 320px;
    bottom: -80px;
    right: -20px;
  }

  /* Section-Headings reduzieren */
  .elementor-widget-heading h2.elementor-heading-title {
    font-size: 36px !important;
    line-height: 1.05 !important;
  }
  .elementor-widget-heading h3.elementor-heading-title {
    font-size: 22px !important;
  }

  /* Section-Padding reduzieren */
  .acko-services > .e-con-inner,
  .acko-warum > .e-con-inner,
  .acko-ablauf > .e-con-inner,
  .acko-about > .e-con-inner,
  .acko-testimonials > .e-con-inner,
  .acko-standorte > .e-con-inner,
  .acko-faq > .e-con-inner,
  .acko-final-cta > .e-con-inner,
  .acko-services > .elementor-container,
  .acko-warum > .elementor-container,
  .acko-ablauf > .elementor-container,
  .acko-about > .elementor-container,
  .acko-testimonials > .elementor-container,
  .acko-standorte > .elementor-container,
  .acko-faq > .elementor-container,
  .acko-final-cta > .elementor-container {
    padding-top: 60px !important;
    padding-bottom: 60px !important;
  }

  /* USP-Strip: Trenner unten statt rechts auf mobile */
  .acko-usp .e-con-inner > .e-con:not(:last-child),
  .acko-usp .elementor-container > .e-con:not(:last-child) {
    border-right: none !important;
    border-bottom: 1px solid rgba(255,255,255,0.08) !important;
    padding-bottom: 16px !important;
    margin-bottom: 16px !important;
  }
  .acko-stats .e-con-inner > .e-con:not(:last-child),
  .acko-stats .elementor-container > .e-con:not(:last-child) {
    border-right: none !important;
    border-bottom: 1px solid rgba(255,255,255,0.08) !important;
  }

  /* Großes Chevron auf Mobile reduzieren */
  .acko-final-cta::before {
    font-size: 240px;
    right: -40px;
  }
  .acko-addr-card::after {
    font-size: 160px;
    bottom: -30px;
  }

  /* Service-Cards Mindesthöhe reduzieren */
  .acko-svc-card {
    min-height: 200px !important;
  }
}

@media (max-width: 480px) {
  /* Standort-Chips: 1 Spalte */
  .acko-stand-grid > .e-con,
  .acko-stand-grid > .elementor-element {
    width: 100% !important;
  }
}

/* ─── 19. Print Styles ─────────────────────────────────────── */
@media print {
  @page { size: A4 portrait; margin: 12mm 10mm; }
  body {
    -webkit-print-color-adjust: exact !important;
    print-color-adjust: exact !important;
  }
  .acko-hero::before,
  .acko-hero::after,
  .acko-final-cta::before,
  .acko-addr-card::after { display: none !important; }
  .e-con, .elementor-section, .elementor-widget {
    page-break-inside: avoid;
  }
  a { color: inherit !important; text-decoration: none !important; }
}

/* ─── 20. Reduced Motion (Accessibility) ───────────────────── */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    transition-duration: 0.01ms !important;
  }
}

/* ─── 21. Helper-Klassen (optional verwenden) ──────────────── */
.acko-accent { color: var(--acko-amber) !important; }
.acko-text-balance { text-wrap: balance; }
.acko-text-pretty  { text-wrap: pretty; }

/* Card-Schatten (auf eigene Container anwendbar via CSS-Class) */
.acko-card-elevated {
  box-shadow: 0 12px 40px rgba(0,0,0,0.08);
}
/* ──────────────────────────────────────────────
   Acko — Process (4 Schritte) — Custom CSS
   Einfügen unter: Site Settings → Custom CSS
   ────────────────────────────────────────────── */

:root {
  --acko-amber:        #F5A623;
  --acko-amber-dark:   #E09010;
  --acko-petrol:       #143B47;
  --acko-petrol-dark:  #0E2A33;
  --acko-white:        #FFFFFF;
  --acko-gray-text:    #B7C4CA;
  --acko-divider:      rgba(255, 255, 255, 0.12);

  --acko-display: 'Barlow Condensed', system-ui, -apple-system, sans-serif;
  --acko-sans:    'Barlow', system-ui, -apple-system, sans-serif;
}

/* ──────────────────────────────────────────────
   Eyebrow — Strich vor dem Text
   (greift für die Hauptsektion UND die 01/02/03/04-Labels)
   ────────────────────────────────────────────── */
.acko-eyebrow .elementor-heading-title {
  display: inline-flex !important;
  align-items: center;
}
.acko-eyebrow .elementor-heading-title::before {
  content: "";
  display: inline-block;
  width: 24px;
  height: 2px;
  background: var(--acko-amber);
  margin-right: 12px;
  flex-shrink: 0;
}

/* Step-Nummer-Eyebrow: schmalerer Strich für die Karten */
.acko-step-num .elementor-heading-title::before {
  width: 16px;
  margin-right: 10px;
}

/* ──────────────────────────────────────────────
   Process-Sektion — Layout-Feinschliff
   ────────────────────────────────────────────── */
.acko-process {
  position: relative;
  overflow: hidden;
}

/* Subtiler Glow oben links für Tiefe (optional dezent) */
.acko-process::before {
  content: "";
  position: absolute;
  top: -200px;
  left: -200px;
  width: 600px;
  height: 600px;
  background: radial-gradient(circle, rgba(245,166,35,0.05) 0%, transparent 70%);
  pointer-events: none;
  z-index: 0;
}
.acko-process > .e-con-inner,
.acko-process > .elementor-container {
  position: relative;
  z-index: 1;
}

/* Intro-Block: Headline & Subline maximal ~720px breit halten */
.acko-process-intro > .elementor-widget-text-editor,
.acko-process-intro > .elementor-element[data-element_type="widget"]:has(p) {
  max-width: 640px;
}

/* ──────────────────────────────────────────────
   4-Spalten-Grid
   ────────────────────────────────────────────── */
.acko-step-card {
  position: relative;
  transition: transform 0.25s ease;
}

/* Erste Karte: kein linkes Padding (bündig mit Headline darüber) */
.acko-process-grid > .acko-step-card:first-child {
  padding-left: 0 !important;
}
/* Letzte Karte: kein rechtes Padding */
.acko-process-grid > .acko-step-card:last-child {
  padding-right: 0 !important;
}

/* Dezenter Hover-Lift */
.acko-step-card:hover {
  transform: translateY(-3px);
}

/* ──────────────────────────────────────────────
   CTA-Zeile
   ────────────────────────────────────────────── */
.acko-process-cta .elementor-button {
  letter-spacing: 0.3px;
  box-shadow: 0 8px 24px rgba(245, 166, 35, 0.25);
  transition: all 0.25s ease;
}
.acko-process-cta .elementor-button:hover {
  box-shadow: 0 12px 32px rgba(245, 166, 35, 0.4);
  transform: translateY(-1px);
}

/* ──────────────────────────────────────────────
   Tablet (≤ 1024px): 4 → 2 Spalten
   ────────────────────────────────────────────── */
@media (max-width: 1024px) {
  .acko-process-grid > .acko-step-card {
    width: 50% !important;
    padding: 28px !important;
  }
  /* Trenner umverteilen: Karten 1 & 3 bekommen rechten Border, 1 & 2 unteren */
  .acko-process-grid > .acko-step-card {
    border-right: 1px solid var(--acko-divider) !important;
    border-bottom: 1px solid var(--acko-divider) !important;
  }
  .acko-process-grid > .acko-step-card:nth-child(2n) {
    border-right: 0 !important;
  }
  .acko-process-grid > .acko-step-card:nth-last-child(-n+2) {
    border-bottom: 0 !important;
  }
}

/* ──────────────────────────────────────────────
   Mobile (≤ 640px): alles untereinander
   ────────────────────────────────────────────── */
@media (max-width: 640px) {
  .acko-process {
    padding-top: 72px !important;
    padding-bottom: 72px !important;
  }
  .acko-process-grid {
    margin-top: 40px !important;
    margin-bottom: 40px !important;
  }
  .acko-process-grid > .acko-step-card {
    width: 100% !important;
    padding: 28px 0 !important;
    border-right: 0 !important;
    border-bottom: 1px solid var(--acko-divider) !important;
  }
  .acko-process-grid > .acko-step-card:last-child {
    border-bottom: 0 !important;
  }
  .acko-process-cta {
    flex-direction: column !important;
    align-items: flex-start !important;
    gap: 16px !important;
  }
}
/* ──────────────────────────────────────────────
   Acko — Industries (Wir sprechen Ihre Branche)
   Einfügen unter: Site Settings → Custom CSS
   ────────────────────────────────────────────── */

:root {
  --acko-amber:        #F5A623;
  --acko-amber-dark:   #E09010;
  --acko-amber-soft:   rgba(245, 166, 35, 0.7);
  --acko-amber-tint:   rgba(245, 166, 35, 0.06);
  --acko-petrol:       #143B47;
  --acko-cream:        #F2EADC;
  --acko-card-border:  rgba(20, 59, 71, 0.08);
  --acko-card-shadow:  0 1px 3px rgba(20, 59, 71, 0.04);
  --acko-card-shadow-hover: 0 12px 32px rgba(20, 59, 71, 0.10);
  --acko-gray-text:    #7A828C;

  --acko-display: 'Barlow Condensed', system-ui, -apple-system, sans-serif;
  --acko-sans:    'Barlow', system-ui, -apple-system, sans-serif;
}

/* ──────────────────────────────────────────────
   Eyebrow — Strich vor dem Text
   (gilt auch für die andere Sektion, falls beide Custom-CSS gemerged werden)
   ────────────────────────────────────────────── */
.acko-eyebrow .elementor-heading-title {
  display: inline-flex !important;
  align-items: center;
}
.acko-eyebrow .elementor-heading-title::before {
  content: "";
  display: inline-block;
  width: 24px;
  height: 2px;
  background: var(--acko-amber);
  margin-right: 12px;
  flex-shrink: 0;
}

/* ──────────────────────────────────────────────
   Sektion: Industries
   ────────────────────────────────────────────── */
.acko-industries {
  position: relative;
}

/* Subline schmal halten (max ~600px) */
.acko-industries-intro > .elementor-widget-text-editor {
  max-width: 600px;
}

/* ──────────────────────────────────────────────
   Card-Grid
   ────────────────────────────────────────────── */
.acko-industries-grid {
  /* nichts Spezielles — Layout kommt aus den Container-Settings */
}

.acko-industry-card {
  box-shadow: var(--acko-card-shadow);
  transition: box-shadow 0.25s ease, transform 0.25s ease, border-color 0.25s ease;

  /* width:33.33% kommt aus dem JSON, wir respektieren den Gap (24px) */
  /* Elementor verteilt das automatisch via flexbox */
}

.acko-industry-card:hover {
  box-shadow: var(--acko-card-shadow-hover);
  transform: translateY(-3px);
  border-color: rgba(245, 166, 35, 0.35) !important;
}

/* ──────────────────────────────────────────────
   Icon-Box (oben links auf jeder Card)
   ────────────────────────────────────────────── */
.acko-card-icon {
  /* Inneres Icon zentrieren */
  flex: 0 0 auto !important;
}
.acko-card-icon .elementor-icon {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100%;
}
.acko-card-icon .elementor-icon svg,
.acko-card-icon .elementor-icon i {
  font-size: 22px !important;
  width: 22px;
  height: 22px;
}

/* ──────────────────────────────────────────────
   Standard-Link unten („Branchen-Standard ›")
   margin-top:auto schiebt den Link an die untere Kante
   ────────────────────────────────────────────── */
.acko-card-link {
  margin-top: auto !important;
  font-weight: 700;
}
.acko-card-link p {
  margin: 0 !important;
}
.acko-card-link a,
.acko-card-link-a {
  color: var(--acko-petrol) !important;
  text-decoration: none !important;
  font-weight: 700;
  letter-spacing: 0.2px;
  transition: color 0.2s ease;
}
.acko-card-link a:hover,
.acko-card-link-a:hover {
  color: var(--acko-amber-dark) !important;
}

/* ──────────────────────────────────────────────
   Tablet (≤ 1024px): 3 → 2 Spalten
   ────────────────────────────────────────────── */
@media (max-width: 1024px) {
  .acko-industries-grid > .acko-industry-card {
    width: calc(50% - 12px) !important;  /* 24px Gap → -12px pro Karte */
  }
}

/* ──────────────────────────────────────────────
   Mobile (≤ 640px): 1 Spalte
   ────────────────────────────────────────────── */
@media (max-width: 640px) {
  .acko-industries {
    padding-top: 72px !important;
    padding-bottom: 72px !important;
  }
  .acko-industries-grid {
    margin-top: 40px !important;
  }
  .acko-industries-grid > .acko-industry-card {
    width: 100% !important;
    padding: 28px !important;
  }
}
/* ============================================
   HubSpot Form – acko Design
   ============================================ */

/* >>> HIER deine acko-Brand-Farben einsetzen <<< */
.hs-form-frame {
  --acko-primary: #0c3a6b;           /* Hauptfarbe (Buttons, Fokus) */
  --acko-primary-hover: #082a4f;     /* Hover-Zustand */
  --acko-text: #1a1a1a;              /* Fließtext / Labels */
  --acko-muted: #6b7280;             /* Hilfetexte */
  --acko-border: #d8dde3;            /* Input-Rahmen */
  --acko-border-focus: var(--acko-primary);
  --acko-bg: #ffffff;                /* Input-Hintergrund */
  --acko-bg-soft: #f7f9fc;           /* Section-Hintergrund optional */
  --acko-error: #c0392b;
  --acko-radius: 6px;
  --acko-font: "Inter", "Helvetica Neue", Arial, sans-serif;
}

/* Container */
.hs-form-frame {
  font-family: var(--acko-font);
  color: var(--acko-text);
  max-width: 640px;
  margin: 0 auto;
}

/* Form-Wrapper */
.hs-form-frame form,
.hs-form-frame .hs-form {
  display: flex;
  flex-direction: column;
  gap: 18px;
}

/* Feld-Wrapper */
.hs-form-frame .hs-form-field {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

/* Labels */
.hs-form-frame label,
.hs-form-frame .hs-form-field > label {
  font-size: 14px;
  font-weight: 600;
  color: var(--acko-text);
  letter-spacing: 0.01em;
}

/* Pflichtfeld-Stern */
.hs-form-frame .hs-form-required {
  color: var(--acko-error);
  margin-left: 3px;
}

/* Hilfe-Text unter Labels */
.hs-form-frame legend.hs-field-desc {
  font-size: 13px;
  color: var(--acko-muted);
  font-weight: 400;
  margin-bottom: 4px;
}

/* Inputs, Textarea, Select */
.hs-form-frame .hs-input,
.hs-form-frame input[type="text"],
.hs-form-frame input[type="email"],
.hs-form-frame input[type="tel"],
.hs-form-frame input[type="number"],
.hs-form-frame textarea,
.hs-form-frame select {
  width: 100%;
  box-sizing: border-box;
  padding: 12px 14px;
  font-size: 15px;
  font-family: inherit;
  color: var(--acko-text);
  background: var(--acko-bg);
  border: 1px solid var(--acko-border);
  border-radius: var(--acko-radius);
  transition: border-color 0.15s ease, box-shadow 0.15s ease;
  outline: none;
}

.hs-form-frame .hs-input::placeholder,
.hs-form-frame textarea::placeholder {
  color: #a0a6b0;
}

/* Focus-Zustand */
.hs-form-frame .hs-input:focus,
.hs-form-frame textarea:focus,
.hs-form-frame select:focus {
  border-color: var(--acko-border-focus);
  box-shadow: 0 0 0 3px rgba(12, 58, 107, 0.15);
}

/* Textarea */
.hs-form-frame textarea {
  min-height: 120px;
  resize: vertical;
}

/* Checkboxes & Radios */
.hs-form-frame .inputs-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.hs-form-frame .inputs-list li label {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  font-weight: 400;
  font-size: 14px;
  cursor: pointer;
  line-height: 1.5;
}

.hs-form-frame input[type="checkbox"],
.hs-form-frame input[type="radio"] {
  width: 18px;
  height: 18px;
  margin-top: 2px;
  accent-color: var(--acko-primary);
  cursor: pointer;
}

/* GDPR-Block / Legal-Text */
.hs-form-frame .legal-consent-container,
.hs-form-frame .hs-richtext {
  font-size: 13px;
  color: var(--acko-muted);
  line-height: 1.55;
}

.hs-form-frame .legal-consent-container a,
.hs-form-frame .hs-richtext a {
  color: var(--acko-primary);
  text-decoration: underline;
}

/* Submit-Button */
.hs-form-frame .hs-button,
.hs-form-frame input[type="submit"],
.hs-form-frame .hs-submit input {
  display: inline-block;
  width: 100%;
  padding: 14px 28px;
  font-family: inherit;
  font-size: 15px;
  font-weight: 600;
  letter-spacing: 0.02em;
  color: #ffffff;
  background: var(--acko-primary);
  border: none;
  border-radius: var(--acko-radius);
  cursor: pointer;
  transition: background 0.15s ease, transform 0.05s ease;
  margin-top: 8px;
}

.hs-form-frame .hs-button:hover,
.hs-form-frame input[type="submit"]:hover {
  background: var(--acko-primary-hover);
}

.hs-form-frame .hs-button:active,
.hs-form-frame input[type="submit"]:active {
  transform: translateY(1px);
}

.hs-form-frame .hs-button:disabled {
  opacity: 0.6;
  cursor: not-allowed;
}

/* Fehler-Zustände */
.hs-form-frame .hs-input.invalid,
.hs-form-frame .hs-input.error {
  border-color: var(--acko-error);
  box-shadow: 0 0 0 3px rgba(192, 57, 43, 0.12);
}

.hs-form-frame .hs-error-msg,
.hs-form-frame .hs-error-msgs label {
  color: var(--acko-error);
  font-size: 13px;
  margin-top: 4px;
  font-weight: 500;
}

/* Erfolgsmeldung nach Submit */
.hs-form-frame .submitted-message {
  padding: 24px;
  background: var(--acko-bg-soft);
  border-left: 4px solid var(--acko-primary);
  border-radius: var(--acko-radius);
  font-size: 15px;
  line-height: 1.55;
}

/* Zwei-Spalten-Layout für nebeneinander liegende Felder (z.B. Vor-/Nachname) */
.hs-form-frame .hs-fieldtype-text.hs_firstname,
.hs-form-frame .hs-fieldtype-text.hs_lastname {
  flex: 1;
}

@media (min-width: 600px) {
  .hs-form-frame .hs-form-field.hs-fieldtype-text.hs_firstname,
  .hs-form-frame .hs-form-field.hs-fieldtype-text.hs_lastname {
    display: inline-flex;
    width: calc(50% - 9px);
    vertical-align: top;
  }
  .hs-form-frame .hs-form-field.hs-fieldtype-text.hs_firstname {
    margin-right: 9px;
  }
  .hs-form-frame .hs-form-field.hs-fieldtype-text.hs_lastname {
    margin-left: 9px;
  }
}

/* Mobile */
@media (max-width: 599px) {
  .hs-form-frame .hs-input,
  .hs-form-frame textarea {
    font-size: 16px; /* verhindert Auto-Zoom auf iOS */
  }
}
/* ═══════════════════════════════════════════════════════════════
   acko eGbR — Standort Heilbronn · Custom CSS
   Einfügen unter: Site Settings → Custom CSS
   ═══════════════════════════════════════════════════════════════ */

:root {
  --acko-amber:        #F5A623;
  --acko-amber-dark:   #E09010;
  --acko-amber-deep:   #C57A08;
  --acko-amber-soft:   #FFF3DC;
  --acko-near-black:   #1A1A1A;
  --acko-gray-900:     #2A2A2A;
  --acko-gray-700:     #3D3D3D;
  --acko-gray-500:     #6E6E6E;
  --acko-gray-400:     #888888;
  --acko-gray-300:     #BBBBBB;
  --acko-gray-200:     #EBEBEB;
  --acko-gray-100:     #F4F4F4;
  --acko-gray-50:      #FAFAFA;
  --acko-gray-section: #F5F5F5;

  --acko-display: 'Barlow Condensed', system-ui, sans-serif;
  --acko-sans:    'Barlow', system-ui, sans-serif;
  --acko-mono:    'JetBrains Mono', ui-monospace, monospace;
}

body {
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  font-family: var(--acko-sans);
}

/* ─── Eyebrow mit Strich-Akzent ───────────────────────────── */
.acko-hero-eyebrow .elementor-heading-title,
.acko-eyebrow .elementor-heading-title {
  display: inline-flex !important;
  align-items: center;
}
.acko-hero-eyebrow .elementor-heading-title::before,
.acko-eyebrow .elementor-heading-title::before {
  content: "";
  display: inline-block;
  width: 32px;
  height: 2px;
  background: var(--acko-amber);
  margin-right: 14px;
  flex-shrink: 0;
}

/* Section-Num kein Strich-Prefix nötig wegn em-dash; aber bündig */
.acko-sec-num .elementor-heading-title {
  display: inline-flex;
  align-items: center;
  gap: 12px;
}
.acko-sec-num .elementor-heading-title::before {
  content: "";
  display: inline-block;
  width: 32px;
  height: 1px;
  background: var(--acko-amber);
}

/* ═══ BREADCRUMB ═══════════════════════════════════════════ */
.acko-breadcrumb {
  border-bottom: 3px solid var(--acko-amber) !important;
  font-size: 12px;
}
.acko-breadcrumb .acko-bc-link {
  color: #888 !important;
  text-decoration: none !important;
  transition: color 160ms;
}
.acko-breadcrumb .acko-bc-link:hover { color: var(--acko-amber) !important; }
.acko-breadcrumb .acko-bc-sep { color: #444; margin: 0 6px; }
.acko-breadcrumb .acko-bc-current {
  color: var(--acko-amber) !important;
  font-weight: 700 !important;
  letter-spacing: 0.04em;
  text-transform: uppercase;
  font-size: 11px;
}
.acko-breadcrumb .acko-bc-meta-wrap p { margin: 0; }

/* ═══ HERO ═════════════════════════════════════════════════ */
.acko-hero {
  position: relative;
  overflow: hidden;
}
.acko-hero::before {
  content: "HEILBRONN";
  position: absolute;
  right: -120px;
  top: 60px;
  font-family: var(--acko-display);
  font-size: 520px;
  font-weight: 900;
  line-height: 0.8;
  color: var(--acko-gray-50);
  letter-spacing: -0.04em;
  user-select: none;
  pointer-events: none;
  white-space: nowrap;
  z-index: 0;
}
.acko-hero > .e-con-inner,
.acko-hero > .elementor-container {
  position: relative;
  z-index: 2;
}

/* H1: Underline-Effekt für "Heilbronn" */
.acko-hero-h1 .acko-hl-underline {
  display: inline-block;
  position: relative;
  padding-bottom: 4px;
}
.acko-hero-h1 .acko-hl-underline::after {
  content: '';
  position: absolute;
  left: 0; right: 0; bottom: -2px;
  height: 6px;
  background: var(--acko-amber);
}
.acko-hero-h1 em {
  font-style: normal;
  font-weight: 400;
  color: #888;
  font-family: var(--acko-display);
}

/* Hero-Meta Strip: Trenner zwischen Cells */
.acko-hero-meta > .e-con-inner > .acko-meta-cell:not(:last-child),
.acko-hero-meta > .elementor-container > .acko-meta-cell:not(:last-child) {
  border-right: 1px solid var(--acko-gray-200) !important;
}
.acko-hero-meta .acko-meta-cell {
  padding-right: 28px !important;
  padding-left: 28px !important;
}
.acko-hero-meta .acko-meta-cell:first-child {
  padding-left: 0 !important;
}
.acko-hero-meta .acko-meta-cell-last {
  padding-right: 0 !important;
}
.acko-hero-meta .acko-meta-val small {
  font-family: var(--acko-sans);
  font-weight: 500;
  color: #888;
  font-size: 13px;
  margin-left: 4px;
}

/* ═══ SECTION-HEADER (editorial 1+2-Grid) ═════════════════ */
.acko-sec-head { margin-bottom: 56px; }

/* ═══ MAP-SECTION ══════════════════════════════════════════ */
.acko-map-box {
  position: relative;
  aspect-ratio: 4/3;
}

/* Districts-Liste */
.acko-districts-list-wrap .acko-list-label .elementor-heading-title {
  border-bottom: 2px solid var(--acko-near-black);
  padding-bottom: 14px;
  display: block;
}
.acko-districts-list-wrap .acko-list-arrow {
  color: var(--acko-amber);
  margin-left: 4px;
}

.acko-districts-list-wrap .acko-district-link {
  display: grid;
  grid-template-columns: 28px 1fr auto auto;
  gap: 14px;
  align-items: center;
  padding: 14px 0;
  border-bottom: 1px solid #F0F0F0;
  text-decoration: none !important;
  color: inherit;
  transition: padding-left 200ms;
}
.acko-districts-list-wrap .acko-district-link:hover {
  padding-left: 6px;
}
.acko-districts-list-wrap .acko-district-num {
  font-family: var(--acko-mono);
  font-size: 11px;
  font-weight: 600;
  color: #BBB;
}
.acko-districts-list-wrap .acko-district-name {
  font-family: var(--acko-display);
  font-size: 22px;
  font-weight: 700;
  color: var(--acko-near-black);
  line-height: 1;
  letter-spacing: -0.005em;
}
.acko-districts-list-wrap .acko-district-zip {
  font-size: 11px;
  color: #999;
  font-family: var(--acko-mono);
}
.acko-districts-list-wrap .acko-district-go {
  color: var(--acko-amber);
  font-weight: 900;
  font-size: 16px;
  transition: transform 200ms;
}
.acko-districts-list-wrap .acko-district-link:hover .acko-district-go {
  transform: translateX(4px);
}

/* ═══ ARCHIVE-MATRIX ═══════════════════════════════════════ */
.acko-archive {
  background: #fff;
}
.acko-archive .acko-arch-row {
  transition: background 160ms;
}
.acko-archive .acko-arch-row:hover {
  background: var(--acko-gray-50);
}
.acko-archive .acko-arch-row:hover .acko-arch-city {
  background: var(--acko-gray-50) !important;
}

/* Link-Cells in Matrix */
.acko-archive .acko-arch-link-cell .acko-arch-link {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  text-decoration: none !important;
  color: var(--acko-near-black) !important;
  font-size: 13px;
  font-weight: 500;
  transition: color 140ms;
  width: 100%;
}
.acko-archive .acko-arch-link-arrow {
  color: #DDD;
  font-weight: 900;
  font-size: 14px;
  transition: color 140ms;
}
.acko-archive .acko-arch-link-cell:hover {
  background: var(--acko-near-black) !important;
}
.acko-archive .acko-arch-link-cell:hover .acko-arch-link {
  color: var(--acko-amber) !important;
  font-weight: 700;
}
.acko-archive .acko-arch-link-cell:hover .acko-arch-link-arrow {
  color: var(--acko-amber);
}

.acko-arch-meta-bar p { margin: 0; }
.acko-arch-meta-bar .acko-arch-meta-link {
  color: var(--acko-amber) !important;
  text-decoration: none !important;
  font-weight: 700;
}

/* ═══ BRANCHEN ═════════════════════════════════════════════ */
.acko-branches-grid {
  background: var(--acko-gray-200);
}
.acko-branch-card {
  transition: background 220ms;
}
.acko-branch-card:hover {
  background: var(--acko-gray-50) !important;
}
.acko-branch-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}
.acko-branch-tag {
  display: inline-block;
  padding: 3px 9px;
  border-radius: 9999px;
  background: var(--acko-gray-100);
  color: #777;
  font-size: 10px;
  font-weight: 600;
  letter-spacing: 0.04em;
}
.acko-branch-link-arrow {
  color: var(--acko-amber);
  font-size: 14px;
  font-weight: 900;
  transition: transform 220ms;
  display: inline-block;
}
.acko-branch-card:hover .acko-branch-link-arrow {
  transform: translateX(4px);
}
.acko-branch-link-label {
  font-size: 12px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--acko-near-black);
}
.acko-branch-card p { margin: 0; }

/* ═══ ABOUT (dark) ═════════════════════════════════════════ */
.acko-about {
  position: relative;
  overflow: hidden;
}
.acko-about::before {
  content: 'HN';
  position: absolute;
  font-family: var(--acko-display);
  font-size: 720px;
  font-weight: 900;
  line-height: 0.8;
  color: rgba(245, 166, 35, 0.04);
  right: -80px;
  top: -80px;
  letter-spacing: -0.05em;
  user-select: none;
  pointer-events: none;
  z-index: 0;
}
.acko-about > .e-con-inner,
.acko-about > .elementor-container {
  position: relative;
  z-index: 2;
}
.acko-about h2 em {
  font-style: normal;
  color: var(--acko-amber);
}
.acko-about-stat {
  background: var(--acko-near-black) !important;
}

/* ═══ REFERENZEN ═══════════════════════════════════════════ */
.acko-ref-card {
  transition: border-color 200ms ease, box-shadow 200ms ease, transform 200ms ease;
}
.acko-ref-card:hover {
  border-color: var(--acko-amber) !important;
  box-shadow: 0 4px 20px rgba(245, 166, 35, 0.08);
  transform: translateY(-2px);
}
.acko-ref-card .acko-ref-stats {
  display: flex;
  gap: 14px;
  padding-top: 12px;
  border-top: 1px solid #F0F0F0;
}
.acko-ref-card .acko-ref-stat {
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.acko-ref-card .acko-ref-stat-num {
  font-family: var(--acko-display);
  font-size: 18px;
  font-weight: 700;
  color: var(--acko-near-black);
  line-height: 1.1;
}
.acko-ref-card .acko-ref-stat-lbl {
  font-size: 10px;
  color: #999;
}
.acko-ref-card .acko-ref-loc {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-family: var(--acko-mono);
}
.acko-ref-card .acko-ref-loc::before {
  content: '◉';
  color: var(--acko-amber);
}
.acko-ref-card p { margin: 0; }

/* ═══ NEWS ═════════════════════════════════════════════════ */
.acko-news-list .acko-news-link {
  display: grid;
  grid-template-columns: 130px 1fr 220px auto;
  gap: 32px;
  align-items: center;
  padding: 24px 0;
  border-bottom: 1px solid var(--acko-gray-200);
  text-decoration: none !important;
  color: inherit;
  transition: padding-left 200ms;
}
.acko-news-list > div:first-child .acko-news-link,
.acko-news-list .elementor-widget:first-child .acko-news-link {
  border-top: 2px solid var(--acko-near-black);
}
.acko-news-list .acko-news-link:hover {
  padding-left: 8px;
}
.acko-news-list .acko-news-date {
  font-family: var(--acko-mono);
  font-size: 12px;
  color: #999;
  letter-spacing: 0.04em;
}
.acko-news-list .acko-news-mid {
  display: block;
}
.acko-news-list .acko-news-cat {
  display: inline-block;
  padding: 3px 10px;
  border-radius: 9999px;
  background: var(--acko-near-black);
  color: var(--acko-amber);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.08em;
  margin-right: 12px;
  text-transform: uppercase;
  vertical-align: middle;
}
.acko-news-list .acko-news-title {
  font-size: 16px;
  font-weight: 600;
  color: var(--acko-near-black);
  line-height: 1.4;
}
.acko-news-list .acko-news-loc {
  font-family: var(--acko-mono);
  font-size: 11px;
  color: #888;
}
.acko-news-list .acko-news-loc::before {
  content: '◉ ';
  color: var(--acko-amber);
}
.acko-news-list .acko-news-arrow {
  color: #CCC;
  font-weight: 900;
  font-size: 18px;
  transition: color 200ms, transform 200ms;
}
.acko-news-list .acko-news-link:hover .acko-news-arrow {
  color: var(--acko-amber);
  transform: translateX(4px);
}
.acko-news-list p { margin: 0; }

/* ═══ FAQ-Accordion ════════════════════════════════════════ */
.acko-faq .elementor-accordion {
  border-top: 2px solid var(--acko-near-black);
}
.acko-faq .elementor-accordion .elementor-accordion-item {
  border-left: none !important;
  border-right: none !important;
  border-top: none !important;
  border-bottom: 1px solid var(--acko-gray-200) !important;
}
.acko-faq .elementor-accordion .elementor-tab-title {
  background: transparent !important;
  padding: 24px 0 !important;
  transition: color 160ms ease;
}
.acko-faq .elementor-accordion .elementor-tab-title:hover,
.acko-faq .elementor-accordion .elementor-tab-title.elementor-active {
  color: var(--acko-amber-dark) !important;
}
.acko-faq .elementor-accordion .elementor-tab-content {
  border-top: none !important;
  padding: 0 0 28px 0 !important;
}
.acko-faq h2 em {
  font-style: normal;
  color: var(--acko-amber);
}

/* ═══ KONTAKT-Card ═════════════════════════════════════════ */
.acko-kontakt-section h2 em {
  font-style: normal;
  color: #999;
  font-weight: 400;
}
.acko-contact-card {
  position: relative;
}
.acko-contact-card::before {
  content: '';
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  width: 4px;
  background: var(--acko-amber);
}
.acko-contact-avatar {
  background: linear-gradient(135deg, var(--acko-amber), var(--acko-amber-dark)) !important;
  flex-grow: 0 !important;
}
.acko-contact-avatar .elementor-heading-title {
  color: var(--acko-near-black) !important;
}
.acko-contact-info-row a {
  color: var(--acko-near-black) !important;
  text-decoration: none !important;
  font-weight: 600;
}
.acko-contact-info-row a:hover { color: var(--acko-amber) !important; }
.acko-contact-cta-col .elementor-button {
  width: 100% !important;
  justify-content: center !important;
}

/* ═══ FINAL CTA ════════════════════════════════════════════ */
.acko-final-cta {
  position: relative;
  overflow: hidden;
}
.acko-final-cta::before {
  content: 'HN';
  position: absolute;
  right: -40px;
  bottom: -180px;
  font-family: var(--acko-display);
  font-size: 480px;
  font-weight: 900;
  line-height: 0.8;
  color: rgba(26, 26, 26, 0.06);
  letter-spacing: -0.04em;
  user-select: none;
  pointer-events: none;
  z-index: 0;
}
.acko-final-cta > .e-con-inner,
.acko-final-cta > .elementor-container {
  position: relative;
  z-index: 2;
}
.acko-final-cta-col .acko-final-phone-btn {
  display: block;
  background: rgba(26, 26, 26, 0.08);
  color: var(--acko-near-black);
  padding: 16px 28px;
  border-radius: 9999px;
  text-align: center;
  font-weight: 700;
  font-size: 15px;
  text-decoration: none;
  transition: background 180ms;
}
.acko-final-cta-col .acko-final-phone-btn:hover {
  background: rgba(26, 26, 26, 0.14);
}



/* ═══ Buttons (Hover-Polish, Accessibility) ════════════════ */
.elementor-button {
  transition: transform 180ms ease, box-shadow 180ms ease, background 180ms ease !important;
}
.elementor-button:hover { transform: translateY(-1px); }
.elementor-button[style*="rgb(245, 166, 35)"]:hover,
.elementor-button[style*="#F5A623"]:hover {
  box-shadow: 0 12px 32px rgba(245, 166, 35, 0.35);
}
.elementor-button:focus-visible,
a:focus-visible {
  outline: 2px solid var(--acko-amber);
  outline-offset: 3px;
}

/* ═══ MOBILE / RESPONSIVE ══════════════════════════════════ */
@media (max-width: 1024px) {
  .acko-hero::before {
    font-size: 360px;
    right: -80px;
    top: 80px;
  }
  .acko-about::before { font-size: 480px; }
  .acko-final-cta::before { font-size: 320px; bottom: -120px; }

  /* Archive: horizontal scrollen, kleinere Typo */
  .acko-archive .acko-arch-city-name { font-size: 18px !important; }
  .acko-archive .acko-arch-link-cell .acko-arch-link { font-size: 12px; }
  .acko-archive .acko-arch-link-cell { padding: 12px 12px !important; }

  /* News-Grid auf Tablet kompakter */
  .acko-news-list .acko-news-link {
    grid-template-columns: 100px 1fr 160px auto;
    gap: 20px;
  }
}

@media (max-width: 767px) {
  /* Hero */
  .acko-hero::before { font-size: 220px; right: -60px; top: 100px; }
  .acko-hero-h1 .elementor-heading-title { line-height: 0.98 !important; }

  /* Hero-Meta: Strip in Spalten */
  .acko-hero-meta > .e-con-inner > .acko-meta-cell:not(:last-child),
  .acko-hero-meta > .elementor-container > .acko-meta-cell:not(:last-child) {
    border-right: none !important;
    border-bottom: 1px solid var(--acko-gray-200) !important;
    padding-bottom: 16px !important;
    margin-bottom: 16px !important;
  }
  .acko-hero-meta .acko-meta-cell {
    padding-left: 0 !important;
    padding-right: 0 !important;
    width: 100% !important;
  }

  /* Section-Header → einspaltig (Lede unter Headline) */
  .acko-sec-head { margin-bottom: 36px !important; }

  /* Map-Section */
  .acko-map-box { aspect-ratio: 1/1; min-height: 280px; }

  /* Archive: scrollbar oder stark reduziert */
  .acko-archive {
    overflow-x: auto;
  }
  .acko-archive .acko-arch-head-row,
  .acko-archive .acko-arch-row {
    min-width: 720px;
  }

  /* Branchen: 1 Spalte */
  .acko-branches-grid > .e-con,
  .acko-branches-grid > .elementor-element {
    width: 100% !important;
  }

  /* Referenzen: 1-2 Spalten */
  .acko-refs-grid > .e-con,
  .acko-refs-grid > .elementor-element {
    width: calc(50% - 8px) !important;
  }

  /* About-Stats: gestapelt */
  .acko-about-stats > .e-con,
  .acko-about-stats > .elementor-element {
    width: 100% !important;
  }

  /* News: gestapelt */
  .acko-news-list .acko-news-link {
    grid-template-columns: 1fr auto;
    gap: 8px;
    padding: 18px 0;
  }
  .acko-news-list .acko-news-date {
    grid-column: 1 / -1;
    font-size: 11px;
  }
  .acko-news-list .acko-news-mid {
    grid-column: 1;
  }
  .acko-news-list .acko-news-loc {
    grid-column: 1 / -1;
    margin-top: 4px;
  }
  .acko-news-list .acko-news-arrow {
    grid-column: 2;
    grid-row: 2;
    align-self: center;
  }

  /* Kontakt-Card: gestapelt, Avatar oben */
  .acko-contact-card {
    flex-direction: column !important;
    align-items: flex-start !important;
  }
  .acko-contact-cta-col {
    width: 100% !important;
  }

  /* Final CTA */
  .acko-final-cta::before { font-size: 220px; bottom: -80px; }



/* ═══ Print / Reduced-Motion ═══════════════════════════════ */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    transition-duration: 0.01ms !important;
  }
}

@media print {
  @page { size: A4 portrait; margin: 12mm 10mm; }
  body { -webkit-print-color-adjust: exact !important; print-color-adjust: exact !important; }
  .acko-hero::before, .acko-about::before, .acko-final-cta::before { display: none !important; }
  .e-con, .elementor-widget { page-break-inside: avoid; }
  a { color: inherit !important; text-decoration: none !important; }
}
/* ═══════════════════════════════════════════════════════════════
   acko Standorte — Custom CSS
   Einfügen unter: Site Settings → Custom CSS
   ═══════════════════════════════════════════════════════════════ */

:root {
  /* Design Tokens */
  --acko-amber:        #F5A623;
  --acko-amber-dark:   #E09010;
  --acko-amber-deep:   #C57A08;
  --acko-amber-soft:   #FFF3DC;
  --acko-near-black:   #1A1A1A;
  --acko-gray-900:     #2A2A2A;
  --acko-gray-700:     #444444;
  --acko-gray-500:     #666666;
  --acko-gray-400:     #888888;
  --acko-gray-300:     #ABABAB;
  --acko-gray-200:     #C8C8C8;
  --acko-gray-100:     #EBEBEB;
  --acko-gray-50:      #F5F5F5;
  --acko-gray-25:      #FAFAFA;

  --acko-display: 'Barlow Condensed', system-ui, sans-serif;
  --acko-sans:    'Barlow', system-ui, sans-serif;
}

body {
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

/* ── Eyebrow mit Strich-Akzent ───────────────────────────────── */
.acko-eyebrow .elementor-heading-title {
  display: inline-flex !important;
  align-items: center;
}
.acko-eyebrow .elementor-heading-title::before {
  content: "";
  display: inline-block;
  width: 24px;
  height: 2px;
  background: var(--acko-amber);
  margin-right: 12px;
  flex-shrink: 0;
}

/* Helper: Uppercase-Klasse für Region-Labels & Stat-Labels */
.acko-stat-uppercase .elementor-heading-title {
  text-transform: uppercase;
}


/* ═══════════════════════════════════════════════════════════════
   1) PAGE HERO
   ═══════════════════════════════════════════════════════════════ */
.acko-page-hero {
  position: relative;
  overflow: hidden;
}

/* Großes Hintergrund-Chevron */
.acko-page-hero::before {
  content: "››";
  position: absolute;
  right: -40px;
  bottom: -120px;
  font-family: var(--acko-display);
  font-size: 360px;
  font-weight: 900;
  color: rgba(245,166,35,0.08);
  line-height: 1;
  letter-spacing: -0.04em;
  pointer-events: none;
  z-index: 1;
}
.acko-page-hero > .e-con-inner,
.acko-page-hero > .elementor-container {
  position: relative;
  z-index: 2;
}

/* Hero-Stats: Trennlinien zwischen den Cells */
.acko-hero-stats {
  max-width: 820px;
}
.acko-hero-stats > .acko-hero-stat {
  padding-right: 32px;
  padding-left: 0;
  border-right: 1px solid var(--acko-gray-900);
}
.acko-hero-stats > .acko-hero-stat:nth-child(n+2) {
  padding-left: 32px;
}
.acko-hero-stats > .acko-hero-stat-last {
  border-right: none !important;
  padding-right: 0 !important;
}


/* ═══════════════════════════════════════════════════════════════
   2) MAP SECTION
   ═══════════════════════════════════════════════════════════════ */
.acko-map-canvas {
  aspect-ratio: 1 / 1.05;
}
/* Die SVG-Karte rendert komplett aus dem HTML-Widget heraus.
   Ihre internen Styles (Pin-Animation, Hover, Klick-Logik) sind
   im Widget selbst eingebettet und brauchen hier kein zusätzliches CSS. */

.acko-map-meta-tile {
  transition: border-color 200ms ease, background 200ms ease;
}
.acko-map-meta-tile:hover {
  border-color: var(--acko-amber) !important;
  background: var(--acko-amber-soft) !important;
}


/* ═══════════════════════════════════════════════════════════════
   3) ARCHIVE SECTION — Filter + City-Grid
   ═══════════════════════════════════════════════════════════════ */

/* Filter-Bar: Such-Feld */
.acko-filter-search {
  transition: border-color 180ms ease, background 180ms ease;
  cursor: text;
}
.acko-filter-search:hover {
  border-color: var(--acko-gray-200) !important;
  background: #fff !important;
}

/* Chips */
.acko-chip {
  transition: border-color 160ms ease, background 160ms ease, color 160ms ease;
  cursor: pointer;
  flex-grow: 0 !important;
  flex-shrink: 0 !important;
  width: auto !important;
}
.acko-chip:hover:not(.acko-chip-on) {
  border-color: var(--acko-gray-200) !important;
  color: var(--acko-near-black) !important;
}
.acko-chip-on {
  background: var(--acko-near-black) !important;
  border-color: var(--acko-near-black) !important;
}
.acko-chip-on .elementor-heading-title {
  color: #fff !important;
}

.acko-sort-select {
  transition: border-color 180ms ease;
  cursor: pointer;
  flex-grow: 0 !important;
}
.acko-sort-select:hover {
  border-color: var(--acko-gray-200) !important;
}

/* City-Grid */
.acko-city-grid {
  align-items: stretch;
}

/* City-Card */
.acko-city-card {
  transition: transform 220ms ease, box-shadow 220ms ease, border-color 220ms ease !important;
  cursor: pointer;
}
.acko-city-card:hover {
  transform: translateY(-3px);
  box-shadow: 0 12px 36px rgba(0,0,0,0.10);
  border-color: var(--acko-near-black) !important;
}

.acko-city-card-hub {
  border-color: var(--acko-amber) !important;
}
.acko-city-card-hub:hover {
  border-color: var(--acko-amber-deep) !important;
  box-shadow: 0 12px 36px rgba(245,166,35,0.22) !important;
}

/* Hub-Tag (das gold-farbene "STAMMSITZ"-Pill oben in der Hub-Card) */
.acko-hub-tag .elementor-heading-title {
  display: inline-block !important;
  background: var(--acko-amber);
  color: var(--acko-near-black) !important;
  padding: 4px 10px;
  border-radius: 9999px;
  font-size: 10px !important;
}

/* CTA-Link Hover */
.acko-city-card:hover .acko-city-cta .elementor-heading-title {
  color: var(--acko-amber-dark) !important;
}


/* ═══════════════════════════════════════════════════════════════
   4) REACTION SECTION — Radius-Diagramm
   ═══════════════════════════════════════════════════════════════ */
.acko-radius-diagram {
  position: relative;
  aspect-ratio: 1 / 1;
  overflow: hidden;
}

/* Drei dashed Ringe */
.acko-radius-diagram::before,
.acko-radius-diagram::after {
  content: "";
  position: absolute;
  top: 50%; left: 50%;
  border: 1.5px dashed rgba(245,166,35,0.4);
  border-radius: 50%;
  transform: translate(-50%, -50%);
  pointer-events: none;
}
.acko-radius-diagram::before {
  width: 50%; height: 50%;
}
.acko-radius-diagram::after {
  width: 76%; height: 76%;
}

/* Innerster Ring: über inset-Element nachbilden via box-shadow */
.acko-radius-diagram > * {
  position: relative;
  z-index: 3;
}

/* Pin-Label und der Pin-Punkt */
.acko-radius-pinlabel {
  position: relative;
  margin-top: 32px !important;
}
.acko-radius-pinlabel::before {
  content: "";
  position: absolute;
  top: -32px;
  left: 50%;
  transform: translateX(-50%);
  width: 16px; height: 16px;
  background: var(--acko-amber);
  border-radius: 50%;
  box-shadow:
    0 0 0 8px rgba(245,166,35,0.18),
    0 0 0 16px rgba(245,166,35,0.08);
}

/* Innerster Ring (24%) als zusätzliches Element via outline am Pin */
.acko-radius-pinlabel::after {
  content: "15 km · 25 min   30 km · 45 min   50 km · 60 min";
  position: absolute;
  top: -52px;
  left: 50%;
  transform: translateX(-50%);
  font-family: var(--acko-display);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.06em;
  color: var(--acko-amber-deep);
  background: var(--acko-gray-25);
  padding: 0 8px;
  white-space: nowrap;
  display: none; /* ausgeblendet, dafür über echte Labels — siehe unten */
}

/* Stadt-Marker rund ums Pin */
.acko-radius-diagram .acko-radius-pinlabel + *::before { content: none; }

/* Wir overlayen mit eigenen Pseudo-Inhalten via einer Überlagerung */
.acko-radius-diagram::before {
  /* Mittlerer Ring bleibt */
}

/* Zusätzliche Stadt-Marker via einem maskenartigen Overlay */
.acko-reaction-section .acko-radius-diagram {
  background-image:
    radial-gradient(circle, transparent 11%, rgba(245,166,35,0.08) 11%, rgba(245,166,35,0.08) 12%, transparent 12%);
  background-size: 100% 100%;
}

/* Reaktions-Items Hover */
.acko-reaction-item {
  transition: background 180ms ease;
}
.acko-reaction-item:hover {
  background: var(--acko-gray-25);
}


/* ═══════════════════════════════════════════════════════════════
   5) FAQ
   ═══════════════════════════════════════════════════════════════ */
.acko-faq .elementor-accordion .elementor-accordion-item {
  border-left: none !important;
  border-right: none !important;
  border-top: 1px solid var(--acko-gray-100) !important;
  border-bottom: none !important;
  background: transparent !important;
  margin-bottom: 0 !important;
}
.acko-faq .elementor-accordion .elementor-accordion-item:last-child {
  border-bottom: 1px solid var(--acko-gray-100) !important;
}
.acko-faq .elementor-accordion .elementor-tab-title {
  background: transparent !important;
  padding: 22px 0 !important;
  transition: color 160ms ease;
  font-weight: 600 !important;
  font-family: var(--acko-sans) !important;
  font-size: 16px !important;
}
.acko-faq .elementor-accordion .elementor-tab-title:hover,
.acko-faq .elementor-accordion .elementor-tab-title.elementor-active {
  color: var(--acko-amber-dark) !important;
}
.acko-faq .elementor-accordion .elementor-tab-content {
  border-top: none !important;
  padding: 0 52px 22px 0 !important;
  background: transparent !important;
  font-size: 14.5px !important;
  line-height: 1.65 !important;
  color: var(--acko-gray-500) !important;
}
.acko-faq .elementor-accordion .elementor-accordion-icon {
  flex: 0 0 28px !important;
  width: 28px !important;
  height: 28px !important;
  border-radius: 9999px !important;
  background: var(--acko-amber-soft) !important;
  color: var(--acko-amber-dark) !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  transition: transform 220ms, background 200ms !important;
  font-size: 12px !important;
}
.acko-faq .elementor-accordion .elementor-active .elementor-accordion-icon {
  background: var(--acko-amber) !important;
  color: var(--acko-near-black) !important;
}


/* ═══════════════════════════════════════════════════════════════
   6) CTA BANNER
   ═══════════════════════════════════════════════════════════════ */
.acko-cta-banner {
  position: relative;
  overflow: hidden;
}
.acko-cta-banner::before {
  content: "››";
  position: absolute;
  right: -24px;
  bottom: -100px;
  font-family: var(--acko-display);
  font-size: 320px;
  font-weight: 900;
  color: rgba(245,166,35,0.10);
  line-height: 1;
  letter-spacing: -0.04em;
  pointer-events: none;
  z-index: 0;
}
.acko-cta-banner > * {
  position: relative;
  z-index: 1;
}


/* ═══════════════════════════════════════════════════════════════
   BUTTONS — Hover & Focus
   ═══════════════════════════════════════════════════════════════ */
.elementor-button {
  transition: transform 180ms ease, box-shadow 180ms ease, background 180ms ease !important;
  letter-spacing: 0.01em;
}
.elementor-button:hover {
  transform: translateY(-1px);
}
.elementor-button[style*="rgb(245, 166, 35)"]:hover,
.elementor-button[style*="#F5A623"]:hover {
  box-shadow: 0 12px 32px rgba(245,166,35,0.35);
}
.elementor-button:focus-visible,
a:focus-visible {
  outline: 2px solid var(--acko-amber);
  outline-offset: 3px;
}


/* ═══════════════════════════════════════════════════════════════
   MOBILE-ANPASSUNGEN
   ═══════════════════════════════════════════════════════════════ */
@media (max-width: 1024px) {
  .acko-page-hero .elementor-heading-title h1,
  .acko-page-hero h1.elementor-heading-title {
    font-size: 48px !important;
  }
  .acko-page-hero::before {
    font-size: 280px;
    bottom: -100px;
  }
  .acko-cta-banner::before {
    font-size: 240px;
  }
}

@media (max-width: 980px) {
  /* Map + Reaction Sektionen: 1-spaltig */
  .acko-map-section .acko-map-canvas,
  .acko-reaction-section .acko-radius-diagram {
    width: 100% !important;
  }
  /* City-Cards 2-spaltig */
  .acko-city-grid > .acko-city-card {
    width: calc(50% - 10px) !important;
  }
  /* Hero-Stats 2x2 */
  .acko-hero-stats > .acko-hero-stat {
    width: 50% !important;
    padding: 16px 0 !important;
    border-right: none !important;
    border-bottom: 1px solid var(--acko-gray-900);
  }
  .acko-hero-stats > .acko-hero-stat:nth-child(n+2) {
    padding-left: 0 !important;
  }
  .acko-hero-stats > .acko-hero-stat-last {
    border-bottom: none !important;
  }
}

@media (max-width: 767px) {
  .acko-page-hero {
    padding-top: 64px !important;
    padding-bottom: 56px !important;
  }
  .acko-page-hero .elementor-heading-title h1,
  .acko-page-hero h1.elementor-heading-title {
    font-size: 36px !important;
    line-height: 1.05 !important;
  }
  .acko-page-hero::before {
    font-size: 200px;
    bottom: -60px;
    right: -20px;
  }

  .elementor-widget-heading h2.elementor-heading-title {
    font-size: 30px !important;
    line-height: 1.08 !important;
  }

  /* City-Cards 1-spaltig */
  .acko-city-grid > .acko-city-card {
    width: 100% !important;
  }

  /* Section-Padding reduzieren */
  .acko-map-section > .e-con-inner,
  .acko-archive-section > .e-con-inner,
  .acko-reaction-section > .e-con-inner,
  .acko-faq-section > .e-con-inner,
  .acko-cta-section > .e-con-inner {
    padding-top: 56px !important;
    padding-bottom: 56px !important;
  }

  /* CTA Banner kompakter */
  .acko-cta-banner {
    padding: 40px 28px !important;
  }
  .acko-cta-banner::before {
    font-size: 200px;
  }
}

@media (max-width: 480px) {
  .acko-hero-stats > .acko-hero-stat {
    width: 100% !important;
  }
  /* Filter-Bar Search nimmt volle Breite */
  .acko-filter-search,
  .acko-sort-select {
    width: 100% !important;
  }
}


/* ═══════════════════════════════════════════════════════════════
   PRINT & REDUCED-MOTION
   ═══════════════════════════════════════════════════════════════ */
@media print {
  .acko-page-hero::before,
  .acko-cta-banner::before,
  .acko-map-canvas::before,
  .acko-map-canvas::after,
  .acko-radius-diagram::before,
  .acko-radius-diagram::after { display: none !important; }
}

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    transition-duration: 0.01ms !important;
  }
}


/* ═══════════════════════════════════════════════════════════════
   HELPER-KLASSEN (im Elementor unter Advanced → CSS Classes)
   ═══════════════════════════════════════════════════════════════ */
.acko-accent       { color: var(--acko-amber) !important; }
.acko-text-balance { text-wrap: balance; }
.acko-text-pretty  { text-wrap: pretty; }
/* ──────────────────────────────────────────────────────────────
   acko · Gebäudereinigung Heilbronn — Custom CSS  (v2)
   Einfügen unter: WordPress → Elementor → Site Settings → Custom CSS
   ────────────────────────────────────────────────────────────── */

@import url('https://fonts.googleapis.com/css2?family=Barlow:ital,wght@0,400;0,500;0,600;0,700;0,800;0,900;1,400&family=Barlow+Condensed:wght@300;400;500;600;700;800;900&display=swap');

:root {
  --hn-amber:        #F5A623;
  --hn-amber-dark:   #E09010;
  --hn-amber-deep:   #C57A08;
  --hn-amber-soft:   #FFF3DC;
  --hn-near:         #1A1A1A;
  --hn-ink:          #0D0D0D;
  --hn-gray-900:     #2A2A2A;
  --hn-gray-700:     #555555;
  --hn-gray-500:     #888888;
  --hn-gray-400:     #ABABAB;
  --hn-gray-300:     #C8C8C8;
  --hn-gray-200:     #E0E0E0;
  --hn-gray-100:     #F4F4F4;
  --hn-gray-50:      #FAFAFA;
  --hn-wa-green:     #25D366;

  --hn-display: 'Barlow Condensed', system-ui, sans-serif;
  --hn-sans:    'Barlow', system-ui, sans-serif;
}

body {
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

/* ── Eyebrow mit Strich-Akzent vorne ─────────────────────── */
.hn-eyebrow .elementor-heading-title {
  display: inline-flex !important;
  align-items: center;
}
.hn-eyebrow .elementor-heading-title::before {
  content: "";
  display: inline-block;
  width: 28px;
  height: 2px;
  background: var(--hn-amber);
  margin-right: 12px;
  flex-shrink: 0;
}

/* ── Locator-Strip: Pill mit Punkt-Indikator ────────────── */
.hn-locator-pill .elementor-heading-title {
  display: inline-flex !important;
  align-items: center;
  gap: 8px;
  padding: 4px 12px;
  background: var(--hn-amber-soft);
  border-radius: 9999px;
  letter-spacing: 0.06em !important;
}
.hn-locator-pill .elementor-heading-title::before {
  content: "";
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--hn-amber);
  box-shadow: 0 0 0 3px rgba(245,166,35,0.25);
  flex-shrink: 0;
}

/* ════════════════════════════════════════════════════════════
   HERO
   ════════════════════════════════════════════════════════════ */
.hn-hero {
  position: relative;
  overflow: hidden;
  min-height: 720px;
}
.hn-hero::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(255,255,255,0.025) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,0.025) 1px, transparent 1px);
  background-size: 56px 56px;
  -webkit-mask-image: radial-gradient(ellipse 80% 60% at 70% 50%, #000 30%, transparent 80%);
          mask-image: radial-gradient(ellipse 80% 60% at 70% 50%, #000 30%, transparent 80%);
  opacity: 0.3;
  pointer-events: none;
  z-index: 1;
}
.hn-hero::after {
  content: "";
  position: absolute;
  inset: 0;
  background:
    radial-gradient(circle at 18% 30%, rgba(245,166,35,0.12) 0%, transparent 35%),
    radial-gradient(circle at 80% 70%, rgba(245,166,35,0.06) 0%, transparent 40%);
  opacity: 0.6;
  pointer-events: none;
  z-index: 1;
}
.hn-hero > .e-con-inner,
.hn-hero > .elementor-container {
  position: relative;
  z-index: 2;
}

/* ── Hero H1 — Outline-Effekt für "Ein Anruf," ─────────── */
.hn-hero .hn-stroke {
  -webkit-text-stroke: 1.5px rgba(245,166,35,0.85);
  color: transparent;
  font-weight: 900;
}

/* ── Hero CTA-Row: Call-Block + WhatsApp-Pill ───────────── */
.hn-hero-ctas { align-items: center !important; }

/* Großer orangener Call-Block (Container mit Link) */
.hn-call-block {
  width: -moz-fit-content !important;
  width: fit-content !important;
  flex-grow: 0 !important;
  cursor: pointer;
  text-decoration: none !important;
  transition: box-shadow 220ms ease, transform 200ms ease, background 200ms ease !important;
}
.hn-call-block:hover {
  box-shadow: 0 8px 28px rgba(245,166,35,0.5);
  transform: translateY(-1px);
  background: var(--hn-amber-dark) !important;
}
.hn-call-icon { flex-shrink: 0; }

/* WhatsApp-Pill */
.hn-wa-pill {
  width: -moz-fit-content !important;
  width: fit-content !important;
  flex-grow: 0 !important;
  cursor: pointer;
  text-decoration: none !important;
  transition: border-color 200ms ease, background 200ms ease !important;
}
.hn-wa-pill:hover {
  border-color: #fff !important;
  background: rgba(255,255,255,0.06) !important;
}

/* ── Trust-Stats ────────────────────────────────────────── */
.hn-trust .hn-trust-item {
  width: auto !important;
  flex: 0 1 auto;
}
.hn-trust .hn-trust-item:not(:last-child) {
  padding-right: 28px;
}

/* ════════════════════════════════════════════════════════════
   HERO-RIGHT: SVG-Illustration + Floating-Callouts
   ════════════════════════════════════════════════════════════ */
.hn-hero-right { position: relative !important; }

/* SVG-Wrap (das HTML-Widget rendert <div class="hn-illu-wrap">) */
.hn-illu-wrap {
  position: relative;
  width: 100%;
  aspect-ratio: 1 / 1.05;
  display: flex;
  align-items: center;
  justify-content: center;
}
.hn-illu-wrap svg {
  width: 100%;
  height: 100%;
  display: block;
}

/* Floating-Callouts — Desktop: absolut über die Illustration */
@media (min-width: 1025px) {
  .hn-callout {
    position: absolute !important;
    width: auto !important;
    max-width: 220px;
    box-shadow: 0 24px 48px rgba(0,0,0,0.5);
    z-index: 4;
    flex-grow: 0 !important;
  }
  .hn-callout-tl { top: 4%;     left: -6%; }
  .hn-callout-bl { bottom: 18%; left: -8%; }
  .hn-callout-br { bottom: 8%;  right: -4%; }
}
/* Mobile: Callouts unter der Illustration stapeln */
@media (max-width: 1024px) {
  .hn-callout {
    width: auto !important;
    max-width: 100%;
    flex-grow: 0 !important;
  }
}

/* ════════════════════════════════════════════════════════════
   USP-BAR
   ════════════════════════════════════════════════════════════ */
.hn-usp-cell:not(:last-child) {
  border-right: 1px solid #EBEBEB;
}
@media (max-width: 767px) {
  .hn-usp-cell {
    border-right: none !important;
    border-bottom: 1px solid #EBEBEB;
    padding: 18px 0 !important;
    width: 100% !important;
  }
  .hn-usp-cell:last-child { border-bottom: none; }
}
.hn-usp-cell > .e-con-inner > .elementor-element:first-child,
.hn-usp-cell > .elementor-container > .elementor-element:first-child {
  flex-shrink: 0;
}

/* ════════════════════════════════════════════════════════════
   LEISTUNGEN — Cards mit Hover
   ════════════════════════════════════════════════════════════ */
.hn-lcard {
  position: relative;
  transition: transform 220ms ease, box-shadow 220ms ease, border-color 220ms ease !important;
  cursor: pointer;
}
.hn-lcard:hover {
  border-color: var(--hn-amber) !important;
  transform: translateY(-2px);
  box-shadow: 0 12px 32px rgba(245,166,35,0.12);
}
.hn-lcard-lg {
  background: linear-gradient(155deg, #1A1A1A 0%, #2A2A2A 100%) !important;
}
.hn-lcard-lg:hover {
  border-color: var(--hn-amber) !important;
  box-shadow: 0 16px 40px rgba(0,0,0,0.4);
}
.hn-lcard > .e-con-inner > .elementor-element:first-child,
.hn-lcard > .elementor-container > .elementor-element:first-child {
  position: absolute !important;
  top: 22px;
  right: 24px;
  z-index: 2;
  width: auto !important;
}

/* ════════════════════════════════════════════════════════════
   BRANCHEN-Tabs (Pill-Style)
   ════════════════════════════════════════════════════════════ */
.hn-branchen .elementor-tabs-wrapper {
  display: flex !important;
  flex-wrap: wrap;
  gap: 4px;
  padding: 6px;
  background: #0D0D0D;
  border: 1px solid var(--hn-gray-900);
  border-radius: 9999px;
  width: -moz-fit-content;
  width: fit-content;
  border-bottom: 1px solid var(--hn-gray-900) !important;
}
.hn-branchen .elementor-tab-title {
  border: none !important;
  background: transparent !important;
  color: var(--hn-gray-500) !important;
  padding: 10px 18px !important;
  border-radius: 9999px !important;
  font-family: var(--hn-sans) !important;
  font-size: 13px !important;
  font-weight: 700 !important;
  margin: 0 !important;
  white-space: nowrap;
  transition: color 180ms ease, background 180ms ease;
}
.hn-branchen .elementor-tab-title:hover { color: #fff !important; }
.hn-branchen .elementor-tab-title.elementor-active {
  background: var(--hn-amber) !important;
  color: var(--hn-near) !important;
}
.hn-branchen .elementor-tabs-content-wrapper {
  border: none !important;
  margin-top: 32px;
}
.hn-branchen .elementor-tab-content {
  border: none !important;
  padding: 32px 0 0 0 !important;
  background: transparent !important;
  color: var(--hn-gray-400) !important;
}
.hn-branchen .elementor-tab-mobile-title {
  background: var(--hn-ink) !important;
  color: var(--hn-gray-400) !important;
  border: 1px solid var(--hn-gray-900) !important;
  border-radius: 8px !important;
  margin-bottom: 8px;
}
.hn-branchen .elementor-tab-mobile-title.elementor-active {
  background: var(--hn-amber) !important;
  color: var(--hn-near) !important;
}

/* ════════════════════════════════════════════════════════════
   PROCESS — Verbindungslinie + Sticky-Aside
   ════════════════════════════════════════════════════════════ */
.hn-pstep-list { position: relative; }
.hn-pstep-list::before {
  content: "";
  position: absolute;
  left: 23px;
  top: 24px;
  bottom: 24px;
  width: 2px;
  background: repeating-linear-gradient(
    180deg, var(--hn-amber) 0, var(--hn-amber) 6px,
    transparent 6px, transparent 12px
  );
  pointer-events: none;
  z-index: 0;
}
.hn-pstep { position: relative; z-index: 1; }
.hn-pstep-num { z-index: 2; }
.hn-pstep-meta .elementor-heading-title {
  display: inline-block;
  background: var(--hn-amber-soft);
  padding: 3px 10px;
  border-radius: 9999px;
  letter-spacing: 0.06em !important;
  text-transform: uppercase;
}
@media (min-width: 1025px) {
  .hn-process-aside {
    position: sticky !important;
    top: 100px;
    align-self: flex-start;
  }
}

/* ════════════════════════════════════════════════════════════
   STADTTEILE
   ════════════════════════════════════════════════════════════ */
.hn-nbhd-chip {
  transition: border-color 180ms ease, transform 180ms ease !important;
}
.hn-nbhd-chip:hover {
  border-color: var(--hn-amber) !important;
  transform: translateY(-1px);
}
.hn-nbhd-marker {
  box-shadow: 0 0 0 4px rgba(245,166,35,0.15);
  flex-shrink: 0;
}
.hn-nbhd-foot { text-align: center; margin-top: 28px; }

/* ════════════════════════════════════════════════════════════
   TESTIMONIALS
   ════════════════════════════════════════════════════════════ */
.hn-tc {
  position: relative;
  transition: border-color 220ms ease, box-shadow 220ms ease, transform 220ms ease !important;
}
.hn-tc:hover {
  border-color: var(--hn-amber) !important;
  box-shadow: 0 12px 32px rgba(245,166,35,0.10);
  transform: translateY(-2px);
}
.hn-tc::before {
  content: "„";
  position: absolute;
  top: 8px;
  right: 24px;
  font-family: var(--hn-display);
  font-size: 80px;
  font-weight: 900;
  line-height: 1;
  color: var(--hn-amber-soft);
  pointer-events: none;
  z-index: 0;
}
.hn-tc > * { position: relative; z-index: 1; }
.hn-tc-pin {
  margin-left: auto !important;
  flex-grow: 0 !important;
  width: auto !important;
  flex-shrink: 0;
}
.hn-tc-avatar { flex-shrink: 0; }

/* ════════════════════════════════════════════════════════════
   FAQ-Accordion-Polish
   ════════════════════════════════════════════════════════════ */
.hn-faq-section .elementor-accordion .elementor-accordion-item {
  border: 1px solid #EBEBEB !important;
  border-radius: 10px !important;
  background: #fff !important;
  margin-bottom: 8px;
  overflow: hidden;
  transition: border-color 200ms ease;
}
.hn-faq-section .elementor-accordion .elementor-accordion-item:has(.elementor-active) {
  border-color: var(--hn-amber) !important;
}
.hn-faq-section .elementor-accordion .elementor-tab-title {
  background: transparent !important;
  border: none !important;
  padding: 22px 24px !important;
  transition: background 180ms ease;
}
.hn-faq-section .elementor-accordion .elementor-tab-title:hover {
  background: var(--hn-gray-50) !important;
}
.hn-faq-section .elementor-accordion .elementor-tab-content {
  border-top: none !important;
  padding: 4px 24px 22px !important;
  font-size: 14px !important;
  color: var(--hn-gray-700) !important;
}
.hn-faq-section .elementor-accordion .elementor-tab-content strong {
  color: var(--hn-near) !important;
  font-weight: 700;
}

/* ════════════════════════════════════════════════════════════
   SEO-Section
   ════════════════════════════════════════════════════════════ */
.hn-seo h3 {
  font-family: var(--hn-display);
  font-size: 22px;
  font-weight: 800;
  color: var(--hn-near);
  margin-top: 28px;
  margin-bottom: 10px;
  letter-spacing: -0.005em;
}
.hn-seo strong { color: var(--hn-near); font-weight: 700; }
.hn-seo a { color: var(--hn-amber-deep); font-weight: 700; text-decoration: none; }

/* ════════════════════════════════════════════════════════════
   CTA-BANNER
   ════════════════════════════════════════════════════════════ */
.hn-cta-banner {
  position: relative;
  overflow: hidden;
}
.hn-cta-banner::before {
  content: "";
  position: absolute;
  right: -100px;
  top: 50%;
  transform: translateY(-50%);
  width: 500px;
  height: 500px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(245,166,35,0.18) 0%, transparent 70%);
  pointer-events: none;
  z-index: 1;
}
.hn-cta-banner > .e-con-inner,
.hn-cta-banner > .elementor-container {
  position: relative;
  z-index: 2;
}
.hn-cta-call,
.hn-cta-wa {
  transition: transform 200ms ease, box-shadow 220ms ease, background 200ms ease, border-color 200ms ease !important;
  cursor: pointer;
  text-decoration: none !important;
}
.hn-cta-call:hover {
  box-shadow: 0 12px 32px rgba(245,166,35,0.4);
  transform: translateY(-1px);
}
.hn-cta-wa:hover {
  border-color: #fff !important;
  background: rgba(255,255,255,0.04) !important;
}

/* ════════════════════════════════════════════════════════════
   STICKY-CALL-DOCK (fixed position rechts unten)
   ════════════════════════════════════════════════════════════ */
.hn-sticky-dock {
  position: fixed !important;
  right: 24px;
  bottom: 24px;
  z-index: 250;
  width: auto !important;
  max-width: -moz-fit-content;
  max-width: fit-content;
  flex-grow: 0 !important;
  pointer-events: none;
  background: transparent !important;
  padding: 0 !important;
}
.hn-sticky-dock > * { pointer-events: auto; }
.hn-sticky-dock > .e-con-inner,
.hn-sticky-dock > .elementor-container {
  width: auto !important;
  max-width: none;
}
.hn-sticky-pill {
  width: -moz-fit-content !important;
  width: fit-content !important;
  flex-grow: 0 !important;
  box-shadow: 0 8px 24px rgba(0,0,0,0.18);
  cursor: pointer;
  text-decoration: none !important;
  transition: transform 180ms ease, box-shadow 180ms ease !important;
}
.hn-sticky-pill:hover {
  transform: translateY(-1px);
  box-shadow: 0 12px 28px rgba(0,0,0,0.24);
}

/* Auf Mobile etwas kompakter */
@media (max-width: 480px) {
  .hn-sticky-dock {
    right: 12px;
    bottom: 12px;
  }
}

/* ════════════════════════════════════════════════════════════
   Buttons — Fokus-Sichtbarkeit
   ════════════════════════════════════════════════════════════ */
.elementor-button:focus-visible,
a:focus-visible,
button:focus-visible {
  outline: 2px solid var(--hn-amber);
  outline-offset: 3px;
}

/* ════════════════════════════════════════════════════════════
   FOOTER
   ════════════════════════════════════════════════════════════ */
.hn-footer-bottom .elementor-widget-text-editor:last-child p {
  text-align: right;
}

/* ════════════════════════════════════════════════════════════
   MOBILE / TABLET ANPASSUNGEN
   ════════════════════════════════════════════════════════════ */
@media (max-width: 1024px) {
  .hn-hero {
    padding: 72px 24px 64px !important;
    min-height: auto;
  }
  .hn-hero h1.elementor-heading-title { font-size: 56px !important; }

  .hn-leistungen > .e-con-inner,
  .hn-branchen > .e-con-inner,
  .hn-process > .e-con-inner,
  .hn-stadtteile > .e-con-inner,
  .hn-testimonials > .e-con-inner,
  .hn-faq-section > .e-con-inner,
  .hn-seo > .e-con-inner,
  .hn-cta-banner > .e-con-inner {
    padding-top: 64px !important;
    padding-bottom: 64px !important;
  }
}

@media (max-width: 767px) {
  .hn-hero h1.elementor-heading-title {
    font-size: 40px !important;
    line-height: 1 !important;
  }
  .hn-hero-left, .hn-hero-right { width: 100% !important; }

  .hn-trust { gap: 18px !important; }
  .hn-trust-item { width: 46% !important; }

  .hn-leistungen-grid > .e-con,
  .hn-leistungen-grid > .elementor-element { width: 100% !important; }
  .hn-lcard-lg { min-height: auto !important; }

  .elementor-widget-heading h2.elementor-heading-title {
    font-size: 32px !important;
    line-height: 1.05 !important;
  }

  .hn-nbhd-chip,
  .hn-tc { width: 100% !important; }

  .hn-pstep-list, .hn-process-aside { width: 100% !important; }
  .hn-process-aside { position: static !important; margin-top: 32px; }

  .hn-seo .e-con-inner > .e-con,
  .hn-seo > .e-con-inner > .elementor-element { width: 100% !important; }

  .hn-cta-banner .e-con-inner > .e-con { width: 100% !important; }

  .hn-footer .e-con-inner > .e-con,
  .hn-footer-bottom { flex-direction: column !important; gap: 16px; }
  .hn-footer .e-con-inner > .e-con { width: 100% !important; }
  .hn-footer-bottom .elementor-widget-text-editor:last-child p { text-align: left; }

  /* Sticky-Pills auf Mobile: Telefonnummer/WhatsApp-Text ausblenden */
  .hn-sticky-pill .elementor-heading-title { display: none; }
  .hn-sticky-pill { padding: 14px !important; }
}

@media (max-width: 480px) {
  .hn-locator { display: none; }
  .hn-trust-item { width: 100% !important; }
}

/* Reduced Motion */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    transition-duration: 0.01ms !important;
  }
}/* ──────────────────────────────────────────────────────────────
   acko — WAS Service-Tiles · Custom CSS
   Einfügen unter: Site Settings → Custom CSS
   ────────────────────────────────────────────────────────────── */

:root {
  --acko-amber:       #F5A623;
  --acko-amber-dark:  #E09010;
  --acko-amber-deep:  #C57A08;
  --acko-near-black:  #1A1A1A;
  --acko-ink-2:       #555555;
  --acko-ink-3:       #888888;
  --acko-line-soft:   #EBEBEB;
  --acko-bg-gray:     #F5F5F5;
  --acko-display:     'Barlow Condensed', system-ui, sans-serif;
  --acko-sans:        'Barlow', system-ui, sans-serif;
}

/* ── Eyebrow mit Strich-Akzent ─────────────────────────────── */
.acko-eyebrow .elementor-heading-title {
  display: inline-flex !important;
  align-items: center;
}
.acko-eyebrow .elementor-heading-title::before {
  content: "";
  display: inline-block;
  width: 20px;
  height: 2px;
  background: var(--acko-amber);
  margin-right: 8px;
  flex-shrink: 0;
}

/* ── Header Body-Copy Breite begrenzen ─────────────────────── */
.acko-was-head .elementor-widget-text-editor {
  max-width: 580px;
}

/* ── Service-Tile Card ─────────────────────────────────────── */
.acko-was-tile {
  cursor: pointer;
  transition: background 220ms, border-color 220ms, transform 220ms,
              box-shadow 220ms;
}

/* Description soll Pfeil nach unten drücken */
.acko-was-tile > .elementor-element.acko-was-desc,
.acko-was-tile .elementor-widget.acko-was-desc {
  flex-grow: 1;
}

/* Hover: Card wird dunkel */
.acko-was-tile:hover {
  background-color: var(--acko-near-black) !important;
  border-color: var(--acko-near-black) !important;
  transform: translateY(-2px);
  box-shadow: 0 8px 24px rgba(0,0,0,0.12);
}

/* Hover: Texte hellen sich auf */
.acko-was-tile:hover .acko-was-name .elementor-heading-title {
  color: #fff !important;
}
.acko-was-tile:hover .acko-was-desc,
.acko-was-tile:hover .acko-was-desc p {
  color: rgba(255,255,255,0.65) !important;
}
.acko-was-tile:hover .acko-was-num .elementor-heading-title {
  color: var(--acko-amber) !important;
}
/* Pfeil bleibt amber, evtl. leichte Bewegung */
.acko-was-tile:hover .acko-was-arrow .elementor-heading-title {
  color: var(--acko-amber) !important;
  transform: translateX(2px);
  transition: transform 220ms;
}

/* ── Responsive: 5 → 2 → 1 Spalten ─────────────────────────── */
@media (max-width: 1024px) {
  .acko-was-grid > .e-con,
  .acko-was-grid > .elementor-element {
    width: calc(50% - 6px) !important;
  }
}
@media (max-width: 600px) {
  .acko-was-grid > .e-con,
  .acko-was-grid > .elementor-element {
    width: 100% !important;
  }
}/* End custom CSS */