@charset "utf-8";

/*============================================*/
/*看板周辺 */
/*============================================*/
#introduction {text-align: center;}
h1#top_title {display:none;}
#introduction picture {
  display:block;
  margin: 0 auto;
}
.lead{
  background-color: rgba(255, 255, 255, 0.8);
  padding: 50px 0px;
  margin-bottom: 50px;
}
.lead-img{
  background-color: rgba(255, 216, 209, 0.8);
}
h2.lead_title {
    font-family: "Zen Old Mincho", serif;
    font-size: 2.2rem;
    font-weight: bold;
    color: #666;
    margin-bottom: 30px;
}
.lead_text {
  font-family: "Zen Old Mincho", serif;
  font-size: 1.2rem;
  font-weight: bold;
  color: #666;
  line-height: 1.6em;
  letter-spacing: 1px;
  margin-bottom: 50px;
}
#introduction p {
  font-size: 1rem;
  font-weight: normal;
  line-height: 1.8em;
  text-align: left;
}
#introduction p span{
    font-weight: bold;
}
@media (max-width: 767px) {
h2.lead_title {font-size: 1.5rem;}
#introduction,.lead_text {font-size: 1.1rem;}
#introduction p {
    font-size: 0.85rem;
    padding: 0px;
}
}
#introduction nav {
  padding: 0px;
  max-width: 900px;
  margin: 0px auto;
}
#introduction nav menu {
  list-style-type: none;
  padding-left: 0;
  display: grid;
  grid-column-gap: 10px;
  grid-row-gap: 10px;
  grid-template-rows: column;
  grid-template-columns: repeat(4, 1fr);
}
#introduction nav menu li {
  background-color:#fff8f9;
  border: solid 1px #d35b62;
  border-radius: 5px;
  text-align: center;
  padding: 10px;
  font-size: 0.9rem;
  font-weight: bold;
  color:#d35b62;
}
#introduction nav menu li:hover {
    border: solid 1px #d35b62;
    box-shadow: 2px 2px 0px #d35b62;
}
#introduction nav menu li img{
    padding: 0px;
    margin: 0px 0px 0px 5px;
}
@media (max-width: 767px) {
#introduction nav {padding: 0px;}
#introduction nav menu {
grid-column-gap: 5px;
grid-row-gap: 5px;
grid-template-columns: repeat(2, 1fr);
}
#introduction nav menu li {
  padding: 3px 5px;
  font-size: 0.75rem;
  letter-spacing: 0px;
}
#introduction nav menu li img{margin: 0px;}
}

