@charset "UTF-8";
/* プライバシーポリシーページの追加カスタマイズ */
.is-privacy-title {
  font-weight: 700;
  font-size: clamp(1.125rem, 0.8519rem + 1.165vw, 2.25rem) !important;
}

/* 個別記事ページのCSS（旧サイトから移行） */

.yarpp-related a {
  color: #000;
}
.wp-block-image figcaption {
  margin-top: 0.5em;
  margin-bottom: 1em;
  text-align: center;
}

mark {
  background: rgba(0, 0, 0, 0) linear-gradient(transparent 72%, #ffff00 0%) repeat scroll 0 0;
}

.breadcrumbs {
  padding-top: 56px;
  width: 960px;
  margin-left: auto;
  margin-right: auto;
}

.breadcrumbs p {
  display: inline-block;
  color: #c7c7c7;
  margin: 0;
  font-size: 14px;
  margin-top: 21.5px;
  margin-bottom: 21.5px;
}

.breadcrumbs p a {
  color: #c7c7c7;
}

#p-single {
  width: 100%;
  padding-top: 80px;
  padding-bottom: 30px;
  background-color: #fff;
  margin-inline: auto;
  /* ------------------------------------------ */
  /* ▼引用ボックスの先頭(左上)に表示する文字▼ */
  /* ------------------------------------------ */
  /* ▼引用ボックスの末尾(右下)に表示する文字▼ */
}

#p-single h1,
#p-single h2,
#p-single h3,
#p-single h4,
#p-single h5,
#p-single h6 {
  margin-top: 0;
  margin-bottom: 15px;
}

#p-single h2,
#p-single h3,
#p-single h4,
#p-single h5 {
  margin-top: 40px;
}

#p-single h3 {
  padding: 5px 10px;
}

#p-single p {
  color: #56585c;
  font-family: "Noto Sans JP", sans-serif;
  font-size: 16px;
  font-style: normal;
  font-weight: 500;
  line-height: 30px;
  letter-spacing: 1px;
}

#p-single li {
  color: #56585c;
  font-family: "Noto Sans JP", sans-serif;
  font-size: 18px;
  font-style: normal;
  font-weight: 500;
  line-height: 130%;
  letter-spacing: 1px;
}

#p-single .wp-block-image {
  margin: 0 0 40px 0;
  text-align: center;
}

#p-single article {
  max-width: 960px;
  background-color: white;
  margin-left: auto;
  margin-right: auto;
  padding-top: 30px;
  padding-bottom: 20px;
  border-radius: 4px;
}

#article img {
  display: block;
  width: 100%;
  max-width: 100%;
  height: auto;
}

#p-single article .thumbnail {
  width: 100%;
  height: auto;
  max-height: 100%;
  margin-bottom: 15px;
}

#p-single article .article-post {
  max-width: 800px;
  /* 	margin-left: auto;
	margin-right: auto; */
}

#p-single article .article-post h1 {
  color: #41c9b4;
  font-family: "Noto Sans JP", sans-serif;
  font-size: 30px;
  font-style: normal;
  font-weight: 700;
  line-height: 160%;
  margin-bottom: 30px;
}

#p-single article .article-post .contents-table {
  width: 100%;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  padding: 40px 30px;
  background-color: #f7f7f7;
  margin-bottom: 100px;
  border-radius: 4px;
}

#p-single article .article-post .contents-table p {
  margin: 0;
  font-size: 18px;
}

#p-single article .article-post .contents-table ul li {
  font-size: 16px;
}

#p-single article .article-post .contents-table ol li {
  font-size: 16px;
}

#p-single h2 {
  color: #56585c;
  font-family: "Noto Sans JP", sans-serif;
  font-size: 20px;
  font-style: normal;
  font-weight: 700;
  line-height: 130%;
  letter-spacing: 2px;
  padding: 16px;
  border-left: 5px solid #41c9b4;
  background: #f0f9fe;
  margin-bottom: 16px;
}

#p-single article .article-post h3 {
  color: #56585c;
  text-align: left;
  font-family: "Noto Sans JP", sans-serif;
  font-size: 20px;
  font-style: normal;
  font-weight: 700;
  line-height: 150%;
  position: relative;
  padding-left: 0;
  padding-bottom: 10px;
  margin-bottom: 24px;
}
#p-single article .article-post h3:before {
  position: absolute;
  bottom: -6px;
  left: 0;
  width: 215px;
  height: 4px;
  content: "";
  background: #41c9b4;
}

#p-single article .article-post .content-row {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  margin-bottom: 50px;
}

