/* =====================================================
   Legal Center — Unified / Calm / Minimal / Polished
   ===================================================== */

/* === Global body & container === */
body {
  line-height: 1.6;
  background-color: #fff;
  margin: 0;
  margin-top: 10%;
  padding: 0;
}

.legal-wrapper {
  font-family: "Helvetica Neue", Helvetica, Arial, sans-serif;
  color: #1a1a1a;
  max-width: 980px;
  margin: 2rem auto;
  padding: 0 1rem 1rem;
}

/* === Headings === */
.legal-wrapper h1 {
  font-size: 2.5rem;
  font-weight: 700;
  margin-bottom: 1rem;
}

.legal-wrapper h2 {
  font-size: 1.5rem;
  font-weight: 600;
  margin-top: 2rem;
  margin-bottom: 0.75rem;
}

.legal-wrapper h3 {
  font-size: 1.125rem;
  font-weight: 500;
  margin-top: 1.5rem;
  margin-bottom: 0.5rem;
}

/* === Paragraphs, lists, links === */
.legal-wrapper p {
  margin-bottom: 1rem;
  font-size: 0.95rem;
  line-height: 1.6;
}

.legal-wrapper ul {
  padding-left: 1.5rem;
  margin-bottom: 1rem;
  list-style: disc;
}

.legal-wrapper li {
  margin-bottom: 0.5rem;
}

.legal-wrapper a,
.legal-wrapper a:visited {
  color: currentColor;
  text-decoration: none;
}

.legal-wrapper a:hover,
.legal-wrapper a:focus-visible {
  text-decoration: underline;
}

/* === Meta & warnings === */
.legal-meta {
  font-size: 0.875rem;
  color: #555;
  margin-bottom: 2rem;
}

.legal-warning {
  background-color: #fff4e5;
  border-left: 4px solid #ffa500;
  padding: 1rem;
  margin-bottom: 2rem;
  font-size: 0.95rem;
}

/* === Legal Index Link === */
.legal-index-link {
  margin-bottom: 1rem;
  font-size: 0.95rem;
}

.legal-index-link a {
  color: #1a73e8;
  text-decoration: underline;
}

.legal-index-link a:hover {
  color: #155ab6;
}


/* === Collapsible Legal Sections === */
.legal-section {
  margin-bottom: 2.5rem;
  margin-top: 10%;
  border-top: 1px solid #e0e0e0;
  padding-top: 0rem;
}

.legal-section-title {
  font-size: 1.25rem;
  font-weight: 600;
  margin-bottom: 0.5rem;
}

.legal-section-2 {
  margin-bottom: 2rem;
  border-top: 1px solid #e0e0e0;
  padding-top: 0rem;
}

.legal-list .legal-item {
  margin-bottom: 1rem;
  border-bottom: 1px solid rgba(0,0,0,0.08);
  padding: 0.75rem 0;
}

.legal-item:last-child {
  border-bottom: none;
}


/* === Bag Notice & Governing Language === */
.legal-section p {
  margin-bottom: 0.75rem;
  font-size: 0.95rem;
  color: #333;
}

/* === Tables === */
.legal-table {
  width: 100%;
  border-collapse: collapse;
  margin: 0.75rem 0 1.5rem 0;
  font-size: 0.9rem;
}

.legal-table th,
.legal-table td {
  border: 1px solid rgba(0,0,0,0.15);
  padding: 0.5rem 0.6rem;
}

.legal-table th {
  background: rgba(0,0,0,0.08);
  font-weight: 600;
}

/* === Accessibility improvements === */
.legal-wrapper a {
  outline: 2px solid transparent;
}

.legal-wrapper a:focus {
  outline: 2px solid #1a73e8;
  outline-offset: 2px;
}

/* === i18n / multi-language support === */
html[lang="ja"] .legal-wrapper,
html[lang="kr"] .legal-wrapper,
html[lang="cn"] .legal-wrapper,
html[lang="zn"] .legal-wrapper {
  letter-spacing: normal;
  word-break: break-word;
}

/* === Responsive Adjustments === */

/* ≤ 900px */
@media (max-width: 900px) {
  .legal-wrapper {
    padding: 0 0.75rem;
  }
  .legal-wrapper h1 {
    font-size: 2.25rem;
  }
  .legal-wrapper h2 {
    font-size: 1.35rem;
  }
  .legal-wrapper h3 {
    font-size: 1.05rem;
  }
  .legal-meta,
  .legal-section p,
  .legal-index-link {
    font-size: 0.85rem;
  }
  .legal-toggle-all button {
    font-size: 0.9rem;
    padding: 0.45rem 0.85rem;
  }
}

/* ≤ 600px */
@media (max-width: 600px) {
  .legal-wrapper {
    margin: 1.5rem auto;
    padding: 2rem 1rem 3rem;
  }
  .legal-wrapper h1 {
    font-size: 2rem;
  }
  .legal-wrapper h2 {
    font-size: 1.25rem;
  }
  .legal-wrapper h3,
  .legal-content p,
  .legal-content li {
    font-size: 0.95rem;
  }
  .legal-meta,
  .legal-section p,
  .legal-index-link {
    font-size: 0.8rem;
  }
  .legal-toggle-all button {
    font-size: 0.85rem;
    padding: 0.4rem 0.8rem;
  }
}

/* ≤ 400px */
@media (max-width: 400px) {
  .legal-wrapper {
    margin: 1rem auto;
    padding: 0 0.5rem;
  }
  .legal-wrapper h1 {
    font-size: 1.75rem;
  }
  .legal-wrapper h2 {
    font-size: 1.1rem;
  }
  .legal-wrapper h3 {
    font-size: 0.95rem;
  }
  .legal-meta,
  .legal-section p,
  .legal-index-link {
    font-size: 0.75rem;
  }
  .legal-toggle-all button {
    font-size: 0.8rem;
    padding: 0.35rem 0.7rem;
  }
  .legal-wrapper ul {
    padding-left: 1.25rem;
  }
  .legal-content {
    padding: 0.5rem 0.5rem 0.5rem 0;
  }
}
