@charset "UTF-8";
/* ========================================
root
======================================== */
:root {
  interpolate-size: allow-keywords;
  /* ========================================
      ScrollBar
  ======================================== */
  --scrollBehavior: auto;
  --common_scrollbarWidth: 7.5px;
  --common_scrollbarHeight: 7.5px;
  --common_scrollbarBorderRadius: 0;
  --common_scrollbarTrackBg: #333;
  --common_scrollbarThumbBg: #555;
  /* ========================================
  // selection
  ======================================== */
  --selectionBgColor: rgba(0, 179, 237, 0.9);
  --selectionFontColor: #fff;
  /* ========================================
  // Main Color
  ======================================== */
  --MainBgColor: #fff;
  --MainFontColor: #333;
  --LinkColor: #333;
  --LinkHoverColor: #333;
  /* ========================================
  // font
  ======================================== */
  --fontFamily:
      "Hiragino Sans W3", "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN W3", "メイリオ", Meiryo, "ＭＳ Ｐゴシック",
      "MS PGothic", sans-serif;
  --fontFeatureSettings: "pkna" on;
  --fontSize: 16px;
  --lineHeight: 1.5;
  --fontWeight: 400;
  --wordBreak: break-all;
  /* ========================================
  Focus
  ======================================== */
  --focusColor: #0066cc;
  --focusRing: rgba(0, 102, 204, 0.25);
}

/* ========================================
defaults
======================================== */
*,
*:before,
*:after {
  margin: 0;
  padding: 0;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
}

/* ========================================
html, body
======================================== */
::-moz-selection {
  background-color: var(--selectionBgColor);
  color: var(--selectionFontColor);
}
::selection {
  background-color: var(--selectionBgColor);
  color: var(--selectionFontColor);
}

html {
  scroll-behavior: var(--common_scrollBehavior);
  -webkit-text-size-adjust: 100%;
  -moz-text-size-adjust: 100%;
   -ms-text-size-adjust: 100%;
       text-size-adjust: 100%;
}
html, html * {
  scrollbar-color: var(--common_scrollbarThumbBg) var(--common_scrollbarTrackBg);
  scrollbar-width: thin;
}

html,
body {
  margin: 0;
  padding: 0;
  width: 100%;
  min-height: 100vh;
  min-height: -webkit-fill-available;
}

body {
  position: relative;
  display: block;
  width: 100%;
  overflow-x: clip;
  -webkit-text-size-adjust: 100%;
     -moz-text-size-adjust: 100%;
      -ms-text-size-adjust: 100%;
          text-size-adjust: 100%;
  vertical-align: baseline;
  word-break: var(--wordBreak);
  font-family: var(--fontFamily);
  -webkit-font-feature-settings: var(--fontFeatureSettings);
          font-feature-settings: var(--fontFeatureSettings);
  font-size: var(--fontSize);
  line-height: var(--lineHeight);
  font-weight: var(--fontWeight);
  font-variant-numeric: tabular-nums;
  font-smoothing: antialiased;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  font-optical-sizing: auto;
  font-style: normal;
  word-wrap: break-word;
  overflow-wrap: break-word;
  background: var(--MainBgColor);
  color: var(--MainFontColor);
}

/* ========================================
Inline elements
======================================== */
strong,
b {
  font-weight: bold;
}

em {
  font-style: italic;
}

i {
  font-style: italic;
}

small {
  font-size: 0.875em;
}

mark {
  background-color: transparent;
  color: inherit;
  padding-inline: 0.125em;
}

sub,
sup {
  font-size: 0.75em;
  line-height: 0;
  position: relative;
  vertical-align: baseline;
}

sub {
  bottom: -0.25em;
}

sup {
  top: -0.5em;
}

code,
kbd,
samp {
  font-family: var(--fontFamily-mono);
  font-size: 0.875em;
}

code {
  background-color: transparent;
  padding: 0.125em 0.25em;
  border-radius: 3px;
}

kbd {
  background-color: transparent;
  border: 1px solid #ccc;
  border-radius: 3px;
  padding: 0.125em 0.375em;
  font-size: 0.8125em;
}

abbr[title] {
  cursor: help;
  -webkit-text-decoration: underline dotted;
          text-decoration: underline dotted;
  text-underline-offset: 0.125em;
}

del {
  text-decoration: line-through;
}

ins {
  text-decoration: underline;
}

