@charset "utf-8";

/*投稿の位置調整*/
img.alignright {
    display: block;
    margin: 0 0 0 auto;
}
img.alignleft {
    display: block;
    margin: 0 auto 0 0;
}
img.aligncenter {
    display: block;
    margin: 0 auto;
}

.c-post [class^=c-grid__item], .c-post [class*=" c-grid__item"] {
    background-color: #fff!important;
}

/*投稿用ページ区切り*/
.pagebreak-links{
  text-align: center;
  margin-bottom: 30px;
}
.pagebreak-links .post-page-numbers{
  background-color: #402699;
  border: 1px solid #cbcbcb;
  border-radius: 8rem;
  color: #fff;
  display: inline-block;
  height: 48px;
  line-height: 46px;
  margin: 0 10px;
  padding: 0 0.25rem;
  position: relative;
  width: 75px;
}
.pagebreak-links .current{
  background-color: #f5f5f5 !important;
  color: #6b6b6b !important;
}

/*トップページ NEWSテキストサイズ調整 */
.c-title-top .txtsmall {
    font-size: 1.9rem;
}

@media screen and (min-width: 992px) {
    .c-title-top .txtsmall {
        font-size: 1.5rem;
    }
}

/*レスポンシブの表示・非表示*/
.pc_view{
  display: block;
}
.sp_view{
  display: none;
}
@media screen and (max-width: 992px){
  .pc_view{
    display: none;
  }
  .sp_view{
    display: block;
  }
}

/*段落字下げ */
.font_indent::first-letter {
  display: inline-block;
  margin-left: 1rem; /* 字下げのスペースを指定 */
}

/*Ｑ＆Ａ字下げ */
.qa dl{
  counter-increment: qa;
}
.qa dl dt{
  margin-left:2rem;
}
.qa dl dt:before{
  content: "Q" counter(qa) ".";
  margin-right: 10px;
  margin-left:-2rem;
}
.qa dl dd{
  margin-left:2rem;
}
.qa dl dd:before{
  content: "A" counter(qa) ".";
  margin-right: 10px;
  margin-left:-2rem;
}

/*ulスペース */
.c-post ul{
  /*margin-bottom: 4rem!important;*/
}



/*------------------------------------------
   common
--------------------------------------------*/
.u-bg-orange {
  background-color: #ea6f00 !important;
}
.u-bg-brown {
  background-color: #3c2c25 !important;
}
.u-bg-ygreen {
  background-color: #d3eea6 !important;
}
.u-bg-beige {
  background-color: #f5f5ee !important;
}
.u-t-orange {
  color: #ea6f00 !important;
}
.u-t-brown {
  color: #3c2c25 !important;
}
.u-t-lgray {
  color: #7f7f7c !important;
}
.u-b-orange {
  border-color: #ea6f00 !important;
}
.u-b-lgray {
  border-color: #7f7f7c !important;
}
.u-b-thick {
  border-width: 3px !important;
}
.l-header {
  border: none !important;
}
@media screen and (min-width: 992px) {
  .l-header {
    height: 96px;
    align-items: center;
  }
}
.l-header__logo {
  max-width: 159px;
  height: auto!important;
}
@media screen and (min-width: 992px) {
  .l-header__logo {}
}
.l-header__menu-parent--contact a {
  background-color: #ea6f00 !important;
}
.l-header__menu-parent:before {
  background-color: inherit;
  color: #ea6f00;
}
@media screen and (min-width: 992px) {
  li.l-header__menu-parent.is-current a {
    color: #ea6f00 !important;
  }
}
.l-header__navigation {
  background-color: #3c2c25;
  opacity: .9;
}
@media screen and (min-width: 992px) {
  .l-header__navigation {
    background-color: transparent;
  }
}
.l-header__toggle-icon {
  background-color: #ea6f00 !important;
}
.l-header__toggle-text {
  color: #ea6f00 !important;
}
.u-bg-breadcrumb {
  background-color: #ebebde !important;
}
@media screen and (min-width: 992px) {
  .l-main {
    padding-top: 96px !important;
  }
}
@media screen and (min-width: 1200px) {
  .l-main {
    padding-top: 96px !important;
  }
}
.l-footer__totop {
  aspect-ratio: 1 / 1;
  background-image: url(../images/pagetop.png) !important;
}
.l-footer {
  background-color: #3c2c25;
}
.l-footer .c-contact-button, .l-header__navigation .c-contact-button {
  border-radius: 8rem;
  color: #fff;
  display: block;
  font-weight: 500;
  margin-inline: auto;
  max-width: 20rem;
  overflow: hidden;
  padding: 1.25rem 2.75rem;
  position: relative;
  text-align: center;
  text-overflow: ellipsis;
  white-space: nowrap;
  width: 100%;
}
.l-footer .c-contact-button i, .l-header__navigation .c-contact-button i {
  padding-right: 1rem;
}

