/* =========================================
   1. DESIGN TOKENS
   ========================================= */
:root {
  /* Farben */
  --color-primary-50:  #eff4ff;
  --color-primary-100: #dbe7ff;
  --color-primary-200: #bfd3ff;
  --color-primary-300: #93b4ff;
  --color-primary-400: #5c86ff;
  --color-primary-500: #2563eb;
  --color-primary-600: #1d4ed8;
  --color-primary-700: #1e40af;
  --color-primary-800: #1e3a8a;
  --color-primary-900: #172554;

  --color-neutral-50:  #f8fafc;
  --color-neutral-100: #f1f5f9;
  --color-neutral-200: #e2e8f0;
  --color-neutral-300: #cbd5e1;
  --color-neutral-400: #94a3b8;
  --color-neutral-500: #64748b;
  --color-neutral-600: #475569;
  --color-neutral-700: #334155;
  --color-neutral-800: #1e293b;
  --color-neutral-900: #0f172a;

  --color-accent-50:  #fff7ed;
  --color-accent-100: #ffedd5;
  --color-accent-200: #fed7aa;
  --color-accent-300: #fdba74;
  --color-accent-400: #fb923c;
  --color-accent-500: #f97316;
  --color-accent-600: #ea580c;
  --color-accent-700: #c2410c;

  --color-success:       #16a34a;
  --color-success-soft:  #dcfce7;
  --color-success-strong:#166534;
  --color-warning:       #eab308;
  --color-warning-soft:  #fef9c3;
  --color-warning-strong:#854d0e;
  --color-danger:        #dc2626;
  --color-danger-soft:   #fee2e2;
  --color-danger-strong: #991b1b;	   
  --color-topbar-bg: var(--color-primary-500);


  /* Flächen / Rahmen */
  --color-page-bg:       var(--color-neutral-50);
  --color-bg:            var(--color-page-bg);
  --color-bg-dark:       #0f1012;
  --color-surface:       #ffffff;
  --color-surface-alt:   #f9fafb;
  --color-surface-elevated: #ffffff;
  --color-surface-subtle:   var(--color-neutral-50);
  --color-topbar-bg:        var(--color-neutral-900);
  --color-navbar-bg:        rgba(248,250,252,0.98);
  --color-navbar-bg-scrolled:#ffffff;
  --color-footer-bg:        #181818;

  --color-border-subtle: var(--color-neutral-200);
  --color-border-soft:   rgba(148,163,184,0.40);
  --color-border-strong: var(--color-neutral-400);

  /* Brand-Aliasse */
  --color-primary:           var(--color-primary-500);
  --color-primary-soft:      var(--color-primary-50);
  --color-primary-soft-text: var(--color-primary-700);

  /* Text */
  --color-text:          #222222;
  --color-text-muted:    #6c757d;
  --color-text-soft:     #9ca3af;
  --color-on-primary:    #ffffff;
  --color-on-surface:    #111111;
  --color-on-dark:       #f9fafb;
  --color-on-accent:     #111111;

  /* Links */
  --color-link:            var(--color-primary-600);
  --color-link-hover:      var(--color-primary-700);
  --color-link-muted:      var(--color-neutral-600);
  --color-link-on-dark:    var(--color-accent-200);
  --color-link-on-dark-hover: #ffffff;

  /* Overlays / Badges / Inputs */
  --color-overlay-soft:     rgba(15,23,42,0.35);
  --color-overlay-strong:   rgba(15,23,42,0.6);

  --badge-bg:               rgba(148,163,184,0.12);
  --badge-border:           rgba(148,163,184,0.6);
  --badge-text:             var(--color-neutral-800);
  --badge-bg-on-dark:       rgba(15,23,42,0.7);
  --badge-border-on-dark:   rgba(148,163,184,0.7);
  --badge-text-on-dark:     var(--color-neutral-50);

  --field-bg:              #ffffff;
  --field-bg-disabled:     #f4f4f5;
  --field-border:          var(--color-border-subtle);
  --field-border-hover:    var(--color-neutral-400);
  --field-border-focus:    var(--color-primary-400);
  --field-placeholder:     var(--color-neutral-400);
  --field-text:            var(--color-text);
  --field-text-on-dark:    var(--color-on-dark);
  --field-error-border:    var(--color-danger);
  --field-error-bg:        var(--color-danger-soft);
  --field-success-border:  var(--color-success);
  --field-success-bg:      var(--color-success-soft);

  /* Typografie */
  --font-family-base: 'Inter', system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;

  --font-size-xs: 0.75rem;
  --font-size-sm: 0.875rem;
  --font-size-md: 0.95rem;
  --font-size-lg: 1.125rem;
  --font-size-xl: 1.5rem;

  --font-size-2xl: 2rem;
  --font-size-3xl: 2.5rem;

  --font-weight-regular: 400;
  --font-weight-medium:  500;
  --font-weight-semibold:600;
  --font-weight-bold:    700;
  --font-weight-black:   800;

  --line-height-tight: 1.2;
  --line-height-normal:1.5;
  --line-height-loose: 1.7;
  --line-height-base:  var(--line-height-normal);

  --heading-hero-size:        clamp(var(--font-size-2xl), 3vw + 1rem, var(--font-size-3xl));
  --heading-hero-weight:      var(--font-weight-black);
  --heading-section-size:     var(--font-size-2xl);
  --heading-section-weight:   var(--font-weight-bold);
  --heading-subsection-size:  1.25rem;
  --heading-subsection-weight:var(--font-weight-semibold);

  /* Spacing */
  --space-0:   0;
  --space-1:   0.25rem;
  --space-2:   0.5rem;
  --space-3:   0.75rem;
  --space-4:   1rem;
  --space-5:   1.5rem;
  --space-6:   2rem;
  --space-8:   3rem;
  --space-10:  4rem;

  --section-space-y-sm:  var(--space-5);
  --section-space-y-md:  var(--space-6);
  --section-space-y-lg:  var(--space-8);

  /* Radius / Schatten / Motion */
  --radius-sm: 8px;
  --radius-md: 10px;
  --radius-lg: 14px;
  --radius-pill: 999px;

  --shadow-micro:  0 4px 10px rgba(15,23,42,0.10);
  --shadow-soft:   0 16px 32px rgba(0,0,0,0.05);
  --shadow-strong: 0 24px 48px rgba(0,0,0,0.12);

  --focus-ring-soft:   0 0 0 3px rgba(148,163,184,0.45);
  --focus-ring-strong: 0 0 0 3px rgba(13,110,253,0.55);

  --duration-fast:  120ms;
  --duration-base:  180ms;
  --duration-slow:  260ms;

  --easing-standard: cubic-bezier(0.22,0.61,0.36,1);

  /* Z-Index */
  --z-topbar:   1040;
  --z-navbar:   1030;
  --z-dropdown: 1050;
  --z-overlay:  1060;
  --z-modal:    1070;

  /* Button-Tokens */
  --btn-radius:           var(--radius-md);
  --btn-height-md:        44px;
  --btn-height-sm:        36px;
  --btn-height-lg:        48px;
  --btn-padding-x:        1.7rem;
  --btn-padding-y:        0.6rem;
  --btn-gap:              0.45rem;

  --btn-font-family:      var(--font-family-base);
  --btn-font-size:        var(--font-size-md);
  --btn-font-weight:      var(--font-weight-semibold);
  --btn-line-height:      1.1;

  --btn-shadow:           0 10px 20px rgba(15,23,42,0.08);
  --btn-shadow-hover:     0 14px 30px rgba(15,23,42,0.14);

  --state-disabled-opacity: 0.55;

  --btn-primary-bg:            var(--color-primary-500);
  --btn-primary-bg-hover:      var(--color-primary-600);
  --btn-primary-border:        var(--color-primary-500);
  --btn-primary-border-hover:  var(--color-primary-600);
  --btn-primary-text:          var(--color-on-primary);

  --btn-secondary-bg:          var(--color-surface);
  --btn-secondary-bg-hover:    var(--color-neutral-50);
  --btn-secondary-border:      var(--color-border-subtle);
  --btn-secondary-border-hover:var(--color-primary-200);
  --btn-secondary-text:        var(--color-neutral-800);
  --btn-secondary-text-hover:  var(--color-primary-700);

  --btn-ghost-bg:              transparent;
  --btn-ghost-bg-hover:        var(--color-neutral-50);
  --btn-ghost-border:          var(--color-border-subtle);
  --btn-ghost-border-hover:    var(--color-primary-300);
  --btn-ghost-text:            var(--color-neutral-800);
  --btn-ghost-text-hover:      var(--color-primary-700);

  --btn-dark-bg:               var(--color-neutral-900);
  --btn-dark-bg-hover:         var(--color-neutral-800);
  --btn-dark-border:           var(--color-neutral-900);
  --btn-dark-border-hover:     var(--color-neutral-800);
  --btn-dark-text:             var(--color-on-dark);

  --btn-danger-bg:             linear-gradient(135deg, var(--color-danger), var(--color-accent-500));
  --btn-danger-bg-hover:       linear-gradient(135deg, #b91c1c, var(--color-accent-600));
  --btn-danger-border:         rgba(0,0,0,0.06);
  --btn-danger-border-hover:   rgba(0,0,0,0.10);
  --btn-danger-text:           var(--color-on-primary);

  /* Bootstrap Bridge */
  --bs-body-bg:         var(--color-page-bg);
  --bs-body-color:      var(--color-text);
  --bs-border-color:    var(--color-border-subtle);
  --bs-primary:         var(--color-primary-500);
  --bs-secondary:       var(--color-neutral-600);
  --bs-success:         var(--color-success);
  --bs-danger:          var(--color-danger);
  --bs-warning:         var(--color-warning);
  --bs-info:            var(--color-primary-300);
  --bs-link-color:       var(--color-link);
  --bs-link-hover-color: var(--color-link-hover);
  --bs-badge-color:         var(--badge-text);
  --bs-badge-bg:            var(--badge-bg);
  --bs-badge-border-radius: var(--radius-pill);

  /* Content-Breite */
  --content-max-width: 72rem;
}

/* =========================================
   2. GLOBAL
   ========================================= */
*,
*::before,
*::after {
  box-sizing: border-box;
}

html,
body {
  margin: 0;
  padding: 0;
}

body {
  font-family: var(--font-family-base);
  background: var(--color-page-bg);
  color: var(--color-text);
  line-height: var(--line-height-base);
  -webkit-font-smoothing: antialiased;
}

img,
picture,
video,
canvas,
svg {
  display: block;
  max-width: 100%;
}

a {
  color: inherit;
  text-decoration: none;
}

.hk-link {
  color: var(--color-link);
  text-decoration: none;
}
.hk-link:hover {
  color: var(--color-link-hover);
  text-decoration: underline;
  text-underline-offset: 2px;
}

/* Fokus nur bei Tastatur */
:focus-visible {
  outline: var(--focus-ring-soft);
}

/* Content Breite */
.hk-content,
.hk-section-inner {
  max-width: var(--content-max-width);
  margin-inline: auto;
}

/* Stacks */
.hk-stack > * + * {
  margin-top: var(--space-3);
}
.hk-stack--lg > * + * {
  margin-top: var(--space-4);
}
.hk-stack--xl > * + * {
  margin-top: var(--space-5);
}

/* Sektionen */
.hk-section {
  padding-block: var(--section-space-y-md);
}
.hk-section--lg {
  padding-block: var(--section-space-y-lg);
}
.hk-section--sm {
  padding-block: var(--section-space-y-sm);
}

/* =========================================
   3. TYPOGRAFIE-KLASSEN
   ========================================= */
.hk-eyebrow {
  font-size: var(--font-size-xs);
  text-transform: uppercase;
  letter-spacing: 0.14em;
  color: var(--color-neutral-500);
}

.hk-heading-hero {
  font-size: var(--heading-hero-size);
  font-weight: var(--heading-hero-weight);
  line-height: var(--line-height-tight);
  letter-spacing: -0.03em;
  color: var(--color-neutral-900);
  margin-bottom: var(--space-2);
}

.hk-heading-section {
  font-size: var(--heading-section-size);
  font-weight: var(--heading-section-weight);
  line-height: var(--line-height-tight);
  letter-spacing: -0.02em;
  color: var(--color-neutral-900);
  margin-bottom: var(--space-2);
}

.hk-heading-subsection {
  font-size: var(--heading-subsection-size);
  font-weight: var(--heading-subsection-weight);
  line-height: var(--line-height-tight);
  color: var(--color-neutral-900);
  margin-bottom: var(--space-2);
}

.hk-subtitle {
  font-size: var(--font-size-md);
  line-height: var(--line-height-loose);
  color: var(--color-neutral-600);
  max-width: 42rem;
  margin: 0 0 var(--space-3);
}

.hk-subtitle-box {
  display: block;
  max-width: 44rem;
  padding: var(--space-3) var(--space-4);
  border-radius: var(--radius-sm);
  background: var(--color-surface-alt);
  border: 1px solid var(--color-border-subtle);
  font-size: var(--font-size-md);
  line-height: var(--line-height-normal);
  color: var(--color-neutral-600);
  box-shadow: var(--shadow-soft);
}

.hk-subtitle-box--accent {
  background: var(--color-primary-soft);
  border-color: var(--color-primary-100);
  color: var(--color-primary-soft-text);
}

.hk-subtitle-box-inner {
  display: flex;
  gap: var(--space-2);
  align-items: flex-start;
}

.hk-subtitle-box-icon {
  flex-shrink: 0;
  width: 28px;
  height: 28px;
  border-radius: var(--radius-sm);
  background: var(--color-primary-soft);
  display: inline-flex;
  align-items: center;
  justify-content: center;

  color: var(--color-primary-600);
  margin-top: 2px;
}

/* =========================================
   4. BUTTON SYSTEM
   ========================================= */
.btn,
.k-btn {
  border-radius: var(--btn-radius);
  padding-inline: var(--btn-padding-x);
  padding-block:  var(--btn-padding-y);
  min-height:     var(--btn-height-md);

  font-family: var(--btn-font-family);
  font-size:   var(--btn-font-size);
  font-weight: var(--btn-font-weight);
  line-height: var(--btn-line-height);

  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--btn-gap);

  border-width: 1px;
  border-style: solid;
  border-color: transparent;
  cursor: pointer;
  position: relative;
  overflow: hidden;

  background-color: transparent;
  color: var(--color-on-surface);
  box-shadow: none;

  -webkit-tap-highlight-color: transparent;
  appearance: none;
  text-decoration: none;

  transition:
    background-color var(--duration-base) var(--easing-standard),
    color            var(--duration-base) var(--easing-standard),
    border-color     var(--duration-base) var(--easing-standard),
    box-shadow       var(--duration-base) var(--easing-standard),
    transform        var(--duration-fast) var(--easing-standard);
}

