/* pages.css — page-specific layout (header/footer chrome + hero) */

/* ---------- Site header ---------- */
.site-header {
  position: sticky;
  top: 0;
  z-index: 100;
  height: var(--header-h);
  display: flex;
  align-items: center;
  background: color-mix(in srgb, var(--color-bg) 88%, transparent);
  backdrop-filter: saturate(180%) blur(10px);
  border-bottom: 1px solid var(--color-border);
}
.site-header .container {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-3);
}
.site-logo {
  display: inline-flex;
  align-items: center;
  gap: var(--space-1);
  font-weight: 800;
  font-size: var(--step-1);
  color: var(--color-fg);
  letter-spacing: -0.02em;
}
.site-logo:hover { text-decoration: none; }
.site-logo img { width: 28px; height: 28px; }

.site-nav {
  display: flex;
  align-items: center;
  gap: var(--space-3);
}
.site-nav a {
  color: var(--color-fg);
  font-weight: 600;
  font-size: var(--step-0);
}
.site-nav a[aria-current="page"] { color: var(--accent); }

.nav-toggle {
  display: none;
  background: none;
  border: 0;
  cursor: pointer;
  padding: var(--space-1);
}

@media (max-width: 640px) {
  .nav-toggle { display: block; }
  .site-nav {
    position: absolute;
    inset: var(--header-h) 0 auto 0;
    flex-direction: column;
    align-items: flex-start;
    gap: var(--space-2);
    padding: var(--space-3);
    background: var(--color-bg);
    border-bottom: 1px solid var(--color-border);
    box-shadow: var(--shadow-2);
  }
  .site-nav[hidden] { display: none; }
}

/* ---------- Site footer ---------- */
.site-footer {
  margin-top: var(--space-6);
  padding-block: var(--space-4);
  background: var(--color-surface);
  border-top: 1px solid var(--color-border);
  font-size: var(--step--1);
}
.site-footer .container {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-3) var(--space-4);
  align-items: center;
  justify-content: space-between;
}
.footer-links { display: flex; flex-wrap: wrap; gap: var(--space-3); }
.footer-links a { color: var(--color-muted); }

/* ---------- Hero ---------- */
.hero {
  padding-block: var(--space-6) var(--space-5);
  background: linear-gradient(
    180deg,
    var(--accent-soft) 0%,
    var(--color-bg) 100%
  );
}
.hero h1 { font-size: var(--step-5); max-width: 14ch; }
.hero p { font-size: var(--step-1); color: var(--color-muted); max-width: 48ch; }
.hero__cta { display: flex; gap: var(--space-2); margin-top: var(--space-3); flex-wrap: wrap; }

/* ---------- Cookie consent banner ---------- */
.consent {
  position: fixed;
  inset: auto var(--space-2) var(--space-2) var(--space-2);
  z-index: 500;
  max-width: 520px;
  margin-inline: auto;
  background: var(--color-fg);
  color: var(--color-bg);
  padding: var(--space-3);
  border-radius: var(--radius);
  box-shadow: var(--shadow-2);
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
  align-items: center;
  justify-content: space-between;
}
.consent p { margin: 0; font-size: var(--step--1); flex: 1 1 240px; }
.consent a { color: var(--color-bg); text-decoration: underline; }
.consent__actions { display: flex; gap: var(--space-1); }
.consent button {
  font: inherit; font-weight: 600; font-size: var(--step--1);
  padding: 0.5em 1em; border-radius: var(--radius-sm); border: 0; cursor: pointer;
}
.consent__accept { background: var(--accent); color: var(--accent-contrast); }
.consent__decline { background: transparent; color: var(--color-bg); border: 1px solid currentColor; }

/* ---------- Section variants (Phase 2) ---------- */
.section--alt { background: var(--color-surface); }
.section-foot { margin-top: var(--space-4); }

.about-blurb h2 { font-size: var(--step-2); }