/*------------------------------------------
   トップページ　メインビジュアル
--------------------------------------------*/
.p-mainvisual {
  margin-bottom: 55px;
  height: inherit;
  padding-top: 60px;
  background: url(../images/sp_main_img.png) no-repeat top center;
  background-size: 100% auto;
  position: relative;
  box-sizing: border-box;
  z-index: 2;
}
@media screen and (min-width: 1024px) {
  .p-mainvisual {
    margin-bottom: 50px;
    height: 760px;
    padding-top: 100px;
    background: url(../images/main_img.png) no-repeat bottom center;
    background-size: cover;
  }
}

.c-intro__content {
  position: relative;
  z-index: 2;
  padding-top: 15%;
}
@media screen and (min-width: 1024px) {
  .c-intro__content {
    display: flex;
    margin: 0 auto 0 0;
    max-width: 1530px;
    padding-top: 0;
    padding-left: 5%;
  }
}
.c-intro__content-image {
  aspect-ratio: 8 / 5;
  background-position: center;
  background-size: cover;
  margin-bottom: 2rem;
  padding: 5%;
}
@media screen and (min-width: 1024px) {
  .c-intro__content-image {
    aspect-ratio: auto;
    flex-shrink: 0;
    margin-bottom: 0;
    max-width: none;
    width: 60%;
  }
}
.c-intro__content-text {
  margin: 0 auto;
  max-width: 570px;
}
@media screen and (min-width: 1024px) {
  .c-intro__content-text {
    flex-shrink: 0;
    width: 40%;
  }
}


.c-title-border, .c-title-border_center {
  position: relative;
  padding-bottom: 1rem;
}
@media screen and (min-width: 992px) {
  .c-title-border {}
}
.c-title-border::after, .c-title-border_center::after {
  bottom: 0;
  content: "";
  display: block;
  height: 2px;
  left: 0;
  position: absolute;
  width: 38px;
  background-color: #ea6f00;
}
@media screen and (min-width: 992px) {
  .c-title-border::after, .c-title-border_center::after {
    width: 56px;
    height: 4px;
  }
}
.c-title-border_center::after {
  left: 50%;
  transform: translateX(-50%);
}