.btn--sm {
  padding-inline: 1.1rem;
  padding-block:  0.4rem;
  min-height:     var(--btn-height-sm);
  font-size:      var(--font-size-sm);
}

.btn--lg {
  padding-inline: 2.1rem;
  padding-block:  0.75rem;
  min-height:     var(--btn-height-lg);
  font-size:      var(--font-size-lg);
}

.btn--full {
  width: 100%;
  justify-content: center;
}

.btn--icon {
  padding-inline: 0.6rem;
  min-width: 40px;
  justify-content: center;
}
.btn--icon i,
.btn--icon svg {
  font-size: 1.1rem;
}

.btn--pill {
  border-radius: var(--radius-pill);
}
.btn--square {
  border-radius: 4px;
}

.btn--icon-only {
  padding-inline: 0.55rem;
  min-width: 2.4rem;
  justify-content: center;
}

.btn--text {
  padding-inline: 0.2rem;
  padding-block: 0.1rem;
  min-height: auto;
  background: transparent;
  border-color: transparent;
  box-shadow: none;
  color: var(--color-link);
  font-weight: var(--font-weight-medium);
}
.btn--text:hover {
  color: var(--color-link-hover);
  text-decoration: underline;
  text-underline-offset: 2px;
  transform: none;
}

.btn:focus-visible,
.k-btn:focus-visible {
  outline: none;
  box-shadow: none;
}

.btn:disabled,
.btn[disabled],
.k-btn:disabled,
.k-btn[disabled] {
  opacity: var(--state-disabled-opacity);
  cursor: not-allowed;
  box-shadow: none;
  transform: none;
}

.btn:not(:disabled):hover,
.k-btn:not(:disabled):hover {
  transform: translateY(-1px);
}

.btn:not(:disabled):active,
.k-btn:not(:disabled):active {
  transform: translateY(0);
}

/* Varianten */

.btn--primary,
.k-btn-primary,
.btn-hk-primary,
.hk-nav-cta {
  background-color: var(--btn-primary-bg);
  border-color:     var(--btn-primary-border);
  color:            var(--btn-primary-text);
  box-shadow:       var(--btn-shadow);
}
.btn--primary:not(:disabled):hover,
.k-btn-primary:not(:disabled):hover,
.btn-hk-primary:not(:disabled):hover,
.hk-nav-cta:not(:disabled):hover {
  background-color: var(--btn-primary-bg-hover);
  border-color:     var(--btn-primary-border-hover);
  color:            var(--btn-primary-text);
  box-shadow:       var(--btn-shadow-hover);
}
.btn--primary:not(:disabled):active,
.k-btn-primary:not(:disabled):active,
.btn-hk-primary:not(:disabled):active,
.hk-nav-cta:not(:disabled):active {
  box-shadow: 0 6px 14px rgba(13,110,253,0.30);
}

/* Shine nur auf Primaries */
.btn--primary::after,
.k-btn-primary::after,
.btn-hk-primary::after,
.hk-nav-cta::after {
  content: "";
  position: absolute;
  top: -120%;
  left: -40%;
  width: 40%;
  height: 300%;
  background: linear-gradient(
    120deg,
    transparent 0%,
    rgba(255,255,255,0.75) 50%,
    transparent 100%
  );
  opacity: 0;
  transform: translateX(-120%);
  pointer-events: none;
}
.btn--primary:hover::after,
.k-btn-primary:hover::after,
.btn-hk-primary:hover::after,
.hk-nav-cta:hover::after {
  opacity: 1;
  animation: btn-shine var(--duration-slow) var(--easing-standard);
}

@keyframes btn-shine {
  0%   { transform: translateX(-140%); opacity: 0; }
  20%  { opacity: 1; }
  100% { transform: translateX(220%); opacity: 0; }
}

/* Secondary */
.btn--secondary,
.k-btn-secondary,
.btn-hk-secondary {
  background-color: var(--btn-secondary-bg);
  border-color:     var(--btn-secondary-border);
  color:            var(--btn-secondary-text);
  box-shadow:       0 6px 14px rgba(15,23,42,0.06);
}
.btn--secondary:not(:disabled):hover,
.k-btn-secondary:not(:disabled):hover,
.btn-hk-secondary:not(:disabled):hover {
  background-color: var(--btn-secondary-bg-hover);
  border-color:     var(--btn-secondary-border-hover);
  color:            var(--btn-secondary-text-hover);
}

/* Ghost */
.btn--ghost,
.k-btn-ghost,
.btn-hk-ghost {
  background-color: var(--btn-ghost-bg);
  border-color:     var(--btn-ghost-border);
  color:            var(--btn-ghost-text);
  box-shadow:       none;
}
.btn--ghost:not(:disabled):hover,
.k-btn-ghost:not(:disabled):hover,
.btn-hk-ghost:not(:disabled):hover {
  background-color: var(--btn-ghost-bg-hover);
  border-color:     var(--btn-ghost-border-hover);
  color:            var(--btn-ghost-text-hover);
}

/* Dark */
.btn--dark,
.k-btn-solid-dark {
  background-color: var(--btn-dark-bg);
  border-color:     var(--btn-dark-border);
  color:            var(--btn-dark-text);
}
.btn--dark:not(:disabled):hover,
.k-btn-solid-dark:not(:disabled):hover {
  background-color: var(--btn-dark-bg-hover);
  border-color:     var(--btn-dark-border-hover);
}

/* Danger / Notdienst */
.btn--danger,
.k-btn-danger,
.btn-hk-notdienst {
  background:   var(--btn-danger-bg);
  border-color: var(--btn-danger-border);
  color:        var(--btn-danger-text);
  box-shadow:   0 12px 26px rgba(220,38,38,0.35);
}
.btn--danger:not(:disabled):hover,
.k-btn-danger:not(:disabled):hover,
.btn-hk-notdienst:not(:disabled):hover {
  background:   var(--btn-danger-bg-hover);
  border-color: var(--btn-danger-border-hover);
  color:        var(--btn-danger-text);
}

