/* Error pages (401/403/404/500).
   Keep this file ASCII-only for safety across mixed-encoding pages. */

body {
  margin: 0;
  color: var(--jakka-text, #111827);
  font-family: var(--jakka-font-sans, system-ui, -apple-system, "Segoe UI", Roboto, "Noto Sans JP", "Hiragino Sans", "Yu Gothic", Meiryo, sans-serif);
  line-height: 1.65;
  background: linear-gradient(180deg, var(--jakka-accent-soft, #fff7ed) 0%, var(--jakka-bg, #ffffff) 60%);
  -webkit-text-size-adjust: 100%;
}

a {
  color: var(--jakka-link, #c2410c);
}

a:visited {
  color: var(--jakka-link, #c2410c);
}

a:hover {
  text-decoration: underline;
}

main.error-page {
  max-width: var(--jakka-container, 1100px);
  margin: 1rem auto 3rem;
  padding: 1.1rem 1rem;
  background: var(--jakka-surface, #ffffff);
  border: 1px solid var(--jakka-border, #eee);
  border-radius: var(--jakka-radius-3, 18px);
  box-shadow: 0 14px 44px rgba(17, 24, 39, 0.12);
}

@media (min-width: 720px) {
  main.error-page {
    padding: 1.5rem 1.6rem;
  }
}

main.error-page > :first-child {
  margin-top: 0;
}

main.error-page > :last-child {
  margin-bottom: 0;
}

main.error-page h1 {
  margin: 0 0 0.5rem;
  font-size: clamp(1.6rem, 3.2vw, 2.25rem);
  line-height: 1.15;
  letter-spacing: -0.02em;
}

main.error-page h1::after {
  content: "";
  display: block;
  width: 4.25rem;
  height: 0.35rem;
  background: var(--jakka-accent, #ffcd32);
  border-radius: 999px;
  margin-top: 0.75rem;
}

main.error-page h2 {
  margin: 1.25rem 0 0.5rem;
  font-size: 1.2rem;
  letter-spacing: -0.01em;
}

main.error-page h3 {
  margin: 0.75rem 0;
  font-size: 1rem;
}

main.error-page p {
  margin: 0.7rem 0;
  max-width: var(--jakka-prose, 70ch);
}

main.error-page ul,
main.error-page ol {
  margin: 0.6rem 0 1rem;
  padding-left: 1.25rem;
  max-width: var(--jakka-prose, 70ch);
}

main.error-page li {
  margin: 0.25rem 0;
}

main.error-page li::marker {
  color: var(--jakka-accent-ink, #9a3412);
}

main.error-page h3 a,
main.error-page a[onclick*="history.back"] {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 44px;
  padding: 0.45rem 0.95rem;
  border-radius: 999px;
  border: 1px solid var(--jakka-chip-border, #ddd);
  background: var(--jakka-chip-bg, #fafafa);
  color: var(--jakka-text, #111827);
  text-decoration: none;
  font-weight: 800;
  box-shadow: 0 10px 22px rgba(17, 24, 39, 0.08);
}

main.error-page h3 a:visited,
main.error-page a[onclick*="history.back"]:visited {
  color: var(--jakka-text, #111827);
}

main.error-page h3 a:hover,
main.error-page a[onclick*="history.back"]:hover {
  text-decoration: none;
  filter: brightness(0.97);
}

main.error-page h3 a:focus,
main.error-page h3 a:focus-visible,
main.error-page a[onclick*="history.back"]:focus,
main.error-page a[onclick*="history.back"]:focus-visible {
  outline: none;
  box-shadow: var(--jakka-focus-ring, 0 0 0 3px rgba(194, 65, 12, 0.35));
}

main.error-page img {
  max-width: 100%;
  height: auto;
  border-radius: 10px;
}

main.error-page table {
  width: 100%;
  max-width: 56rem;
  margin: 0.85rem 0 1.25rem;
  border: 1px solid var(--jakka-border-strong, #ccc);
  border-radius: var(--jakka-radius-2, 14px);
  border-spacing: 0;
  background: var(--jakka-surface, #ffffff);
}

main.error-page th,
main.error-page td {
  padding: 0.65rem 0.75rem;
  border-bottom: 1px solid var(--jakka-border, #eee);
  vertical-align: top;
}

main.error-page tr:last-child th,
main.error-page tr:last-child td {
  border-bottom: none;
}

main.error-page th {
  background: var(--jakka-surface-soft, #f3f3f3);
  text-align: left;
}

@media (max-width: 719px) {
  main.error-page table {
    display: block;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
  }
}