#p-single article .article-post .content-row p {
  width: 430px;
}

#p-single article .article-post .content-row img {
  width: 500px;
  height: 300px;
  border-radius: 4px;
}

#p-single article .article-post h4 {
  font-size: 18px;
  color: #56585c;
  position: relative;
}
#p-single article .article-post h4:before {
  position: absolute;
  bottom: -6px;
  left: 0;
  width: 100%;
  height: 2px;
  content: "";
  background: #41c9b4;
}
.vk_borderBox:not([class*="vk_borderBox-color"]).is-style-vk_borderBox-style-solid-kado-tit-tab
  > .vk_borderBox_title_container:not(.has-background),
.vk_borderBox:not([class*="vk_borderBox-color"]).is-style-vk_borderBox-style-solid-round-tit-tab
  > .vk_borderBox_title_container:not(.has-background),
.vk_borderBox:not([class*="vk_borderBox-color"]).is-style-vk_borderBox-style-solid-kado-tit-banner
  > .vk_borderBox_title_container:not(.has-background) {
  background-color: #41c9b4;
  border-radius: 8px 8px 0 0;
  padding: 8px 24px;
}
.vk_borderBox:not([class*="vk_borderBox-color"]).is-style-vk_borderBox-style-solid-kado-tit-tab
  > .vk_borderBox_title_container:not(.has-background)
  h4.vk_borderBox_title,
.vk_borderBox:not([class*="vk_borderBox-color"]).is-style-vk_borderBox-style-solid-round-tit-tab
  > .vk_borderBox_title_container:not(.has-background)
  h4.vk_borderBox_title,
.vk_borderBox:not([class*="vk_borderBox-color"]).is-style-vk_borderBox-style-solid-kado-tit-banner
  > .vk_borderBox_title_container:not(.has-background)
  h4.vk_borderBox_title {
  color: #fff !important;
  font-size: 20px;
  font-weight: 700;
  line-height: 30px;
  text-align: center;
}
.vk_borderBox:not([class*="vk_borderBox-color"]):not(.has-text-color) {
  color: #41c9b4;
  margin-top: 12px;
}
#p-single article .article-post .next_h4 {
  font-size: 16px;
}

#p-single article .article-post h5 {
  font-size: 18px;
}

#p-single article .article-post h5:before {
  content: "●";
  display: inline-block;
  margin-right: 5px;
}

#p-single article .article-post .content-lists {
  padding: 35px 40px;
  border: 1px solid #c7c7c7;
  border-radius: 4px;
  margin-bottom: 80px;
}

#p-single article .article-post .content-lists ul {
  margin: 0;
}

#p-single article .article-post .content-lists ol {
  margin: 0;
}

#p-single article .article-post .content-lists ul li {
  margin-bottom: 16px;
}

#p-single article .article-post .content-lists ol li {
  margin-bottom: 16px;
}

#p-single article .article-post .content-lists ul li:nth-last-child(1) {
  margin-bottom: 0;
}

#p-single article .article-post .content-lists ol li:nth-last-child(1) {
  margin-bottom: 0;
}

#p-single article .article-post .content-btn {
  margin-bottom: 60px;
}

#p-single article .article-post .content-btn button {
  width: 400px;
  height: 100px;
  border-radius: 4px;
  font-size: 16px;
}

#p-single article .article-post .content-btn .blue_btn {
  background-color: #033481;
  color: white;
  border: none;
  margin-right: 30px;
}

#p-single article .article-post .content-btn .white_btn {
  background-color: white;
  color: #033481;
  border-color: #033481;
  border: 1px solid #033481;
}

#p-single article .article-post .content-quote {
  margin-bottom: 60px;
  /* ▼引用ボックス自体の装飾 */
  /* ------------------------------------------ */
  /* ▼引用ボックスの先頭(左上)に表示する文字▼ */
  /* ------------------------------------------ */
  /* ▼引用ボックスの末尾(右下)に表示する文字▼ */
}

#p-single article .article-post .content-quote .big-quotationmark {
  position: relative;
  /* 後述の疑似要素の表示位置の基準にする(必須) */
  background-color: #f7f7f7;
  /* 背景色(任意) */
  border: 1px solid #c7c7c7;
  /* 枠線(任意) */
  padding: 50px 40px 45px;
  margin: 0;
  border-radius: 4px;
}

#p-single article .article-post .content-quote .big-quotationmark::before {
  content: " “ ";
  /* 記号 */
  display: block;
  font-size: 300%;
  /* 表示サイズ */
  color: #033481;
  /* 表示色 */
  position: absolute;
  /* 絶対配置 */
  top: 25px;
  /* ボックス上端からの距離 */
  left: 20px;
  /* ボックス左端からの距離 */
}