/* Nav-CTA dichter */
.hk-nav-cta {
  font-size: .9rem;
  padding-inline: 1.5rem;
  padding-block:  .45rem;
  min-height: 40px;
}

/* Reduced Motion */
@media (prefers-reduced-motion: reduce) {
  .btn,
  .k-btn {
    transition: none !important;
    transform: none !important;
    box-shadow: none !important;
  }

  .btn::after,
  .k-btn::after,
  .hk-nav-cta::after {
    animation: none !important;
  }
}
/* ab sehr großen Bildschirmen den Bootstrap-Container etwas öffnen */
@media (min-width: 1800px) {
  .container {
    max-width: 1440px;
  }
}

@media (min-width: 2200px) {
  .container {
    max-width: 1600px;
  }
}

/* =========================================
   5. TOPBAR
   ========================================= */
.hk-topbar {
  position: relative;
  z-index: var(--z-topbar);
  background-color: var(--color-topbar-bg);
  color: var(--color-on-dark);
  font-size: var(--font-size-xs);
  border-bottom: 1px solid var(--color-border-soft);
}

.hk-topbar .container {
  max-width: 1320px;
}

.hk-topbar-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-2);
  padding-block: 0.3rem;
  min-height: 34px;
}

.hk-topbar-left,
.hk-topbar-right {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  min-width: 0;
}

.hk-topbar-action {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.35rem;
  padding-inline: 0.4rem;
  padding-block: 0.15rem;
  min-height: 30px;
  margin: 0;
  border: 0;
  background: transparent;
  color: rgba(248,250,252,0.9);
  font: inherit;
  white-space: nowrap;
  line-height: 1.1;
  opacity: 0.95;
  cursor: pointer;
  text-decoration: none;
  transition:
    color       var(--duration-base) var(--easing-standard),
    opacity     var(--duration-base) var(--easing-standard),
    text-shadow var(--duration-base) var(--easing-standard);
}

.hk-topbar-action i {
  font-size: 0.95rem;
  line-height: 1;
}

.hk-topbar-action:hover {
  color: #ffffff;
  opacity: 1;
}

.hk-topbar a:focus-visible,
.hk-topbar button:focus-visible {
  outline: none;
  box-shadow: 0 0 0 2px rgba(248,250,252,0.9);
  border-radius: 3px;
}

.hk-topbar-action--location {
  padding-right: 0.55rem;
}

.hk-topbar-action--alert {
  font-weight: var(--font-weight-semibold);
  color: var(--color-accent-200);
  text-shadow: 0 0 0 rgba(248,250,252,0);
  animation: hk-alert-pulse 2200ms ease-out 800ms 2;
}
.hk-topbar-action--alert:hover {
  color: #ffffff;
}

.hk-topbar-location {
  position: relative;
}

.hk-topbar-location-menu {
  min-width: 230px;
  font-size: var(--font-size-xs);
  border-radius: var(--radius-md);
  border: 1px solid var(--color-border-soft);
  background-color: var(--color-surface-elevated);
  box-shadow: 0 16px 32px rgba(15,23,42,0.4);
  padding: 0.25rem 0;
  margin-top: 0.25rem;
}

.hk-topbar-location-menu .dropdown-item {
  font-size: var(--font-size-xs);
  padding: 0.35rem 0.85rem;
  white-space: normal;
}
.hk-topbar-location-menu .dropdown-item:hover {
  background-color: var(--color-neutral-100);
  color: var(--color-neutral-900);
}

@keyframes hk-alert-pulse {
  0% {
    color: var(--color-accent-200);
    text-shadow: 0 0 0 rgba(248,250,252,0);
  }
  15% {
    color: #ffffff;
    text-shadow: 0 0 12px rgba(248,250,252,0.9);
  }
  40% {
    color: var(--color-accent-100);
    text-shadow: 0 0 0 rgba(248,250,252,0);
  }
  100% {
    color: var(--color-accent-200);
    text-shadow: 0 0 0 rgba(248,250,252,0);
  }
}

/* Topbar responsive */
@media (max-width: 767.98px) {
  .hk-topbar-inner {
    flex-direction: column;
    align-items: flex-start;
    gap: 0.25rem;
  }

  .hk-topbar-right {
    width: 100%;
    justify-content: space-between;
    flex-wrap: nowrap;
  }
}

@media (max-width: 575.98px) {
  .hk-topbar-inner {
    flex-direction: row;
    align-items: center;
    justify-content: space-between;
    gap: 0.4rem;
    padding-block: 0.3rem;
  }

  .hk-topbar-left,
  .hk-topbar-right {
    flex-wrap: nowrap;
    gap: 0.35rem;
  }

  .hk-topbar-label {
    display: none;
  }
  .hk-topbar-label--alert {
    display: inline;
  }

  .hk-topbar-action {
    padding-inline: 0.3rem;
    padding-block: 0.15rem;
    min-height: 32px;
  }

  .hk-topbar-action i {
    font-size: 1.05rem;
  }
}

/* =========================================
   6. NAVBAR / MEGA-MENÜ
   ========================================= */
:target {
  scroll-margin-top: 90px;
}

.hk-nav-main {
  background: transparent;
}

.hk-nav-sticky {
  position: sticky;
  top: 0;
  z-index: var(--z-navbar);
  backdrop-filter: blur(18px);
  -webkit-backdrop-filter: blur(18px);
  background:
    linear-gradient(to bottom, rgba(248,250,252,0.98), rgba(248,250,252,0.94));
  border-bottom: 1px solid var(--color-neutral-200);
  transition:
    background-color 180ms var(--easing-standard),
    box-shadow       180ms var(--easing-standard),
    transform        180ms var(--easing-standard),
    border-color     180ms var(--easing-standard);
}

.hk-nav-container {
  max-width: 1320px;
}

