:root {
  --color-bg: #f7f3e7;
  --color-text: #001D3D;
  --grid-size: 20px;
  --logo-aspect: 4449 / 1040; /* Actual SVG aspect ratio */
  --spacing-base: 24px;
}

* {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}

body {
  font-family: 'Work Sans', sans-serif;
  background: var(--color-bg);
  color: var(--color-text);
  padding: clamp(40px, 4vw, 80px); /* Min 2 grid (40px), max 4 grid (80px), scales in between */
  min-height: 100vh;
  display: flex;
  align-items: flex-start;
  justify-content: flex-start;
  /* Subtle grey grid background */
  background-image:
    linear-gradient(to right, rgba(0, 0, 0, 0.05) 1px, transparent 1px),
    linear-gradient(to bottom, rgba(0, 0, 0, 0.05) 1px, transparent 1px);
  background-size: var(--grid-size) var(--grid-size);
}

.container {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 24px;
  width: fit-content;
  min-width: 0;
  margin: 0;
  padding: 0;
}

.logo {
  height: 75px;
  aspect-ratio: var(--logo-aspect);
  display: block;
  flex-shrink: 0;
  object-fit: contain;
  object-position: left top;
  margin: 0;
  padding: 0;
}

.tagline {
  font-size: 16px;
  font-weight: 300;
  letter-spacing: -0.01em;
  white-space: nowrap;
  flex-shrink: 0;
  margin: 0;
}

.contact {
  color: var(--color-text);
  text-decoration: underline;
  transition: opacity 0.2s ease;
}

.contact:focus {
  outline: 2px solid var(--color-text);
  outline-offset: 2px;
}

/* Only apply hover effects on devices with hover capability */
@media (hover: hover) {
  .contact:hover {
    opacity: 0.7;
  }
}

/* Mobile responsive */
@media (max-width: 768px) {
  body {
    padding: clamp(40px, 3vw, 80px);
  }

  .logo {
    height: 60px;
    /* aspect-ratio automatically maintains width */
  }

  .tagline {
    font-size: 14px;
  }
}
