/* Kingdom Joy Games — vintage carnival / circus poster aesthetic */
:root {
  --cream: #f6ead1;
  --cream-2: #ecdba6;
  --tomato: #c1342a;
  --tomato-2: #8e1e15;
  --gold: #e0b53a;
  --ink: #1a1208;
  --ink-soft: #5c4a2a;
  --display: 'Alfa Slab One', 'Rockwell', serif;
  --body: 'Sansita', Georgia, serif;
}
* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; background: var(--cream); color: var(--ink); font-family: var(--body); font-size: 17px; line-height: 1.65; -webkit-font-smoothing: antialiased; }
body {
  background-image:
    repeating-linear-gradient(90deg, transparent 0 32px, rgba(193,52,42,0.05) 32px 64px);
}
a { color: var(--tomato); text-decoration: none; font-weight: 700; }
a:hover { color: var(--ink); }
.wrap { max-width: 1180px; margin: 0 auto; padding: 0 28px; }
.wrap-narrow { max-width: 760px; margin: 0 auto; padding: 0 28px; }

header.kj-top { display: flex; justify-content: space-between; align-items: center; padding: 24px 0; flex-wrap: wrap; gap: 16px; border-bottom: 6px double var(--tomato); }
.kj-mark { display: flex; align-items: center; gap: 14px; }
.kj-medal { width: 56px; height: 56px; background: var(--tomato); color: var(--gold); border-radius: 50%; display: flex; align-items: center; justify-content: center; font-family: var(--display); font-size: 22px; border: 4px solid var(--gold); box-shadow: 0 0 0 2px var(--tomato); }
.kj-name { font-family: var(--display); font-size: 22px; color: var(--ink); letter-spacing: 0.02em; line-height: 1.1; }
.kj-name .sub { display: block; font-family: var(--body); font-style: italic; font-size: 12px; color: var(--ink-soft); letter-spacing: 0.16em; text-transform: uppercase; margin-top: 4px; }
nav.kj-nav a { margin-left: 24px; font-family: var(--display); font-size: 12px; letter-spacing: 0.24em; text-transform: uppercase; color: var(--tomato-2); }
nav.kj-nav a:hover { color: var(--ink); }

/* Hero — circus marquee */
section.kj-hero { padding: 64px 0; text-align: center; position: relative; }
.kj-hero .arch { font-family: var(--body); font-style: italic; font-size: 22px; color: var(--tomato); margin-bottom: 12px; letter-spacing: 0.16em; }
.kj-hero h1 { font-family: var(--display); font-size: clamp(60px, 11vw, 140px); line-height: 0.95; margin: 0 0 16px; text-transform: uppercase; color: var(--ink); }
.kj-hero h1 em { font-style: italic; color: var(--tomato); }
.kj-hero h1 .gold { color: var(--gold); -webkit-text-stroke: 2px var(--ink); }
.kj-hero .star-row { font-size: 28px; color: var(--gold); letter-spacing: 0.4em; margin: 16px 0 24px; }
.kj-hero p.lead { font-size: 20px; max-width: 600px; margin: 0 auto; color: var(--ink-soft); font-style: italic; }
.kj-hero .ribbon { display: inline-block; background: var(--tomato); color: var(--cream); padding: 14px 32px; font-family: var(--display); font-size: 18px; letter-spacing: 0.28em; text-transform: uppercase; margin-top: 32px; border: 3px solid var(--ink); position: relative; }

/* Section */
section.kj-section { padding: 72px 0; }
.kj-eyebrow { font-family: var(--body); font-style: italic; font-size: 22px; color: var(--tomato); text-align: center; margin-bottom: 8px; letter-spacing: 0.08em; }
section.kj-section h2 { font-family: var(--display); font-size: clamp(40px, 6vw, 76px); margin: 0 0 16px; text-transform: uppercase; text-align: center; line-height: 1; color: var(--ink); }
section.kj-section h2 em { color: var(--tomato); font-style: italic; }
section.kj-section p.lead { text-align: center; font-size: 19px; max-width: 60ch; margin: 0 auto 32px; color: var(--ink-soft); font-style: italic; }