.hk-nav-sticky.is-scrolled {
  background:
    linear-gradient(to bottom, #ffffff, var(--color-surface));
  border-color: rgba(148,163,184,0.45);
  box-shadow: 0 18px 40px rgba(15,23,42,0.16);
  transform: translateY(-1px);
}

/* Brand */
.hk-nav-brand {
  font-family: var(--font-family-base);
  font-size: 1.7rem;
  font-weight: 800;
  letter-spacing: -0.02em;
  color: var(--color-primary-900);
  text-decoration: none;
  display: inline-flex;
  align-items: center;
  gap: .25rem;
}
.hk-nav-brand:hover {
  color: var(--color-primary-700);
}
.hk-nav-sticky.is-scrolled .hk-nav-brand {
  font-size: 1.6rem;
}

/* Toggler */
.hk-nav-toggler {
  border-radius: var(--radius-md);
  border: 1px solid var(--color-neutral-300);
  padding: .25rem .75rem;
  background: rgba(248,250,252,.98);
  box-shadow: 0 4px 14px rgba(15,23,42,.16);
  display: flex;
  align-items: center;
  justify-content: center;
}
.hk-nav-toggler[aria-expanded="true"] {
  background: var(--color-surface);
  box-shadow: 0 8px 22px rgba(15,23,42,.22);
}
.hk-nav-toggler:focus-visible {
  outline: none;
}

.navbar-toggler-icon {
  width: 1.6em;
  height: 1.6em;
  background-size: 100% 100%;
  background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 30 30'%3e%3cpath stroke='rgba(15,23,42,0.9)' stroke-linecap='round' stroke-width='2' d='M4 8h22M4 15h22M4 22h22'/%3e%3c/svg%3e");
}

/* Links */
.hk-nav-main .navbar-nav {
  align-items: center;
}

.hk-nav-link {
  font-size: .98rem;
  font-weight: 500;
  letter-spacing: .01em;
  color: var(--color-neutral-700) !important;
  position: relative;
  padding: .65rem .6rem;
  margin-inline: .15rem;
  transition:
    color   160ms var(--easing-standard),
    opacity 160ms var(--easing-standard);
}

.hk-nav-link::after {
  content: "";
  position: absolute;
  left: 50%;
  bottom: .15rem;
  width: 0;
  height: 2px;
  border-radius: 999px;
  background: linear-gradient(90deg,var(--color-primary-400),var(--color-primary-600));
  transform: translateX(-50%);
  transition: width 160ms var(--easing-standard);
}

.hk-nav-link:hover {
  color: var(--color-primary-900) !important;
}
.hk-nav-link:hover::after,
.hk-nav-link.is-active::after,
.hk-nav-link[aria-current="page"]::after {
  width: 26px;
}

.hk-nav-link:focus-visible {
  outline: none;
  color: var(--color-primary-900) !important;
}
.hk-nav-link:focus-visible::after {
  width: 26px;
}

.hk-nav-link--dropdown {
  padding-right: .9rem;
}

.hk-nav-chevron {
  display: inline-block;
  margin-left: .3rem;
  width: 9px;
  height: 9px;
  border-right: 2px solid var(--color-neutral-700);
  border-bottom: 2px solid var(--color-neutral-700);
  transform: rotate(45deg);
  transition:
    transform   180ms var(--easing-standard),
    border-color 160ms var(--easing-standard);
}
.show > .hk-nav-link--dropdown .hk-nav-chevron {
  transform: rotate(-135deg);
  border-color: var(--color-primary-700);
}

/* Icon-Bubbles */
.hk-nav-icon {
  width: 26px;
  height: 26px;
  border-radius: 10px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: 1px solid rgba(148,163,184,.45);
  background: rgba(248,250,252,.97);
  color: var(--color-primary-600);
  font-size: .9rem;
  flex-shrink: 0;
  transition:
    background-color 150ms var(--easing-standard),
    color            150ms var(--easing-standard),
    border-color     150ms var(--easing-standard),
    transform        120ms var(--easing-standard);
}

/* Dropdowns */
.hk-nav-dropdown {
  border-radius: var(--radius-md);
  border: 1px solid var(--color-border-subtle);
  background: var(--color-surface);
  padding: .4rem 0 .45rem;
  box-shadow: 0 18px 40px rgba(15,23,42,0.14);
  min-width: 240px;
  margin-top: .55rem;
}

.hk-nav-dropdown .dropdown-item {
  font-size: .95rem;
  color: var(--color-neutral-800);
  background: transparent;
  padding: .5rem 1.1rem;
  transition:
    background-color 150ms var(--easing-standard),
    color            150ms var(--easing-standard),
    padding-left     120ms ease-out;
}
.hk-nav-dropdown .dropdown-item:hover {
  background: var(--color-neutral-100);
  color: var(--color-primary-800);
  padding-left: 1.25rem;
}

.hk-nav-dd-item {
  display: flex;
  align-items: center;
  gap: .55rem;
}

/* Mega-Menü */
.dropdown-mega {
  position: static;
}

.hk-mega {
  border-radius: var(--radius-lg);
  border: 1px solid rgba(148,163,184,.25);
  background:
    radial-gradient(circle at 0 0, rgba(13,110,253,.06), transparent 55%),
    radial-gradient(circle at 100% 0, rgba(13,110,253,.04), transparent 55%),
    var(--color-surface);
  padding: 0;
  box-shadow: 0 24px 50px rgba(15,23,42,0.18);
  margin-top: .55rem;
  overflow: hidden;
}

@media (min-width: 992px) {
  .hk-nav-container {
    position: relative;
  }
  .dropdown-mega .dropdown-menu.hk-mega {
    position: absolute;
    top: 100%;
    left: 50%;
    transform: translateX(-50%);
    width: 100%;
    max-width: 1320px;
  }

  .navbar-nav .dropdown-menu.hk-nav-dropdown {
    margin-top: .5rem;
  }
}

.hk-mega .container {
  padding: 1.5rem 1.8rem 1.6rem;
}
.hk-mega .row {
  row-gap: 1.7rem;
}

.hk-mega-eyebrow {
  font-size: .78rem;
  letter-spacing: .16em;
  text-transform: uppercase;
  font-weight: 600;
  color: var(--color-primary-700);
}
.hk-mega-title {
  font-size: 1.05rem;
  font-weight: 700;
  color: var(--color-neutral-900);
}
.hk-mega-text {
  font-size: .9rem;
  color: var(--color-text-muted);
}
.hk-mega-heading {
  font-size: .86rem;
  text-transform: uppercase;
  letter-spacing: .16em;
  color: var(--color-text-muted);
  margin-bottom: .55rem;
}

.hk-mega-list {
  display: flex;
  flex-direction: column;
  gap: .5rem;
}
.hk-mega-item {
  position: relative;
  display: flex;
  align-items: flex-start;
  gap: .8rem;
  padding: .75rem .9rem;
  border-radius: var(--radius-md);
  text-decoration: none;
  color: var(--color-text);
  background: rgba(255,255,255,0.97);
  backdrop-filter: blur(6px);
  border: 1px solid rgba(148,163,184,0.18);
  box-shadow: 0 4px 10px rgba(15,23,42,0.05);
  transition:
    background   150ms var(--easing-standard),
    transform    120ms var(--easing-standard),
    box-shadow   150ms var(--easing-standard),
    border-color 150ms var(--easing-standard);
}
.hk-mega-item::after {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  border-top: 2px solid transparent;
  transition: border-color 150ms var(--easing-standard);
}
.hk-mega-item:hover {
  background: #ffffff;
  transform: translateY(-2px);
  border-color: rgba(37,99,235,0.28);
  box-shadow: 0 16px 34px rgba(15,23,42,0.18);
}
.hk-mega-item:hover::after {
  border-color: rgba(37,99,235,0.65);
}
.hk-mega-item:hover .hk-nav-icon {
  background: linear-gradient(135deg,var(--color-primary-500),var(--color-primary-400));
  color: #ffffff;
  border-color: var(--color-primary-500);
  transform: translateY(-1px);
}

.hk-mega-link-title {
  font-size: .96rem;
  font-weight: 600;
  color: var(--color-neutral-900);
}
.hk-mega-link-sub {
  font-size: .8rem;
  color: var(--color-text-muted);
}

/* Lead-Card im Mega */
.hk-mega-lead {
  border-radius: var(--radius-lg);
  padding: 1.2rem 1.3rem;
  background:
    linear-gradient(135deg, rgba(13,110,253,.12), rgba(13,110,253,.03)),
    radial-gradient(circle at 0 0, rgba(13,110,253,.12), transparent 60%),
    rgba(255,255,255,0.97);
  border: 1px solid rgba(148,163,184,.35);
  box-shadow: 0 18px 40px rgba(15,23,42,.2);
  backdrop-filter: blur(12px);
}

/* Nav rechte Seite */
.hk-nav-right {
  flex-shrink: 0;
}
.hk-nav-phone {
  font-size: .88rem;
  font-weight: 500;
  color: var(--color-text-muted);
  text-decoration: none;
}
.hk-nav-phone i {
  font-size: .95rem;
}
.hk-nav-phone:hover {
  color: var(--color-primary-700);
}

/* Navbar responsive */
@media (max-width: 991.98px) {
  .hk-nav-main .navbar-nav {
    align-items: flex-start;
  }
  .hk-nav-link {
    padding: .55rem 0;
  }

  .hk-mega {
    box-shadow: none;
    border-radius: 0;
    border-left: none;
    border-right: none;
    background: var(--color-surface);
  }

  .hk-mega-item {
    box-shadow: none;
    border-radius: 0;
    border-left: none;
    border-right: none;
  }

  .hk-nav-dropdown {
    box-shadow: none;
    border-radius: 0;
    border-left: none;
    border-right: none;
    border-bottom: 1px solid var(--color-neutral-200);
    width: 100%;
    min-width: 0;
    margin: 0;

    padding: .3rem 1rem .6rem;
  }
  .hk-nav-dd-item {
    padding: .5rem 0;
  }

  .hk-nav-cta {
    margin-top: .75rem;
    width: 100%;
    justify-content: center;
  }
}

	  /* ============================================================
     2) HEADER-FEINTUNING – KRAUSE (TOPBAR + NAV)
     ============================================================ */

  /* Topbar-Farbe: helleres Technik-Blau */
  :root {
    --color-topbar-bg: var(--color-primary-500);
  }

  /* --------------------------------------
     TOPBAR – reduziert, ohne Boxen
     -------------------------------------- */
  .hk-topbar {
    position: relative;
    z-index: var(--z-topbar);
    background: linear-gradient(
      90deg,
      var(--color-primary-500),
      var(--color-primary-400)
    );
    color: var(--color-on-dark);
    font-size: var(--font-size-xs);
    border-bottom: 1px solid rgba(15,23,42,0.25);
  }

  .hk-topbar .container {
    max-width: 1320px;
  }

  .hk-topbar-inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem;
    padding-block: 0.18rem;
    min-height: 30px;
  }

  .hk-topbar-left,
  .hk-topbar-right {
    display: flex;
    align-items: center;
    gap: 0.55rem;
    min-width: 0;
  }

  .hk-topbar-right {
    flex-shrink: 0;
  }

  /* Basis für alle Topbar-Aktionen */
  .hk-topbar-action {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.3rem;
    padding-inline: 0;
    padding-block: 0;
    margin: 0;
    border: 0;
    background: transparent;
    color: rgba(248,250,252,0.96);
    font: inherit;
    white-space: nowrap;
    line-height: 1.1;
    opacity: 0.98;
    cursor: pointer;
    text-decoration: none;
    transition:
      color       var(--duration-base) var(--easing-standard),
      opacity     var(--duration-base) var(--easing-standard),
      text-shadow var(--duration-base) var(--easing-standard);
  }

  .hk-topbar-action i {
    font-size: 0.95rem;
    line-height: 1;
  }

  .hk-topbar a:focus-visible,
  .hk-topbar button:focus-visible {
    outline: none;
    box-shadow: 0 0 0 2px rgba(248,250,252,0.9);
    border-radius: 4px;
  }

  /* Text-Links rechts */
  .hk-topbar-link {
    font-size: 0.8rem;
    font-weight: var(--font-weight-medium);
    color: rgba(248,250,252,0.96);
  }

  .hk-topbar-link i {
    font-size: 0.95rem;
  }

  .hk-topbar-link:hover {
    color: #ffffff;
    opacity: 1;
    text-decoration: underline;
    text-underline-offset: 2px;
  }

  /* SCHADEN MELDEN – keine Hover-Effekte (wie gewünscht) */
  .hk-topbar-link--primary:hover {
    color: rgba(248,250,252,0.96);
    opacity: 0.98;
    text-decoration: none;
  }

  .hk-topbar-label-text {
    display: inline;
  }

  /* Region-Dropdown – optisch aufgeräumt */
  .hk-topbar-location-menu {
    font-size: var(--font-size-xs);
    border-radius: var(--radius-md);
    border: 1px solid rgba(15,23,42,0.35);
    background-color: var(--color-surface-elevated);
    box-shadow: 0 16px 32px rgba(15,23,42,0.4);
    padding: 0.25rem 0.15rem 0.35rem;
    margin-top: 0.25rem;
  }

  .hk-topbar-location-menu .dropdown-header {
    font-size: 0.72rem;
    text-transform: uppercase;
    letter-spacing: 0.16em;
    color: var(--color-neutral-500);
    padding: 0.45rem 0.8rem 0.25rem;
  }

  .hk-topbar-location-menu .dropdown-divider {
    margin: 0.3rem 0.6rem 0.25rem;
    border-top: 1px dashed rgba(148,163,184,0.6);
  }

  .hk-topbar-location-menu .dropdown-item {
    font-size: var(--font-size-xs);
    padding: 0.35rem 0.65rem;
    margin: 0.05rem 0.25rem;
    border-radius: var(--radius-sm);
    white-space: normal;
    color: var(--color-neutral-800);
    background: transparent;
    transition:
      background-color var(--duration-base) var(--easing-standard),
      color            var(--duration-base) var(--easing-standard),
      transform        var(--duration-fast) var(--easing-standard);
  }

  .hk-topbar-location-menu .dropdown-item:hover {
    background-color: var(--color-neutral-100);
    color: var(--color-neutral-900);
    transform: translateX(1px);
  }


  /* Tablet & kleiner: Region komplett ausblenden, nur rechts lassen */
  @media (max-width: 767.98px) {
    .hk-topbar-left {
      display: none;
    }

    .hk-topbar-inner {
      justify-content: flex-end;
    }
  }

  /* Sehr kleine Geräte: enger, aber „Schaden melden“ bleibt lesbar */
  @media (max-width: 575.98px) {
    .hk-topbar-inner {
      padding-block: 0.18rem;
      gap: 0.35rem;
    }

    .hk-topbar-right {
      gap: 0.35rem;
    }

    .hk-topbar-link {
      font-size: 0.75rem;
      gap: 0.25rem;
    }

    .hk-topbar-link i {
      font-size: 0.95rem;
    }
  }

  /* --------------------------------------
     BRAND & NAV-LAYOUT / CTA-Harmonie
     -------------------------------------- */

  .hk-nav-brand {
    text-transform: uppercase;
    letter-spacing: 0.16em;
    font-weight: var(--font-weight-black);
  }

  :target {
    scroll-margin-top: 90px;
  }

  .hk-nav-main {
    background: transparent;
  }

  .hk-nav-sticky {
    position: sticky;
    top: 0;
    z-index: var(--z-navbar);
    backdrop-filter: blur(18px);
    -webkit-backdrop-filter: blur(18px);
    background:
      linear-gradient(to bottom, rgba(248,250,252,0.98), rgba(248,250,252,0.94));
    border-bottom: 1px solid var(--color-neutral-200);
    transition:
      background-color 180ms var(--easing-standard),
      box-shadow       180ms var(--easing-standard),
      transform        180ms var(--easing-standard),
      border-color     180ms var(--easing-standard);
  }

  .hk-nav-container {
    max-width: 1320px;
  }

  .hk-nav-sticky.is-scrolled {
    background:
      linear-gradient(to bottom, #ffffff, var(--color-surface));
    border-color: rgba(148,163,184,0.45);
    box-shadow: 0 18px 40px rgba(15,23,42,0.16);
    transform: translateY(-1px);
  }

  .hk-nav-main .navbar-nav {
    align-items: center;
  }

  /* Menüpunkte auf Desktop mittig ausrichten */
  @media (min-width: 992px) {
    .hk-nav-main .navbar-nav {
      flex: 1 1 auto;
      justify-content: center;
      align-items: center;
    }
  }

  /* Toggler */
  .hk-nav-toggler {
    border-radius: var(--radius-md);
    border: 1px solid var(--color-neutral-300);
    padding: .25rem .75rem;
    background: rgba(248,250,252,.98);
    box-shadow: 0 4px 14px rgba(15,23,42,.16);
    display: flex;
    align-items: center;
    justify-content: center;
  }
  .hk-nav-toggler[aria-expanded="true"] {
    background: var(--color-surface);
    box-shadow: 0 8px 22px rgba(15,23,42,.22);
  }
  .hk-nav-toggler:focus-visible {
    outline: none;
  }

  .navbar-toggler-icon {
    width: 1.6em;
    height: 1.6em;
    background-size: 100% 100%;
    background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 30 30'%3e%3cpath stroke='rgba(15,23,42,0.9)' stroke-linecap='round' stroke-width='2' d='M4 8h22M4 15h22M4 22h22'/%3e%3c/svg%3e");
  }

  /* Haupt-Navigationslinks */
  .hk-nav-link {
    font-size: .98rem;
    font-weight: 500;
    letter-spacing: .01em;
    color: var(--color-neutral-700) !important;
    position: relative;
    padding: .65rem .6rem;
    margin-inline: .15rem;
    transition:
      color   160ms var(--easing-standard),
      opacity 160ms var(--easing-standard);
  }

  .hk-nav-link::after {
    content: "";
    position: absolute;
    left: 50%;
    bottom: .15rem;
    width: 0;
    height: 2px;
    border-radius: 999px;
    background: linear-gradient(90deg,var(--color-primary-400),var(--color-primary-600));
    transform: translateX(-50%);
    transition: width 160ms var(--easing-standard);
  }

  .hk-nav-link:hover {
    color: var(--color-primary-900) !important;
  }
  .hk-nav-link:hover::after,
  .hk-nav-link.is-active::after,
  .hk-nav-link[aria-current="page"]::after {
    width: 26px;
  }

  .hk-nav-link:focus-visible {
    outline: none;
    color: var(--color-primary-900) !important;
  }
  .hk-nav-link:focus-visible::after {
    width: 26px;
  }

  .hk-nav-link--dropdown {
    padding-right: .9rem;
  }

  /* Chevron */
  .hk-nav-chevron {
    display: inline-block;
    margin-left: .3rem;
    width: 9px;
    height: 9px;
    border-right: 2px solid var(--color-neutral-700);
    border-bottom: 2px solid var(--color-neutral-700);
    transform: rotate(45deg);
    transition:
      transform   180ms var(--easing-standard),
      border-color 160ms var(--easing-standard);
  }
  .show > .hk-nav-link--dropdown .hk-nav-chevron {
    transform: rotate(-135deg);
    border-color: var(--color-primary-700);
  }

  /* Icon-Bubbles */
  .hk-nav-icon {
    width: 26px;
    height: 26px;
    border-radius: 10px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    border: 1px solid rgba(148,163,184,.45);
    background: rgba(248,250,252,.97);
    color: var(--color-primary-600);
    font-size: .9rem;
    flex-shrink: 0;
    transition:
      background-color 150ms var(--easing-standard),
      color            150ms var(--easing-standard),
      border-color     150ms var(--easing-standard),
      transform        120ms var(--easing-standard);
  }

  /* Dropdown-Basis */
  .hk-nav-dropdown {
    border-radius: var(--radius-md);
    border: 1px solid var(--color-border-subtle);
    background: var(--color-surface);
    padding: .4rem 0 .45rem;
    box-shadow: 0 18px 40px rgba(15,23,42,0.14);
    min-width: 240px;
    margin-top: .55rem;
  }

  .hk-nav-dropdown .dropdown-item {
    font-size: .95rem;
    color: var(--color-neutral-800);
    background: transparent;
    padding: .5rem 1.1rem;
    transition:
      background-color 150ms var(--easing-standard),
      color            150ms var(--easing-standard),
      padding-left     120ms ease-out;
  }
  .hk-nav-dropdown .dropdown-item:hover {
    background: var(--color-neutral-100);
    color: var(--color-primary-800);
    padding-left: 1.25rem;
  }

  /* --------------------------------------
     LEISTUNGEN – Dropdown mit 2. Ebene
     -------------------------------------- */
  .dropdown-standard {
    position: relative;
  }
  .dropdown-submenu {
    position: relative;
  }

  .hk-dropdown-toggle {
    width: 100%;
    border: 0;
    background: transparent;
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 0.45rem 1.1rem;
    cursor: pointer;
  }

  .hk-dd-text {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    text-align: left;
  }

  .hk-dd-title {
    font-weight: var(--font-weight-semibold);
    font-size: 0.92rem;
  }

  .hk-dd-sub {
    font-size: 0.78rem;
    color: var(--color-text-muted);
  }

  .hk-dd-chevron {
    width: 9px;
    height: 9px;
    border-right: 2px solid var(--color-neutral-500);
    border-bottom: 2px solid var(--color-neutral-500);
    transform: rotate(-45deg);
    flex-shrink: 0;
    margin-left: 0.75rem;
    transition:
      transform    var(--duration-base) var(--easing-standard),
      border-color var(--duration-base) var(--easing-standard);
  }

  .dropdown-submenu:hover > .hk-dropdown-toggle .hk-dd-chevron,
  .dropdown-submenu:focus-within > .hk-dropdown-toggle .hk-dd-chevron,
  .dropdown-submenu.is-open > .hk-dropdown-toggle .hk-dd-chevron {
    transform: rotate(45deg);
    border-color: var(--color-primary-600);
  }

  .hk-nav-submenu {
    min-width: 240px;
  }

  @media (min-width: 992px) {
    .hk-nav-submenu {
      position: absolute;
      top: -0.3rem;
      left: 100%;
      margin-left: 0.12rem;
      border-radius: var(--radius-md);
      box-shadow: 0 18px 40px rgba(15,23,42,0.22);
      display: none;
      z-index: var(--z-dropdown);
    }

    .dropdown-submenu:hover > .hk-nav-submenu,
    .dropdown-submenu:focus-within > .hk-nav-submenu {
      display: block;
    }

    .navbar-nav .dropdown-menu.hk-nav-dropdown {
      margin-top: 0.5rem;
    }
  }

  /* Mobile: einklappbare 2. Ebene */
  @media (max-width: 991.98px) {
    .hk-nav-main .navbar-nav {
      align-items: flex-start;
    }
    .hk-nav-link {
      padding: .55rem 0;
    }

    .hk-nav-submenu {
      position: static;
      display: none;
      border-radius: 0;
      box-shadow: none;
      margin: 0.2rem 0 0.5rem 0.4rem;
      padding: 0.1rem 0 0.4rem 0.6rem;
      border-left: 2px solid var(--color-neutral-200);
    }

    .dropdown-submenu.is-open > .hk-nav-submenu {
      display: block;
    }

    .hk-nav-dropdown {
      box-shadow: none;
      border-radius: 0;
      border-left: none;
      border-right: none;
      border-bottom: 1px solid var(--color-neutral-200);
      width: 100%;
      min-width: 0;
      margin: 0;
      padding: 0.3rem 0.75rem 0.6rem;
    }

    .hk-nav-dropdown .dropdown-item {
      padding-inline: 0.1rem;
    }

    .hk-nav-cta {
      margin-top: 0.75rem;
      width: 100%;
      justify-content: center;
    }
  }

  .hk-nav-submenu .dropdown-item i {
    font-size: 1rem;
  }

  /* --------------------------------------
     Mega-Menüs (Service & Unternehmen)
     -------------------------------------- */
  .dropdown-mega {
    position: static;
  }

  .hk-mega {
    border-radius: var(--radius-lg);
    border: 1px solid rgba(148,163,184,.25);
    background: var(--color-surface);
    padding: 0;
    box-shadow: 0 24px 50px rgba(15,23,42,0.18);
    margin-top: .55rem;
    overflow: hidden;
  }

  .hk-mega--service {
    background:
      radial-gradient(circle at 0 0, rgba(37,99,235,0.08), transparent 55%),
      radial-gradient(circle at 100% 0, rgba(37,99,235,0.04), transparent 55%),
      var(--color-surface);
  }

  .hk-mega--unternehmen {
    background:
      radial-gradient(circle at 0 0, rgba(15,23,42,0.06), transparent 55%),
      radial-gradient(circle at 100% 0, rgba(37,99,235,0.04), transparent 55%),
      var(--color-surface);
  }

  @media (min-width: 992px) {
    .hk-nav-container {
      position: relative;
    }
    .dropdown-mega .dropdown-menu.hk-mega {
      position: absolute;
      top: 100%;
      left: 50%;
      transform: translateX(-50%);
      width: 100%;
      max-width: 1320px;
    }
    .hk-mega .container {
      max-width: var(--content-max-width);
    }
  }

  .hk-mega .container {
    padding: 1.5rem 1.8rem 1.6rem;
  }
  .hk-mega .row {
    row-gap: 1.7rem;
  }

  .hk-mega-eyebrow {
    font-size: .78rem;
    letter-spacing: .16em;
    text-transform: uppercase;
    font-weight: 600;
    color: var(--color-primary-700);
  }
  .hk-mega-title {
    font-size: 1.05rem;
    font-weight: 700;
    color: var(--color-neutral-900);
  }
  .hk-mega-text {
    font-size: .9rem;
    color: var(--color-text-muted);
  }

  .hk-mega-heading {
    font-size: 0.8rem;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--color-text-muted);
    margin-bottom: 0.55rem;
  }

  .hk-mega-lead {
    border-radius: var(--radius-lg);
    padding: 1.05rem 1.1rem;
    background:
      linear-gradient(135deg, rgba(37,99,235,0.12), rgba(37,99,235,0.03)),
      rgba(255,255,255,0.97);
    border: 1px solid rgba(148,163,184,0.35);
    box-shadow: var(--shadow-strong);
    backdrop-filter: blur(12px);
  }

  .hk-mega-lead--unternehmen {
    background:
      linear-gradient(135deg, rgba(15,23,42,0.12), rgba(15,23,42,0.02)),
      rgba(255,255,255,0.98);
  }

  .hk-mega-lead--split {
    display: grid;
    grid-template-columns: minmax(0, 2.2fr) minmax(0, 1.6fr);
    gap: 1.2rem;
    align-items: center;
  }
  .hk-mega-lead-main {
    display: flex;
    flex-direction: column;
    gap: 0.4rem;
  }
  .hk-mega-lead-meta {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
  }

  .hk-mega-badge-row {
    display: flex;
    flex-wrap: wrap;
    gap: 0.35rem;
  }

  .hk-mega-badge {
    padding: 0.18rem 0.75rem;
    border-radius: var(--radius-pill);
    border: 1px solid rgba(148,163,184,0.65);
    background: rgba(15,23,42,0.06);
    font-size: var(--font-size-xs);
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--color-neutral-800);
    display: inline-flex;
    align-items: center;
    gap: 0.3rem;
  }

  .hk-mega-badge i {
    font-size: 0.9rem;
  }

  .hk-mega-stats {
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem;
  }

  .hk-mega-stat {
    min-width: 90px;
  }

  .hk-mega-stat-value {
    font-size: 1.25rem;
    font-weight: var(--font-weight-bold);
    letter-spacing: -0.02em;
    color: var(--color-neutral-900);
    line-height: 1.1;
  }

  .hk-mega-stat-label {
    font-size: 0.75rem;
    color: var(--color-text-muted);
  }

  @media (max-width: 991.98px) {
    .hk-mega-lead--split {
      grid-template-columns: minmax(0, 1fr);
    }
  }

  .hk-mega-list {
    display: flex;
    flex-direction: column;
    gap: 0.45rem;
  }

  .hk-mega-item {
    position: relative;
    display: flex;
    align-items: flex-start;
    gap: 0.7rem;
    padding: 0.7rem 0.8rem;
    border-radius: var(--radius-md);
    text-decoration: none;
    color: var(--color-text);
    background: rgba(255,255,255,0.96);
    border: 1px solid rgba(148,163,184,0.22);
    box-shadow: var(--shadow-micro);
    transition:
      background   var(--duration-base) var(--easing-standard),
      transform    var(--duration-fast) var(--easing-standard),
      box-shadow   var(--duration-base) var(--easing-standard),
      border-color var(--duration-base) var(--easing-standard);
  }

  .hk-mega-item:hover {
    background: #ffffff;
    transform: translateY(-2px);
    border-color: rgba(37,99,235,0.35);
    box-shadow: 0 16px 32px rgba(15,23,42,0.18);
  }

  .hk-mega-link-title {
    font-size: 0.95rem;
    font-weight: var(--font-weight-semibold);
    color: var(--color-neutral-900);
  }

  .hk-mega-link-sub {
    font-size: 0.8rem;
    color: var(--color-text-muted);
  }

  .hk-mega-item .hk-nav-icon {
    width: 30px;
    height: 30px;
    border-radius: 11px;
    border: 1px solid rgba(148,163,184,0.55);
    background: rgba(248,250,252,0.96);
    color: var(--color-primary-600);
    font-size: 1rem;
  }

  .hk-mega-item:hover .hk-nav-icon {
    background: linear-gradient(
      135deg,
      var(--color-primary-500),
      var(--color-primary-400)
    );
    color: #ffffff;
    border-color: var(--color-primary-500);
  }

  /* Service-Mega – Schnellzugriff-Band */
  .hk-mega-footer-actions {
    margin-top: 0.9rem;
    padding-top: 0.6rem;
    border-top: 1px dashed rgba(148,163,184,0.55);
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.45rem;
  }

  .hk-mega-footer-label {
    font-size: 0.78rem;
    color: var(--color-text-muted);
    display: inline-flex;
    align-items: center;
    gap: 0.25rem;
    margin-right: 0.25rem;
  }

  .hk-mega-footer-label i {
    font-size: 0.9rem;
  }

  .hk-mega-qa {
    font-size: 0.8rem;
  }

  @media (max-width: 575.98px) {
    .hk-mega-footer-actions {
      flex-direction: column;
      align-items: flex-start;
    }

    .hk-mega-footer-label {
      margin-bottom: 0.2rem;
    }

    .hk-mega-qa {
      width: 100%;
      justify-content: flex-start;
    }
  }

  /* --------------------------------------
     Rechte Seite der Navbar – CTAs
     -------------------------------------- */
  .hk-nav-right {
    flex-shrink: 0;
    display: flex;
    align-items: center;
    gap: 0.55rem;
  }

  .hk-nav-action {
    font-size: 0.9rem;
    padding-inline: 1.5rem;
    padding-block: 0.45rem;
    min-height: 40px;
    border-radius: var(--btn-radius);
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: var(--btn-gap);
  }