/*------------------------------------------
   トップページ　記事
--------------------------------------------*/
.c-titlebox {
  width: 100%;
  padding-left: 1rem;
  padding-right: 1rem;
}
@media screen and (min-width: 1024px) {
  .c-titlebox {
    margin: 0 auto;
    max-width: 1310px;
    width: 100%;
    display: flex;
    align-items: center;
  }
}
@media screen and (min-width: 1400px) {
  .c-titlebox {
    max-width: 1310px;
    margin-left: 20%;
    width: 68.23%;
  }
}
@media screen and (min-width: 1024px) {
  .c-titlebox__text {
    padding-right: 4.375rem;
    width: 52.6%;
  }
  .c-titlebox__image {
    max-width: 660px;
    width: 47.4%;
  }
}
.c-overlap {
  position: relative;
}
.c-overlap .deco1 {
  position: absolute;
  right: 16px;
  bottom: -20px;
  width: 90px;
  z-index: 2;
}
@media screen and (min-width: 768px) {
  .c-overlap .deco1 {
    right: 40px;
    width: 140px;
  }
}
.c-overlap .deco2 {
  position: absolute;
  left: 16px;
  bottom: -20px;
  width: 98px;
  z-index: 2;
}
@media screen and (min-width: 768px) {
  .c-overlap .deco2 {
    left: 80px;
    width: 154px;
  }
}
.c-overlap .deco3 {
  position: absolute;
  right: 16px;
  bottom: -20px;
  width: 90px;
  z-index: 2;
}
@media screen and (min-width: 768px) {
  .c-overlap .deco3 {
    right: 40px;
    width: 120px;
  }
}
.c-overlap .c-overlap__left {
  border-radius: 0 0 0 2rem;
  left: auto;
  right: 0;
  bottom: 0;
  display: block;
  position: absolute;
  top: 0;
  z-index: 1;
}
@media screen and (min-width: 992px) {
  .c-overlap .c-overlap__left {}
}
.c-overlap .c-overlap__left, .c-overlap .c-overlap__right {
  display: block !important;
  background: linear-gradient(rgba(255, 255, 255, 0), rgba(245, 245, 238, 1));
  width: calc(100% - 4.17%);
}
@media screen and (min-width: 1200px) {
  .c-overlap .c-overlap__left, .c-overlap .c-overlap__right {}
}
.c-overlap .c-overlap__line {
  background-color: inherit !important;
}
.c-swiper .c-swiper__article {
  background-color: #f5f5ee;
  background-image: none;
}
.c-swiper .swiper-pagination-bullet-active {
  background-color: #eaa500;
}
.p-news {
  background-image: none;
}

/*------------------------------------------
   投稿一覧
--------------------------------------------*/
.c-side-title {
  line-height: 1 !important;
}
.c-tags li {
  border: none !important;
  display: inline-block;
  margin-left: .25rem;
}
.c-tags li:not(:last-child) {
  margin-bottom: .5rem;
  margin-left: .25rem;
}
.c-tags a {
  border: 1px solid #7f7f7c;
  border-radius: 8rem;
  color: #7f7f7c;
  font-size: .707rem;
  padding: .25rem .5rem;
}
body {
  counter-reset: number 0;
}
.c-side-ranking li {
  position: relative;
}
.c-side-ranking li::before {
  counter-increment: number 1;
  content: counter(number);
  width: 28px;
  height: 28px;
  border-radius: 50%;
  background-color: #3c2c25;
  text-align: center;
  line-height: 28px;
  font-size: .875rem;
  font-weight: bold;
  color: #fff;
  position: absolute;
  top: -14px;
  z-index: 2;
  left: 8px;
}
.post-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 0;
  list-style: none;
  padding: 0;
  margin-top: 0.5rem;
}
.post-tags li {
  padding: 0.3rem 0 0.3rem 0.3rem;
  font-size: .875rem;
  text-decoration: none;
  line-height: .875rem;
}
.post-tags li:first-child {
  padding-left: 1.5em;
  position: relative;
}
.post-tags li:first-child::before {
  font-family: 'Material Icons Outlined';
  content: '\f05b';
  position: absolute;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
  font-size: 1.25rem;
  color: #ea6f00;
}

/*一覧ページ用*/
.posts-list .post-tags li:first-child::before {
    font-family: 'Material Icons Outlined';
    content: '\f05b';
    position: absolute;
    left: 0;
    top: 50%;
    transform: translateY(-50%);
    font-size: 1.25rem;
    color: #7f7f7c;
}