/* Games — poster strips */
.poster-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; margin-top: 32px; }
@media (max-width: 1000px) { .poster-grid { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 720px)  { .poster-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 480px)  { .poster-grid { grid-template-columns: 1fr; } }
.poster { background: var(--cream-2); border: 3px solid var(--ink); padding: 18px 14px; text-align: center; box-shadow: 4px 4px 0 var(--tomato); transition: all .15s ease; }
.poster:hover { transform: translate(-2px,-2px); box-shadow: 6px 6px 0 var(--tomato); }
.poster .stamp { font-family: var(--display); font-size: 11px; letter-spacing: 0.24em; color: var(--tomato); margin-bottom: 4px; text-transform: uppercase; }
.poster h3 { font-family: var(--display); font-size: 15px; line-height: 1.15; margin: 0 0 4px; text-transform: uppercase; color: var(--ink); }
.poster .alt { font-family: var(--body); font-style: italic; font-size: 12px; color: var(--ink-soft); }

/* About */
.about-card { background: var(--tomato); color: var(--cream); padding: 56px; margin: 32px 0; text-align: center; border: 6px double var(--gold); }
.about-card h2 { color: var(--cream); }
.about-card h2 em { color: var(--gold); }
.about-card p { font-size: 19px; max-width: 60ch; margin: 0 auto; color: var(--cream); font-style: italic; }
.about-card .stars { font-size: 24px; color: var(--gold); letter-spacing: 0.4em; margin-bottom: 16px; }

/* Contact */
.contact-card { text-align: center; padding: 56px; border-top: 6px double var(--tomato); border-bottom: 6px double var(--tomato); margin: 24px 0; }
.contact-card h3 { font-family: var(--display); font-size: 40px; margin: 0 0 12px; text-transform: uppercase; color: var(--ink); }
.contact-card a.mail { font-family: var(--body); font-style: italic; font-size: 22px; color: var(--tomato); border-bottom: 2px dashed var(--tomato); padding-bottom: 4px; }

footer.kj-foot { padding: 48px 0; text-align: center; color: var(--ink-soft); font-size: 14px; font-style: italic; }
footer.kj-foot .star-row { font-size: 18px; color: var(--gold); letter-spacing: 0.4em; margin-bottom: 8px; }
footer.kj-foot a { color: var(--tomato); margin: 0 10px; font-weight: 700; }

/* Legal */
.legal-page { padding: 32px 0 96px; }
.legal-page .legal-eyebrow { font-family: var(--body); font-style: italic; font-size: 22px; color: var(--tomato); text-align: center; margin-bottom: 6px; }
.legal-page h1 { font-family: var(--display); font-size: clamp(44px, 7vw, 84px); text-align: center; text-transform: uppercase; margin: 0 0 16px; color: var(--ink); line-height: 1; }
.legal-page .back-link { display: block; text-align: center; font-style: italic; font-size: 15px; color: var(--ink-soft); margin-bottom: 32px; }
.legal-page .legal-body { font-size: 16px; line-height: 1.78; color: var(--ink); margin-top: 24px; border-top: 6px double var(--tomato); padding-top: 32px; }
.legal-page .legal-body h2, .legal-page .legal-body h3, .legal-page .legal-body h4 { font-family: var(--display); color: var(--ink); font-weight: 400; text-transform: uppercase; margin: 1.6em 0 0.4em; line-height: 1.15; }
.legal-page .legal-body h2 { font-size: 26px; color: var(--tomato); }
.legal-page .legal-body h3 { font-size: 20px; }
.legal-page .legal-body h4 { font-size: 16px; }
.legal-page .legal-body p { margin: 0 0 1em; }
.legal-page .legal-body strong { color: var(--tomato); }
.legal-page .legal-body a { border-bottom: 1px solid var(--gold); }
.legal-page .legal-body ul, .legal-page .legal-body ol { padding-left: 1.4em; margin: 0 0 1em; }
.legal-page .legal-body li { margin-bottom: 0.4em; }
.legal-page .legal-body table { width: 100%; border-collapse: collapse; margin: 1.5em 0; font-size: 14px; border: 3px solid var(--ink); }
.legal-page .legal-body th, .legal-page .legal-body td { border: 1px solid var(--ink); padding: 10px 12px; vertical-align: top; text-align: left; }
.legal-page .legal-body th { background: var(--cream-2); font-family: var(--display); font-size: 13px; text-transform: uppercase; }
