/* Variablen in CSS umgewandelt */
:root {
    --color: #000000; /* Icon-Farbe */
    --animation: 0.6s; /* Animationsdauer */
    --scale: 0.5; /* Skalierung */
  }
  
  .hamburger {
    position: absolute;
    right: 10px;
    top: 10px;
 
    transform: scale(var(--scale));
    
    display: block;
    width: 68px;
    height: 68px;
    -webkit-touch-callout: none;
    user-select: none;

    visibility: hidden;
  }
  
  /* Transition Mask */
  .path-burger {
    position: absolute;
    top: 0;
    left: 0;
    height: 68px;
    width: 68px;
    mask: url(#mask);
    
  }
  
  .animate-path {
    position: absolute;
    top: 0;
    left: 0;
    width: 68px;
    height: 68px;
  }
  
  .path-rotation {
    height: 34px;
    width: 34px;
    margin: 34px 34px 0 0;
    transform: rotate(0deg);
    transform-origin: 100% 0;
  }
  
  .path-rotation::before {
    content: '';
    display: block;
    width: 30px;
    height: 34px;
    margin: 0 4px 0 0;
    background: var(--color);
  }
  
  /* Keyframe-Animationen */
  @keyframes rotate-out {
    0% {
      transform: rotate(0deg);
    }
    40% {
      transform: rotate(180deg);
    }
    100% {
      transform: rotate(360deg);
    }
  }
  
  @keyframes rotate-in {
    0% {
      transform: rotate(360deg);
    }
    40% {
      transform: rotate(180deg);
    }
    100% {
      transform: rotate(0deg);
    }
  }
  
  .hamburger.is-open .path {
    animation: dash-in var(--animation) linear normal;
    animation-fill-mode: forwards;
  }
  
  .hamburger.is-open .animate-path {
    animation: rotate-in var(--animation) linear normal;
    animation-fill-mode: forwards;
  }
  
  .hamburger.is-closed .path {
    animation: dash-out var(--animation) linear normal;
    animation-fill-mode: forwards;
  }
  
  .hamburger.is-closed .animate-path {
    animation: rotate-out var(--animation) linear normal;
    animation-fill-mode: forwards;
  }
  
  .path {
    stroke-dasharray: 240;
    stroke-dashoffset: 240;
    stroke-linejoin: round;
  }
  
  @keyframes dash-in {
    0% {
      stroke-dashoffset: 240;
    }
    40% {
      stroke-dashoffset: 240;
    }
    100% {
      stroke-dashoffset: 0;
    }
  }
  
  @keyframes dash-out {
    0% {
      stroke-dashoffset: 0;
    }
    40% {
      stroke-dashoffset: 240;
    }
    100% {
      stroke-dashoffset: 240;
    }
  }

  .burger-icon {
    position: absolute;
    padding: 20px 16px;
    height: 68px;
    width: 68px;
  }
  
  .burger-container {
    position: relative;
    height: 28px;
    width: 36px;
  }
  
  .burger-bun-top,
  .burger-bun-bot,
  .burger-filling {
    position: absolute;
    display: block;
    height: 4px;
    width: 36px;
    border-radius: 2px;
    background: var(--color);
  }
  
  .burger-bun-top {
    top: 0;
    transform-origin: 34px 2px;
  }
  
  .burger-bun-bot {
    bottom: 0;
    transform-origin: 34px 2px;
  }
  
  .burger-filling {
    top: 12px;
  }

  .burger-ring {
    position: absolute;
    top: 0;
    left: 0;
    width: 68px;
    height: 68px;
  }
  
  .svg-ring {
    width: 68px;
    height: 68px;
  }

  .svg-ring path {
    stroke: white;
  }

  .hamburger.is-open .burger-bun-top {
    animation: bun-top-out var(--animation) linear normal;
    animation-fill-mode: forwards;
  }
  
  .hamburger.is-open .burger-bun-bot {
    animation: bun-bot-out var(--animation) linear normal;
    animation-fill-mode: forwards;
  }
  
  .hamburger.is-closed .burger-bun-top {
    animation: bun-top-in var(--animation) linear normal;
    animation-fill-mode: forwards;
  }
  
  .hamburger.is-closed .burger-bun-bot {
    animation: bun-bot-in var(--animation) linear normal;
    animation-fill-mode: forwards;
  }
  
  @keyframes bun-top-out {
    0% {
      left: 0;
      top: 0;
      transform: rotate(0deg);
    }
    20% {
      left: 0;
      top: 0;
      transform: rotate(15deg);
    }
    80% {
      left: -5px;
      top: 0;
      transform: rotate(-60deg);
    }
    100% {
      left: -5px;
      top: 1px;
      transform: rotate(-45deg);
    }
  }
  
  @keyframes bun-bot-out {
    0% {
      left: 0;
      transform: rotate(0deg);
    }
    20% {
      left: 0;
      transform: rotate(-15deg);
    }
    80% {
      left: -5px;
      transform: rotate(60deg);
    }
    100% {
      left: -5px;
      transform: rotate(45deg);
    }
  }
  
  @keyframes bun-top-in {
    0% {
      left: -5px;
      bot: 0;
      transform: rotate(-45deg);
    }
    20% {
      left: -5px;
      bot: 0;
      transform: rotate(-60deg);
    }
    80% {
      left: 0;
      bot: 0;
      transform: rotate(15deg);
    }
    100% {
      left: 0;
      bot: 1px;
      transform: rotate(0deg);
    }
  }
  
  @keyframes bun-bot-in {
    0% {
      left: -5px;
      transform: rotate(45deg);
    }
    20% {
      left: -5px;
      bot: 0;
      transform: rotate(60deg);
    }
    80% {
      left: 0;
      bot: 0;
      transform: rotate(-15deg);
    }
    100% {
      left: 0;
      transform: rotate(0deg);
    }
  }
  
  /* Burger-Füllung */
  .hamburger.is-open .burger-filling {
    animation: burger-fill-out var(--animation) linear normal;
    animation-fill-mode: forwards;
  }
  
  .hamburger.is-closed .burger-filling {
    animation: burger-fill-in var(--animation) linear normal;
    animation-fill-mode: forwards;
  }
  
  @keyframes burger-fill-in {
    0% {
      width: 0;
      left: 36px;
    }
    40% {
      width: 0;
      left: 40px;
    }
    80% {
      width: 36px;
      left: -6px;
    }
    100% {
      width: 36px;
      left: 0px;
    }
  }
  
  @keyframes burger-fill-out {
    0% {
      width: 36px;
      left: 0px;
    }
    20% {
      width: 42px;
      left: -6px;
    }
    40% {
      width: 0;
      left: 40px;
    }
    100% {
      width: 0;
      left: 36px;
    }
  }
  