.post-tags li a {
  color: #ea6f00;
  padding: 0.3rem 0.6rem;
  font-size: .875rem;
  text-decoration: none;
}
.c-link-pagenation li > a {
  aspect-ratio: 1 / 1;
  background-color: #fff;
  border: none !important;
  border-radius: 50%;
  color: #7f7f7c;
  width: 100%;
}
.c-link-pagenation li > a:hover, .c-link-pagenation li > a.is-current {
  background-color: #ea6f00;
  color: #fff;
}
.c-post h2 {
  color: #3c2c25;
  font-size: 1.5rem;
  line-height: 1.5;
  padding: 1rem 2rem;
  background-color: #f8d1ad;
  border-left: none !important;
  border-top: none !important;
  border-bottom: none !important;
  font-weight: bold;
}
.c-post h3 {
  border-bottom: 1px solid #ea6f00 !important;
  border-top: 2px solid #ea6f00 !important;
  border-left: none !important;
  color: #3c2c25 !important;
  font-size: 1.25rem !important;
  line-height: 1.8 !important;
  padding-block: 1rem !important;
}
.c-post h4 {
  color: #3c2c25;
  border-left: none !important;
}
.c-post h4::before {
  color: #3c2c25;
}
.c-post mark {
  background: linear-gradient(transparent 50%, #fef348 50%);
  color: #3c2c25;
}
.c-post strong {
  font-weight: bold;
  background: none;
}

.c-post .alert {  
  font-weight: bold;
  display: inline;
  background: linear-gradient(transparent 50%, #fef348 50%);
  margin-bottom: 1.5rem;
}
.c-post a {
  color: #3c2c25 !important;
  display: inline;
  text-decoration: underline;
}
.c-post table tr:first-child td {
  border-bottom: 2px solid #cbcbcb;
}
.c-post table tr td:first-child {
  background-color: #f5f5ee;
}

.c-form {
  background-color: #fff !important;
}
.p-country-name {
  display: none !important;
}
.mwform-radio-field.horizontal-item {
  display: block;
  margin: 0 !important;
  padding: 0 !important;
}
.c-form dd label {
  width: 100%;
}
.c-form .error {
  color: #ea6f00 !important;
}
.c-form .is-error label, .c-form .is-error input, .c-form .is-error textarea {
  background-color: #f5f5ee !important;
  border-color: #ea6f00 !important;
}
@media screen and (min-width: 768px) {
  .c-form dd label {
    width: 50%;
  }
}

#toc_container {
  width: 100% !important;
  border-radius: 1.5rem;
  border-width: 2px;
  border-color: #ea6f00;  
  padding: 2.5rem;
}
#toc_container p.toc_title {
  text-align: left;
  color: #ea6f00;
  font-size: 1.25rem;
}
#toc_container span.toc_toggle {
  color: #3c2c25;
  font-size: .875rem;
}
#toc_container p.toc_title+ul.toc_list {
  margin-bottom: 1rem!important;
}
#toc_container .toc_list li a {
  font-size: 1rem;
}
.c-link-prev-next span {
  color: #3c2c25 !important;
}
.c-link-prev-next .c-link-prev-next__prev,
.c-link-prev-next .c-link-prev-next__next {
  background-color: inherit!important;
  border: none!important;
  border-radius: inherit!important;
  color: #3c2c25!important;
}
.c-link-prev-next .c-link-prev-next__prev .u-button-arrow,
.c-link-prev-next .c-link-prev-next__next .u-button-arrow {
  padding-bottom: .5rem;
  border-bottom: 1px solid #3c2c25;
}
.c-link-prev-next .c-link-prev-next__next i,
.c-link-prev-next .c-link-prev-next__prev i {
  background-color: #ea6f00;
  border-radius: 50%;
  color: #fff;
  display: inline-block;
  font-size: 1.25rem;
  padding: .25rem;
}
.c-link-prev-next .c-link-prev-next__next i {
  right: 0!important;
}
.c-link-prev-next .c-link-prev-next__prev i {
  left: 0!important;
}
.c-post-button::after {
  font-family: 'Material Icons';
  content: '\e89e';
  font-size: 1rem;
}
.c-post a.c-link-button {
  color: #fff !important;
  font-size: 1rem !important;
}


/*定型文　区切り線追加*/
hr.dots {
  margin: 2em auto 3rem !important;
  width: 40%;
  height: 12px;
  border: none;

  background-image: radial-gradient(circle, #3c2c25 3px, transparent 4px);
  background-size: 30px 12px;
  background-repeat: repeat-x;
  background-position: center;
}