#p-single article .article-post .content-quote .big-quotationmark::after {
  content: "”";
  /* 記号 */
  display: block;
  font-size: 300%;
  /* 表示サイズ */
  color: #033481;
  /* 表示色 */
  position: absolute;
  /* 絶対配置 */
  bottom: 0;
  /* ボックス下端からの距離 */
  right: 20px;
  /* ボックス右端からの距離 */
  height: 50px;
}

#p-single article .article-post .content-table {
  margin-bottom: 80px;
}

#p-single article .article-post .content-table table {
  width: 100%;
  border: 1px solid #033481;
  border-collapse: separate;
  border-spacing: 0;
  border-radius: 4px;
  overflow: hidden;
}
#p-single article .article-post .content-table table tr {
  height: 60px;
}

#p-single article .article-post .content-table table tr th {
  background-color: #f7f7f7;
}

#p-single article .article-post .content-table table tr td {
  padding-left: 30px;
}

#p-single article .article-post .content-table table .border-grey {
  border-bottom: #c7c7c7;
}
#p-single article .article-post table th,
#p-single article .article-post table td {
  white-space: nowrap;
  min-width: 60px;
}
#p-single article .article-post .content-column {
  background-color: #f7f7f7;
  border-radius: 4px;
  padding: 40px;
  border: 1px solid #c7c7c7;
}
#p-single article .article-post a {
  color: #41c9b4;
}
#p-single article .article-post .content-column .column-title {
  font-size: 20px;
  margin-bottom: 20px;
}

#p-single article .article-post .content-column .column-content {
  font-size: 16px;
}
a.wp-block-button__link.wp-element-button {
  display: flex;
  width: 350px;
  height: 68px;
  padding: 19px 73px;
  justify-content: center;
  align-items: center;
  gap: 10px;
  border-radius: 60px;
  background: #41c9b4;
  margin-top: 40px;
  margin-bottom: 40px;
}
#p-single article .article-post .wp-block-button a {
  color: #fff;
  text-align: center;
  font-family: "Noto Sans JP", sans-serif;
  font-size: 20px;
  font-style: normal;
  font-weight: 700;
  line-height: 150%; /* 30px */
}
.wp-block-code {
  box-sizing: border-box;
  padding: 24px;
  background-color: #ebebeb;
}
.wp-block-code code {
  color: #56585c;
  font-feature-settings:
    "clig" off,
    "liga" off;
  /* LP/S */
  font-family: "Noto Sans JP", sans-serif;
  font-size: 18px;
  font-style: normal;
  font-weight: 500;
  line-height: 30px; /* 166.667% */
  letter-spacing: 1px;
}
.schema-faq-section {
  margin-top: clamp(20px, 2.1vw, 34px);
  margin-bottom: clamp(20px, 2.1vw, 34px);
}
.schema-faq-question {
  display: flex;
  padding: 12px;
  align-items: center;
  gap: 8px;
  align-self: stretch;
  border-radius: 16px;
  background: #e3f1fe;
  color: #000;
  text-align: left;
  font-family: "Noto Sans JP", sans-serif;
  font-size: clamp(14px, 1.5vw, 18px);
  font-style: normal;
  font-weight: 700;
  line-height: normal;
  letter-spacing: 4px;
}
.schema-faq-question:before {
  /*content: url(images/Q.png);*/
  display: inline-block;
  vertical-align: middle;
  width: 30px;
  height: 30px;
  padding-top: 7px;
}
#p-single ul {
  display: flex;
  padding: 16px 24px;
  flex-direction: column;
  align-items: flex-start;
  gap: 8px;
  align-self: stretch;
  border: 1px dashed #41c9b4;
  background: #f4f6fc;
}
#p-single ol {
  display: flex;
  padding: 16px 24px;
  flex-direction: column;
  align-items: flex-start;
  gap: 8px;
  align-self: stretch;
  border: 1px dashed #41c9b4;
  background: #f4f6fc;
}
#p-single ul li {
  font-size: clamp(11.25px, 1.25vw, 16px);
  margin-bottom: 8px;
  list-style: none;
  padding-left: 24px;
  text-indent: -1em;
}
#p-single ol li {
  font-size: 16px;
  margin-bottom: 16px;
  list-style: none;
  padding-left: 24px;
}

#p-single ul > li:last-child {
  margin-bottom: 0;
}

