/* Homepage-specific styles (builds on base.css) */

/* Skip link */
.skip-link {
  position: absolute;
  left: -9999px;
  top: auto;
  width: 1px;
  height: 1px;
  overflow: hidden;
}
.skip-link:focus {
  left: 16px;
  top: 16px;
  width: auto;
  height: auto;
  background: var(--color-primary);
  color: var(--color-primary-contrast);
  padding: var(--space-2) var(--space-4);
  border-radius: var(--radius-lg);
  z-index: 1000;
}

/* Header */
.site-header {
  position: sticky;
  top: 0;
  background: var(--color-surface);
  border-bottom: 1px solid var(--color-border);
  z-index: 999;
}
.header-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding-block: var(--space-3);
}
.brand__link {
  color: var(--color-text);
  font-weight: 800;
  font-size: var(--text-xl);
}

/* Nav */
.nav-toggle {
  display: inline-flex;
  flex-direction: column;
  gap: 4px;
  border: 1px solid var(--color-border);
  background: var(--color-surface);
  padding: 8px;
  border-radius: var(--radius-md);
      position: relative;
    z-index: 10;
}
.nav-toggle__bar {
  width: 22px;
  height: 2px;
  background: var(--color-text);
}
.site-nav {
  position: fixed;
  inset: 0 0 0 auto;
  width: min(88vw, 320px);
  max-width: 100%;
  background: var(--color-surface);
  border-left: 1px solid var(--color-border);
  transform: translateX(100%);
  transition: transform var(--duration-slow) var(--ease-standard);
  padding: var(--space-8) var(--space-6);
}
.site-nav.is-open { transform: translateX(0); }

.nav-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}
.nav-list a { font-weight: 600; color: var(--color-text); }
.nav-list a.btn { color: var(--color-primary-contrast); }

/* Desktop nav */
@media (min-width: 992px) {
  .nav-toggle { display: none; }
  .site-nav {
    position: static;
    transform: none;
    width: auto;
    border: 0;
    padding: 0;
  }
  .nav-list {
    flex-direction: row;
    align-items: center;
    gap: var(--space-6);
  }
}

/* Sections */
.section { padding-block: clamp(var(--space-10), 6vw, var(--space-18)); }
.section-intro { color: var(--color-text-muted); }

/* Hero */
.hero__grid {
  display: grid;
  gap: var(--space-8);
  align-items: center;
  grid-template-columns: 1fr;
}
.hero__content p { max-width: 56ch; }
.hero__cta { display: flex; gap: var(--space-4); flex-wrap: wrap; margin-block: var(--space-4); }
.hero__media img { border-radius: var(--radius-xl); box-shadow: var(--shadow-lg); }
.quick-form {
  margin-top: var(--space-6);
  display: grid;
  gap: var(--space-4);
  grid-template-columns: 1fr;
  max-width: 560px;
}
@media (min-width: 992px) {
  .hero__grid { grid-template-columns: 1.1fr 0.9fr; }
}

/* Inspiration */
.inspo__grid { display: grid; gap: var(--space-8); align-items: center; grid-template-columns: 1fr; }
.inspo__media img { border-radius: var(--radius-xl); }
@media (min-width: 992px) { .inspo__grid { grid-template-columns: 0.9fr 1.1fr; } }

/* Services */
.services__grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-6);
  margin-top: var(--space-6);
}
.service img { border-radius: var(--radius-lg); margin-bottom: var(--space-4); }
.service__content h3 { margin-bottom: var(--space-2); }
.services__cta { margin-top: var(--space-6); }
@media (min-width: 768px) { .services__grid { grid-template-columns: repeat(2, 1fr); } }

/* Testimonials */
.testimonials__grid { display: grid; gap: var(--space-6); align-items: start; }
.testimonials__grid img { border-radius: var(--radius-lg); }
.testimonials__copy { display: grid; gap: var(--space-4); }
.testimonials blockquote { margin: 0; padding-left: var(--space-4); border-left: 3px solid var(--color-primary); color: var(--color-text); }
.testimonials cite { display: block; color: var(--color-text-muted); margin-top: var(--space-1); font-style: normal; }

/* Meet */
.meet__grid { display: grid; gap: var(--space-8); align-items: center; grid-template-columns: 1fr; }
.meet__media img { border-radius: var(--radius-xl); box-shadow: var(--shadow-md); }
@media (min-width: 992px) { .meet__grid { grid-template-columns: 0.9fr 1.1fr; } }

/* Philosophy */
.philosophy__grid { display: grid; gap: var(--space-8); align-items: center; grid-template-columns: 1fr; }
.philosophy__media img { border-radius: var(--radius-xl); }
@media (min-width: 992px) { .philosophy__grid { grid-template-columns: 1.1fr 0.9fr; } }

/* CTA */
.cta__inner { text-align: center; }
.cta__buttons { display: inline-flex; gap: var(--space-4); flex-wrap: wrap; margin-top: var(--space-4); }

/* Blog */
.blog__grid { display: grid; gap: var(--space-8); align-items: center; grid-template-columns: 1fr; }
.blog__media img { border-radius: var(--radius-xl); }
.blog__links { display: flex; gap: var(--space-4); flex-wrap: wrap; margin-top: var(--space-2); }
@media (min-width: 992px) { .blog__grid { grid-template-columns: 0.9fr 1.1fr; } }

/* Events */
.events__grid { display: grid; gap: var(--space-8); align-items: center; grid-template-columns: 1fr; }
.events__media img { border-radius: var(--radius-xl); }
@media (min-width: 992px) { .events__grid { grid-template-columns: 1.1fr 0.9fr; } }

/* Contact */
.contact__grid { display: grid; gap: var(--space-8); grid-template-columns: 1fr; }
.contact__list { list-style: none; padding: 0; margin: 0; display: grid; gap: var(--space-2); }
.contact__form { display: grid; gap: var(--space-4); }
@media (min-width: 992px) { .contact__grid { grid-template-columns: 0.9fr 1.1fr; } }

/* Footer */
.site-footer { background: var(--color-surface); border-top: 1px solid var(--color-border); }
.footer__grid { display: grid; gap: var(--space-8); padding-block: var(--space-10); grid-template-columns: 1fr; }
.footer__title { font-weight: 800; font-size: var(--text-xl); margin-bottom: var(--space-2); }
.footer__heading { font-size: var(--text-lg); margin-bottom: var(--space-3); }
.footer__links { list-style: none; padding: 0; margin: 0; display: grid; gap: var(--space-2); }
.footer__bottom { padding-block: var(--space-4); border-top: 1px solid var(--color-border); font-size: var(--text-sm); color: var(--color-text-muted); }
@media (min-width: 992px) { .footer__grid { grid-template-columns: 1.2fr 1fr 1fr; } }

/* Cookie banner */
.cookie-banner {
  position: fixed;
  inset: auto 0 0 0;
  background: transparent;
  z-index: 1000;
}
.cookie-banner[hidden] { display: none; }
.cookie-banner__inner {
  margin: var(--space-4);
  padding: var(--space-4);
  border-radius: var(--radius-xl);
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  box-shadow: var(--shadow-lg);
  display: grid;
  gap: var(--space-4);
  grid-template-columns: 1fr;
}
.cookie-banner__actions { display: flex; gap: var(--space-3); flex-wrap: wrap; justify-content: flex-end; }

/* Minor tweaks */
.btn--sm { padding: 8px 14px; font-size: var(--text-sm); }