/* =========================================
   7. FOOTER

   ========================================= */

.hk-footer {
  padding-block: var(--space-6);
  background:
    radial-gradient(circle at top left, rgba(13,110,253,0.22), transparent 55%),
    radial-gradient(circle at bottom right, rgba(15,23,42,0.85), transparent 55%),
    var(--color-neutral-900);
  color: var(--color-on-dark);
}

.hk-footer .container {
  max-width: 1320px;
}

.hk-footer-inner {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}

.hk-footer-brand {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}

.hk-footer-logo-text {
  display: flex;
  flex-direction: column;
  gap: 0.15rem;
}

.hk-footer-logo-name {
  font-size: 1.4rem;
  font-weight: var(--font-weight-bold);
  letter-spacing: -0.03em;
  color: #ffffff;
}

.hk-footer-logo-sub {
  font-size: var(--font-size-xs);
  text-transform: uppercase;
  letter-spacing: 0.16em;
  color: var(--color-neutral-400);
}

.hk-footer-claim {
  margin: 0;
  font-size: var(--font-size-sm);
  line-height: var(--line-height-loose);
  color: var(--color-neutral-200);
}

.hk-footer-badges {
  display: flex;
  flex-wrap: wrap;
  gap: 0.4rem;
}

.hk-footer-badge {
  padding: 0.18rem 0.7rem;
  border-radius: var(--radius-pill);
  border: 1px solid rgba(148,163,184,0.6);
  background: rgba(15,23,42,0.7);
  font-size: var(--font-size-xs);
  color: var(--color-neutral-100);
}

