/* We Joy Play — paper collage / cut-paper scrapbook aesthetic */
:root {
  --cream: #faf6ea;
  --cream-2: #ede4ce;
  --kraft: #c6a373;
  --tomato: #d94534;
  --leaf: #5a8a4a;
  --sky: #4a8cbf;
  --buttery: #f7c84a;
  --ink: #2a1f17;
  --ink-soft: #5c4c3a;
  --display: 'Fraunces', 'Noto Sans JP', 'Noto Sans KR', Georgia, serif;
  --body: 'Schibsted Grotesk', 'Noto Sans JP', 'Noto Sans KR', system-ui, sans-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.7; -webkit-font-smoothing: antialiased; }
body {
  background:
    radial-gradient(circle at 20% 10%, rgba(198,163,115,0.18) 0, transparent 30%),
    radial-gradient(circle at 90% 80%, rgba(217,69,52,0.12) 0, transparent 30%),
    var(--cream);
}
a { color: var(--tomato); text-decoration: none; font-weight: 600; }
a:hover { color: var(--ink); }
.wrap { max-width: 1100px; margin: 0 auto; padding: 0 28px; }
.wrap-narrow { max-width: 760px; margin: 0 auto; padding: 0 28px; }

/* Paper-strip helper */
.tape-strip { display: inline-block; padding: 4px 12px; background: var(--buttery); transform: rotate(-2deg); font-family: var(--body); font-weight: 600; font-size: 12px; letter-spacing: 0.12em; text-transform: uppercase; box-shadow: 0 2px 0 rgba(42,31,23,0.15); }

header.wj-top { display: flex; justify-content: space-between; align-items: center; padding: 28px 0; flex-wrap: wrap; gap: 16px; }
.wj-mark { display: flex; align-items: center; gap: 14px; }
.wj-stamp { width: 52px; height: 56px; background: var(--tomato); color: var(--cream); font-family: var(--display); font-weight: 800; font-size: 20px; display: flex; align-items: center; justify-content: center; transform: rotate(-3deg); position: relative; clip-path: polygon(8% 0, 100% 0, 92% 100%, 0 100%); }
.wj-name { font-family: var(--display); font-weight: 700; font-size: 26px; color: var(--ink); line-height: 1; letter-spacing: -0.01em; }
.wj-name em { font-style: italic; color: var(--tomato); }
.wj-name .sub { display: block; font-family: var(--body); font-weight: 500; font-size: 12px; color: var(--ink-soft); letter-spacing: 0.18em; text-transform: uppercase; margin-top: 4px; }
nav.wj-nav a { margin-left: 24px; font-family: var(--body); font-weight: 600; font-size: 14px; color: var(--ink); }
nav.wj-nav a:hover { color: var(--tomato); }

/* Hero — torn paper card */
section.wj-hero { padding: 56px 0 64px; }
.wj-hero-card {
  background: white;
  padding: 64px 56px;
  position: relative;
  box-shadow: 0 24px 48px rgba(42,31,23,0.10);
  transform: rotate(-0.8deg);
}
.wj-hero-card::before {
  content: ""; position: absolute; top: -8px; left: 32px; width: 80px; height: 20px; background: var(--buttery); transform: rotate(-3deg); box-shadow: 0 2px 0 rgba(42,31,23,0.15);
}
.wj-hero-card::after {
  content: ""; position: absolute; bottom: -8px; right: 32px; width: 100px; height: 18px; background: var(--leaf); transform: rotate(2deg); box-shadow: 0 2px 0 rgba(42,31,23,0.15);
}
.wj-hero-card .tape-strip { margin-bottom: 16px; }
.wj-hero-card h1 { font-family: var(--display); font-weight: 700; font-size: clamp(56px, 8.5vw, 116px); line-height: 0.98; letter-spacing: -0.02em; margin: 0 0 24px; color: var(--ink); }
.wj-hero-card h1 em { font-style: italic; color: var(--tomato); }
.wj-hero-card h1 .sky { color: var(--sky); }
.wj-hero-card p.lead { font-size: 19px; max-width: 520px; color: var(--ink-soft); }
.wj-hero-card .stickers { display: flex; gap: 16px; margin-top: 24px; flex-wrap: wrap; }
.sticker-paper { padding: 8px 14px; background: var(--cream-2); border: 1px dashed var(--kraft); font-family: var(--body); font-weight: 600; font-size: 12px; letter-spacing: 0.08em; color: var(--ink); transform: rotate(-1deg); }
.sticker-paper:nth-child(2) { background: var(--leaf); color: white; border-color: var(--leaf); transform: rotate(1deg); }
.sticker-paper:nth-child(3) { background: var(--sky); color: white; border-color: var(--sky); transform: rotate(-2deg); }

/* Section */
section.wj-section { padding: 72px 0; }
.wj-eyebrow { font-family: var(--display); font-style: italic; font-weight: 500; font-size: 22px; color: var(--tomato); margin-bottom: 4px; }
section.wj-section h2 { font-family: var(--display); font-weight: 700; font-size: clamp(40px, 6vw, 76px); margin: 0 0 16px; line-height: 1; color: var(--ink); letter-spacing: -0.02em; }
section.wj-section h2 em { font-style: italic; color: var(--leaf); }
section.wj-section p.lead { font-size: 18px; max-width: 60ch; color: var(--ink-soft); }