#p-single ol > li:last-child {
  margin-bottom: 0;
}

#p-single ul > li::before {
  position: relative;
  top: 2px;
  left: -16px;
  display: inline-block;
  width: 16px;
  height: 16px;
  content: "";
  border-radius: 100%;
  background: #41c9b4;
}

#p-single ol > li::before {
  position: relative;
  top: 2px;
  left: -16px;
  display: inline-block;
  width: 16px;
  height: 16px;
  content: "";
  border-radius: 100%;
  background: #41c9b4;
}

#p-single #toc_container.no_bullets {
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  padding: 0;
  margin-top: 40px;
  margin-bottom: 40px;
}

#p-single #toc_container.no_bullets .toc_list {
  padding: 0;
  margin: 0;
  border: none;
  display: flex;
  padding: 0 clamp(12px, 4vw, 24px);
  flex-direction: column;
  align-items: flex-start;
  gap: 0px;
  align-self: stretch;
}
#toc_container p.toc_title {
  text-align: center;
  font-weight: 700;
  margin: 0;
  padding: 0;
  display: flex;
  padding: 9px 0px 8px 0px;
  justify-content: center;
  align-items: center;
  align-self: stretch;
  border-radius: 20px 20px 0 0;
  background: #41c9b4;
  color: #fff;
}
#toc_container span.toc_toggle {
  display: none;
}
#p-single #toc_container.no_bullets .toc_list > li {
  list-style: none;
  padding: clamp(4px, 1.25vw, 12px) 0 0 0;
  margin: 0;
  text-indent: 0;
}

#p-single #toc_container.no_bullets .toc_list > li > a {
  color: #41c9b4;
  text-align: center;
  font-family: "Noto Sans JP", sans-serif;
  font-size: 18px;
  font-style: normal;
  font-weight: 700;
  line-height: 150%;
}
#p-single #toc_container.no_bullets .toc_list > li > ul {
  padding: 0;
  border: none;
  display: block;
  list-style-type: disc;
  -webkit-margin-start: 0px;
  margin-inline-start: 0px;
  -webkit-margin-end: 0px;
  margin-inline-end: 0px;
  -webkit-padding-start: clamp(12px, 2.2vw, 20px);
  padding-inline-start: clamp(12px, 2.2vw, 20px);
}

#p-single #toc_container.no_bullets .toc_list > li > ol {
  padding: 0;
  border: none;
  display: block;
  list-style-type: disc;
  -webkit-margin-before: 1em;
  margin-block-start: 1em;
  -webkit-margin-after: 1em;
  margin-block-end: 1em;
  -webkit-margin-start: 0px;
  margin-inline-start: 0px;
  -webkit-margin-end: 0px;
  margin-inline-end: 0px;
  -webkit-padding-start: 40px;
  padding-inline-start: 40px;
  margin-top: 4px;
}

#p-single #toc_container.no_bullets .toc_list > li > ul li {
  margin: 0;
}

#p-single #toc_container.no_bullets .toc_list > li > ol li {
  margin: 3px 0;
}

#p-single #toc_container.no_bullets .toc_list > li > ul li > a {
  color: #56585c;
  font-family: "Noto Sans JP", sans-serif;
  font-size: clamp(14px, 1.25vw, 16px);
  font-style: normal;
  font-weight: 500;
  line-height: 1.7em;
  letter-spacing: 1px;
}
#p-single #toc_container.no_bullets .toc_list > li > ol li > a {
  color: #56585c;
  font-family: "Noto Sans JP", sans-serif;
  font-size: 18px;
  font-style: normal;
  font-weight: 500;
  line-height: 30px;
  letter-spacing: 1px;
}

#p-single #toc_container.no_bullets .toc_list > li > ul li ul {
  padding: 0;
  border: none;
  display: block;
  list-style-type: disc;
  -webkit-margin-start: 0px;
  margin-inline-start: 0px;
  -webkit-margin-end: 0px;
  margin-inline-end: 0px;
  -webkit-padding-start: clamp(12px, 2.2vw, 20px);
  padding-inline-start: clamp(12px, 2.2vw, 20px);
}

#p-single #toc_container.no_bullets .toc_list > li > ol li ol {
  padding: 0;
  margin: 0 !important;
  border: none;
  display: block;
  list-style-type: disc;
  -webkit-margin-before: 1em;
  margin-block-start: 1em;
  -webkit-margin-after: 1em;
  margin-block-end: 1em;
  -webkit-margin-start: 0px;
  margin-inline-start: 0px;
  -webkit-margin-end: 0px;
  margin-inline-end: 0px;
  -webkit-padding-start: 40px;
  padding-inline-start: 40px;
}

