﻿/* Homepage-specific styles building on base.css */

/* Global */
.skip-link {
  position: absolute;
  top: -40px;
  left: 16px;
  background: var(--color-primary);
  color: var(--color-primary-contrast);
  padding: 8px 12px;
  border-radius: var(--radius-md);
  z-index: 1000;
}
.skip-link:focus { top: 16px; }

/* Header */
.site-header {
  position: sticky;
  top: 0;
  z-index: 50;
  background: color-mix(in srgb, var(--color-surface) 90%, transparent);
  backdrop-filter: saturate(1.2) blur(8px);
  border-bottom: 1px solid var(--color-border);
}
.header-inner {
  display: grid;
  grid-template-columns: 1fr auto auto;
  gap: var(--space-4);
  align-items: center;
  min-height: 64px;
}
.brand a {
  font-weight: 800;
  font-size: 1.125rem;
  color: var(--color-text);
}
.nav-toggle {
  display: inline-flex;
  flex-direction: column;
  gap: 4px;
  width: 42px;
  height: 42px;
  align-items: center;
  justify-content: center;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  background: var(--color-surface);
}
.nav-toggle__bar { width: 18px; height: 2px; background: var(--color-text); border-radius: 2px; }

.primary-nav {
  position: fixed;
  inset: 64px 0 auto 0;
  background: var(--color-surface);
  border-bottom: 1px solid var(--color-border);
  transform: translateY(-120%);
  transition: transform var(--duration-normal) var(--easing-standard);
}
.primary-nav .nav-list { display: grid; gap: var(--space-2); padding: var(--space-5) var(--space-6); }
.primary-nav .nav-cta { padding: 0 var(--space-6) var(--space-5); }
.primary-nav a { color: var(--color-text); font-weight: 600; }
.primary-nav.is-open { transform: translateY(0); }

@media (min-width: 960px) {
  .nav-toggle { display: none; }
  .primary-nav {
    position: static;
    transform: none !important;
    background: transparent;
    border: 0;
  }
  .header-inner { grid-template-columns: 1fr auto; }
  .primary-nav .nav-list {
    display: inline-flex;
    gap: var(--space-4);
    padding: 0;
  }
  .primary-nav .nav-cta { padding: 0 0 0 var(--space-4); display: inline-flex; }
}

/* Hero */
.section-hero {
  padding: clamp(var(--space-12), 8vw, var(--space-20)) 0 var(--space-12);
}
.hero-grid {
  display: grid;
  gap: var(--space-8);
  grid-template-columns: 1fr;
}
.hero-copy h1 { max-width: 22ch; }
.hero-actions { display: inline-flex; gap: var(--space-3); margin-top: var(--space-4); flex-wrap: wrap; }
.hero-media img { border-radius: var(--radius-lg); box-shadow: var(--shadow-lg); }

@media (min-width: 960px) {
  .hero-grid { grid-template-columns: 1.1fr 0.9fr; align-items: center; }
}

/* Inventory */
.section { padding: var(--space-14) 0; }
.section-header { margin-bottom: var(--space-6); }
.inventory-grid { display: grid; gap: var(--space-4); }
.inventory-grid img { border-radius: var(--radius-lg); }
.inventory-quicklinks { display: flex; flex-wrap: wrap; gap: var(--space-2); }
.chip {
  display: inline-flex;
  align-items: center;
  height: 36px;
  padding: 0 var(--space-3);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-full);
  color: var(--color-text);
  background: var(--color-surface);
}

/* Filtering */
.filtering-grid { display: grid; gap: var(--space-8); align-items: center; }
.filter-form .form-row { display: grid; gap: var(--space-3); }
.filter-form .form-actions { display: flex; gap: var(--space-3); margin-top: var(--space-3); flex-wrap: wrap; }
.filtering-media img { border-radius: var(--radius-lg); box-shadow: var(--shadow-md); }

@media (min-width: 800px) {
  .filtering-grid { grid-template-columns: 1fr 1fr; }
  .filter-form .form-row { grid-template-columns: repeat(3, 1fr); }
}

/* Realtime */
.realtime-card { display: grid; gap: var(--space-2); }

/* Reviews */
.reviews-grid { display: grid; gap: var(--space-8); align-items: center; }
.reviews-media img { border-radius: var(--radius-lg); box-shadow: var(--shadow-md); }
.quotes { padding-left: var(--space-6); }
.quotes li { margin-bottom: var(--space-2); }
@media (min-width: 900px) {
  .reviews-grid { grid-template-columns: 1fr 1fr; }
}

/* Pricing */
.pricing-grid { display: grid; gap: var(--space-8); align-items: center; }
.pricing-media img { border-radius: var(--radius-lg); box-shadow: var(--shadow-md); }
@media (min-width: 900px) {
  .pricing-grid { grid-template-columns: 1fr 1fr; }
}

/* Steps */
.steps { counter-reset: step; display: grid; gap: var(--space-6); margin-top: var(--space-4); grid-template-columns: 1fr; }
.steps li { list-style: none; padding-left: var(--space-8); position: relative; }
.steps li::before {
  counter-increment: step;
  content: counter(step);
  position: absolute; left: 0; top: 0.1rem;
  width: 32px; height: 32px; border-radius: var(--radius-full);
  background: var(--color-primary); color: var(--color-primary-contrast);
  display: inline-flex; align-items: center; justify-content: center; font-weight: 700;
}
.steps h3 { margin-bottom: var(--space-2); }
.steps-cta { margin-top: var(--space-4); }
@media (min-width: 800px) {
  .steps { grid-template-columns: repeat(3, 1fr); }
}

/* Support */
.support-card { display: grid; gap: var(--space-4); grid-template-columns: 1fr; align-items: center; }
.support-actions { display: flex; gap: var(--space-3); flex-wrap: wrap; }
@media (min-width: 800px) {
  .support-card { grid-template-columns: 2fr auto; }
}

/* Service */
.section-service p { max-width: 60ch; }

/* Trust */
.trust-grid { display: grid; gap: var(--space-6); }
.trust-list { margin: 0; padding-left: var(--space-6); }
.trust-cta { margin-top: var(--space-4); }

/* Footer */
.site-footer { border-top: 1px solid var(--color-border); padding-top: var(--space-10); margin-top: var(--space-14); }
.footer-grid { display: grid; gap: var(--space-8); grid-template-columns: 1fr; }
.footer-logo { font-weight: 800; color: var(--color-text); }
.footer-title { font-size: var(--text-lg); margin-bottom: var(--space-3); }
.footer-list li { margin-bottom: 8px; }
.footer-bottom { border-top: 1px solid var(--color-border); padding: var(--space-4) 0; margin-top: var(--space-6); }
@media (min-width: 900px) {
  .footer-grid { grid-template-columns: 1.4fr 1fr 1fr; }
}

/* Cookie consent */
.cookie-consent {
  position: fixed;
  bottom: 0; left: 0; right: 0;
  background: var(--color-surface);
  border-top: 1px solid var(--color-border);
  box-shadow: var(--shadow-md);
  z-index: 100;
}
.cookie-consent__inner {
  display: grid;
  gap: var(--space-3);
  grid-template-columns: 1fr;
  padding: var(--space-4) 0;
}
.cookie-consent__actions { display: flex; gap: var(--space-3); justify-content: flex-end; flex-wrap: wrap; }
@media (min-width: 800px) {
  .cookie-consent__inner { grid-template-columns: 1fr auto; align-items: center; }
}


