/* ═══════════════════════════════════════════════════════════════════
   PETA VALE — STYLE.CSS
   Single stylesheet for all pages. Cached after first visit.
   Structure:
     1.  Root variables + reset
     2.  Typography defaults
     3.  Layout utilities
     4.  Nav
     5.  Hero (homepage)
     6.  About section
     7.  Section headers (reusable)
     8.  Signs grid (daily + list)
     9.  Sign detail page
     10. Peta Index card (K-index summary + detail)
     11. Forecast 3-day strip
     12. Purchase cards (natal, synastry, forecast)
     13. Sample pages
     14. Footer
     15. Media queries (responsive)
   ═══════════════════════════════════════════════════════════════════ */


/* ─── 1. ROOT + RESET ─────────────────────────────────────────────── */

*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}

:root{
  --bg:#f5eee0;
  --surface:#efe5d0;
  --surface-soft:#f0e7d3;
  --card:#faf4e7;
  --card-raised:#fffaed;

  --border:rgba(93,31,35,0.12);
  --border-strong:rgba(93,31,35,0.25);
  --border-ink:rgba(26,24,20,0.08);

  --burgundy:#5d1f23;
  --burgundy-soft:#8a4a4e;
  --burgundy-deep:#3e1115;
  --burgundy-tint:rgba(93,31,35,0.06);

  --ink:#1a1814;
  --ink-soft:#4a4440;
  --ink-muted:#7a7268;
  --ink-whisper:#a39a8d;

  --state-clarity:#2f6f5d;
  --state-cocoon:#3f5680;
  --state-pressure:#6a3d82;
  --state-overload:#a1343d;
  --state-unsettled:#8a6a2b;

  --serif:"Cormorant Garamond",Georgia,"Times New Roman",serif;
  --sans:"Inter",system-ui,-apple-system,sans-serif;

  --wrap-narrow:680px;
  --wrap-reading:820px;
  --wrap-wide:1100px;
  --wrap-hero:1240px;
}

html{scroll-behavior:smooth}
body{
  background:var(--bg);
  color:var(--ink);
  font-family:var(--sans);
  font-weight:300;
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  min-height:100vh;
  overflow-x:hidden;
}

a{color:var(--burgundy);text-decoration:none;transition:color 0.2s}
a:hover{color:var(--burgundy-deep)}

img{max-width:100%;height:auto;display:block}


/* ─── 2. TYPOGRAPHY ───────────────────────────────────────────────── */

h1,h2,h3,h4{
  font-family:var(--serif);
  font-weight:500;
  line-height:1.1;
  color:var(--ink);
  letter-spacing:-0.01em;
}
h1 .italic,h2 .italic,h3 .italic{
  font-style:italic;font-weight:400;
  color:var(--burgundy);
}
.eyebrow{
  font-family:var(--sans);
  font-size:11px;font-weight:500;
  text-transform:uppercase;
  letter-spacing:0.35em;
  color:var(--burgundy);
  margin-bottom:22px;
}


/* ─── 3. LAYOUT UTILITIES ─────────────────────────────────────────── */

.wrap-narrow{max-width:var(--wrap-narrow);margin:0 auto;padding:0 24px}
.wrap-reading{max-width:var(--wrap-reading);margin:0 auto;padding:0 24px}
.wrap-wide{max-width:var(--wrap-wide);margin:0 auto;padding:0 24px}
.wrap-hero{max-width:var(--wrap-hero);margin:0 auto;padding:0 48px}

.divider{
  display:block;
  width:80px;height:1px;
  background:var(--burgundy);
  margin:40px auto;
  opacity:0.4;
  border:none;
}


/* ─── 4. NAV ──────────────────────────────────────────────────────── */