#p-single #toc_container.no_bullets .toc_list > li > ul li::before {
  position: relative;
  top: -4px;
  left: -10px;
  display: inline-block;
  width: 6px;
  height: 6px;
  width: 3px;
  height: 3px;
  content: "";
  border-radius: 100%;
  background: black;
}

#p-single #toc_container.no_bullets .toc_list > li > ol li::before {
  position: relative;
  top: -4px;
  left: -10px;
  display: inline-block;
  width: 6px;
  height: 6px;
  width: 3px;
  height: 3px;
  content: "";
  border-radius: 100%;
  background: black;
}

#p-single #toc_container.no_bullets .toc_list > li::before {
  display: none;
}

#p-single #toc_container.no_bullets .toc_list li:last-child ul {
  margin-bottom: 0;
}

#p-single #toc_container.contracted {
  width: 100% !important;
}

#p-single blockquote,
#p-single blockquote.wp-block-quote,
blockquote.wp-embedded-content {
  width: 100%;
  position: relative;
  display: inline-block;
  padding: 24px;
  flex-direction: column;
  align-items: flex-start;
  gap: 8px;
  align-self: stretch;
  color: #56585c;
  font-feature-settings:
    "clig" off,
    "liga" off;
  /* LP/S */
  font-family: "Noto Sans JP", sans-serif;
  font-size: clamp(11.25px, 1.25vw, 16px);
  font-style: normal;
  font-weight: 500;
  line-height: 30px; /* 166.667% */
  letter-spacing: 1px;
  border: 1px solid rgba(0, 0, 0, 0.2);
  background: #f4f6fc;
  margin-left: 0;
  margin-right: 0;
}
#p-single article .article-post a {
  color: #41c9b4;
}
#p-single blockquote p,
#p-single blockquote a {
  word-wrap: break-word !important;
  margin: 0;
}

#p-single blockquote::before {
  content: " “ ";
  display: block;
  font-size: 300%;
  color: #41c9b4;
  position: absolute;
  top: 12px;
  left: 12px;
}

#p-single blockquote::after {
  content: "”";
  display: block;
  font-size: 300%;
  color: #41c9b4;
  position: absolute;
  bottom: 0;
  right: 12px;
}

#p-single .wp-block-table {
  margin-top: 16px;
  margin-bottom: 20px;
}

#p-single table {
  width: 100%;
  border: none;
  border-collapse: separate;
  border-spacing: 0;
  border-radius: 4px;
  overflow: hidden;
  font-size: clamp(12px, 1.33vw, 16px);
  font-weight: 500;
  table-layout: auto;
}

#p-single table thead {
  background-color: none;
}
#p-single table thead {
  border-bottom: none;
}
#p-single table thead tr th {
  width: 160px;
  padding: clamp(11.25px, 1.77vw, 16px);
  border-bottom: none;
  background-color: #f4f6fc;
}
#p-single table tbody td {
  padding: 10px;
  white-space: normal;
}
.wp-block-table td,
.wp-block-table th,
#p-single article .article-post .content-table table,
#p-single article .article-post .content-table table tr,
#p-single article .article-post .content-table table th,
#p-single article .article-post .content-table table td {
  color: #56585c;
  border: none;
}
.wp-block-table {
  border-top: 0.704px solid rgba(0, 0, 0, 0.2);
  border-left: 0.704px solid rgba(0, 0, 0, 0.2);
}
.wp-block-table th,
.wp-block-table td {
  border-bottom: 0.704px solid rgba(0, 0, 0, 0.2);
  border-right: 0.704px solid rgba(0, 0, 0, 0.2);
}
#p-single table thead tr th,
#p-single article .article-post .content-table table th,
#p-single article .article-post .content-table table td {
  border-bottom: 0.704px solid rgba(0, 0, 0, 0.2);
}
figcaption.wp-element-caption {
  color: #56585c;
}
#p-single .wp-block-group .wp-block-group__inner-container {
  background-color: #f7f7f7;
  border-radius: 4px;
  padding: 40px;
  border: 1px solid #c7c7c7;
}

#p-single .wp-block-group .wp-block-group__inner-container h6 {
  font-size: 20px;
  margin-bottom: 20px;
}

