:root {
  --bg-purple: #7B4FE5;
  --orange: #FF5A1F;
  --yellow: #FFC835;
  --ink: #2B1A0E;
  --ink-soft: #8A4B25;
  --card: #FFFBEC;
  --border: 3px solid var(--ink);
  --border-fat: 5px solid var(--ink);
  --shadow: 0 6px 0 var(--ink);
  --font: "Fredoka", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}

* { box-sizing: border-box; }

body {
  margin: 0;
  min-height: 100vh;
  background:
    url("/images/BG-pattern-mixed.svg") repeat,
    var(--bg-purple);
  background-size: 250px auto;
  color: var(--ink);
  font-family: var(--font);
  line-height: 1.55;
  padding: 28px 16px 48px;
}

.legal-shell {
  width: min(920px, 100%);
  margin: 0 auto;
}

.legal-top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 22px;
}

.brand {
  display: flex;
  align-items: center;
  gap: 10px;
  color: var(--card);
  font-weight: 900;
  font-size: 20px;
  text-decoration: none;
  text-shadow: 0 3px 0 var(--ink);
}

.brand img {
  width: 44px;
  height: 44px;
  object-fit: contain;
  filter: drop-shadow(0 3px 0 var(--ink));
}

.back-link {
  background: var(--card);
  color: var(--ink);
  border: var(--border);
  border-radius: 999px;
  box-shadow: 0 3px 0 var(--ink);
  padding: 9px 14px;
  font-weight: 900;
  text-decoration: none;
}

.legal-card {
  background: var(--card);
  border: var(--border-fat);
  border-radius: 30px;
  box-shadow: var(--shadow);
  padding: clamp(22px, 4vw, 42px);
}

h1 {
  margin: 0 0 8px;
  color: var(--yellow);
  font-size: clamp(34px, 7vw, 64px);
  line-height: 0.95;
  text-shadow:
    -2px 0 0 var(--ink),
    2px 0 0 var(--ink),
    0 -2px 0 var(--ink),
    0 2px 0 var(--ink),
    0 5px 0 var(--orange),
    0 8px 0 var(--ink);
}

.meta {
  color: var(--ink-soft);
  font-weight: 800;
  margin-bottom: 22px;
}

h2 {
  margin: 26px 0 8px;
  color: var(--orange);
  font-size: 22px;
  letter-spacing: 0.02em;
  text-transform: uppercase;
}

p, li {
  font-size: 16px;
  font-weight: 650;
}

ul { padding-left: 22px; }

.notice {
  background: #FFE8A5;
  border: var(--border);
  border-radius: 20px;
  box-shadow: 0 4px 0 rgba(43, 26, 14, 0.25);
  padding: 14px 16px;
  font-weight: 800;
}

.doc-nav {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin: 20px 0 0;
}

.doc-nav a {
  background: var(--yellow);
  border: 2px solid var(--ink);
  border-radius: 999px;
  color: var(--ink);
  padding: 8px 11px;
  font-size: 13px;
  font-weight: 900;
  text-decoration: none;
}

a { color: var(--orange); }

@media (max-width: 560px) {
  body { padding: 16px 10px 36px; }
  .legal-top { align-items: flex-start; }
  .back-link { font-size: 13px; }
  .legal-card { border-radius: 24px; }
}