/* ---------- Long-form prose (about, legal) ---------- */
.prose h1 { font-size: var(--step-4); }
.prose h2 {
  font-size: var(--step-2);
  margin-top: var(--space-4);
}
.prose p,
.prose li { max-width: 68ch; }
.prose ul {
  margin: 0 0 var(--space-2);
  padding-left: var(--space-3);
}
.prose li { margin-bottom: var(--space-1); }
.prose .btn + .btn { margin-left: var(--space-1); }

/* ---------- Empty filter state ---------- */
.apps-empty { margin-top: var(--space-3); }

/* ---------- Contact ---------- */
.contact-cta { margin-top: var(--space-4); }
.contact-note { font-size: var(--step--1); }

/* ---------- App detail page (app-page.js, implementation-plan §9) ---------- */
.app-hero-section { padding-top: var(--space-6); }
.app-section { padding-block: var(--space-6); }

.app-hero {
  display: flex;
  align-items: flex-start;
  gap: var(--space-4);
  flex-wrap: wrap;
}
.app-hero__icon {
  width: 96px;
  height: 96px;
  border-radius: 22px;
  box-shadow: var(--shadow-2);
  flex: none;
}
.app-hero__body { flex: 1 1 320px; min-width: 0; }
.app-hero__chips { margin-bottom: var(--space-2); }
.app-hero h1 { font-size: var(--step-4); margin: 0 0 var(--space-2); }
.app-hero__pitch {
  font-size: var(--step-1);
  color: var(--color-muted);
  max-width: 52ch;
  margin: 0 0 var(--space-4);
}

.app-legal { padding-block: var(--space-4); }
.app-legal .muted a { color: var(--color-muted); text-decoration: underline; }

/* ---------- FAQ accordion (app-page.js, P4-T04) ---------- */
.faq {
  border-top: 1px solid var(--color-border);
}
.faq__item {
  border-bottom: 1px solid var(--color-border);
}
.faq__q {
  cursor: pointer;
  padding: var(--space-3) 0;
  font-weight: 600;
  font-size: var(--step-1);
  list-style: none;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-2);
}
.faq__q::-webkit-details-marker { display: none; }
.faq__q::after {
  content: "+";
  color: var(--accent);
  font-weight: 700;
  font-size: var(--step-2);
  line-height: 1;
  flex: none;
}
.faq__item[open] .faq__q::after { content: "\2013"; }
.faq__q:focus-visible {
  outline: 2px solid var(--accent);
  outline-offset: 2px;
  border-radius: var(--radius-sm);
}
.faq__a {
  padding-bottom: var(--space-3);
  color: var(--color-muted);
}
.faq__a p { margin: 0; max-width: 68ch; }

/* ---------- Press kit (press.js, P4-T01) ---------- */
.press-boilerplate { margin-top: var(--space-4); }
.press-apps {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: var(--space-3);
}
.press-app {
  background: var(--color-bg);
  border: 1px solid var(--color-border);
  border-radius: var(--radius);
  padding: var(--space-3);
}
.press-app__head {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  margin-bottom: var(--space-2);
}
.press-app__icon { border-radius: 16px; flex: none; box-shadow: var(--shadow-1); }
.press-app__name { font-size: var(--step-1); margin: 0 0 var(--space-1); }
.press-app__pitch,
.press-app__desc,
.press-app__platforms,
.press-app__assets {
  font-size: var(--step--1);
  margin: 0 0 var(--space-2);
}
.press-app__desc { color: var(--color-muted); }
.press-app__assets a,
.press-app__platforms a { text-decoration: underline; }

/* ---------- Blog (scaffold, P4-T02) ---------- */
.blog-empty {
  margin-top: var(--space-4);
  padding: var(--space-5) var(--space-3);
  text-align: center;
  border: 1px dashed var(--color-border);
  border-radius: var(--radius);
  color: var(--color-muted);
}
.blog-empty p { margin: 0 0 var(--space-2); }
.blog-empty p:last-child { margin-bottom: 0; }
