/* Penrose Park: public website + legal pages.
   Calm, paper-and-sage brand palette mirrored from @ppp/theme. */
:root {
  --ink: #1A1F1A;
  --ink-soft: #3D4A3D;
  --ink-muted: #7A857A;
  --paper: #FAF9F4;
  --paper-soft: #F2F0E8;
  --paper-deep: #E8E5D9;
  --accent: #2D5A3D;
  --accent-soft: #5A8A6A;
  --gold: #C9A85C;
  --maxw: 760px;
}
* { box-sizing: border-box; margin: 0; padding: 0; }
html { -webkit-text-size-adjust: 100%; overflow-x: hidden; }
body {
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
  background: var(--paper);
  color: var(--ink);
  line-height: 1.65;
  font-size: 17px;
  -webkit-font-smoothing: antialiased;
  /* Sticky footer: keep the footer at the bottom of the viewport even when the
     page has little content (the landing page). */
  min-height: 100vh;
  display: flex;
  flex-direction: column;
}
a { color: var(--accent); text-decoration: none; }
a:hover { text-decoration: underline; }

.topbar { border-bottom: 1px solid var(--paper-deep); background: var(--paper); }
.topbar-inner {
  max-width: var(--maxw); margin: 0 auto; padding: 18px 24px;
  display: flex; align-items: center; gap: 10px;
}
.mark { width: 14px; height: 14px; border-radius: 4px; background: var(--ink); transform: rotate(45deg); }
.wordmark { font-weight: 700; letter-spacing: -0.3px; font-size: 17px; }
.topbar-inner nav { margin-left: auto; display: flex; gap: 18px; font-size: 14px; }
.topbar-inner nav a { color: var(--ink-muted); }

main { max-width: var(--maxw); margin: 0 auto; padding: 48px 24px 80px; flex: 1 0 auto; width: 100%; }

/* Landing */
.hero { text-align: center; padding: 64px 0 40px; }
.hero h1 { font-size: 40px; letter-spacing: -1px; line-height: 1.1; }
.hero p { color: var(--ink-soft); font-size: 19px; margin-top: 14px; }
.games { display: flex; flex-wrap: wrap; gap: 12px; justify-content: center; margin-top: 36px; }
.game-chip {
  border: 1px solid var(--paper-deep); border-radius: 999px;
  padding: 8px 16px; font-size: 14px; color: var(--ink-soft); background: var(--paper-soft);
}

/* Partner / direct-sold advertising card */
.partners {
  max-width: 560px; margin: 8px auto 0; text-align: center;
  background: var(--paper-soft); border: 1px solid var(--paper-deep);
  border-radius: 16px; padding: 28px 30px;
}
.partners h2 { font-size: 21px; letter-spacing: -0.3px; }
.partners p { color: var(--ink-soft); font-size: 16px; margin-top: 10px; }

/* Landing flower framing — two tall blooms growing up the side walls, their
   stems tight against the top of the footer (anchored via bottom:100% from the
   footer, which spans the full viewport width). Decorative; sit behind the
   content. */
.landing main { position: relative; z-index: 1; }
.landing footer { position: relative; }
.landing .blooms {
  position: absolute; left: 0; right: 0; bottom: 100%;
  height: 0; z-index: 0; pointer-events: none;
}
.landing .bloom {
  position: absolute; bottom: 0; display: block; width: auto;
}
/* The two blooms are intentionally different sizes; the left one is smaller. */
.landing .bloom-left { left: 0; height: clamp(330px, 63vh, 710px); }
.landing .bloom-right { right: 4%; height: clamp(380px, 74vh, 840px); }

@media (max-width: 900px) {
  .landing .bloom-left { height: clamp(250px, 38vh, 400px); opacity: 0.5; }
  .landing .bloom-right { height: clamp(290px, 45vh, 470px); right: 2%; opacity: 0.5; }
}
@media (max-width: 560px) {
  .landing .bloom-left { height: 200px; left: -34px; opacity: 0.4; }
  .landing .bloom-right { height: 235px; right: -28px; opacity: 0.4; }
}

/* Legal docs */
.doc h1 { font-size: 30px; letter-spacing: -0.5px; }
.doc .updated { color: var(--ink-muted); font-size: 14px; margin-top: 6px; margin-bottom: 8px; }
.doc .intro { color: var(--ink-soft); margin: 18px 0 28px; }
.doc h2 {
  font-size: 19px; margin-top: 36px; margin-bottom: 10px; letter-spacing: -0.2px;
  padding-top: 18px; border-top: 1px solid var(--paper-deep);
}
.doc h3 { font-size: 16px; margin-top: 22px; margin-bottom: 6px; color: var(--ink-soft); }
.doc p { margin: 10px 0; }
.doc ul { margin: 10px 0 10px 22px; }
.doc li { margin: 6px 0; }
.doc .todo {
  background: #FBF1DD; border: 1px solid var(--gold); color: #6f5410;
  padding: 1px 6px; border-radius: 5px; font-size: 0.92em; font-weight: 600;
}
.doc .callout {
  background: var(--paper-soft); border: 1px solid var(--paper-deep);
  border-radius: 12px; padding: 16px 18px; margin: 22px 0; font-size: 15px; color: var(--ink-soft);
}
.toc { background: var(--paper-soft); border-radius: 12px; padding: 16px 20px; margin: 24px 0 8px; }
.toc strong { font-size: 13px; text-transform: uppercase; letter-spacing: 0.8px; color: var(--ink-muted); }
.toc ol { margin: 8px 0 0 20px; font-size: 15px; }

footer {
  border-top: 1px solid var(--paper-deep); margin-top: 40px;
  background: var(--paper-soft); flex-shrink: 0;
}
footer .inner {
  max-width: var(--maxw); margin: 0 auto; padding: 28px 24px;
  font-size: 13px; color: var(--ink-muted); display: flex; flex-wrap: wrap; gap: 6px 18px;
  align-items: center;
}
footer .company { color: var(--ink-soft); }
footer nav { margin-left: auto; display: flex; gap: 16px; }

@media (max-width: 520px) {
  body { font-size: 16px; }
  .hero h1 { font-size: 32px; }
  .partners { padding: 22px 20px; }
  .partners h2 { font-size: 19px; }
}