nav.site-nav{
  position:sticky;top:0;z-index:50;
  background:rgba(245,238,224,0.92);
  backdrop-filter:blur(8px);
  border-bottom:1px solid var(--border);
  padding:18px 48px;
  display:flex;align-items:center;justify-content:space-between;
}
.brand{
  font-family:var(--serif);
  font-size:22px;font-weight:500;
  color:var(--burgundy);
  letter-spacing:0.15em;
}
.brand em{font-style:normal;font-weight:400}
.nav-links{display:flex;gap:36px}
.nav-links a{
  font-family:var(--sans);
  font-size:12px;font-weight:400;
  color:var(--ink-soft);
  text-transform:uppercase;
  letter-spacing:0.2em;
}
.nav-links a:hover{color:var(--burgundy)}
.nav-links a.active{color:var(--burgundy)}


/* ─── 5. HERO ─────────────────────────────────────────────────────── */

.hero{
  max-width:var(--wrap-hero);margin:0 auto;
  padding:90px 48px 110px;
  display:grid;
  grid-template-columns:1fr 1.1fr;
  gap:80px;
  align-items:center;
  min-height:calc(100vh - 75px);
}
.hero-text{max-width:520px}
.hero h1{
  font-size:clamp(48px,6vw,84px);
  margin-bottom:28px;
}
.hero .tagline{
  font-family:var(--serif);
  font-size:clamp(20px,2.2vw,26px);
  font-weight:400;font-style:italic;
  color:var(--ink-soft);
  margin-bottom:48px;
  line-height:1.4;
}
.hero-portrait{
  position:relative;
  aspect-ratio:4/3;
  overflow:hidden;
}
.hero-portrait img{
  width:100%;height:100%;
  object-fit:cover;
  object-position:center 30%;
}
.hero-portrait::after{
  content:'';
  position:absolute;inset:0;
  box-shadow:inset 0 0 60px 30px var(--bg);
  pointer-events:none;
}


/* ─── 6. ABOUT SECTION ────────────────────────────────────────────── */

.about{
  background:var(--surface);
  border-top:1px solid var(--border);
  border-bottom:1px solid var(--border);
  padding:110px 48px;
}
.about-inner{max-width:var(--wrap-narrow);margin:0 auto}
.about-label{
  font-family:var(--sans);
  font-size:11px;font-weight:500;
  text-transform:uppercase;
  letter-spacing:0.35em;
  color:var(--burgundy);
  margin-bottom:22px;
  text-align:center;
}
.about h2{
  font-size:clamp(34px,4.5vw,54px);
  margin-bottom:48px;
  text-align:center;
  line-height:1.08;
}
.about-body p{
  font-size:17px;
  line-height:1.85;
  color:var(--ink-soft);
  margin-bottom:26px;
}
.about-body p:last-child{margin-bottom:0}
.about-body p.lead{
  font-family:var(--serif);
  font-style:italic;
  font-size:21px;
  line-height:1.55;
  color:var(--ink);
  margin-bottom:36px;
  text-align:center;
  max-width:560px;
  margin-left:auto;
  margin-right:auto;
}
.about-body p strong{
  font-weight:500;
  color:var(--ink);
}
.about-signature{
  font-family:var(--serif);
  font-style:italic;
  font-size:22px;
  color:var(--burgundy);
  text-align:center;
  margin-top:48px;
  letter-spacing:0.05em;
}


/* ─── 7. SECTION HEADERS (reusable across pages) ──────────────────── */

.page-header{
  padding:90px 48px 60px;
  text-align:center;
  background:var(--bg);
}
.page-header h1{
  font-size:clamp(40px,5.5vw,68px);
  margin-bottom:16px;
}
.page-header .lede{
  font-family:var(--serif);
  font-style:italic;
  font-size:20px;
  color:var(--ink-soft);
  max-width:560px;
  margin:0 auto;
  line-height:1.5;
}
.page-header .date-line{
  font-family:var(--sans);
  font-size:12px;font-weight:400;
  text-transform:uppercase;
  letter-spacing:0.3em;
  color:var(--burgundy);
  margin-bottom:24px;
}


/* ─── 8. SIGNS GRID (daily page + signs overview) ─────────────────── */

