/* Header Layout - BEM naming */

.header {
  background-color: #417C94FF;
  border-bottom: 1px solid var(--color-border);
  box-shadow: var(--shadow-sm);
  position: relative;  /* Non-sticky by default (desktop) */
  z-index: 9999;      /* High z-index to stay above map and all other elements */
}

/* Mobile: Make header sticky */
@media (max-width: 768px) {
  .header {
    position: sticky;
    top: 0;
  }
}

.header__content {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--spacing-md) 0;
  gap: var(--spacing-lg);
}

/* Logo component */
.logo {
  /* must shrink: a fixed 350px logo + flex-shrink:0 overflows the header
     on 360px phones (~328px available inside the container) */
  flex-shrink: 1;
  min-width: 0;
  display: flex;
  align-items: center;
  text-decoration: none;
}

.logo:hover {
  text-decoration: none;
}

.logo-image {
  width: 350px;
  height: auto;
  object-fit: contain;
  max-width: 100%;
}

/* Header search component */
.header__search {
  flex-shrink: 0;
}

.search-form {
  display: flex;
  gap: var(--spacing-sm);
}

.search-form--header {
  flex-direction: column;
  gap: var(--spacing-sm);
}

.search__input {
  min-width: 200px;
  padding: var(--spacing-sm) var(--spacing-md);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  font-size: var(--font-size-sm);
}

.search__button {
  background-color: var(--color-primary);
  color: var(--color-text-white);
  border: none;
  padding: var(--spacing-sm) var(--spacing-md);
  border-radius: var(--radius-md);
  font-weight: 500;
  cursor: pointer;
  transition: background-color 0.2s ease;
}

.search__button:hover {
  background-color: var(--color-primary-dark);
}

/* Legacy classes for backwards compatibility */
.header-content {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--spacing-md) 0;
  gap: var(--spacing-lg);
}

.header-search {
  flex-shrink: 0;
}

.search-input {
  min-width: 200px;
  padding: var(--spacing-sm) var(--spacing-md);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  font-size: var(--font-size-sm);
}

.search-button {
  background-color: var(--color-primary);
  color: var(--color-text-white);
  border: none;
  padding: var(--spacing-sm) var(--spacing-md);
  border-radius: var(--radius-md);
  font-weight: 500;
  cursor: pointer;
  transition: background-color 0.2s ease;
}

.search-button:hover {
  background-color: var(--color-primary-dark);
} 