/* Sky Club LA — main stylesheet
 * Sprint 0 phase 1: minimal — Hello Sky Club, age-gate, header, footer
 * Sprint 0 phase 2: full parity styling
 */

/* --- Tokens --- */
:root {
  --sc-green: #1a3a1f;
  --sc-green-soft: #2d5a32;
  --sc-cream: #f4f1ea;
  --sc-gold: #c9a559;
  --sc-ink: #1a1a1a;
  --sc-muted: #6b7280;
  --sc-line: rgba(0,0,0,0.08);
  --sc-shadow: 0 8px 24px rgba(0,0,0,0.08);
  --sc-radius: 12px;
  --sc-container: 1200px;
  --sc-font-sans: ui-sans-serif, system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;
  --sc-font-display: "Georgia", "Times New Roman", serif;
}

* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
body {
  font-family: var(--sc-font-sans);
  color: var(--sc-ink);
  background: var(--sc-cream);
  line-height: 1.55;
  -webkit-font-smoothing: antialiased;
}
body.minimal { background: var(--sc-green); color: var(--sc-cream); }

a { color: var(--sc-green-soft); }
a:hover, a:focus { color: var(--sc-green); }

h1, h2, h3, h4 { font-family: var(--sc-font-display); color: var(--sc-green); margin-top: 0; }
h1 { font-size: 2.4rem; line-height: 1.15; }
h2 { font-size: 1.8rem; }
h3 { font-size: 1.3rem; }

.container { max-width: var(--sc-container); margin: 0 auto; padding: 0 1.25rem; }

.skip-link { position: absolute; left: -9999px; }
.skip-link:focus { left: 1rem; top: 1rem; background: var(--sc-green); color: var(--sc-cream); padding: .5rem 1rem; border-radius: 6px; z-index: 9999; }

/* --- Header --- */
.site-header { background: var(--sc-green); color: var(--sc-cream); padding: .75rem 0; }
.header-inner { display: flex; align-items: center; justify-content: space-between; gap: 1rem; flex-wrap: wrap; }
.logo img { height: 48px; width: auto; display: block; }
.site-nav ul { list-style: none; margin: 0; padding: 0; display: flex; gap: 1rem; flex-wrap: wrap; }
.site-nav a { color: var(--sc-cream); text-decoration: none; font-weight: 600; font-size: .95rem; padding: .25rem .5rem; border-radius: 6px; }
.site-nav a:hover, .site-nav a:focus, .site-nav a.active { background: rgba(255,255,255,0.1); color: var(--sc-gold); }

/* --- Hero --- */
.hero { padding: 4rem 0; background: linear-gradient(180deg, var(--sc-cream), #ffffff); text-align: center; }
.hero-logo { height: 120px; margin-bottom: 1.5rem; }
.hero h1 { font-size: 3rem; margin-bottom: .5rem; }
.lead { font-size: 1.15rem; color: var(--sc-ink); max-width: 720px; margin: 1rem auto; }
.muted { color: var(--sc-muted); }
.cta-row { display: flex; gap: 1rem; justify-content: center; flex-wrap: wrap; margin: 2rem 0; }

.btn { display: inline-block; padding: .75rem 1.5rem; border-radius: var(--sc-radius); font-weight: 600; text-decoration: none; border: 0; cursor: pointer; transition: transform .1s ease; }
.btn:hover { transform: translateY(-1px); }
.btn-primary { background: var(--sc-green); color: var(--sc-cream); }
.btn-primary:hover { background: var(--sc-green-soft); color: var(--sc-cream); }
.btn-secondary { background: transparent; color: var(--sc-green); border: 2px solid var(--sc-green); }

/* --- Locations --- */
.locations { padding: 4rem 0; }
.loc-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); gap: 1.5rem; margin-top: 2rem; }
.loc-card { background: #ffffff; border: 1px solid var(--sc-line); border-radius: var(--sc-radius); padding: 1.5rem; box-shadow: var(--sc-shadow); }

/* --- Footer --- */
.site-footer { background: var(--sc-green); color: var(--sc-cream); padding: 3rem 0 1rem; margin-top: 4rem; }
.site-footer h3, .site-footer h4 { color: var(--sc-gold); }
.site-footer a { color: var(--sc-cream); text-decoration: underline; }
.footer-inner { display: grid; grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); gap: 2rem; }
.footer-col p { margin: .25rem 0; font-size: .95rem; }
.social { list-style: none; padding: 0; margin: 0; }
.social li { margin: .25rem 0; }
.footer-legal { border-top: 1px solid rgba(255,255,255,0.1); margin-top: 2rem; padding-top: 1rem; font-size: .85rem; color: rgba(244,241,234,0.85); }
.footer-legal a { color: var(--sc-gold); }

/* --- Age gate --- */
.age-gate-wrap { min-height: 100vh; display: flex; align-items: center; justify-content: center; padding: 2rem 1rem; background: linear-gradient(180deg, var(--sc-green), var(--sc-green-soft)); }
.age-gate-card { background: var(--sc-cream); color: var(--sc-ink); border-radius: var(--sc-radius); padding: 2.5rem; max-width: 540px; box-shadow: var(--sc-shadow); text-align: center; }
.ag-logo { height: 80px; margin-bottom: 1rem; }
.ag-form { display: flex; flex-direction: column; gap: 1rem; align-items: stretch; margin-top: 1.5rem; }
.ag-form input[type=date] { padding: .5rem; border-radius: 6px; border: 1px solid var(--sc-line); width: 100%; }
.ag-confirm { font-size: .95rem; text-align: left; display: flex; gap: .5rem; align-items: flex-start; }
.ag-licenses { font-size: .8rem; color: var(--sc-muted); margin-top: 1.5rem; }

/* --- Error pages --- */
.error-page { padding: 4rem 0; text-align: center; }

/* --- Responsive --- */
@media (max-width: 720px) {
  .site-nav ul { gap: .5rem; }
  .hero h1 { font-size: 2.2rem; }
}