#p-single .wp-block-group .wp-block-group__inner-container p {
  font-size: 16px;
}
#p-single ul > li::before {
  position: relative;
  top: 2px;
  left: -16px;
  display: inline-block;
  width: 16px;
  height: 16px;
  content: "";
  border-radius: 100%;
  background: #41c9b4;
}
#p-single ol > li::before {
  position: relative;
  top: 2px;
  left: -16px;
  display: inline-block;
  width: 16px;
  height: 16px;
  content: "";
  border-radius: 100%;
  background: #41c9b4;
}
#p-single #toc_container.no_bullets .toc_list {
  padding-top: 1em;
  list-style-type: decimal;
  padding-bottom: clamp(12px, 1.25vw, 24px);
}
#p-single #toc_container.no_bullets .toc_list > li > ul li::before {
  display: none;
}
#p-single #toc_container.no_bullets .toc_list > li > ul li {
  list-style: none;
  padding-left: 0;
  padding-top: 4px;
  text-indent: 0;
}
#p-single #toc_container span.toc_number.toc_depth_2 {
  display: none;
}
.pccta img {
  max-width: 100%;
  height: auto;
  width: 100%;
}
.wp-block-table td,
.wp-block-table th {
  padding: 0.5em;
  background-color: #f4f6fc;
}
.wp-block-table td,
.wp-block-table td {
  padding: 0.5em;
  background-color: #fff;
}
.wp-block-buttons > .wp-block-button {
  margin: auto;
}
#p-single article .article-post a {
  color: #41c9b4;
}
@media screen and (min-width: 1400px) {
  #p-single article {
    max-width: 760px;
    /* margin-left: 0;
    margin-right: 0; */
  }
  #p-single article .article-post {
    max-width: 760px;
  }
  #article img {
    width: 100%;
  }

  .wp-block-embed iframe.wp-embedded-content {
    clip: auto !important;
  }
  .alert-info {
    background-color: #d9edf7;
    color: #31708f;
    border-color: #bce8f1;
    margin: 40px 0;
  }
}

@media screen and (min-width: 1100px) {
  .spcta {
    display: none;
  }
}

@media screen and (min-width: 900px) {
  .textwidget {
    margin-bottom: 39px;
  }

  .textwidget .sticky__banner--cont {
    max-width: 402px;
    margin-bottom: 40px;
    transition: all 0.5s ease 0s;
  }
  .textwidget .sticky__banner--cont img:hover {
    opacity: 0.8;
  }
  .under_899,
  br.pad_only {
    display: none;
  }
}

@media screen and (min-width: 900px) {
  #sidebar .related__article img {
    width: 100%;
    height: 100%;
    object-fit: cover;
  }
  .spcta {
    display: none;
  }
}
@media screen and (min-width: 900px) and (max-width: 1399px) {
  header .header_wrapper,
  .cta_footer {
    width: 80%;
  }
  .single_wrapper {
    display: flex;
    justify-content: space-between;
    width: 80%;
  }
  #p-single {
    width: 70%;
  }

  #p-single article .article-post {
    width: calc(100% - 24px);
  }
  #p-single article .article-post h1 {
    font-size: clamp(21px, 2.33vw, 30px);
    margin-top: 0;
  }
  #p-single p {
    font-size: clamp(11.25px, 1.25vw, 16px);
    line-height: clamp(21px, 2.33vw, 30px);
  }
  #toc_container p.toc_title {
    font-size: clamp(12.5px, 1.39vw, 18px);
  }
  #p-single #toc_container.no_bullets .toc_list > li > a {
    font-size: clamp(16px, 1.78vw, 18px);
  }
  #p-single #toc_container.no_bullets .toc_list > li > ul li > a {
    font-size: clamp(14px, 1.56vw, 16px);
  }
  #p-single article .article-post h2 {
    font-size: clamp(16px, 1.78vw, 20px);
    line-height: 1.3;
    padding: clamp(10px, 1.11vw, 16px);
  }
  #p-single table {
    font-size: clamp(11.25px, 1.25vw, 18px);
  }
  #p-single table th,
  #p-single table td {
    padding: clamp(11.25px, 1.25vw, 16px);
  }
  #p-single article .article-post h3 {
    font-size: clamp(14px, 1.55vw, 20px);
  }
  #p-single h2,
  #related_blog h2 {
    font-size: clamp(18.75px, 2.08vw, 30px);
  }

  .textwidget,
  .textwidget .sticky__banner--cont {
    margin-bottom: clamp(25px, 2.77vw, 40px);
  }
  .author__company--wrapper {
    padding-top: clamp(15px, 1.66vw, 24px);
    padding-bottom: clamp(15px, 1.66vw, 24px);
    padding-left: clamp(25px, 2.77vw, 40px);
    padding-right: clamp(25px, 2.77vw, 40px);
  }
  .author__company--wrapper .img__flex img {
    width: clamp(62.5px, 6.94vw, 100px);
    height: clamp(62.5px, 6.94vw, 100px);
    margin-right: clamp(20px, 2.22vw, 32px);
  }
  .author__company--wrapper .img__flex .block,
  .author__company--wrapper .img__flex .block .name {
    font-size: clamp(10.8px, 1.2vw, 16.8px);
  }
  .author__company--wrapper .cont {
    font-size: clamp(11.25px, 1.25vw, 18px);
    line-height: 1.66;
  }
}

