/* FrameLand Home Styles (builds on base.css) */

/* Layout helpers */
.section { padding: var(--space-16) 0; }

/* Skip link */
.skip-link {
  position: absolute; left: 8px; top: -40px; z-index: 9999;
  background: var(--color-surface); color: var(--color-text);
  padding: var(--space-2) var(--space-3); border-radius: var(--radius-sm);
  box-shadow: var(--shadow-soft);
}
.skip-link:focus { top: 8px; }

/* Header */
.site-header {
  position: sticky; top: 0; z-index: 1000;
  background: var(--color-surface);
  border-bottom: 1px solid var(--gray-200);
}
.header-inner { min-height: 64px; }
.brand a {
  font-family: var(--font-heading);
  font-size: 1.375rem; font-weight: 700; letter-spacing: 0.5px;
  color: var(--color-text);
}

/* Navigation */
.nav-toggle { display: none; width: 40px; height: 40px; align-items: center; justify-content: center; border-radius: var(--radius-md); }
.nav-toggle:focus-visible { box-shadow: 0 0 0 3px var(--focus-color); }
.nav-toggle__bar { width: 22px; height: 2px; background: var(--color-text); margin: 3px 0; border-radius: 2px; display: block; transition: transform var(--duration-normal) var(--easing-standard), opacity var(--duration-normal) var(--easing-standard); }

.primary-nav { display: block; }
.nav-list { display: flex; gap: var(--space-6); list-style: none; padding: 0; margin: 0; }
.nav-list a { color: var(--color-text); font-weight: 500; }
.nav-list a:hover { text-decoration: none; opacity: 0.9; }

/* Mobile nav */
@media (max-width: 900px) {
  .nav-toggle { display: inline-flex; }
  .primary-nav { position: fixed; inset: 0 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); box-shadow: var(--shadow-md); }
  .primary-nav.is-open { transform: translateY(64px); }
  .nav-list { padding: var(--space-6); gap: var(--space-4); flex-direction: column; }
  body.menu-open { overflow: hidden; }
}

/* Hero */
.hero { padding-top: var(--space-20); padding-bottom: var(--space-16); }
.hero-grid { display: grid; grid-template-columns: 1.2fr 1fr; gap: var(--space-10); align-items: center; }
.hero-copy p { max-width: 56ch; }
.hero-ctas { display: flex; gap: var(--space-4); margin-top: var(--space-4); flex-wrap: wrap; }
.hero-media img { border-radius: var(--radius-xl); box-shadow: var(--shadow-lg); border: 1px solid var(--gray-200); }

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

/* Eyebrow */
.eyebrow {
  font-size: var(--text-sm); letter-spacing: 0.08em; text-transform: uppercase;
  color: var(--gray-700); margin-bottom: var(--space-2);
}

/* Grids */
.grid-two { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-10); align-items: center; }
.grid-two.reverse { grid-auto-flow: dense; }
.grid-two.reverse > :first-child { order: 2; }
.grid-two.reverse > :last-child { order: 1; }

@media (max-width: 960px) {
  .grid-two { grid-template-columns: 1fr; }
  .grid-two.reverse > :first-child, .grid-two.reverse > :last-child { order: initial; }
}

/* Media frame */
.media-frame img { border-radius: var(--radius-lg); box-shadow: var(--shadow-md); border: 1px solid var(--gray-200); }

/* Category pills */
.category-pills { display: flex; flex-wrap: wrap; gap: var(--space-3); }
.pill {
  display: inline-flex; align-items: center; justify-content: center;
  padding: 0.5rem 0.9rem; border-radius: var(--radius-pill);
  background: var(--gray-100); color: var(--gray-800);
  border: 1px solid var(--gray-200); box-shadow: var(--shadow-subtle);
}
.pill:hover { text-decoration: none; background: var(--gray-50); }

/* Brands */
.brand-list { list-style: none; padding: 0; margin: var(--space-4) 0; display: grid; grid-template-columns: repeat(auto-fit, minmax(12rem, 1fr)); gap: var(--space-3); }
.brand-list li { background: var(--color-surface); border: 1px solid var(--gray-200); border-radius: var(--radius-md); padding: var(--space-3) var(--space-4); text-align: center; box-shadow: var(--shadow-subtle); }

/* Reviews */
.reviews .review .stars { color: var(--color-warning); font-weight: 700; margin-bottom: var(--space-2); }
.reviews .review footer { margin-top: var(--space-3); color: var(--gray-700); font-size: var(--text-sm); }

/* Footer */
.site-footer { background: var(--color-surface); border-top: 1px solid var(--gray-200); }
.footer-grid { display: grid; gap: var(--space-10); grid-template-columns: 1.2fr 1fr 1fr; padding-top: var(--space-12); padding-bottom: var(--space-10); }
.footer-logo { font-family: var(--font-heading); font-weight: 700; font-size: 1.25rem; color: var(--color-text); display: inline-block; margin-bottom: var(--space-3); }
.footer-nav h3, .footer-legal h3 { font-size: 1rem; margin-bottom: var(--space-3); font-family: var(--font-sans); font-weight: 600; }
.footer-nav ul, .footer-legal ul { list-style: none; padding: 0; margin: 0; display: grid; gap: 0.5rem; }
.footer-bottom { border-top: 1px solid var(--gray-200); padding-top: var(--space-6); padding-bottom: var(--space-8); display: flex; justify-content: space-between; align-items: center; }

@media (max-width: 960px) {
  .footer-grid { grid-template-columns: 1fr; }
  .footer-bottom { flex-direction: column; gap: var(--space-3); text-align: center; }
}

/* Cookie banner */
.cookie-consent { position: fixed; inset: auto 0 0 0; background: var(--color-surface); border-top: 1px solid var(--gray-300); box-shadow: 0 -8px 24px rgba(0,0,0,0.08); z-index: 2000; }
.cookie-consent__inner { display: flex; gap: var(--space-6); align-items: center; justify-content: space-between; padding-top: var(--space-4); padding-bottom: var(--space-4); }
.cookie-text { margin: 0; color: var(--gray-800); }
.cookie-actions { display: flex; gap: var(--space-3); flex-wrap: wrap; }

@media (max-width: 720px) {
  .cookie-consent__inner { flex-direction: column; align-items: stretch; }
  .cookie-actions { justify-content: flex-end; }
}
