/* Home-specific styles building on base.css */

/* Accessibility: skip link */
.skip-link {
  position: absolute;
  top: -100%;
  left: 0;
  background: var(--color-primary);
  color: #fff;
  padding: 8px 12px;
  border-radius: var(--radius-sm);
  transition: top var(--duration-fast) var(--easing-standard);
  z-index: 1000;
}
.skip-link:focus { top: 8px; }

/* Header */
.site-header {
  position: sticky;
  top: 0;
  z-index: 999;
  background: color-mix(in oklab, var(--color-surface) 92%, transparent);
  backdrop-filter: saturate(140%) blur(10px);
  border-bottom: 1px solid var(--gray-200);
}
.header-inner { display: grid; grid-template-columns: auto 1fr; align-items: center; gap: var(--space-4); padding-block: var(--space-4); }
.brand-link { font-weight: 800; font-size: var(--fs-xl); color: var(--color-text); letter-spacing: -0.02em; }

/* Primary nav */
.menu-toggle { display: none; border: 1px solid var(--gray-300); background: var(--gray-0); border-radius: var(--radius-md); padding: 10px; line-height: 0; }
.menu-toggle__bar { display: block; width: 22px; height: 2px; background: var(--color-text); margin: 4px 0; border-radius: 2px; }

.primary-nav { display: flex; align-items: center; justify-content: space-between; gap: var(--space-6); }
.nav-list { display: flex; gap: var(--space-5); list-style: none; padding: 0; margin: 0; }
.nav-list a { color: var(--color-text); font-weight: 600; }
.nav-list a:hover { text-decoration: underline; }
.nav-list .cta-link { color: var(--color-primary); }

.site-search { display: flex; align-items: center; gap: var(--space-2); min-width: min(420px, 50vw); }
.site-search input { min-width: 0; }

@media (max-width: 960px) {
  .menu-toggle { display: inline-flex; justify-self: end; flex-direction: column;}
  .primary-nav { position: fixed; inset: 64px 0 auto 0; background: var(--color-surface); border-bottom: 1px solid var(--gray-200); padding: var(--space-5) var(--container-pad); flex-direction: column; gap: var(--space-5); transform: translateY(-150%); transition: transform var(--duration-normal) var(--easing-standard); }
  .primary-nav.open { transform: translateY(0); }
  .nav-list { flex-direction: column; gap: var(--space-3); }
  .site-search { width: 100%; min-width: 0; }
}

/* Hero */
.hero { color: #fff; padding-block: clamp(2rem, 4vw + 1rem, 5rem); }
.hero-grid { display: grid; grid-template-columns: 1.2fr 1fr; gap: var(--space-10); align-items: center; }
.hero-copy h1 { margin: 0 0 0.4em; font-size: var(--fs-5xl); }
.hero-actions { display: flex; gap: var(--space-3); margin-top: var(--space-4); }
.hero-highlights { display: flex; flex-wrap: wrap; gap: var(--space-2); margin-top: var(--space-4); list-style: none; padding: 0; }
.hero-media img { border-radius: var(--radius-lg); box-shadow: var(--shadow-lg); }

@media (max-width: 960px) {
  .hero-grid { grid-template-columns: 1fr; }
  .hero-media { order: -1; }
}

/* Sections */
.section--padded { padding-block: clamp(2rem, 4vw + 1rem, 5rem); }
.card-media img { border-radius: var(--radius-md); margin-bottom: var(--space-4); }
.card-body h2 { font-size: var(--fs-2xl); }
.card-actions { display: flex; flex-wrap: wrap; gap: var(--space-3); margin-top: var(--space-4); }

/* CTA Band */
.cta-band { background: var(--gray-50); border-top: 1px solid var(--gray-200); border-bottom: 1px solid var(--gray-200); }
.cta-band-inner { display: grid; gap: var(--space-3); align-items: center; grid-template-columns: 1fr auto auto; padding-block: var(--space-6); }
.cta-band-title { margin: 0; }
.cta-band-text { margin: 0; color: var(--color-muted); }
.cta-band-actions { display: flex; gap: var(--space-3); }
@media (max-width: 720px) {
  .cta-band-inner { grid-template-columns: 1fr; }
}

/* Footer */
.site-footer { background: var(--color-surface); border-top: 1px solid var(--gray-200); margin-top: var(--space-10); }
.footer-grid { display: grid; gap: var(--space-8); padding-block: var(--space-8); grid-template-columns: 1.2fr 1fr 1fr; }
.footer-title { margin-bottom: var(--space-3); }
.footer-links { list-style: none; padding: 0; margin: 0; display: grid; gap: var(--space-2); }
.footer-base { border-top: 1px solid var(--gray-200); padding-block: var(--space-5); color: var(--color-muted); }
@media (max-width: 960px) {
  .footer-grid { grid-template-columns: 1fr; }
}

/* Cookie consent */
.cookie-consent { position: fixed; left: 0; right: 0; bottom: 0; z-index: 1000; background: var(--color-surface); border-top: 1px solid var(--gray-200); box-shadow: var(--shadow-md); }
.cookie-consent__inner { display: grid; gap: var(--space-4); align-items: center; grid-template-columns: 1fr auto; padding-block: var(--space-4); }
.cookie-consent__text { margin: 0; }
.cookie-consent__actions { display: flex; gap: var(--space-3); }
@media (max-width: 720px) {
  .cookie-consent__inner { grid-template-columns: 1fr; }
}

/* Utility tweaks */
.bg-accent-gradient { background-image: var(--gradient-primary); }
