/* Extracted from terms/fee/index.html <style> */
    :root {
      --fg: #0f172a;
      --muted: #475569;
      --bg: #ffffff;
      --card: #f8fafc;
      --border: #e2e8f0;
      --pri: #0ea5e9;
      --pri2: #0284c7;
    }
    body { margin: 0; font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, "Hiragino Kaku Gothic ProN", "Noto Sans JP", "Yu Gothic", sans-serif; color: var(--fg); background: var(--bg); }
    a { color: inherit; }
    .container { max-width: 900px; margin: 0 auto; padding: 0 16px; }
    .header { border-bottom: 1px solid var(--border); background: #fff; position: sticky; top: 0; z-index: 10; }
    .header-inner { display: flex; align-items: center; justify-content: space-between; padding: 14px 0; gap: 12px; flex-wrap: wrap; }
    .legal-page { padding: 2rem 0 3rem; }
    .legal-hero { margin-bottom: 1.5rem; }
    .legal-hero h1 { margin: 0 0 0.5rem; font-size: 1.75rem; color: var(--pri2); }
    .legal-meta { color: var(--muted); font-size: 0.95rem; margin-top: 0.5rem; }
    .legal-card { background: var(--card); border: 1px solid var(--border); border-radius: 16px; padding: 1.5rem; }
    .legal-section + .legal-section { margin-top: 1.5rem; padding-top: 1.5rem; border-top: 1px solid var(--border); }
    .legal-section h2 { margin: 0 0 0.75rem; font-size: 1.1rem; color: var(--fg); }
    .legal-section p,
    .legal-section li { line-height: 1.9; margin: 0; }
    .legal-list { margin: 0.75rem 0 0 1.25rem; padding: 0; }
    .legal-list li + li { margin-top: 0.35rem; }
    .legal-section a { color: var(--pri2); text-decoration: underline; }
    .fee-table { width: 100%; border-collapse: collapse; margin: 0.75rem 0; font-size: 0.95rem; }
    .fee-table th, .fee-table td { border: 1px solid var(--border); padding: 0.6rem 0.75rem; text-align: left; line-height: 1.7; }
    .fee-table th { background: var(--pri2); color: #fff; font-weight: 600; }
    .fee-table tr:nth-child(even) td { background: #f1f5f9; }
    .fee-note { font-size: 0.9rem; color: var(--muted); margin-top: 0.5rem; line-height: 1.7; }
    .footer { margin-top: 2rem; padding: 20px 0 40px; border-top: 1px solid var(--border); color: var(--muted); font-size: 13px; }
    .footer a { color: var(--pri2); text-decoration: none; }
    .footer a:hover { text-decoration: underline; }

/* Extracted from terms/fee/index.html style attributes */
.csp-terms-fee-1 {
  margin-top: 1rem;
}
.csp-terms-fee-2 {
  margin-top: 1.5rem;
}
.csp-terms-fee-3 {
  margin-top: 0;
}
.csp-terms-fee-4 {
  margin-top: 0.25rem;
}
.csp-terms-fee-5 {
  margin-top: 0.5rem;
}