.signs-grid{
  max-width:var(--wrap-wide);margin:0 auto;
  padding:40px 48px 80px;
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:20px;
}
.sign-card{
  background:var(--card);
  border:1px solid var(--border);
  padding:32px 20px 28px;
  text-align:center;
  text-decoration:none;
  color:var(--ink);
  transition:border-color 0.2s,background 0.2s,transform 0.15s;
  display:block;
}
.sign-card:hover{
  border-color:var(--burgundy);
  background:var(--card-raised);
  color:var(--ink);
  transform:translateY(-2px);
}
.sign-glyph{
  font-family:var(--serif);
  font-size:32px;
  color:var(--burgundy);
  line-height:1;
  margin-bottom:12px;
  display:block;
}
.sign-image{
  width:100%;
  aspect-ratio:1/1;
  object-fit:contain;
  display:block;
  margin:0 auto 16px;
  max-width:140px;
  transition:transform 0.3s ease;
}
.sign-card:hover .sign-image{
  transform:scale(1.05);
}
.sign-name{
  font-family:var(--serif);
  font-size:22px;
  font-weight:500;
  color:var(--ink);
  margin-bottom:4px;
}
.sign-dates{
  font-family:var(--sans);
  font-size:11px;
  letter-spacing:0.2em;
  text-transform:uppercase;
  color:var(--ink-muted);
  margin-bottom:14px;
}
.sign-preview{
  font-family:var(--serif);
  font-style:italic;
  font-size:14px;
  line-height:1.55;
  color:var(--ink-soft);
  max-width:220px;
  margin:0 auto;
}


/* ─── 9. SIGN DETAIL PAGE ─────────────────────────────────────────── */

.sign-detail{
  max-width:var(--wrap-reading);
  margin:0 auto;
  padding:40px 24px 80px;
}
.sign-detail-glyph{
  font-family:var(--serif);
  font-size:96px;
  color:var(--burgundy);
  text-align:center;
  line-height:1;
  margin-bottom:12px;
}
.sign-detail h1{
  font-size:clamp(40px,5.5vw,68px);
  text-align:center;
  margin-bottom:8px;
}
.sign-detail .sign-dates{
  text-align:center;
  margin-bottom:48px;
}
.sign-today{
  background:var(--card);
  border:1px solid var(--border);
  padding:40px 32px;
  margin-bottom:56px;
}
.sign-today .today-label{
  font-family:var(--sans);
  font-size:11px;
  text-transform:uppercase;
  letter-spacing:0.3em;
  color:var(--burgundy);
  margin-bottom:14px;
}
.sign-today h2{
  font-size:26px;
  font-weight:500;
  margin-bottom:18px;
}
.sign-today .today-body{
  font-size:17px;
  line-height:1.85;
  color:var(--ink-soft);
}
.sign-traits h2{
  font-size:28px;
  font-weight:500;
  margin-bottom:20px;
  margin-top:48px;
}
.sign-traits p{
  font-size:17px;
  line-height:1.85;
  color:var(--ink-soft);
  margin-bottom:22px;
}


/* ─── 10. PETA INDEX — summary card + detail ──────────────────────── */

.index-summary{
  max-width:var(--wrap-wide);margin:0 auto;
  padding:20px 48px 60px;
}
.index-summary-card{
  background:var(--card);
  border:1px solid var(--border);
  padding:32px 36px;
  display:grid;
  grid-template-columns:1fr auto;
  gap:32px;
  align-items:center;
  text-decoration:none;
  color:var(--ink);
  transition:border-color 0.2s,background 0.2s;
}
.index-summary-card:hover{
  border-color:var(--burgundy);
  background:var(--card-raised);
  color:var(--ink);
}
.index-summary-label{
  font-family:var(--sans);
  font-size:11px;
  text-transform:uppercase;
  letter-spacing:0.3em;
  color:var(--burgundy);
  margin-bottom:10px;
}
.index-summary-state{
  font-family:var(--serif);
  font-size:36px;
  font-weight:500;
  color:var(--ink);
  margin-bottom:6px;
  line-height:1.1;
}
.index-summary-note{
  font-family:var(--serif);
  font-style:italic;
  font-size:16px;
  color:var(--ink-soft);
  line-height:1.5;
  max-width:420px;
}
.index-summary-arrow{
  font-family:var(--serif);
  font-style:italic;
  font-size:36px;
  color:var(--burgundy);
  flex-shrink:0;
}

