.pullout {
  position: absolute;
  margin: 0;
  top: 0;
  right: 0;
}

:root {
  --bar-width: 60px;
  --bar-height: 8px;
  --hamburger-gap: 6px;
  --foreground: #333;
  --background: white;
  --hamburger-margin: 5px;
  --timing: 200ms ease-in-out;
  --hamburger-height: calc((var(--bar-height) * 3) + (var(--hamburger-gap) * 2));
  --overflow-x:hidden;
}

.hamburger-menu {
  --x-width: calc(var(--hamburger-height) * 1.41421356237);

  display: flex;
  flex-direction: column;
  gap: var(--hamburger-gap);
  width: max-content;
  position: absolute;
  top: var(--hamburger-margin);
  right: var(--hamburger-margin);
  z-index: 2;
  cursor: pointer;
}

.hamburger-menu:has(input:checked) {
  --background: #333;
}

.hamburger-menu:has(input:focus-visible)::before,
.hamburger-menu:has(input:focus-visible)::after,
.hamburger-menu input:focus-visible) {
  border: 1px solid var(--background);
  box-shadow: 0 0 0 1px var(--foreground);
}

.hamburger-menu::before,
.hamburger-menu::after,
.hamburger-menu input {
  content: "";
  width: var(--bar-width);
  height: var(--bar-height);
  background-color: var(--foreground);
  border-radius: 9999px;
  transform-origin: left center;
  transition: opacity var(--timing), width var(--timing),
    rotate var(--timing), translate var(--timing), background-color var(--timing),
    font-size var(--timing);
}

.hamburger-menu:has(input:checked)::before {
  rotate: 45deg;
  width: var(--x-width);
  translate: 0 calc(var(--bar-height) / -2);
}

.hamburger-menu:has(input:checked)::after {
  rotate: -45deg;
  width: var(--x-width);
  translate: 0 calc(var(--bar-height) / 2);
}

.hamburger-menu input {
  appearance: none;
  padding: 0;
  margin: 0;
  outline: none;
  pointer-events: none;
}

.hamburger-menu input:checked {
  opacity: 0;
  width: 0;
}

.sidebar {
  transition: translate var(--timing);
  translate: 30dvw;
  padding: 0.5rem 1rem;
  padding-top: calc(var(--hamburger-height) + var(--hamburger-margin) + 1rem);
  color: var(--foreground);
  max-width: 15dvw;
  height: 100dvh;
  min-height: 100dvh;
  font-size: max(2dvh, 12px);
  text-align: right;
  direction:ltr;
  overflow-x: hidden;
}

.hamburger-menu:has(input:checked) + .sidebar {
  translate: 0;
}

.hamburger-menu:has(input:unchecked +.sidebar {
  translate: -100%;
}