@media screen and (max-width: 899px) {
  #p-single .wp-element-caption {
    font-size: 12px;
  }
  aside#sidebar {
    display: none;
  }
  br.pad_only {
    display: block;
  }
  .under_899 {
    width: calc(100% - 80px);
    max-width: 899px;
    margin-left: auto;
    margin-right: auto;
  }
  header .header_wrapper {
    width: calc(100% - 80px);
    max-width: 899px;
  }
  .single_wrapper {
    margin-top: 0;
  }

  #p-single article {
    width: 100%;
    max-width: 100%;
  }
  #p-single article .article-post {
    width: calc(100% - 80px);
    max-width: 100%;
    padding-top: 40px;
    margin: auto;
  }
  #p-single article .article-post h1 {
    color: #41c9b4;
    font-family: "Noto Sans JP", sans-serif;
    font-size: 22px;
    font-style: normal;
    font-weight: 700;
    line-height: 160%;
  }
  #p-single p {
    color: #56585c;
    font-family: "Noto Sans JP", sans-serif;
    font-size: 12px;
    font-style: normal;
    font-weight: 500;
    line-height: 24px;
    letter-spacing: 1px;
    margin-bottom: 0;
  }
  #p-single #toc_container.no_bullets .toc_list > li > a {
    color: #41c9b4;
    font-family: "Noto Sans JP", sans-serif;
    font-size: 14px;
    font-style: normal;
    font-weight: 700;
    line-height: 150%;
  }
  #p-single h2 {
    margin-top: 16px;
    margin-bottom: 24px;
  }
  #p-single a.cta {
    text-align: center;
  }
  #p-single a.cta {
    margin-left: 40px;
    margin-right: 40px;
  }
  #p-single a.cta img {
    height: auto;
  }
  #p-single .wp-block-image {
    margin: 0 0 24px 0;
    text-align: center;
  }
  #p-single article .article-post h2 {
    font-size: 18px;
    font-weight: bold;
    padding: 8px 16px;
  }
  .author__company--wrapper .img__flex img {
    width: 72px;
    height: 72px;
    border-radius: 50%;
    margin-right: 16px;
  }
  .author__company--wrapper .img__flex .block {
    font-size: 18px;
  }
  .author__company--wrapper .cont {
    font-size: 14px;
  }
  .sticky__banner--cont {
    text-align: center;
  }
  .sticky__banner--cont img {
    max-width: 352px;
  }
  .yarpp-related {
    margin-bottom: 16px;
    margin-top: 16px;
  }
  .yarpp-related .article {
    display: flex;
    margin-top: 16px;
    margin-bottom: 16px;
  }
  .yarpp-related .article a .thumbnail {
    width: 150px;
    height: 90px;
  }
  .yarpp-related .article a .thumbnail img {
    width: 150px;
    height: 90px;
    max-width: 100% !important;
  }
  .yarpp-related .article .cont_wrapper {
    margin-left: 16px;
    position: relative;
  }
  .yarpp-related .article .cont_wrapper a {
    font-weight: 700;
    text-decoration: none;
    color: #000;
    font-family: "Noto Sans JP", sans-serif;
    font-size: 14px;
    font-style: normal;
    font-weight: 700;
    line-height: normal;
    letter-spacing: 4px;
    overflow: hidden;
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2;
  }
  .yarpp-related .article .cont_wrapper .category-area {
    display: flex;
    height: 25px;
    padding: 2px 0;
    justify-content: center;
    align-items: center;
    gap: 8px;
    position: absolute;
    bottom: 0;
    left: 0;
  }
  .yarpp-related .article .cont_wrapper .category-area .category {
    display: flex;
    height: 25px;
    padding: 2px 12px;
    justify-content: center;
    align-items: center;
    gap: 8px;
    border: none;
    border-radius: 30px;
    background: #41c9b4;
  }
  .yarpp-related .article .cont_wrapper .category-area .category span {
    font-size: 12px;
    color: #fff;
  }

  #closed {
    height: auto;
    margin: auto;
    padding-top: 24px;
    padding-bottom: 70px;
    text-align: center;
  }
  #closed .closed__flex--img img {
    max-width: 276px;
    height: auto;
  }
  #closed .closed__wrapper .copy p {
    color: #41c9b4;
    font-family: "Noto Sans JP", sans-serif;
    font-size: 18px;
    font-style: normal;
    font-weight: 700;
    line-height: 160%;
  }
  #closed .closed__wrapper #cv .wrapper {
    border-radius: 60px;
    background: #41c9b4;
    display: flex;
    width: 327px;
    height: 41.349px;
    padding: 0;
    justify-content: center;
    align-items: center;
    gap: 6.081px;
    align-self: stretch;
  }
  #closed .closed__wrapper #cv .wrapper a {
    color: #fff;
    text-align: center;
    font-family: "Noto Sans JP", sans-serif;
    font-size: 14px;
    font-style: normal;
    font-weight: 700;
    line-height: 150%;
  }
}

