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

/* Layout helpers */
.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: #fff; border: 1px solid var(--gray-300); padding: var(--space-4) var(--space-6); border-radius: var(--radius-md); box-shadow: var(--shadow-sm); }

/* Header */
.site-header { position: sticky; top: 0; z-index: 50; background: color-mix(in oklab, var(--color-surface) 88%, white); border-bottom: 1px solid var(--gray-200); backdrop-filter: saturate(120%) blur(6px); }
.header-inner { display: grid; grid-template-columns: 1fr auto auto; align-items: center; gap: var(--space-5); min-height: 64px; }
.brand-link { font-weight: 700; font-family: var(--font-serif); font-size: 1.25rem; color: var(--color-heading); }
.menu-toggle { display: none; }
.menu-toggle { appearance: none; border: 1px solid var(--gray-300); background: var(--color-surface); color: var(--color-text); border-radius: var(--radius-md); padding: var(--space-4) var(--space-6); cursor: pointer; }
.menu-icon { width: 20px; height: 14px; display: inline-block; margin-right: 8px; background:
  linear-gradient(currentColor, currentColor) 0 0/100% 2px no-repeat,
  linear-gradient(currentColor, currentColor) 0 50%/100% 2px no-repeat,
  linear-gradient(currentColor, currentColor) 0 100%/100% 2px no-repeat; }
.primary-nav { justify-self: end; }
.nav-list { display: flex; gap: var(--space-7); align-items: center; }
.nav-list a { color: var(--color-heading); font-weight: 600; }
.nav-list a:hover { color: var(--color-primary); text-decoration: none; }

@media (max-width: 860px) {
  .header-inner { grid-template-columns: auto 1fr auto; }
  .menu-toggle { display: inline-flex; align-items: center; justify-content: center; }
  .primary-nav { position: fixed; inset: 64px 0 auto 0; background: var(--color-surface); border-bottom: 1px solid var(--gray-200); transform: translateY(-120%); transition: transform var(--duration-normal) var(--easing-standard); padding: var(--space-6) var(--container-pad); }
  .primary-nav.is-open { transform: translateY(0); }
  .nav-list { flex-direction: column; align-items: flex-start; gap: var(--space-5); }
}

/* Hero */
.hero { padding: var(--space-12) 0 var(--space-10); background:
  radial-gradient(80% 60% at 20% 10%, hsl(40 35% 98% / 0.9), transparent 60%),
  linear-gradient(180deg, hsl(40 44% 96%), hsl(40 35% 98%)); }
.hero-inner { display: grid; grid-template-columns: 1.1fr 0.9fr; gap: var(--space-10); align-items: center; }
.hero-copy p { margin-top: var(--space-4); color: var(--gray-700); }
.hero-search { margin-top: var(--space-7); display: grid; grid-template-columns: 1fr auto; gap: var(--space-4); }
.hero-search input { min-width: 0; }
.quick-cats { margin-top: var(--space-5); display: flex; flex-wrap: wrap; gap: var(--space-4); }
.chip { display: inline-flex; align-items: center; padding: 8px 12px; border: 1px solid var(--gray-300); border-radius: var(--radius-pill); background: var(--color-surface); color: var(--color-heading); font-weight: 600; }
.hero-media { min-height: 280px; border-radius: var(--radius-xl); background:
  repeating-linear-gradient(0deg, hsl(210 10% 95%), hsl(210 10% 95%) 2px, transparent 2px, transparent 30px),
  linear-gradient(135deg, hsl(207 45% 62% / 0.18), hsl(16 47% 58% / 0.12)); border: 1px solid var(--gray-200); box-shadow: var(--shadow-md); }

@media (max-width: 980px) { .hero-inner { grid-template-columns: 1fr; } .hero-media { display: none; } }

/* Sections */
.section { padding: var(--space-12) 0; }
.section.alt { background: var(--color-surface); }
.grid-2 { display: grid; grid-template-columns: 1.05fr 0.95fr; gap: var(--space-10); align-items: center; }
.grid-2.reverse { grid-template-columns: 0.95fr 1.05fr; }
.section-media img { border-radius: var(--radius-xl); border: 1px solid var(--gray-200); box-shadow: var(--shadow-sm); }
.section-content p { color: var(--gray-700); }
.section-cta { display: flex; gap: var(--space-4); margin-top: var(--space-6); flex-wrap: wrap; }

@media (max-width: 980px) { .grid-2, .grid-2.reverse { grid-template-columns: 1fr; } }

/* Cards */
.card-list .card { height: 100%; }
.card-title { margin: 0 0 var(--space-2) 0; font-size: var(--fs-500); }
.bullet-list { margin-top: var(--space-5); color: var(--gray-700); }
.bullet-list li { padding-left: 1.25rem; position: relative; }
.bullet-list li::before { content: ""; width: 8px; height: 8px; border-radius: 50%; background: var(--color-accent); position: absolute; left: 0; top: 0.6rem; }

/* Reviews */
.reviews { display: grid; grid-template-columns: repeat(auto-fit, minmax(18rem, 1fr)); }
.review blockquote { margin-top: var(--space-4); color: var(--gray-700); }
.stars { display: inline-flex; gap: 4px; color: var(--color-warning); }
.star { width: 18px; height: 18px; fill: var(--color-warning); }

/* Categories */
.categories .cat { display: block; padding: var(--space-7); text-decoration: none; }
.categories .cat h3 { margin: 0 0 6px 0; }
.categories .cat p { margin: 0; color: var(--gray-600); }
.categories .cat:hover { box-shadow: var(--shadow-md); }

/* Promo */
.promo-callout { display: grid; gap: 6px; }

/* Newsletter */
.newsletter .newsletter-inner { display: grid; gap: var(--space-5); align-items: start; }
.newsletter-form { display: grid; grid-template-columns: 1fr auto; gap: var(--space-4); align-items: center; }
.newsletter-form small { grid-column: 1 / -1; color: var(--gray-600); }
@media (max-width: 600px) { .newsletter-form { grid-template-columns: 1fr; } }

/* Footer */
.site-footer { background: var(--color-surface); border-top: 1px solid var(--gray-200); margin-top: var(--space-12); }
.footer-grid { display: grid; grid-template-columns: 1.1fr 1fr 1fr; gap: var(--space-10); padding-top: var(--space-10); padding-bottom: var(--space-10); }
.footer-title { margin: 0 0 var(--space-4) 0; font-size: var(--fs-500); }
.footer-links { display: grid; gap: 8px; }
.footer-links a { color: var(--color-heading); }
.footer-links a:hover { color: var(--color-primary); text-decoration: none; }
.footer-bottom { border-top: 1px solid var(--gray-200); padding: var(--space-6) 0; color: var(--gray-600); }
@media (max-width: 980px) { .footer-grid { grid-template-columns: 1fr; } }

/* Cookie banner */
.cookie-banner { position: fixed; left: 0; right: 0; bottom: 0; z-index: 100; background: var(--color-surface); border-top: 1px solid var(--gray-200); box-shadow: 0 -8px 24px rgba(16, 24, 40, 0.06); }
.cookie-inner { display: grid; grid-template-columns: 1fr auto; gap: var(--space-6); padding: var(--space-6) var(--container-pad); align-items: center; }
.cookie-inner p { margin: 0; color: var(--gray-700); }
.cookie-actions { display: flex; gap: var(--space-4); }
@media (max-width: 720px) { .cookie-inner { grid-template-columns: 1fr; } .cookie-actions { justify-content: start; } }