.hk-footer-heading {
  font-size: var(--font-size-xs);
  text-transform: uppercase;
  letter-spacing: 0.16em;
  color: var(--color-neutral-300);
  margin-bottom: 0.7rem;
}

.hk-footer-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 0.35rem;
  font-size: var(--font-size-sm);
}

.hk-footer-list a {
  color: var(--color-neutral-100);
  text-decoration: none;
}
.hk-footer-list a:hover {
  color: #ffffff;
  text-decoration: underline;
  text-underline-offset: 3px;
}

.hk-footer-list--contact li {
  display: flex;
  flex-direction: column;
  gap: 0.05rem;
}

.hk-footer-list-label {
  font-size: var(--font-size-xs);
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--color-neutral-400);
}

.hk-footer-social {
  margin-top: var(--space-3);
  display: flex;
  flex-direction: column;
  gap: 0.45rem;
}

.hk-footer-social-label {
  font-size: var(--font-size-xs);
  color: var(--color-neutral-300);
}

.hk-footer-social-icons {
  display: flex;
  gap: 0.4rem;
}

.hk-footer-social-icons a {
  width: 30px;
  height: 30px;
  border-radius: var(--radius-pill);
  border: 1px solid rgba(148,163,184,0.65);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--color-neutral-50);
  font-size: 1.05rem;
  background: rgba(15,23,42,0.6);
  transition:
    background-color var(--duration-base) var(--easing-standard),
    border-color var(--duration-base) var(--easing-standard),
    color var(--duration-base) var(--easing-standard),
    transform var(--duration-fast) var(--easing-standard),
    box-shadow var(--duration-base) var(--easing-standard);
}
.hk-footer-social-icons a:hover {
  background: var(--color-primary-500);
  border-color: var(--color-primary-300);
  color: var(--color-on-primary);
  box-shadow: 0 12px 30px rgba(37,99,235,0.55);
  transform: translateY(-2px);
}

.hk-footer-cta {
  display: flex;
  flex-wrap: wrap;
  gap: 0.6rem;
  align-items: center;
  margin-top: var(--space-3);
}

