:root {
  --och-green: #006400;
}

html,
body {
  max-width: 100%;
  overflow-x: hidden;
}

img,
svg,
video {
  max-width: 100%;
  height: auto;
}

.menu-line {
  height: 0.18rem;
  width: 100%;
  border-radius: 9999px;
  background-color: var(--och-green);
  transition: all 0.3s ease;
}

.header-shell {
  max-width: 72rem;
  margin: 0 auto;
  padding: 1rem 1rem;
}

.header-main {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  flex-wrap: wrap;
}

.header-brand {
  display: flex;
  align-items: center;
  gap: 0.5rem;
}

.header-actions {
  display: flex;
  align-items: center;
  gap: 0.75rem;
}

@media (min-width: 768px) {
  .header-main {
    display: grid;
    grid-template-columns: auto 1fr auto;
    align-items: center;
  }

  .header-nav {
    display: flex;
    justify-content: center;
    gap: 1.5rem;
  }
}

#mobileMenuBtn.is-active .menu-line:nth-child(1) {
  transform: translateY(0.45rem) rotate(45deg);
}

#mobileMenuBtn.is-active .menu-line:nth-child(2) {
  opacity: 0;
}

#mobileMenuBtn.is-active .menu-line:nth-child(3) {
  transform: translateY(-0.45rem) rotate(-45deg);
}

.field-box {
  border: 2px solid #111827;
  height: 28px;
  padding: 2px 6px;
  font-size: 12px;
}

.field-line {
  border-bottom: 2px solid #111827;
  height: 24px;
  padding: 2px 6px;
  font-size: 12px;
}

.section-title {
  color: #111827;
  font-weight: 700;
  font-size: 13px;
}

.passport-box {
  border: 2px solid #111827;
}

.header-title {
  color: var(--och-green);
  text-shadow: -1px -1px 0 #ffffff, 1px -1px 0 #ffffff, -1px 1px 0 #ffffff, 1px 1px 0 #ffffff;
}