q::before {
  content: open-quote;
}
q::after {
  content: close-quote;
}

cite {
  font-style: italic;
}

dfn {
  font-style: italic;
}

var {
  font-style: italic;
}

/* ========================================
Links
======================================== */
a {
  position: relative;
  display: inline;
  color: var(--LinkColor);
  text-decoration: none;
  -webkit-transition: color var(--transitionDuration) ease;
  transition: color var(--transitionDuration) ease;
}
@media (any-hover: hover) {
  a[href^="tel:"] {
    pointer-events: none;
  }
}
@media (any-hover: hover) {
  a:hover {
    color: var(--LinkHoverColor);
    text-decoration: none;
  }
}
a:active, a:hover {
  outline: 0;
}
a:focus-visible {
  outline: 2px solid var(--focusColor);
  outline-offset: 2px;
}

/* ========================================
Lists - ul, ol, li, dl, dt, dd
======================================== */
ul,
ol {
  margin: 0;
  padding: 0;
  list-style: none;
  list-style-position: inside;
}

ul ul,
ol ol,
ul ol,
ol ul {
  margin-left: 1em;
}

li {
  margin: 0;
  padding: 0;
}

/* ========================================
Media - img, picture, video, audio, iframe, svg
======================================== */
img {
  display: inline-block;
  max-width: 100%;
  height: auto;
  vertical-align: middle;
  image-rendering: -webkit-optimize-contrast;
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
}
img.lazy {
  will-change: mask-image;
  opacity: 0;
  -webkit-mask-size: 100% 300%;
          mask-size: 100% 300%;
  -webkit-mask-position: 0 100%;
          mask-position: 0 100%;
  -webkit-mask-image: -webkit-gradient(linear, left top, left bottom, from(#000), color-stop(33%, #000), color-stop(66%, rgba(0, 0, 0, 0)), to(rgba(0, 0, 0, 0)));
  -webkit-mask-image: -webkit-linear-gradient(top, #000, #000 33%, rgba(0, 0, 0, 0) 66%, rgba(0, 0, 0, 0) 100%);
          mask-image: -webkit-gradient(linear, left top, left bottom, from(#000), color-stop(33%, #000), color-stop(66%, rgba(0, 0, 0, 0)), to(rgba(0, 0, 0, 0)));
          mask-image: linear-gradient(to bottom, #000, #000 33%, rgba(0, 0, 0, 0) 66%, rgba(0, 0, 0, 0) 100%);
}
img.lazy.loaded {
  -webkit-transition: all 1.5s ease;
  transition: all 1.5s ease;
  opacity: 1;
  -webkit-mask-position: 0% 0%;
          mask-position: 0% 0%;
}

picture {
  position: relative;
  display: block;
}

figure {
  position: relative;
  display: block;
  margin: 0;
  padding: 0;
}

figcaption {
  position: relative;
  display: block;
  -webkit-margin-before: 0.5em;
          margin-block-start: 0.5em;
  font-size: 0.875em;
  color: #666;
}

video {
  display: inline-block;
  vertical-align: baseline;
  max-width: 100%;
}

audio {
  display: inline-block;
  vertical-align: baseline;
}
audio:not([controls]) {
  display: none;
  height: 0;
}

canvas {
  display: inline-block;
  vertical-align: baseline;
}

iframe {
  max-width: 100%;
  border: 0;
}

svg {
  vertical-align: middle;
  max-width: 100%;
}
svg:not(:root) {
  overflow: hidden;
}
svg.symbols {
  display: none;
}

.media-container {
  position: relative;
  width: 100%;
  aspect-ratio: 16/9;
}
.media-container > iframe,
.media-container > video {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

/* ========================================
Forms
======================================== */
:where(button, [type=button], [type=reset], [type=submit]) {
  -ms-touch-action: manipulation;
      touch-action: manipulation;
}

button,
input,
optgroup,
select,
textarea {
  -webkit-appearance: none;
  border-radius: 0;
  color: inherit;
  font: inherit;
  margin: 0;
}

button,
select {
  text-transform: none;
}

button,
html input[type=button],
input[type=reset],
input[type=submit] {
  cursor: pointer;
}

input[type=text],
input[type=email],
input[type=tel],
input[type=url],
input[type=password],
input[type=search],
input[type=number],
input[type=date],
input[type=datetime-local],
input[type=month],
input[type=week],
input[type=time] {
  display: block;
  width: 100%;
  padding: 0.5em 0.75em;
  background-color: #fff;
  border: 1px solid #ccc;
  border-radius: 4px;
  -webkit-transition: border-color var(--transitionDuration) ease, -webkit-box-shadow var(--transitionDuration) ease;
  transition: border-color var(--transitionDuration) ease, -webkit-box-shadow var(--transitionDuration) ease;
  transition: border-color var(--transitionDuration) ease, box-shadow var(--transitionDuration) ease;
  transition: border-color var(--transitionDuration) ease, box-shadow var(--transitionDuration) ease, -webkit-box-shadow var(--transitionDuration) ease;
}
input[type=text]:focus,
input[type=email]:focus,
input[type=tel]:focus,
input[type=url]:focus,
input[type=password]:focus,
input[type=search]:focus,
input[type=number]:focus,
input[type=date]:focus,
input[type=datetime-local]:focus,
input[type=month]:focus,
input[type=week]:focus,
input[type=time]:focus {
  outline: none;
  border-color: var(--focusColor);
  -webkit-box-shadow: 0 0 0 3px var(--focusRing);
          box-shadow: 0 0 0 3px var(--focusRing);
}
input[type=text]:disabled,
input[type=email]:disabled,
input[type=tel]:disabled,
input[type=url]:disabled,
input[type=password]:disabled,
input[type=search]:disabled,
input[type=number]:disabled,
input[type=date]:disabled,
input[type=datetime-local]:disabled,
input[type=month]:disabled,
input[type=week]:disabled,
input[type=time]:disabled {
  opacity: 0.6;
  cursor: not-allowed;
}
input[type=text]::-webkit-input-placeholder, input[type=email]::-webkit-input-placeholder, input[type=tel]::-webkit-input-placeholder, input[type=url]::-webkit-input-placeholder, input[type=password]::-webkit-input-placeholder, input[type=search]::-webkit-input-placeholder, input[type=number]::-webkit-input-placeholder, input[type=date]::-webkit-input-placeholder, input[type=datetime-local]::-webkit-input-placeholder, input[type=month]::-webkit-input-placeholder, input[type=week]::-webkit-input-placeholder, input[type=time]::-webkit-input-placeholder {
  color: #999;
  opacity: 1;
}
input[type=text]::-moz-placeholder, input[type=email]::-moz-placeholder, input[type=tel]::-moz-placeholder, input[type=url]::-moz-placeholder, input[type=password]::-moz-placeholder, input[type=search]::-moz-placeholder, input[type=number]::-moz-placeholder, input[type=date]::-moz-placeholder, input[type=datetime-local]::-moz-placeholder, input[type=month]::-moz-placeholder, input[type=week]::-moz-placeholder, input[type=time]::-moz-placeholder {
  color: #999;
  opacity: 1;
}
input[type=text]:-ms-input-placeholder, input[type=email]:-ms-input-placeholder, input[type=tel]:-ms-input-placeholder, input[type=url]:-ms-input-placeholder, input[type=password]:-ms-input-placeholder, input[type=search]:-ms-input-placeholder, input[type=number]:-ms-input-placeholder, input[type=date]:-ms-input-placeholder, input[type=datetime-local]:-ms-input-placeholder, input[type=month]:-ms-input-placeholder, input[type=week]:-ms-input-placeholder, input[type=time]:-ms-input-placeholder {
  color: #999;
  opacity: 1;
}
input[type=text]::-ms-input-placeholder, input[type=email]::-ms-input-placeholder, input[type=tel]::-ms-input-placeholder, input[type=url]::-ms-input-placeholder, input[type=password]::-ms-input-placeholder, input[type=search]::-ms-input-placeholder, input[type=number]::-ms-input-placeholder, input[type=date]::-ms-input-placeholder, input[type=datetime-local]::-ms-input-placeholder, input[type=month]::-ms-input-placeholder, input[type=week]::-ms-input-placeholder, input[type=time]::-ms-input-placeholder {
  color: #999;
  opacity: 1;
}
input[type=text]::placeholder,
input[type=email]::placeholder,
input[type=tel]::placeholder,
input[type=url]::placeholder,
input[type=password]::placeholder,
input[type=search]::placeholder,
input[type=number]::placeholder,
input[type=date]::placeholder,
input[type=datetime-local]::placeholder,
input[type=month]::placeholder,
input[type=week]::placeholder,
input[type=time]::placeholder {
  color: #999;
  opacity: 1;
}

textarea {
  display: block;
  width: 100%;
  min-height: 8em;
  padding: 0.5em 0.75em;
  background-color: #fff;
  border: 1px solid #ccc;
  border-radius: 4px;
  resize: vertical;
  line-height: inherit;
  -webkit-transition: border-color var(--transitionDuration) ease, -webkit-box-shadow var(--transitionDuration) ease;
  transition: border-color var(--transitionDuration) ease, -webkit-box-shadow var(--transitionDuration) ease;
  transition: border-color var(--transitionDuration) ease, box-shadow var(--transitionDuration) ease;
  transition: border-color var(--transitionDuration) ease, box-shadow var(--transitionDuration) ease, -webkit-box-shadow var(--transitionDuration) ease;
}
textarea:focus {
  outline: none;
  border-color: var(--focusColor);
  -webkit-box-shadow: 0 0 0 3px var(--focusRing);
          box-shadow: 0 0 0 3px var(--focusRing);
}
textarea:disabled {
  opacity: 0.6;
  cursor: not-allowed;
}
textarea::-webkit-input-placeholder {
  color: #999;
  opacity: 1;
}
textarea::-moz-placeholder {
  color: #999;
  opacity: 1;
}
textarea:-ms-input-placeholder {
  color: #999;
  opacity: 1;
}
textarea::-ms-input-placeholder {
  color: #999;
  opacity: 1;
}
textarea::placeholder {
  color: #999;
  opacity: 1;
}

select {
  display: block;
  width: 100%;
  padding: 0.5em 2.5em 0.5em 0.75em;
  background-color: #fff;
  border: 1px solid #ccc;
  border-radius: 4px;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23333' d='M6 8L1 3h10z'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 0.75em center;
  cursor: pointer;
  -webkit-transition: border-color var(--transitionDuration) ease, -webkit-box-shadow var(--transitionDuration) ease;
  transition: border-color var(--transitionDuration) ease, -webkit-box-shadow var(--transitionDuration) ease;
  transition: border-color var(--transitionDuration) ease, box-shadow var(--transitionDuration) ease;
  transition: border-color var(--transitionDuration) ease, box-shadow var(--transitionDuration) ease, -webkit-box-shadow var(--transitionDuration) ease;
}
select::-ms-expand {
  display: none;
}
select:focus {
  outline: none;
  border-color: var(--focusColor);
  -webkit-box-shadow: 0 0 0 3px var(--focusRing);
          box-shadow: 0 0 0 3px var(--focusRing);
}
select[multiple] {
  background-image: none;
  -webkit-padding-end: 0.75em;
          padding-inline-end: 0.75em;
  height: auto;
}
select:disabled {
  opacity: 0.6;
  cursor: not-allowed;
}

button {
  border: none;
  background-color: transparent;
  cursor: pointer;
}
button:disabled {
  opacity: 0.6;
  cursor: not-allowed;
}

input[type=checkbox],
input[type=radio] {
  width: 1.125em;
  height: 1.125em;
  margin: 0;
  padding: 0;
  vertical-align: middle;
  accent-color: var(--focusColor);
  cursor: pointer;
}

label {
  display: inline-block;
  cursor: pointer;
}
label:has(input[type=checkbox]), label:has(input[type=radio]) {
  display: -webkit-inline-box;
  display: -webkit-inline-flex;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  gap: 0.5em;
}

fieldset {
  margin: 0;
  padding: 0;
  border: 1px solid #ccc;
  border-radius: 4px;
  padding: 1em 1.5em;
}

legend {
  font-weight: 700;
  padding-inline: 0.5em;
}

input:-webkit-autofill {
  -webkit-box-shadow: 0 0 0px 1000px #fff inset;
          box-shadow: 0 0 0px 1000px #fff inset;
  -webkit-text-fill-color: #333 !important;
}

input:-webkit-autofill, input:autofill {
  -webkit-box-shadow: 0 0 0px 1000px #fff inset;
          box-shadow: 0 0 0px 1000px #fff inset;
  -webkit-text-fill-color: #333 !important;
}
input:-webkit-autofill:focus {
  caret-color: #333 !important;
}
input:-webkit-autofill:focus, input:autofill:focus {
  caret-color: #333 !important;
}

input[type=number] {
  -moz-appearance: textfield;
}
input[type=number]::-webkit-outer-spin-button, input[type=number]::-webkit-inner-spin-button {
  -webkit-appearance: none;
  margin: 0;
}

input[type=search]::-webkit-search-cancel-button, input[type=search]::-webkit-search-decoration {
  -webkit-appearance: none;
}

/* ========================================
Sections - Semantic HTML5 elements
======================================== */
header,
aside,
footer,
main,
menu,
nav,
div,
hgroup,
section,
article {
  position: relative;
  display: block;
}

main {
  display: block;
}

details {
  position: relative;
  display: block;
  border: 1px solid #ddd;
  border-radius: 4px;
  padding: 1em;
}
details[open] > summary {
  -webkit-margin-after: 0.75em;
          margin-block-end: 0.75em;
}

summary {
  position: relative;
  display: block;
  cursor: pointer;
  font-weight: 700;
  list-style: none;
}
summary::-webkit-details-marker {
  display: none;
}
summary::before {
  content: "▶";
  display: inline-block;
  -webkit-margin-end: 0.5em;
          margin-inline-end: 0.5em;
  font-size: 0.75em;
  -webkit-transition: -webkit-transform var(--transitionDuration) ease;
  transition: -webkit-transform var(--transitionDuration) ease;
  transition: transform var(--transitionDuration) ease;
  transition: transform var(--transitionDuration) ease, -webkit-transform var(--transitionDuration) ease;
}
details[open] > summary::before {
  -webkit-transform: rotate(90deg);
      -ms-transform: rotate(90deg);
          transform: rotate(90deg);
}
summary:focus-visible {
  outline: 2px solid var(--focusColor);
  outline-offset: 2px;
}

dialog {
  position: fixed;
  inset: 0;
  margin: auto;
  padding: 1.5em;
  background-color: transparent;
  border: none;
  border-radius: 8px;
  -webkit-box-shadow: 0 4px 24px rgba(0, 0, 0, 0.2);
          box-shadow: 0 4px 24px rgba(0, 0, 0, 0.2);
  max-width: 90vw;
  max-height: 85vh;
  overflow: auto;
}
dialog::-webkit-backdrop {
  background-color: transparent;
}
dialog::-ms-backdrop {
  background-color: transparent;
}
dialog::backdrop {
  background-color: transparent;
}
dialog:not([open]) {
  display: none;
}

[hidden],
template {
  display: none;
}

address {
  position: relative;
  display: block;
  font-style: normal;
  line-height: inherit;
}

time {
  position: relative;
  display: inline;
}

/* ========================================
Misc - hr, progress, meter, etc.
======================================== */
hr {
  display: block;
  height: 0;
  border: 0;
  -webkit-border-before: 1px solid #ddd;
          border-block-start: 1px solid #ddd;
  margin-block: 2em;
  -webkit-box-sizing: content-box;
          box-sizing: content-box;
}

progress {
  display: inline-block;
  vertical-align: baseline;
  width: 100%;
  max-width: 300px;
  height: 8px;
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  background-color: transparent;
  border: none;
  border-radius: 4px;
  overflow: hidden;
}
progress::-webkit-progress-bar {
  background-color: transparent;
  border-radius: 4px;
}
progress::-webkit-progress-value {
  background-color: var(--focusColor);
  border-radius: 4px;
}
progress::-moz-progress-bar {
  background-color: var(--focusColor);
  border-radius: 4px;
}

meter {
  display: inline-block;
  vertical-align: baseline;
  width: 100%;
  max-width: 300px;
  height: 8px;
}

output {
  display: inline-block;
}

[hidden] {
  display: none !important;
}

.visually-hidden,
.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  -webkit-clip-path: inset(50%);
          clip-path: inset(50%);
  white-space: nowrap;
  border: 0;
}

.visually-hidden-focusable:focus, .visually-hidden-focusable:focus-within,
.sr-only-focusable:focus,
.sr-only-focusable:focus-within {
  position: static;
  width: auto;
  height: auto;
  margin: 0;
  overflow: visible;
  clip: auto;
  -webkit-clip-path: none;
          clip-path: none;
  white-space: normal;
}

.print-only {
  display: none;
}
@media print {
  .print-only {
    display: block;
  }
}

@media print {
  .no-print {
    display: none !important;
  }
}

/* ========================================
Utilities - ユーティリティクラス
======================================== */
@media (min-width: 768px) {
  .pc_none {
    display: none !important;
  }
}

@media (max-width: 767px) {
  .sp_none {
    display: none !important;
  }
}

.fw-light {
  font-weight: 300;
}
.fw-normal {
  font-weight: 400;
}
.fw-bold {
  font-weight: 700;
}
.fw-100 {
  font-weight: 100;
}
.fw-200 {
  font-weight: 200;
}
.fw-300 {
  font-weight: 300;
}
.fw-400 {
  font-weight: 400;
}
.fw-500 {
  font-weight: 500;
}
.fw-600 {
  font-weight: 600;
}
.fw-700 {
  font-weight: 700;
}
.fw-800 {
  font-weight: 800;
}
.fw-900 {
  font-weight: 900;
}

/* ========================================
page
======================================== */
.page-header {
  width: 100%;
  padding: 32px 24px;
  background: #f7f7f7;
  border-bottom: 1px solid #e5e5e5;
}
@media (max-width: 767px) {
  .page-header {
    padding: 24px 20px;
  }
}
.page-header .container {
  max-width: 800px;
  margin: 0 auto;
}
.page-header__title {
  font-size: 20px;
  font-weight: 700;
  line-height: 1.4;
  text-align: center;
  color: #222;
  letter-spacing: 0.02em;
}
@media (max-width: 767px) {
  .page-header__title {
    font-size: 16px;
  }
}

.page-content {
  display: block;
  width: 100%;
  padding: 80px 24px 64px;
  color: #333;
}
@media (max-width: 767px) {
  .page-content {
    padding: 48px 20px 40px;
  }
}
.page-content .container {
  max-width: 800px;
  margin: 0 auto;
  font-size: 16px;
  line-height: 1.9;
}
@media (max-width: 767px) {
  .page-content .container {
    font-size: 14px;
    line-height: 1.85;
  }
}
.page-content .container {
  /* ========================================
  見出し
  ======================================== */
}
.page-content .container h1 {
  font-size: 28px;
  font-weight: 700;
  line-height: 1.4;
  text-align: center;
  padding-bottom: 24px;
  margin-bottom: 48px;
  border-bottom: 2px solid #333;
}
@media (max-width: 767px) {
  .page-content .container h1 {
    font-size: 22px;
    padding-bottom: 18px;
    margin-bottom: 32px;
  }
}
.page-content .container h2 {
  position: relative;
  font-size: 20px;
  font-weight: 700;
  line-height: 1.5;
  padding: 0 0 8px 14px;
  margin: 48px 0 20px;
  border-bottom: 1px solid #ddd;
}
.page-content .container h2::before {
  content: "";
  position: absolute;
  left: 0;
  top: 6px;
  width: 4px;
  height: calc(100% - 14px);
  background: #333;
}
@media (max-width: 767px) {
  .page-content .container h2 {
    font-size: 17px;
    margin: 36px 0 16px;
  }
}
.page-content .container h3 {
  font-size: 17px;
  font-weight: 700;
  line-height: 1.5;
  margin: 32px 0 12px;
}
@media (max-width: 767px) {
  .page-content .container h3 {
    font-size: 15px;
    margin: 24px 0 10px;
  }
}
.page-content .container h4,
.page-content .container h5,
.page-content .container h6 {
  font-size: 16px;
  font-weight: 700;
  line-height: 1.5;
  margin: 24px 0 8px;
}
@media (max-width: 767px) {
  .page-content .container h4,
  .page-content .container h5,
  .page-content .container h6 {
    font-size: 14px;
  }
}
.page-content .container {
  /* ========================================
  本文
  ======================================== */
}
.page-content .container p {
  margin: 0 0 16px;
}
.page-content .container p:last-child {
  margin-bottom: 0;
}
.page-content .container {
  /* ========================================
  リンク
  ======================================== */
}
.page-content .container a {
  color: #0066cc;
  text-decoration: underline;
  word-break: break-all;
  -webkit-transition: opacity 0.2s ease;
  transition: opacity 0.2s ease;
}
@media (any-hover: hover) {
  .page-content .container a:hover {
    opacity: 0.7;
  }
}
.page-content .container {
  /* ========================================
  リスト
  ======================================== */
}
.page-content .container ul,
.page-content .container ol {
  margin: 0 0 16px;
  padding-left: 1.5em;
}
.page-content .container ul li,
.page-content .container ol li {
  margin-bottom: 6px;
}
.page-content .container ul li:last-child,
.page-content .container ol li:last-child {
  margin-bottom: 0;
}
.page-content .container ul {
  list-style: disc;
}
.page-content .container ol {
  list-style: decimal;
}
.page-content .container {
  /* ========================================
  テーブル
  ======================================== */
}
.page-content .container table {
  width: 100%;
  border-collapse: collapse;
  margin: 0 0 24px;
  font-size: 15px;
}
@media (max-width: 767px) {
  .page-content .container table {
    font-size: 14px;
    border: none;
    border-collapse: separate;
    border-spacing: 0;
  }
}
.page-content .container table th,
.page-content .container table td {
  padding: 12px 16px;
  border: 1px solid #ddd;
  text-align: left;
  vertical-align: top;
}
.page-content .container table th {
  width: 30%;
  background: #f7f7f7;
  font-weight: 700;
  white-space: nowrap;
}
@media (max-width: 767px) {
  .page-content .container table thead,
  .page-content .container table tbody {
    display: block;
    width: 100%;
  }
  .page-content .container table tr {
    display: block;
    width: 100%;
    margin-bottom: 12px;
    border: 1px solid #e5e5e5;
    border-radius: 6px;
    background: #fff;
    overflow: hidden;
  }
  .page-content .container table tr:last-child {
    margin-bottom: 0;
  }
  .page-content .container table th,
  .page-content .container table td {
    display: block;
    width: 100%;
    border: none;
    padding: 10px 14px;
    line-height: 1.7;
  }
  .page-content .container table th {
    position: relative;
    width: 100%;
    white-space: normal;
    background: #f7f7f7;
    font-size: 13px;
    font-weight: 700;
    color: #555;
    letter-spacing: 0.04em;
    padding-left: 22px;
    border-bottom: 1px solid #e5e5e5;
  }
  .page-content .container table th::before {
    content: "";
    position: absolute;
    left: 10px;
    top: 50%;
    -webkit-transform: translateY(-50%);
        -ms-transform: translateY(-50%);
            transform: translateY(-50%);
    width: 3px;
    height: 14px;
    background: #333;
    border-radius: 2px;
  }
  .page-content .container table td {
    background: #fff;
    color: #333;
  }
}
.page-content .container {
  /* ========================================
  定義リスト
  ======================================== */
}
.page-content .container dl {
  margin: 0 0 24px;
}
.page-content .container dl dt {
  font-weight: 700;
  margin-top: 16px;
}
.page-content .container dl dt:first-child {
  margin-top: 0;
}
.page-content .container dl dd {
  margin: 4px 0 0;
  padding-left: 1em;
}
.page-content .container {
  /* ========================================
  引用・区切り
  ======================================== */
}
.page-content .container blockquote {
  margin: 0 0 24px;
  padding: 16px 20px;
  background: #f7f7f7;
  border-left: 4px solid #ccc;
  color: #555;
}
.page-content .container hr {
  border: 0;
  border-top: 1px solid #ddd;
  margin: 32px 0;
}
.page-content .container {
  /* ========================================
  画像
  ======================================== */
}
.page-content .container img {
  max-width: 100%;
  height: auto;
  display: block;
  margin: 16px auto;
}
.page-content .container {
  /* ========================================
  強調
  ======================================== */
}
.page-content .container strong,
.page-content .container b {
  font-weight: 700;
}
.page-content .container em,
.page-content .container i {
  font-style: italic;
}

/* ========================================
footer
======================================== */
.footer {
  width: 100%;
  padding: 32px 20px;
  background: #f7f7f7;
  text-align: center;
}
.footer .footer-links {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
  -webkit-align-items: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-flex-wrap: wrap;
      -ms-flex-wrap: wrap;
          flex-wrap: wrap;
  gap: 8px 12px;
  font-size: 13px;
  line-height: 1.6;
}
.footer .footer-link {
  color: #555;
  text-decoration: none;
  -webkit-transition: opacity 0.2s ease;
  transition: opacity 0.2s ease;
}
@media (any-hover: hover) {
  .footer .footer-link:hover {
    opacity: 0.6;
    text-decoration: underline;
  }
}
.footer .divider {
  color: #aaa;
}