.hk-footer-cta-main i,
.hk-footer-cta-notdienst i {
  font-size: 1rem;
}

.hk-footer-cta-notdienst {
  border-radius: var(--btn-radius);
  border: 1px solid var(--color-neutral-100);
  background: transparent;
  color: var(--color-neutral-50);
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  padding-inline: 1.2rem;
  padding-block: 0.45rem;
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-medium);
}
.hk-footer-cta-notdienst:hover {
  background: var(--color-danger-soft);
  color: var(--color-danger);
  border-color: var(--color-danger);
}

.hk-footer-divider {
  border-color: rgba(148,163,184,0.45);
  margin: var(--space-4) 0 var(--space-2);
}

.hk-footer-bottom {
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-size: var(--font-size-sm);
  color: var(--color-neutral-300);
  gap: 0.75rem;
}

.hk-footer-bottom-right {
  display: flex;
  gap: 1rem;
  flex-wrap: wrap;
}

.hk-footer-bottom-right a {
  color: var(--color-neutral-300);
  text-decoration: none;
}
.hk-footer-bottom-right a:hover {
  color: #ffffff;
  text-decoration: underline;
  text-underline-offset: 3px;
}

/* Footer responsive */
@media (max-width: 991.98px) {
  .hk-footer {
    padding-block: var(--space-5);
  }
}
@media (max-width: 767.98px) {
  .hk-footer {
    padding-block: var(--space-4);
  }
  .hk-footer-bottom {
    flex-direction: column;
    align-items: flex-start;
  }
}
	  /* =========================================
   Content-Breite auf sehr großen Screens
   ========================================= */

/* ab 1440px – etwas breiter */
@media (min-width: 1440px) {
  :root {
    --content-max-width: 78rem;
  }
}

/* ab 1680px – große Monitore */
@media (min-width: 1680px) {
  :root {
    --content-max-width: 82rem;
  }
}

/* ab 2000px – sehr große / 4K-Setups */
@media (min-width: 2000px) {
  :root {
    --content-max-width: 86rem;
  }
}

/* =========================================================
   COOKIE / CONSENT UI – KRAUSE
   Erwartet:
   - deine :root Tokens
   - dein Button-System (.btn, .btn--primary, .btn--secondary, .btn--ghost, .btn--sm, .btn--full)
   ========================================================= */

/* BANNER BASIS */
.hk-consent-banner {
  position: fixed;
  inset-inline: 0;
  bottom: 0.75rem;
  z-index: var(--z-overlay, 1060);
  display: none; /* per JS auf .is-visible setzen */
  pointer-events: none; /* wir erlauben Klick nur auf inneres Panel */
}

.hk-consent-banner.is-visible {
  display: block;
}

.hk-consent-banner-inner {
  pointer-events: auto;
  max-width: 960px;
  margin-inline: auto;
  padding-inline: 0.75rem;
}

