/* ============= Header / top utility bar ============= */
.topbar {
  position: sticky;
  top: 0;
  background: var(--bg);
  border-bottom: 1px solid var(--rule);
  z-index: 50;
}
.topbar__inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding-block: 14px;          /* slightly tighter to balance taller logo */
  gap: var(--space-4);
  min-height: 72px;             /* gives the logo room without changing nav size */
}
.topbar__wordmark {
  display: inline-flex;
  align-items: center;
  height: auto;
}
.topbar__logo {
  height: 48px;                 /* up from 36px */
  width: auto;
  display: block;
}
@media (max-width: 768px) {
  .topbar__logo { height: 40px; }
  .topbar__inner { min-height: 60px; padding-block: 10px; }
}
.topbar__nav {
  display: flex;
  gap: var(--space-4);
  list-style: none;
}
.topbar__nav a {
  font-family: 'Work Sans', sans-serif;
  font-weight: 400;
  font-size: 11px;
  letter-spacing: var(--ls-eyebrow);
  text-transform: uppercase;
  color: var(--ink-muted);
  transition: color 200ms ease;
}
.topbar__nav a:hover { color: var(--ink); }

/* Hamburger button (mobile only) */
.topbar__hamburger {
  display: none;
  background: none;
  border: none;
  padding: 8px;
  cursor: pointer;
  flex-direction: column;
  gap: 4px;
}
.topbar__hamburger span {
  display: block;
  width: 22px;
  height: 1.5px;
  background: var(--ink);
  transition: transform 240ms ease, opacity 240ms ease;
}
.topbar__hamburger[aria-expanded="true"] span:nth-child(1) {
  transform: translateY(5.5px) rotate(45deg);
}
.topbar__hamburger[aria-expanded="true"] span:nth-child(2) {
  opacity: 0;
}
.topbar__hamburger[aria-expanded="true"] span:nth-child(3) {
  transform: translateY(-5.5px) rotate(-45deg);
}

/* Search icon link */
.topbar__search-link {
  display: inline-flex;
  align-items: center;
  color: var(--ink-muted);
  transition: color 200ms ease;
}
.topbar__search-link:hover { color: var(--ink); }

/* Mobile drawer */
.topbar__drawer {
  display: none;
  background: var(--bg);
  border-top: 1px solid var(--rule);
  padding: var(--space-5) 0;
  max-height: calc(100vh - 60px);
  overflow-y: auto;
}
.topbar__drawer-inner {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-5);
  padding: 0 var(--gutter);
}
.topbar__drawer-col h4 {
  font-family: 'Work Sans', sans-serif;
  font-weight: 600;
  font-size: 11px;
  letter-spacing: var(--ls-eyebrow);
  text-transform: uppercase;
  color: var(--accent);
  margin-bottom: var(--space-3);
}
.topbar__drawer-col ul {
  list-style: none;
  padding: 0;
  margin: 0;
}
.topbar__drawer-col li a {
  display: block;
  padding: 8px 0;
  font-family: 'Work Sans', sans-serif;
  font-size: 15px;
  font-weight: 400;
  color: var(--ink);
  text-transform: none;
  letter-spacing: 0;
}
.topbar__drawer-col li a:hover { color: var(--accent); }

@media (max-width: 768px) {
  .topbar__hamburger { display: flex; }
  .topbar__nav--left { display: none; }
  .topbar__nav--right { display: none; }
  .topbar__drawer:not([hidden]) { display: block; }
  .topbar__inner { justify-content: space-between; }
  .topbar__wordmark { margin-left: 0; }
}

@media (min-width: 480px) {
  .topbar__drawer-inner { grid-template-columns: 1fr 1fr 1fr; }
}

/* ============= Footer ============= */
.footer { border-top: 1px solid var(--rule-strong); padding-top: var(--space-7); margin-top: var(--space-8); }
.footer__inner {
  display: grid;
  grid-template-columns: 1.5fr 1fr 1fr 1fr;
  gap: var(--space-6);
  padding-bottom: var(--space-6);
}
.footer__wordmark {
  margin-bottom: var(--space-3);
}
.footer__logo {
  height: 64px;
  width: auto;
  display: block;
}
.footer__tagline { color: var(--ink-muted); font-size: 13px; line-height: 1.7; max-width: 320px; margin-bottom: var(--space-2); }
.footer__city { color: var(--meta); font-size: 11px; letter-spacing: 0.18em; text-transform: uppercase; }
.footer__col h4 {
  font-family: 'Work Sans', sans-serif;
  font-weight: 600;
  font-size: 11px;
  letter-spacing: var(--ls-eyebrow);
  text-transform: uppercase;
  color: var(--ink);
  margin-bottom: var(--space-3);
}
.footer__col ul { list-style: none; }
.footer__col li { font-size: 13px; color: var(--ink-muted); margin-bottom: var(--space-2); }
.footer__col a:hover { color: var(--ink); }
.footer__strip {
  display: flex;
  justify-content: space-between;
  padding-block: var(--space-4);
  border-top: 1px solid var(--rule);
  font-family: 'Work Sans', sans-serif;
  font-size: 10px;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--meta);
}
@media (max-width: 768px) {
  .footer__inner { grid-template-columns: 1fr; gap: var(--space-5); }
  .footer__strip { flex-direction: column; gap: var(--space-2); align-items: flex-start; }
}

/* ============= WhatsApp pill ============= */
.wa-pill {
  position: fixed;
  bottom: 24px;
  left: 24px;
  background: var(--ink);
  color: #fff;
  font-family: 'Work Sans', sans-serif;
  font-weight: 500;
  font-size: 11px;
  letter-spacing: var(--ls-eyebrow);
  text-transform: uppercase;
  padding: 14px 22px;
  border-radius: 100px;
  box-shadow: 0 6px 20px rgba(0,0,0,0.15);
  opacity: 0;
  transform: translateY(8px);
  transition: opacity 280ms ease, transform 280ms ease;
  z-index: 80;
}
.wa-pill.is-visible { opacity: 1; transform: translateY(0); }
@media (max-width: 768px) {
  .wa-pill { bottom: 16px; left: 16px; padding: 12px 18px; font-size: 10px; }
}

/* ============= Newsletter band ============= */
.newsletter {
  background: var(--surface-cream);
  text-align: center;
  padding-block: var(--space-8);
}
.newsletter__title { margin-block: var(--space-3); }
.newsletter__sub { color: var(--ink-muted); margin-bottom: var(--space-5); }
.newsletter__form {
  display: inline-flex;
  width: 100%;
  max-width: 520px;
  border-bottom: 1px solid var(--ink);
  padding: 4px 0;
}
.newsletter__form input {
  flex: 1;
  background: transparent;
  border: none;
  outline: none;
  font-family: 'Work Sans', sans-serif;
  font-size: 14px;
  color: var(--ink);
  padding: 8px 0;
}
.newsletter__form button {
  font-family: 'Work Sans', sans-serif;
  font-weight: 500;
  font-size: 11px;
  letter-spacing: var(--ls-eyebrow);
  text-transform: uppercase;
  color: var(--ink);
}

/* ============= View transitions ============= */
@view-transition { navigation: auto; }
::view-transition-old(root), ::view-transition-new(root) {
  animation-duration: 240ms;
  animation-timing-function: ease;
}