/* state tint applied via modifier class */
.index-summary-card.state-clarity         .index-summary-state{color:var(--state-clarity)}
.index-summary-card.state-cocoon          .index-summary-state{color:var(--state-cocoon)}
.index-summary-card.state-pressure-cooker .index-summary-state{color:var(--state-pressure)}
.index-summary-card.state-overload        .index-summary-state{color:var(--state-overload)}
.index-summary-card.state-unsettled       .index-summary-state{color:var(--state-unsettled)}


/* ─── 11. 3-DAY FORECAST STRIP (K-index detail page) ──────────────── */

.forecast-strip{
  max-width:var(--wrap-wide);margin:0 auto;
  padding:40px 48px 20px;
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:20px;
}
.forecast-day{
  background:var(--card);
  border:1px solid var(--border);
  padding:36px 28px;
  text-align:center;
}
.forecast-day-label{
  font-family:var(--sans);
  font-size:11px;
  text-transform:uppercase;
  letter-spacing:0.3em;
  color:var(--burgundy);
  margin-bottom:24px;
}
.forecast-state{
  font-family:var(--serif);
  font-size:32px;
  font-weight:500;
  margin-bottom:8px;
}
.forecast-tone{
  font-family:var(--serif);
  font-style:italic;
  font-size:14px;
  color:var(--ink-soft);
  margin-bottom:24px;
}
.forecast-metrics{
  display:flex;
  justify-content:center;
  gap:24px;
  padding-top:20px;
  border-top:1px solid var(--border);
  font-size:13px;
  color:var(--ink-muted);
}
.forecast-metric strong{
  color:var(--ink);
  font-weight:500;
}
.forecast-day.state-clarity         .forecast-state{color:var(--state-clarity)}
.forecast-day.state-cocoon          .forecast-state{color:var(--state-cocoon)}
.forecast-day.state-pressure-cooker .forecast-state{color:var(--state-pressure)}
.forecast-day.state-overload        .forecast-state{color:var(--state-overload)}
.forecast-day.state-unsettled       .forecast-state{color:var(--state-unsettled)}


/* ─── 12. PURCHASE CARDS (natal, synastry, forecast) ──────────────── */

.purchase-card{
  background:var(--card);
  border:1px solid var(--border);
  padding:48px 40px;
  max-width:560px;
  margin:40px auto;
  text-align:center;
}
.purchase-card .price-label{
  font-family:var(--sans);
  font-size:11px;
  text-transform:uppercase;
  letter-spacing:0.3em;
  color:var(--burgundy);
  margin-bottom:12px;
}
.purchase-card h3{
  font-size:32px;
  font-weight:500;
  margin-bottom:12px;
}
.purchase-card .price{
  font-family:var(--serif);
  font-size:48px;
  font-weight:500;
  color:var(--burgundy);
  margin-bottom:8px;
  line-height:1;
}
.purchase-card .price-note{
  font-family:var(--serif);
  font-style:italic;
  font-size:15px;
  color:var(--ink-soft);
  margin-bottom:32px;
}
.purchase-card .description{
  font-size:16px;
  line-height:1.75;
  color:var(--ink-soft);
  margin-bottom:32px;
  max-width:440px;
  margin-left:auto;
  margin-right:auto;
}
.purchase-card .sample-link{
  display:inline-block;
  font-size:13px;
  color:var(--burgundy-soft);
  border-bottom:1px solid var(--burgundy-soft);
  padding-bottom:2px;
  margin-bottom:28px;
  letter-spacing:0.03em;
}
.purchase-card .sample-link:hover{
  color:var(--burgundy);
  border-bottom-color:var(--burgundy);
}


/* ─── 13. SAMPLE PAGES (proof of quality) ─────────────────────────── */

.sample-banner{
  background:var(--burgundy-tint);
  border-bottom:1px solid var(--border);
  padding:14px 24px;
  text-align:center;
  font-family:var(--sans);
  font-size:13px;
  color:var(--ink-soft);
}
.sample-banner strong{
  color:var(--burgundy);
  font-weight:500;
}
.sample-banner a{
  font-weight:500;
  border-bottom:1px solid var(--burgundy);
  padding-bottom:1px;
  margin-left:8px;
}