.hk-consent-panel {
  border-radius: var(--radius-lg, 14px);
  padding: 0.9rem 1.1rem;
  background:
    radial-gradient(circle at 0 0, rgba(37,99,235,0.08), transparent 60%),
    radial-gradient(circle at 100% 0, rgba(37,99,235,0.04), transparent 60%),
    var(--color-surface, #ffffff);
  border: 1px solid rgba(148,163,184,0.55);
  box-shadow: 0 22px 45px rgba(15,23,42,0.32);
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 1.1rem;
  font-size: var(--font-size-sm, 0.875rem);
}

/* Banner Inhalt */
.hk-consent-copy {
  flex: 1 1 auto;
  min-width: 0;
}

.hk-consent-eyebrow {
  font-size: 0.75rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  font-weight: var(--font-weight-semibold, 600);
  color: var(--color-primary-700, #1e40af);
  margin-bottom: 0.1rem;
}

.hk-consent-title {
  font-size: 0.98rem;
  font-weight: var(--font-weight-semibold, 600);
  color: var(--color-neutral-900, #0f172a);
}

.hk-consent-text {
  margin: 0.25rem 0 0.35rem;
  color: var(--color-text-muted, #6c757d);
  font-size: 0.85rem;
  line-height: 1.6;
}

.hk-consent-links {
  display: flex;
  flex-wrap: wrap;
  gap: 0.3rem;
  align-items: center;
  font-size: 0.8rem;
  color: var(--color-neutral-500);
}

.hk-consent-links span {
  opacity: 0.75;
}

.hk-consent-links a {
  color: var(--color-link, var(--color-primary-600));
  text-decoration: none;
}
.hk-consent-links a:hover {
  color: var(--color-link-hover, var(--color-primary-700));
  text-decoration: underline;
  text-underline-offset: 2px;
}

/* Banner Buttons */
.hk-consent-actions {
  flex: 0 0 auto;
  display: flex;
  flex-direction: column;
  gap: 0.35rem;
  align-items: flex-end;
}

.hk-consent-actions .btn {
  font-size: 0.8rem;
  padding-inline: 1.1rem;
  padding-block: 0.4rem;
  min-height: 34px;
}

.hk-consent-actions .btn--ghost {
  border-radius: var(--radius-pill, 999px);
}

/* kleine Info unter Buttons */
.hk-consent-note {
  font-size: 0.7rem;
  color: var(--color-text-soft, #9ca3af);
  margin-top: 0.15rem;
}

/* RESPONSIVE – Banner */
@media (max-width: 767.98px) {
  .hk-consent-panel {
    flex-direction: column;
    align-items: stretch;
    padding: 0.85rem 0.85rem 0.9rem;
  }

  .hk-consent-actions {
    align-items: stretch;
  }

  .hk-consent-actions .btn {
    width: 100%;
  }

  .hk-consent-banner-inner {
    padding-inline: 0.5rem;
  }
}

/* =========================================================
   MODAL OVERLAY + DIALOG
   ========================================================= */

.hk-consent-backdrop {
  position: fixed;
  inset: 0;
  background: var(--color-overlay-soft, rgba(15,23,42,0.45));
  z-index: calc(var(--z-overlay, 1060) + 1);
  opacity: 0;
  pointer-events: none;
  transition:
    opacity var(--duration-base, 180ms) var(--easing-standard, ease-out);
}

.hk-consent-backdrop.is-visible {
  opacity: 1;
  pointer-events: auto;
}

.hk-consent-modal {
  position: fixed;
  inset-inline: 0;
  top: 8vh;
  z-index: calc(var(--z-overlay, 1060) + 2);
  display: flex;
  justify-content: center;
  padding-inline: 0.75rem;
  opacity: 0;
  pointer-events: none;
  transform: translateY(10px);
  transition:
    opacity var(--duration-base, 180ms) var(--easing-standard, ease-out),
    transform var(--duration-base, 180ms) var(--easing-standard, ease-out);
}

.hk-consent-modal.is-visible {
  opacity: 1;
  pointer-events: auto;
  transform: translateY(0);
}

.hk-consent-modal-inner {
  max-width: 640px;
  width: 100%;
  max-height: 84vh;
  background: var(--color-surface-elevated, #ffffff);
  border-radius: 18px;
  border: 1px solid rgba(148,163,184,0.55);
  box-shadow: 0 30px 60px rgba(15,23,42,0.35);
  display: flex;
  flex-direction: column;
  overflow: hidden;
}

/* Modal Header */
.hk-consent-modal-header {
  padding: 1rem 1.2rem 0.8rem;
  border-bottom: 1px solid var(--color-border-subtle, #e2e8f0);
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 0.75rem;
}

.hk-consent-modal-title {
  font-size: 1.02rem;
  font-weight: var(--font-weight-semibold, 600);
  color: var(--color-neutral-900, #0f172a);
  margin-bottom: 0.2rem;
}

.hk-consent-modal-subtitle {
  margin: 0;
  font-size: 0.83rem;
  color: var(--color-text-muted, #6b7280);
  line-height: 1.6;
}

.hk-consent-modal-badges {
  margin-top: 0.3rem;
  display: flex;
  flex-wrap: wrap;
  gap: 0.3rem;
}

.hk-consent-modal-badge {
  font-size: 0.7rem;
  border-radius: var(--radius-pill, 999px);
  padding: 0.14rem 0.65rem;
  border: 1px solid rgba(148,163,184,0.75);
  background: rgba(248,250,252,0.85);
  display: inline-flex;
  align-items: center;
  gap: 0.25rem;
  color: var(--color-neutral-700, #334155);
}

.hk-consent-modal-badge i {
  font-size: 0.9rem;
}

.hk-consent-modal-close {
  border: 0;
  background: transparent;
  border-radius: 999px;
  width: 32px;
  height: 32px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  color: var(--color-neutral-500);
  transition:
    background-color var(--duration-base, 180ms) var(--easing-standard, ease-out),
    color            var(--duration-base, 180ms) var(--easing-standard, ease-out),
    transform        var(--duration-fast, 120ms) var(--easing-standard, ease-out);
}
.hk-consent-modal-close:hover {
  background: var(--color-neutral-100, #f1f5f9);
  color: var(--color-neutral-800, #1e293b);
  transform: translateY(-1px);
}

/* Modal Body */
.hk-consent-modal-body {
  padding: 0.8rem 1.2rem;
  overflow: auto;
}

/* Kategorie-Boxen */
.hk-consent-category {
  border-radius: var(--radius-md, 10px);
  border: 1px solid var(--color-border-subtle, #e2e8f0);
  padding: 0.65rem 0.7rem;
  margin-bottom: 0.55rem;
  display: flex;
  align-items: flex-start;
  gap: 0.6rem;
  background: var(--color-surface-subtle, #f8fafc);
}

.hk-consent-category-icon {
  flex-shrink: 0;
  width: 32px;
  height: 32px;
  border-radius: 12px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: rgba(248,250,252,0.9);
  border: 1px solid rgba(148,163,184,0.5);
  color: var(--color-primary-600, #1d4ed8);
  font-size: 1.1rem;
}

.hk-consent-category-main {
  flex: 1 1 auto;
  min-width: 0;
}

.hk-consent-category-title-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.5rem;
}

.hk-consent-category-title {
  font-size: 0.9rem;
  font-weight: var(--font-weight-semibold, 600);
  color: var(--color-neutral-900, #0f172a);
}

.hk-consent-category-tag {
  font-size: 0.7rem;
  text-transform: uppercase;
  letter-spacing: 0.14em;
  color: var(--color-text-soft, #9ca3af);
}

.hk-consent-category-text {
  margin-top: 0.25rem;
  font-size: 0.8rem;
  color: var(--color-text-muted, #6b7280);
  line-height: 1.55;
}

.hk-consent-category-meta {
  margin-top: 0.26rem;
  font-size: 0.75rem;
  color: var(--color-text-soft, #9ca3af);
}

/* Notwendige Cookies – gesperrt */
.hk-consent-category--locked {
  background: linear-gradient(
    135deg,
    rgba(15,23,42,0.04),
    rgba(148,163,184,0.06)
  );
  border-style: dashed;
  border-color: rgba(148,163,184,0.85);
}

.hk-consent-category--locked .hk-consent-category-icon {
  background: rgba(15,23,42,0.85);
  border-color: rgba(15,23,42,0.9);
  color: #e5e7eb;
}

/* Switch-Komponente */
.hk-switch {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;
  cursor: pointer;
  user-select: none;
  font-size: 0.8rem;
  color: var(--color-neutral-700, #334155);
}

.hk-switch input {
  position: absolute;
  opacity: 0;
  pointer-events: none;
}

.hk-switch-track {
  position: relative;
  width: 40px;
  height: 22px;
  border-radius: 999px;
  background: var(--color-neutral-200, #e2e8f0);
  border: 1px solid var(--color-neutral-300, #cbd5e1);
  box-shadow: inset 0 0 0 1px rgba(148,163,184,0.35);
  transition:
    background-color var(--duration-base, 180ms) var(--easing-standard, ease-out),
    border-color     var(--duration-base, 180ms) var(--easing-standard, ease-out);
}

.hk-switch-thumb {
  position: absolute;
  top: 2px;
  left: 3px;
  width: 16px;
  height: 16px;
  border-radius: 50%;
  background: #ffffff;
  box-shadow: 0 2px 4px rgba(15,23,42,0.28);
  transition:
    transform var(--duration-base, 180ms) var(--easing-standard, ease-out);
}

.hk-switch-label {
  font-size: 0.78rem;
  color: var(--color-text-soft, #9ca3af);
}

.hk-switch input:checked + .hk-switch-track {
  background: var(--color-primary-500, #2563eb);
  border-color: var(--color-primary-500, #2563eb);
}

.hk-switch input:checked + .hk-switch-track .hk-switch-thumb {
  transform: translateX(16px);
}

.hk-switch input:checked ~ .hk-switch-label {
  color: var(--color-primary-700, #1e40af);
}

/* deaktivierter Switch (notwendig) */
.hk-consent-category--locked .hk-switch {
  cursor: default;
}
.hk-consent-category--locked .hk-switch-track {
  background: var(--color-neutral-200, #e2e8f0);
  border-color: var(--color-neutral-300, #cbd5e1);
}
.hk-consent-category--locked .hk-switch-thumb {
  box-shadow: none;
}
.hk-consent-category--locked .hk-switch-label {
  color: var(--color-text-soft, #9ca3af);
}

/* Modal Footer */
.hk-consent-modal-footer {
  padding: 0.75rem 1.2rem 0.9rem;
  border-top: 1px solid var(--color-border-subtle, #e2e8f0);
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}

.hk-consent-modal-buttons {
  display: flex;
  flex-wrap: wrap;
  gap: 0.45rem;
}

.hk-consent-modal-buttons .btn {
  font-size: 0.85rem;
  padding-inline: 1.2rem;
  padding-block: 0.45rem;
  min-height: 36px;
}

@media (min-width: 576px) {
  .hk-consent-modal-buttons {
    justify-content: flex-end;
  }
}

@media (max-width: 575.98px) {
  .hk-consent-modal {
    top: 4vh;
  }
  .hk-consent-modal-inner {
    max-height: 92vh;
    border-radius: 16px;
  }
  .hk-consent-modal-buttons {
    flex-direction: column-reverse;
  }
  .hk-consent-modal-buttons .btn {
    width: 100%;
    justify-content: center;
  }
}

.hk-consent-modal-hint {
  font-size: 0.75rem;
  color: var(--color-text-soft, #9ca3af);
}

.hk-consent-modal-hint a {
  color: var(--color-link, var(--color-primary-600));
  text-decoration: none;
}
.hk-consent-modal-hint a:hover {
  text-decoration: underline;
  text-underline-offset: 2px;
}

/* Reduced Motion */
@media (prefers-reduced-motion: reduce) {
  .hk-consent-backdrop,
  .hk-consent-modal,
  .hk-consent-panel,
  .hk-switch-track,
  .hk-switch-thumb {
    transition: none !important;
  }
}

/* =========================================
   FOOTER – BACKGROUND
   ========================================= */

.hk-footer {
  padding-block: var(--space-6);
  background:
    radial-gradient(circle at top left, rgba(13,110,253,0.22), transparent 55%),
    radial-gradient(circle at bottom right, rgba(15,23,42,0.85), transparent 55%),
    var(--color-neutral-900);
  color: var(--color-on-dark);
}

.hk-footer .container {
  max-width: 1320px;
}

.hk-footer-inner {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}

/* =========================================
   BRAND-BLOCK
   ========================================= */

.hk-footer-brand {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}

.hk-footer-logo-text {
  display: flex;
  flex-direction: column;
  gap: 0.15rem;
}

.hk-footer-logo-name {
  font-size: 1.4rem;
  font-weight: var(--font-weight-bold);
  letter-spacing: -0.03em;
  color: #ffffff;
}

.hk-footer-logo-sub {
  font-size: var(--font-size-xs);
  text-transform: uppercase;
  letter-spacing: 0.16em;
  color: var(--color-neutral-400);
}

.hk-footer-claim {
  margin: 0;
  font-size: var(--font-size-sm);
  line-height: var(--line-height-loose);
  color: var(--color-neutral-200);
}

/* BADGES */

.hk-footer-badges {
  display: flex;
  flex-wrap: wrap;
  gap: 0.4rem;
}

.hk-footer-badge {
  padding: 0.18rem 0.7rem;
  border-radius: var(--radius-pill);
  border: 1px solid rgba(148,163,184,0.6);
  background: rgba(15,23,42,0.7);
  font-size: var(--font-size-xs);
  color: var(--color-neutral-100);
}

/* =========================================
   SPALTEN / LISTEN
   ========================================= */

.hk-footer-heading {
  font-size: var(--font-size-xs);
  text-transform: uppercase;
  letter-spacing: 0.16em;
  color: var(--color-neutral-300);
  margin-bottom: 0.7rem;
}

.hk-footer-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 0.35rem;
  font-size: var(--font-size-sm);
}

.hk-footer-list a {
  color: var(--color-neutral-100);
  text-decoration: none;
}

.hk-footer-list a:hover {
  color: #ffffff;
  text-decoration: underline;
  text-underline-offset: 3px;
}

/* Kontakt-Variante mit Label */

.hk-footer-list--contact li {
  display: flex;
  flex-direction: column;
  gap: 0.05rem;
}

.hk-footer-list-label {
  font-size: var(--font-size-xs);
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--color-neutral-400);
}

/* =========================================
   SOCIAL
   ========================================= */

.hk-footer-social {
  margin-top: var(--space-3);
  display: flex;
  flex-direction: column;
  gap: 0.45rem;
}

.hk-footer-social-label {
  font-size: var(--font-size-xs);
  color: var(--color-neutral-300);
}

.hk-footer-social-icons {
  display: flex;
  gap: 0.4rem;
}

.hk-footer-social-icons a {
  width: 30px;
  height: 30px;
  border-radius: var(--radius-pill);
  border: 1px solid rgba(148,163,184,0.65);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  color: var(--color-neutral-50);
  font-size: 1.05rem;
  background: rgba(15,23,42,0.6);
  transition:
    background-color var(--duration-base) var(--easing-standard),
    border-color var(--duration-base) var(--easing-standard),
    color var(--duration-base) var(--easing-standard),
    transform var(--duration-fast) var(--easing-standard),
    box-shadow var(--duration-base) var(--easing-standard);
}

.hk-footer-social-icons a:hover {
  background: var(--color-primary-500);
  border-color: var(--color-primary-300);
  color: var(--color-on-primary);
  box-shadow: 0 12px 30px rgba(37,99,235,0.55);
  transform: translateY(-2px);
}

/* =========================================
   CTA-BUTTONS RECHTS
   ========================================= */

.hk-footer-cta {
  display: flex;
  flex-wrap: wrap;
  gap: 0.6rem;
  align-items: center;
  margin-top: var(--space-3);
}

.hk-footer-cta-main i,
.hk-footer-cta-notdienst i {
  font-size: 1rem;
}

/* Notdienst – hell, klar lesbar auf dunkel */

.hk-footer-cta-notdienst {
  border-radius: var(--btn-radius);
  border: 1px solid var(--color-neutral-100);
  background: transparent;
  color: var(--color-neutral-50);
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  padding-inline: 1.2rem;
  padding-block: 0.45rem;
  font-size: var(--font-size-sm);
  font-weight: var(--font-weight-medium);
}

.hk-footer-cta-notdienst:hover {
  background: var(--color-danger-soft);
  color: var(--color-danger);
  border-color: var(--color-danger);
}

/* =========================================
   BOTTOM BAR
   ========================================= */

.hk-footer-divider {
  border-color: rgba(148,163,184,0.45);
  margin: var(--space-4) 0 var(--space-2);
}

.hk-footer-bottom {
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-size: var(--font-size-sm);
  color: var(--color-neutral-300);
  gap: 0.75rem;
}

.hk-footer-bottom-right {
  display: flex;
  gap: 1rem;
  flex-wrap: wrap;
}

.hk-footer-bottom-right a {
  color: var(--color-neutral-300);
  text-decoration: none;
}

.hk-footer-bottom-right a:hover {
  color: #ffffff;
  text-decoration: underline;
  text-underline-offset: 3px;
}

/* =========================================
   RESPONSIVE
   ========================================= */

@media (max-width: 991.98px) {
  .hk-footer {
    padding-block: var(--space-5);
  }
}

@media (max-width: 767.98px) {
  .hk-footer {
    padding-block: var(--space-4);
  }

  .hk-footer-bottom {
    flex-direction: column;
    align-items: flex-start;
  }
}