/*============================================*/
/*レイアウト */
/*============================================*/
.mamapan {
  overflow: hidden;
  color:#333;
  background: url('img/leaf.png'), linear-gradient(150deg, #fff7f8 0%, #fff0f2 45%, #ffe1e4 70%, #ffd8d1 100%) ;
  /*background-color: #ffeded;
  background-image: url('img/leaf.png');*/
  background-repeat: repeat;
  background-attachment: fixed;
}
.mamapan article {
  font-size: 1rem;
  line-height:2rem;
}
.article_frame {
  position: relative;
  display:block;
  margin: 0px auto;
  max-width:1200px;
  padding: 50px 30px;
  overflow: hidden;
  background-color: rgba(255, 255, 255, 0.8);
  border-bottom: solid 1px #d35b62;
}
.article_frame::after {
    position: absolute;
    content: '';
    right: 0;
    bottom: 0;
    border-width: 0 0 25px 25px;
    border-style: solid;
    border-color: transparent transparent #d35b62 transparent;
}
.article_frame p{line-height: 1.6em;}
@media (max-width: 767px) {
.mamapan article {padding: 0px 5px;}
.article_frame {padding: 50px 5px;}
}
.grd_gp20 {
  display: grid;
  grid-column-gap: 20px;
  grid-row-gap: 20px;
  grid-template-columns: repeat(auto-fit);
  justify-content: center;
}
/*均等2分割*/
.grd_col_2fr {
  grid-template-columns: repeat(2, 1fr);
}
/*均等4分割*/
.grd_col_4fr {
  grid-template-columns: repeat(4, 1fr);
}
@media (max-width: 767px) {
/*スマホ表示の際、分割せず縦並び*/
.grd_sp1fr {
grid-template-columns: 1fr;
grid-column-gap: 10px;
grid-row-gap: 10px;
}
/*スマホ表示の際、均等2分割横並び*/
.grd_sp2fr {
grid-template-columns: 1fr 1fr;
grid-column-gap: 10px;
grid-row-gap: 10px;
  }
}
/*============================================*/
/*画像キャプション設定 */
/*============================================*/
figcaption{
  font-size: clamp(0.9rem, 0.727rem + 0.36vw, 1.2rem);
  margin-top:5px;
  font-family: "Noto Sans JP", sans-serif;
  line-height: 1.5rem;
  color:#333;
}
figcaption span{
  font-size:clamp(0.7rem, 0.627rem + 0.36vw, 0.9rem);
}
figcaption strong{
  font-size:clamp(0.9rem, 0.927rem + 0.36vw, 1.2rem);
  font-weight:bold;
  display:inline-block;
  margin-bottom:20px;
}
figcaption p{
  font-size:clamp(0.813rem, 0.744rem + 0.34vw, 1rem);
  line-height: 1.8em;
}
@media (max-width: 767px) {
    figcaption{margin: 0px;}
}

/*============================================*/
/*見出し */
/*============================================*/
h3.main_heading {
  position: relative;
  font-family: "Zen Old Mincho", serif;
  font-size: 1.6rem;
  font-weight:bold;
  line-height:2.2rem;
  text-align: center;
}
h4.sub_heading {
  font-family: "Arial";
  text-align: left;
  font-size: 1.6rem;
  font-weight:bold;
  color: #555;
  border-left: solid 20px #d35b62;
  border-bottom: solid 1px #d35b62;
  padding: 0px 0px 0px 10px;
}
h4.sub_heading span{
    font-family: "Noto Sans JP", sans-serif;
    font-size: 0.9rem;
    font-weight: bold;
}
h4.sub_heading span::before{
    content: "|";
    font-size: 1.2rem;
    font-weight: normal;
    margin: 0px 15px;
}
h5.sub_sub_heading {
  display: inline-block;
  font-family: "Noto Sans JP", sans-serif;
  font-size: 1.1rem;
  font-weight: bold;
  color: #333;
  background: linear-gradient(transparent 60%, #ffd7d7 60%);
  margin-bottom: 20px;
}
h5.sub_sub_heading span {
    font-family: "Zen Old Mincho", serif;
    font-style: italic;
    font-size: 2.5rem;
    margin-right: 5px;
    margin-top: 2px;
}
@media (max-width: 767px) {
h3.main_heading {font-size: 1.2rem;}
h4.sub_heading {
  font-size: 1.1rem;
  border-left: solid 15px #d35b62;
  padding-left: 5px;
}
h4.sub_heading span{font-size: 0.65rem;}
h4.sub_heading span::before{
    content: "|";
    font-size: 1.0rem;
    margin: 0px 8px;
}
h5.sub_sub_heading {font-size: 0.9rem;}
h5.sub_sub_heading span {font-size: 1.5rem;}
}
/*============================================*/
/*フレックス設定 */
/*============================================*/
/*22+76分割 */
.mam_flex{
    display: flex;
    justify-content: space-between;
    align-items: center;
}
.mam_flex-box01{
    display: inline-block;
    width: 22%;
}
.mam_flex-box02{
    display: inline-block;
    width: 76%;
}
@media (max-width: 767px) {
.mam_flex{display: block;}
.mam_flex-box01{
    width: 70%;
    margin-bottom: 30px;
}
.mam_flex-box02{width: 100%;}
}
/*nav用分割 */
.mamnav_flex{
    display: flex;
    justify-content: space-between;
    align-items: center;
}
.mamnav_flex-box01{
    display: inline-block;
    width: 22%;
}
.mamnav_flex-box02{
    display: inline-block;
    width: 76%;
}
@media (max-width: 767px) {
.mamnav_flex-box01{
    width: 30%;
    margin-bottom: 5px;
}
.mamnav_flex-box02{width: 70%;}
}
/*============================================*/
/*ストライプ装飾付きの箱 */
/*============================================*/
.st-box{
    display: flex;
    justify-content: center;
}
.st-box-00{
    width: 85%;
    position: relative;
    border: solid 1px #d35b62;
    padding: 10px 15px;
    text-align: left;
}
.st-box-00::after {
    position: absolute;
    content: '';
    right: 0;
    bottom: 0;
    border-width: 0 0 20px 20px;
    border-style: solid;
    border-color: transparent transparent #d35b62 transparent;
}
@media (max-width: 767px) {
.st-box-00{width:100%;}
}
.st-box h5{
    font-family: "Noto Sans JP", sans-serif;
    font-size: 1.1rem;
    position: relative;
    margin-bottom: 20px;
}
.st-box h5::after{
    position: absolute;
    left: -5px;
    bottom: 0px;
    width: 100%;
    height: 5px;
    transform: skew(-45deg);
    background-image: repeating-linear-gradient(90deg, transparent 0 3px, #d35b62 3px 5px);
    content: '';
}
.st-box p{
    font-size: 0.9rem;
    line-height: 1.7em;
    margin: 10px 0px;
}

/* ======================================*/
/* 箱全体をリンクに*/
/* ======================================*/
.box-link{
    position: relative;
}
.box-link-a{
    position: absolute;
    width: 100%;
    height: 100%;
    top:0;
    left: 0;
    text-indent: 100%;
    white-space: nowrap;
    overflow: hidden;
    background-color: #fff;
    opacity: 0;
}
.box-link-a:hover{opacity: 0.5;}

/*============================================*/
/*ボタン */
/*============================================*/

.btn_basic {
  font-size: clamp(0.8rem, 0.727rem + 0.36vw, 1rem); /*←変更不可*/
  /*レスポンシブ対応のフォントサイズ指定　https://min-max-calculator.9elements.com/?16,24,320,1200　などで自動計算してclamp以降を書き出してくれる*/
  padding: 0.5rem 2rem;
  font-weight: 700;
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  color: #d35b62;
  border-radius: 0.5rem;
  border: 1px solid #d35b62;
  margin-bottom:20px;
  width:100%;
}

.btn_basic:hover {
  transform:translateY(5px);
  box-shadow: 0px 2px 0px #d35b62;
}

/*============================================*/
/* 全体ピンポイント設定 */
/*============================================*/
.pink {
  color: #FB807A;
  font-weight: bold;
}
.black{color: #333;}
.white{color: #fff;}
/*中央寄せ */
.align-center{text-align: center;}
/*文字右寄せ */
.algn_p_right {text-align: right;}
/*太字*/
.text-bold{font-weight: bold;}
/*文字を少し大きく*/
.text-big1{font-size: 1.2em;}
/*文字を大きく*/
.text-big2{font-size: 1.5em;}
@media (max-width: 767px) {
.text-big2{font-size: 1.4em;}
}
/*文字を少し小さく*/
.text-small1{font-size: 0.8em;}
/*文字を小さく*/
.text-small2{font-size: 0.6em;}
/*下線を引く*/
.text-underline{text-decoration: underline;}
/*画像円切り抜き*/
.img-circle {border-radius: 50%;}
/*角丸*/
.kadomaru {border-radius: 8px;}
/*範囲内にグレーの枠*/
.inline-border-gr {
    outline: solid 1px #ccc;
    outline-offset: -1px;
}
/*範囲外にグレーの枠*/
.border-gr {border: solid 1px #ccc;}

/*============================================*/
/*下に空白 */
/*============================================*/
/* 100px */
.bottom_blank100 {margin-bottom: 100px;}
/* 80px */
.bottom_blank80 {margin-bottom: 80px;}
/* 50px */
.bottom_blank {margin-bottom: 50px;}
/* 30px */
.row_bottom{margin-bottom:30px;}
/* 20px */
.bottom_blank20{margin-bottom: 20px;}
/* 10px */
.bottom_blank10{margin-bottom: 10px;}
/* PC30px、スマホ10px */
.row_bottom30{margin-bottom:30px;}
/* PC80px、スマホ30px */
.row_bottom80{margin-bottom:80px;}
/* PCだけ30px */
.bottom_pcblank30{margin-bottom: 30px;}
@media screen and (max-width: 475px) {
/* PC30px、スマホ10px */
.row_bottom30{margin-bottom:10px;}
/* スマホだけ30px */
.row_bottom-30{margin-bottom:30px;}
/* PC80px、スマホ30px */
.row_bottom80{margin-bottom:30px;}
/* PCだけ30px */
.bottom_pcblank30{margin-bottom: 0px;}
}
/*下部の余白マージン（PCは広く、smpでは狭く）*/
/* PC50px、スマホ30px */
.margin_blank_responsiv50 {margin-bottom:50px;}
@media (max-width: 767px){
.margin_blank_responsiv50 {margin-bottom:30px;}
}
/* PC100px、スマホ50px */
.margin_blank_responsiv {margin-bottom:100px;}
@media (max-width: 767px){
.margin_blank_responsiv {margin-bottom:50px;}
}
/* PC150px、スマホ80px */
.margin_blank_responsiv150 {margin-bottom:150px;}
@media (max-width: 767px){
.margin_blank_responsiv150 {margin-bottom:80px;}
}
/*============================================*/
/*上に空白 */
/*============================================*/
/* 10px */
.top_blank10{margin-top: 10px;}
/* 30px */
.top_blank30{margin-top: 30px;}
/* 50px */
.top_blank50{margin-top: 50px;}
/* 80px */
.top_blank80{margin-top: 80px;}

/*============================================*/
/*枠内で左右に空白 */
/*============================================*/
/* PCだけ左に20px */
.left_blank20{padding-left: 20px;}
@media screen and (max-width: 475px) {
.left_blank20{padding-left: 10px;}
}

/*============================================*/
/* PCスマホ表示 */
/*============================================*/
@media only screen and (max-width : 320px) {
.pc_h{display:none;}
.smp_h{display:inline;}
}
@media only screen and (min-width : 320px) {
.pc_h{display:none;}
.smp_h{display:inline;}
}
@media only screen and (min-width : 992px) {
.pc_h{display:inline;}
.smp_h{display:none;}
}
@media only screen and (min-width : 1200px) {
.pc_h{display:inline;}
.smp_h{display:none;}
}
/*============================================*/
/*SNS */
/*============================================*/
.excursion_sns {background-color: #f1f1f1;}
.sns_wrap {
  max-width: 1200px;
  margin:0 auto;
}
.sns_frame {
  width:60%;
  /* max-width:1200px;*/
  margin:0 auto; 
  text-align: center;
  grid-template-columns: 4fr 3fr 3fr 3fr;
  padding: 70px 0;
}
.sns_frame li:first-child {
  text-align: left;
  height:-webkit-min-content;
  height:-moz-min-content;
  height:min-content;
  border-right: solid 1px #333;
}
.sns_frame img {width:40%;}
.sns_frame h5 {
  font-family: serif;
  font-size: clamp(1.1rem, 0.955rem + 0.73vw, 1.5rem);
  font-weight: bold;
  margin: 20px 0px;
  text-align: center;
}
.sns_frame h6 {
  font-family: "Noto Sans JP", sans-serif;
  font-size: 0.8rem;
  font-weight: normal;
  margin-bottom: 5px;
  line-height:1.1rem
}
.sns_frame p{
  font-size: 0.75rem;
  text-align:left;
  line-height:1rem;
}
.sns_frame a {color:#333;}
@media screen and (max-width: 767px) {
.sns_frame {
  width:70%;
  height:-webkit-min-content;
  height:-moz-min-content;
  height:min-content;
}
.sns_frame img {width:70%;}
.sns_frame h5{margin:8px;}
.sns_frame h6, .sns_frame p {
  display:none;
  height:0;
}
}