@media screen and (max-width: 520px) {
  .under_899 {
    width: calc(100% - 32px);
    max-width: 767px;
  }
  header .header_wrapper,
  #related_blog .wrapper.popular_articles,
  #related_blog .wrapper.new_articles {
    width: calc(100% - 32px);
    max-width: 767px;
  }
  #p-single article .article-post {
    width: calc(100% - 32px);
    padding-top: 28px;
  }
  #p-single article .article-post h3,
  #p-single article .article-post h4 {
    margin-top: 24px;
    margin-bottom: 24px;
  }
  #p-single article .article-post h3:before {
    width: 184px;
    height: 2px;
  }
  #p-single article .article-post h4 {
    font-size: 14px;
  }
  #p-single ul > li {
    font-size: 14px;
  }
  #p-single ol > li {
    font-size: 14px;
  }
  #p-single ul > li::before {
    width: 12px;
    height: 12px;
  }
  #p-single ol > li::before {
    width: 12px;
    height: 12px;
  }
  .wp-block-code {
    padding: 16px;
  }
  .wp-block-code code {
    font-size: 14px;
  }
  #p-single blockquote {
    word-wrap: break-word !important;
  }
  #p-single blockquote::before {
    font-size: 400%;
    left: 16px;
    top: 32px;
  }
  #p-single blockquote::after {
    font-size: 400%;
    right: 16px;
    bottom: 14px;
  }
  #p-single blockquote.wp-block-quote,
  #p-single blockquote.wp-embedded-content {
    padding: 56px 24px;
  }
  #p-single blockquote p,
  #p-single blockquote a {
    word-wrap: break-word !important;
    color: #56585c;
    font-feature-settings:
      "clig" off,
      "liga" off;
    /* LP/S */
    font-family: "Noto Sans JP", sans-serif;
    font-size: 18px;
    font-style: normal;
    font-weight: 500;
    line-height: 30px; /* 166.667% */
    letter-spacing: 1px;
  }
  #p-single article .article-post .wp-block-button {
    margin: auto;
  }
  #p-single article .article-post .wp-block-button a {
    display: flex;
    width: 213px;
    height: 41px;
    color: #fff;
    font-size: 14px;
    padding: 0;
    justify-content: center;
    align-items: center;
    gap: 6.081px;
    transition: all 0.5s ease 0s;
  }
  #p-single .schema-faq-question,
  #p-single p.schema-faq-answer {
    font-size: 14px;
  }
  #p-single .schema-faq-question:before {
    /*content: url(images/Q.png);*/
    width: 23px;
    height: 23px;
    padding-top: 0;
    padding-right: 15px;
  }
  #p-single a.cta {
    width: calc(100% - 32px);
    margin: auto;
  }
}

@media screen and (min-height: 851px) {
  #scroll_850 {
    display: none;
  }
}

@media screen and (max-height: 900px) {
  #sidebar-scroll {
    top: 0;
    margin-top: 50px;
    padding-bottom: 0;
  }
  .textwidget .sticky__banner--cont img {
    max-width: 80%;
  }
}

@media screen and (max-height: 750px) {
  #sidebar-scroll {
    margin-top: 0;
  }
}

@media screen and (max-height: 700px) {
  #sidebar-scroll {
    margin-top: 0px;
  }
  .textwidget .sticky__banner--cont img {
    max-width: 70%;
  }
}

@media screen and (max-height: 650px) {
  .textwidget .sticky__banner--cont img {
    max-width: 60%;
  }
}