/* ─── CTA BUTTONS (shared) ────────────────────────────────────────── */

.cta{
  display:inline-flex;align-items:center;gap:14px;
  background:var(--burgundy);
  color:var(--bg);
  padding:16px 32px;
  font-family:var(--sans);
  font-size:13px;font-weight:500;
  letter-spacing:0.18em;
  text-transform:uppercase;
  text-decoration:none;
  border:none;
  cursor:pointer;
  transition:background 0.2s,transform 0.15s;
}
.cta:hover{
  background:var(--burgundy-deep);
  color:var(--bg);
  transform:translateX(3px);
}
.cta-arrow{
  font-family:var(--serif);
  font-size:18px;
  font-style:italic;
}

.cta-ghost{
  display:inline-flex;align-items:center;gap:10px;
  background:transparent;
  color:var(--burgundy);
  padding:14px 28px;
  font-family:var(--sans);
  font-size:12px;font-weight:500;
  letter-spacing:0.2em;
  text-transform:uppercase;
  text-decoration:none;
  border:1px solid var(--burgundy);
  transition:background 0.2s;
}
.cta-ghost:hover{
  background:var(--burgundy);
  color:var(--bg);
}


/* ─── 14. FOOTER ──────────────────────────────────────────────────── */

footer.site-footer{
  padding:60px 48px 48px;
  max-width:var(--wrap-wide);margin:0 auto;
  text-align:center;
}
.footer-ornament{
  font-family:var(--serif);
  font-size:22px;
  color:var(--burgundy);
  margin-bottom:24px;
  letter-spacing:0.6em;
  padding-left:0.6em;
  opacity:0.7;
}
.disclaimer{
  font-family:var(--serif);
  font-style:italic;
  font-size:15px;
  color:var(--ink-soft);
  max-width:580px;
  margin:0 auto 28px;
  line-height:1.7;
}
.footer-meta{
  font-size:12px;
  color:var(--ink-muted);
  letter-spacing:0.05em;
}
.footer-meta a{
  color:var(--burgundy-soft);
  border-bottom:1px solid transparent;
}
.footer-meta a:hover{
  border-bottom-color:var(--burgundy-soft);
  color:var(--burgundy);
}


/* ─── 15. RESPONSIVE ──────────────────────────────────────────────── */

@media(max-width:960px){
  nav.site-nav{padding:14px 20px}
  .nav-links{gap:18px}
  .nav-links a{font-size:11px;letter-spacing:0.15em}
  .brand{font-size:18px}

  .hero{
    grid-template-columns:1fr;
    padding:50px 32px 70px;
    gap:48px;
    min-height:auto;
  }
  .hero-portrait{order:-1;max-height:50vh;aspect-ratio:16/10}
  .hero-text{max-width:100%}
  .hero h1{font-size:clamp(40px,10vw,64px)}

  .signs-grid{
    grid-template-columns:repeat(3,1fr);
    padding:30px 24px 60px;
  }

  .forecast-strip{
    grid-template-columns:1fr;
    padding:30px 24px 20px;
  }

  .index-summary{padding:20px 24px 40px}
  .index-summary-card{
    grid-template-columns:1fr;
    text-align:center;
    padding:28px 24px;
  }
  .index-summary-arrow{display:none}

  .page-header{padding:60px 24px 40px}
}

@media(max-width:640px){
  .about{padding:72px 24px}
  .about-body p{font-size:16px;line-height:1.75}
  .about-body p.lead{font-size:19px}

  .signs-grid{grid-template-columns:repeat(2,1fr);gap:14px}
  .sign-card{padding:22px 18px}

  .purchase-card{padding:36px 28px;margin:30px 20px}
  .purchase-card h3{font-size:26px}
  .purchase-card .price{font-size:40px}
}

@media(max-width:540px){
  .hero{padding:40px 24px 56px;gap:36px}
  footer.site-footer{padding:40px 24px 32px}
}
