@charset "UTF-8";
@import url("https://fonts.googleapis.com/css2?family=Hind+Madurai:wght@600&family=Noto+Sans+JP:wght@400;500;700&display=swap");
picture {
  margin: 0;
  padding: 0;
}

@media (max-width: 750px) {
  .disp_pc {
    display: none;
  }
}
@media (min-width: 751px) {
  .disp_pc {
    display: block;
  }
}

@media (max-width: 750px) {
  .disp_sp {
    display: block;
  }
}
@media (min-width: 751px) {
  .disp_sp {
    display: none;
  }
}

body {
  color: #222729;
  font-family: "Noto Sans JP", sans-serif;
  font-optical-sizing: auto;
  font-weight: 400;
  font-style: normal;
}
@media (max-width: 750px) {
  body .col-12 {
    width: 89.7435897436vw;
    margin-top: 6vw;
    margin-left: auto;
    margin-right: auto;
    padding: 0;
  }
}
@media (min-width: 751px) {
  body .col-12 {
    width: 80% !important;
    margin-top: 100px;
  }
}
body a {
  color: #222729;
}
body p {
  text-indent: 0;
  text-align: justify;
}
@media (max-width: 750px) {
  body p {
    font-size: 3.0769230769vw;
    line-height: 1.85;
    margin-left: 3.8461538462vw;
  }
}
@media (min-width: 751px) {
  body p {
    font-size: 16px;
    line-height: 2;
    margin-left: 30px;
  }
}
body p img {
  margin-bottom: 0;
}
@media (min-width: 751px) {
  body ul, body ol {
    margin-left: 30px;
  }
}
@media (max-width: 750px) {
  body ul li, body ol li {
    font-size: 3.0769230769vw;
    line-height: 1.8;
  }
}
body ul li p, body ol li p {
  margin-left: 0;
}
body ul ul, body ol ul {
  margin-left: 0;
}
body ul ul li, body ol ul li {
  list-style-type: disc;
}
body img {
  outline: 1px solid #222729;
  margin-bottom: 1rem;
}
body img.icon {
  outline: none;
  margin: 0;
}
@media (max-width: 750px) {
  body img.icon {
    height: 1rem;
    width: auto;
    vertical-align: middle;
    margin: 0 0.25em;
  }
}

header img {
  outline: none;
  margin: 0;
}

h1 {
  border-bottom: 1px solid #222729;
  color: #D71918;
  font-weight: 700;
  position: relative;
}
@media (max-width: 750px) {
  h1 {
    font-size: 5.641025641vw;
    padding-bottom: 3vw;
    margin-top: 10vw;
  }
}
@media (min-width: 751px) {
  h1 {
    font-size: 42px;
    padding-bottom: 0.3em;
    margin-top: 110px;
    margin-bottom: 0.5em;
  }
}
h1:after {
  content: "";
  position: absolute;
  display: block;
  height: 1px;
  background-color: #D71918;
  bottom: -1px;
}
@media (max-width: 750px) {
  h1:after {
    width: 37.1794871795vw;
  }
}
@media (min-width: 751px) {
  h1:after {
    width: 40%;
  }
}
h1#kamameshi {
  margin-top: 0;
}
h1.h2 {
  border: none;
  margin: 0;
  padding: 0;
}
h1.h2:after {
  display: none;
}

h2 {
  color: #D71918;
  font-weight: 700;
  margin-bottom: 1em;
}
@media (max-width: 750px) {
  h2 {
    font-size: 4.1025641026vw;
    line-height: 1.75;
    margin-top: 1.5em;
  }
}
@media (min-width: 751px) {
  h2 {
    font-size: 30px;
    margin-top: 50px;
  }
}

h3 {
  font-weight: 400;
  margin-bottom: 1em;
  position: relative;
}
@media (max-width: 750px) {
  h3 {
    font-size: 4.1025641026vw;
    margin-top: 1em;
    margin-left: 3.8461538462vw;
    line-height: 1.75;
  }
}
@media (min-width: 751px) {
  h3 {
    font-size: 28px;
    margin-top: 1.5em;
    margin-left: 30px;
  }
}
h3:before {
  content: "■";
  color: #222729;
  left: 0;
  line-height: 1;
  position: absolute;
}
@media (max-width: 750px) {
  h3:before {
    font-size: 2.8205128205vw;
    left: -3.8461538462vw;
    top: 2.25vw;
  }
}
@media (min-width: 751px) {
  h3:before {
    left: -30px;
    font-size: 16px;
    top: 0.65em;
  }
}

blockquote {
  background-color: #F1F1F1;
}
@media (max-width: 750px) {
  blockquote {
    padding: 5.1282051282vw;
    margin-left: 3.8461538462vw;
  }
}
@media (min-width: 751px) {
  blockquote {
    margin-bottom: 65px;
    margin-left: 30px;
    padding: 50px;
  }
}
blockquote h4 {
  font-weight: 400;
}
@media (max-width: 750px) {
  blockquote h4 {
    font-size: 4.1025641026vw;
    margin-bottom: 0.75em;
  }
}
@media (min-width: 751px) {
  blockquote h4 {
    font-size: 28px;
    margin-bottom: 0.5em;
  }
}
blockquote p {
  margin-left: 0;
}
@media (max-width: 750px) {
  blockquote ul, blockquote ol {
    margin-left: 5.1282051282vw;
    padding-left: 0;
  }
}
@media (min-width: 751px) {
  blockquote ul, blockquote ol {
    margin-left: 0;
  }
}
@media (max-width: 750px) {
  blockquote ul li, blockquote ol li {
    font-size: 3.0769230769vw;
    line-height: 1.85;
  }
}

.toc ul {
  margin-left: 0;
  padding: 0;
}
.toc ul li {
  list-style: none;
}
@media (max-width: 750px) {
  .toc ul li {
    font-size: 4.1025641026vw;
    margin-top: 0.8em;
  }
}
@media (min-width: 751px) {
  .toc ul li {
    font-size: 24px;
    margin-top: 1.3em;
  }
}
.toc ul li:before {
  content: "■";
  color: #D71918;
  margin-right: 0.5em;
}
.toc ul li a {
  color: #D71918;
  text-decoration: none;
}
@media (max-width: 750px) {
  .toc ul li ul {
    padding-left: 6.4102564103vw;
  }
}
@media (min-width: 751px) {
  .toc ul li ul {
    padding-left: 1.5em;
  }
}
@media (max-width: 750px) {
  .toc ul li ul li {
    font-size: 3.5897435897vw;
    margin-top: 0;
  }
}
@media (min-width: 751px) {
  .toc ul li ul li {
    color: #222729;
    font-size: 20px;
    margin: 0.5em 0;
  }
}
.toc ul li ul li:before {
  content: "└";
  color: #222729;
}
.toc ul li ul li a {
  color: #222729;
}

[data-bs-theme=dark] body {
  color: #fff;
}
[data-bs-theme=dark] body a {
  color: #fff;
}
[data-bs-theme=dark] body h1 {
  border-bottom: 1px solid #fff;
}
[data-bs-theme=dark] body h1.h2 {
  border: none;
}
[data-bs-theme=dark] body h3:before {
  color: #fff;
}
[data-bs-theme=dark] body blockquote {
  color: #222729;
}
[data-bs-theme=dark] body .toc ul li ul li:before {
  color: #fff;
}
[data-bs-theme=dark] body .toc ul li ul li a {
  color: #fff;
}