/* ==========================================================================
   Learn a Rhyme — storybook design system
   ========================================================================== */

:root {
  /* Paper & ink */
  --paper: #f7f1e3;
  --paper-deep: #efe6d0;
  --card: #fffdf6;
  --ink: #3d3428;
  --ink-soft: #6b5f4d;
  --line: #d9cdb4;

  /* Accents */
  --gold: #b98c2e;
  --gold-soft: #d6b566;

  /* Category hues (muted, painterly) */
  --nursery: #a05c65;      /* dusty rose */
  --twister: #4a7a6f;      /* sage teal */
  --limerick: #7a6899;     /* faded violet */
  --counting: #b07a3c;     /* warm ochre */

  --serif-display: "Playfair Display", "Georgia", serif;
  --serif-body: "Lora", "Georgia", serif;
}

* { box-sizing: border-box; }

html { font-size: 17px; }

body {
  margin: 0;
  background: var(--paper);
  background-image: radial-gradient(ellipse at top, #faf5e9 0%, var(--paper) 60%);
  color: var(--ink);
  font-family: var(--serif-body);
  line-height: 1.7;
}

a { color: var(--gold); text-decoration-color: var(--gold-soft); }
a:hover { color: var(--ink); }

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

/* --------------------------------------------------------------------------
   Header / nav
   -------------------------------------------------------------------------- */

.site-header {
  border-bottom: 1px solid var(--line);
  background: var(--card);
}

.site-header .inner {
  max-width: 1060px;
  margin: 0 auto;
  padding: 0.9rem 1.25rem;
  display: flex;
  flex-wrap: wrap;
  align-items: baseline;
  gap: 0.75rem 2rem;
}

.brand {
  font-family: var(--serif-display);
  font-weight: 700;
  font-size: 1.45rem;
  letter-spacing: 0.02em;
  color: var(--ink);
  text-decoration: none;
}
.brand em { color: var(--gold); font-style: italic; }

.site-nav { display: flex; flex-wrap: wrap; gap: 0.25rem 1.4rem; }

.site-nav a {
  font-family: var(--serif-display);
  font-size: 0.98rem;
  color: var(--ink-soft);
  text-decoration: none;
  padding-bottom: 2px;
  border-bottom: 2px solid transparent;
}
.site-nav a:hover { color: var(--ink); border-bottom-color: var(--gold-soft); }
.site-nav a.is-nursery:hover  { border-bottom-color: var(--nursery); }
.site-nav a.is-twister:hover  { border-bottom-color: var(--twister); }
.site-nav a.is-limerick:hover { border-bottom-color: var(--limerick); }
.site-nav a.is-counting:hover { border-bottom-color: var(--counting); }

/* --------------------------------------------------------------------------
   Layout
   -------------------------------------------------------------------------- */

main { max-width: 1060px; margin: 0 auto; padding: 2.25rem 1.25rem 4rem; }

.prose { max-width: 720px; margin: 0 auto; }

h1, h2, h3 {
  font-family: var(--serif-display);
  color: var(--ink);
  line-height: 1.25;
  font-weight: 700;
}

h1 { font-size: 2.5rem; margin: 0 0 0.5rem; }
h2 { font-size: 1.55rem; margin: 2.5rem 0 0.75rem; }

.kicker {
  font-family: var(--serif-display);
  font-style: italic;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  font-size: 0.78rem;
  font-weight: 400;
}
.kicker a { text-decoration: none; }
.kicker.is-nursery, .kicker.is-nursery a { color: var(--nursery); }
.kicker.is-twister, .kicker.is-twister a { color: var(--twister); }
.kicker.is-limerick, .kicker.is-limerick a { color: var(--limerick); }
.kicker.is-counting, .kicker.is-counting a { color: var(--counting); }

.flourish {
  text-align: center;
  color: var(--gold-soft);
  font-size: 1.3rem;
  letter-spacing: 0.6em;
  margin: 2.25rem 0;
  user-select: none;
}

/* --------------------------------------------------------------------------
   Rhyme page pieces
   -------------------------------------------------------------------------- */

.rhyme-hero {
  display: block;
  margin: 1.5rem auto 2rem;
  border-radius: 6px;
  box-shadow: 0 10px 30px rgba(61, 52, 40, 0.18);
}

/* The rhyme itself is the hero of the page: a framed verse plate,
   set upright and large for maximum readability. */
.verse {
  background: var(--card);
  border: 1px solid var(--line);
  outline: 4px double var(--gold-soft);
  outline-offset: -10px;
  border-radius: 6px;
  box-shadow: 0 8px 24px rgba(61, 52, 40, 0.10);
  padding: 2.5rem 2rem;
  font-family: var(--serif-body);
  font-style: normal;
  font-weight: 500;
  font-size: 1.45rem;
  line-height: 1.9;
  text-align: center;
  color: var(--ink);
  margin: 2rem auto;
  max-width: 36em;
}

.verse .stanza { margin: 0 0 1.6em; }
.verse .stanza:last-child { margin-bottom: 0; }

/* Smaller framed treatment for supplementary (extra) verses */
.verse.verse-extra {
  font-size: 1.15rem;
  padding: 1.75rem 1.5rem;
  outline: none;
}

.note {
  background: var(--card);
  border: 1px solid var(--line);
  border-radius: 6px;
  padding: 1rem 1.35rem;
  font-size: 0.95rem;
  color: var(--ink-soft);
}

.download-box {
  background: var(--card);
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 1.5rem;
  margin: 2.5rem 0;
  display: flex;
  gap: 1.5rem;
  align-items: center;
  flex-wrap: wrap;
}
.download-box img {
  width: 150px;
  border: 1px solid var(--line);
  border-radius: 4px;
  background: #fff;
}
.download-box .btn {
  display: inline-block;
  font-family: var(--serif-display);
  background: var(--gold);
  color: #fff;
  text-decoration: none;
  padding: 0.6rem 1.3rem;
  border-radius: 4px;
  margin-top: 0.5rem;
}
.download-box .btn:hover { background: var(--ink); color: #fff; }

/* Coloring page gallery */
.coloring-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
  gap: 1.25rem;
  margin: 1.5rem 0;
}

.coloring-card {
  background: #fff;
  border: 1px solid var(--line);
  border-radius: 8px;
  overflow: hidden;
  text-decoration: none;
  color: var(--ink);
  display: flex;
  flex-direction: column;
  transition: transform 0.15s ease, box-shadow 0.15s ease;
}
.coloring-card:hover {
  transform: translateY(-3px);
  box-shadow: 0 12px 28px rgba(61, 52, 40, 0.16);
}
.coloring-card img { display: block; width: 100%; aspect-ratio: 3 / 4; object-fit: cover; }
.coloring-card span {
  display: block;
  font-family: var(--serif-display);
  font-size: 0.9rem;
  text-align: center;
  padding: 0.6rem 0.5rem;
  border-top: 1px solid var(--line);
}

/* Coloring book promo */
.book-promo {
  background: var(--paper-deep);
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: 1.75rem 2rem;
  margin: 2.5rem 0;
  text-align: center;
}
.book-promo h3 {
  font-family: var(--serif-display);
  font-size: 1.35rem;
  margin: 0 0 0.5rem;
}
.book-promo p {
  color: var(--ink-soft);
  margin: 0 0 1rem;
  font-size: 0.98rem;
}
.book-promo .btn {
  display: inline-block;
  font-family: var(--serif-display);
  background: var(--gold);
  color: #fff;
  text-decoration: none;
  padding: 0.6rem 1.5rem;
  border-radius: 4px;
}
.book-promo .btn:hover { background: var(--ink); color: #fff; }

/* Share buttons */
.share-row {
  display: flex;
  flex-wrap: wrap;
  gap: 0.6rem;
  align-items: center;
  margin: 1rem 0 2rem;
}
.share-row .share-label {
  font-family: var(--serif-display);
  font-style: italic;
  color: var(--ink-soft);
  font-size: 0.95rem;
  margin-right: 0.25rem;
}
.share-btn {
  display: inline-block;
  font-family: var(--serif-display);
  font-size: 0.9rem;
  text-decoration: none;
  color: #fff;
  padding: 0.45rem 1rem;
  border-radius: 4px;
}
.share-btn:hover { color: #fff; opacity: 0.85; }
.share-btn.pinterest { background: #b7081b; }
.share-btn.facebook  { background: #33527e; }
.share-btn.x         { background: #3d3428; }

.related { list-style: none; padding: 0; }
.related li { margin: 0.35rem 0; }

/* --------------------------------------------------------------------------
   Cards (home + category indexes)
   -------------------------------------------------------------------------- */

.card-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(230px, 1fr));
  gap: 1.5rem;
  margin: 2rem 0;
}

.card {
  background: var(--card);
  border: 1px solid var(--line);
  border-radius: 8px;
  overflow: hidden;
  text-decoration: none;
  color: var(--ink);
  display: flex;
  flex-direction: column;
  transition: transform 0.15s ease, box-shadow 0.15s ease;
}
.card:hover {
  transform: translateY(-3px);
  box-shadow: 0 12px 28px rgba(61, 52, 40, 0.16);
  color: var(--ink);
}
.card img { display: block; width: 100%; aspect-ratio: 4 / 3; object-fit: cover; }
.card .card-body { padding: 0.9rem 1.1rem 1.1rem; }
.card h3 { margin: 0 0 0.3rem; font-size: 1.12rem; }
.card p {
  margin: 0;
  font-size: 0.88rem;
  font-style: italic;
  color: var(--ink-soft);
}

.card.is-nursery  { border-top: 3px solid var(--nursery); }
.card.is-twister  { border-top: 3px solid var(--twister); }
.card.is-limerick { border-top: 3px solid var(--limerick); }
.card.is-counting { border-top: 3px solid var(--counting); }

/* --------------------------------------------------------------------------
   Home
   -------------------------------------------------------------------------- */

.home-hero { text-align: center; margin-bottom: 1rem; }
.home-hero img {
  border-radius: 8px;
  box-shadow: 0 12px 36px rgba(61, 52, 40, 0.2);
}
.home-hero h1 { font-size: 2.9rem; margin-top: 1.75rem; }
.home-hero .tagline {
  font-style: italic;
  color: var(--ink-soft);
  font-size: 1.15rem;
  max-width: 40em;
  margin: 0.5rem auto 0;
}

/* --------------------------------------------------------------------------
   Footer
   -------------------------------------------------------------------------- */

.site-footer {
  border-top: 1px solid var(--line);
  background: var(--paper-deep);
  color: var(--ink-soft);
  font-size: 0.85rem;
  text-align: center;
  padding: 2rem 1.25rem;
}
.site-footer a { color: var(--ink-soft); }

/* --------------------------------------------------------------------------
   Small screens
   -------------------------------------------------------------------------- */

@media (max-width: 640px) {
  h1 { font-size: 1.9rem; }
  .home-hero h1 { font-size: 2.1rem; }
  .verse { font-size: 1.15rem; }
}