/* Games — scrapbook polaroids */
.scrap-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 28px; margin-top: 40px; }
@media (max-width: 900px) { .scrap-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 540px) { .scrap-grid { grid-template-columns: 1fr; } }
.polaroid {
  background: white; padding: 16px 16px 24px;
  box-shadow: 0 8px 24px rgba(42,31,23,0.10), 0 2px 0 rgba(42,31,23,0.06);
  transition: all .18s ease;
  position: relative;
}
.polaroid:nth-child(odd)  { transform: rotate(-1.4deg); }
.polaroid:nth-child(even) { transform: rotate(1.1deg); }
.polaroid:hover { transform: rotate(0) translateY(-4px); box-shadow: 0 16px 36px rgba(42,31,23,0.16); }
.polaroid::before { content: ""; position: absolute; top: -10px; left: 50%; transform: translateX(-50%) rotate(-3deg); width: 80px; height: 18px; background: rgba(247,200,74,0.7); }
.polaroid .photo { aspect-ratio: 1.2 / 1; background: linear-gradient(135deg, var(--cream-2), var(--kraft)); display: flex; align-items: center; justify-content: center; font-size: 44px; }
.polaroid:nth-child(7n+1) .photo { background: linear-gradient(135deg, #ffd9b3, #ffb380); }
.polaroid:nth-child(7n+2) .photo { background: linear-gradient(135deg, #cde0c0, var(--leaf)); }
.polaroid:nth-child(7n+3) .photo { background: linear-gradient(135deg, #c4dcef, var(--sky)); }
.polaroid:nth-child(7n+4) .photo { background: linear-gradient(135deg, #f5e2a0, var(--buttery)); }
.polaroid:nth-child(7n+5) .photo { background: linear-gradient(135deg, #f0bfb5, var(--tomato)); }
.polaroid:nth-child(7n+6) .photo { background: linear-gradient(135deg, #e6d8c2, var(--kraft)); }
.polaroid:nth-child(7n+7) .photo { background: linear-gradient(135deg, #e5c8f0, #b07cd9); }
.polaroid .caption { padding: 16px 8px 0; }
.polaroid h3 { font-family: var(--display); font-weight: 700; font-size: 19px; margin: 0 0 4px; line-height: 1.2; color: var(--ink); letter-spacing: -0.01em; }
.polaroid .alt { font-family: var(--display); font-style: italic; font-size: 14px; color: var(--ink-soft); }

/* Studio */
.wj-studio { padding: 56px 48px; background: var(--leaf); color: white; margin: 32px 0; position: relative; box-shadow: 0 16px 36px rgba(42,31,23,0.12); transform: rotate(-0.4deg); }
.wj-studio::before { content: ""; position: absolute; top: -12px; right: 48px; width: 64px; height: 20px; background: var(--tomato); transform: rotate(-3deg); }
.wj-studio h2 { color: white; }
.wj-studio h2 em { color: var(--buttery); }
.wj-studio .wj-eyebrow { color: var(--buttery); }
.wj-studio p { font-size: 19px; max-width: 56ch; color: white; margin: 0; }
.wj-studio p + p { margin-top: 12px; opacity: 0.92; }

/* Contact */
.wj-contact { padding: 56px 32px; background: white; box-shadow: 0 16px 36px rgba(42,31,23,0.10); text-align: center; transform: rotate(0.6deg); margin: 24px 0; }
.wj-contact h3 { font-family: var(--display); font-weight: 700; font-size: 40px; margin: 0 0 12px; line-height: 1; color: var(--ink); letter-spacing: -0.02em; }
.wj-contact h3 em { font-style: italic; color: var(--tomato); }
.wj-contact a.mail { font-family: var(--display); font-weight: 600; font-style: italic; font-size: 22px; color: var(--leaf); border-bottom: 1px dashed var(--leaf); padding-bottom: 4px; }

footer.wj-foot { padding: 48px 0; text-align: center; color: var(--ink-soft); font-size: 14px; }
footer.wj-foot a { color: var(--tomato); margin: 0 10px; font-weight: 600; }
footer.wj-foot .row { font-family: var(--display); font-style: italic; font-size: 18px; color: var(--leaf); margin-bottom: 8px; }

/* Legal */
.legal-page { padding: 48px 0 96px; }
.legal-page .legal-eyebrow { font-family: var(--display); font-style: italic; font-weight: 500; font-size: 22px; color: var(--tomato); margin-bottom: 4px; }
.legal-page h1 { font-family: var(--display); font-weight: 700; font-size: clamp(48px, 7vw, 92px); margin: 0 0 16px; line-height: 1; color: var(--ink); letter-spacing: -0.02em; }
.legal-page h1 em { font-style: italic; color: var(--leaf); }
.legal-page .back-link { font-family: var(--body); font-weight: 600; font-size: 14px; color: var(--tomato); }
.legal-page .legal-body { font-size: 16px; line-height: 1.78; color: var(--ink); margin-top: 32px; background: white; padding: 32px; box-shadow: 0 8px 24px rgba(42,31,23,0.10); border-top: 4px solid var(--tomato); max-width: 70ch; }
.legal-page .legal-body h2, .legal-page .legal-body h3, .legal-page .legal-body h4 { font-family: var(--display); color: var(--ink); font-weight: 700; margin: 1.8em 0 0.4em; line-height: 1.15; letter-spacing: -0.01em; }
.legal-page .legal-body h2 { font-size: 28px; color: var(--tomato); }
.legal-page .legal-body h3 { font-size: 22px; color: var(--leaf); font-style: italic; }
.legal-page .legal-body h4 { font-size: 17px; color: var(--sky); }
.legal-page .legal-body p { margin: 0 0 1em; }
.legal-page .legal-body strong { background: var(--buttery); padding: 0 4px; }
.legal-page .legal-body a { border-bottom: 1px dashed var(--leaf); }
.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; }
.legal-page .legal-body th, .legal-page .legal-body td { border: 1px solid var(--cream-2); padding: 10px 12px; vertical-align: top; text-align: left; }
.legal-page .legal-body th { background: var(--cream); font-family: var(--display); font-weight: 700; font-size: 14px; }
