@charset "utf-8";

/* ----------------------------------------------------
  bootstrap.css　基本の打消し
---------------------------------------------------- */
body{ margin:0; padding:0;}
h1,h2,h3,h4,h5,h6{ margin:0; padding:0; font-weight:normal; clear:both}
p{ margin:0; padding:0}
.navbar {margin-bottom:0; border:none;}
.table-striped > tbody > tr:nth-of-type(odd) { background-color: #eee;}
.table{ margin-bottom:30px}
.table th{ width:30%}
@media (min-width: 768px) {.btn-group-vertical a{ padding-top:15px;padding-bottom:15px}}
img.img-fluid {display: block;}
@media (min-width: 768px) {.modal-dialog {max-width: 650px;}}

/* ----------------------------------------------------
  bootstrap.css 追加
---------------------------------------------------- */
/* --- 1600px以上（xxxl） --- */
@media (min-width: 1600px) {
  .d-xxxl-none        { display: none !important; }
  .d-xxxl-block       { display: block !important; }
  .d-xxxl-inline      { display: inline !important; }
  .d-xxxl-inline-block{ display: inline-block !important; }
  .d-xxxl-flex        { display: flex !important; }
  .d-xxxl-inline-flex { display: inline-flex !important; }
}

/* --- 1800px以上（xxxxl） --- */
@media (min-width: 1800px) {
  .d-xxxxl-none        { display: none !important; }
  .d-xxxxl-block       { display: block !important; }
  .d-xxxxl-inline      { display: inline !important; }
  .d-xxxxl-inline-block{ display: inline-block !important; }
  .d-xxxxl-flex        { display: flex !important; }
  .d-xxxxl-inline-flex { display: inline-flex !important; }
}

/* ----------------------------------------------------
  全体構造
---------------------------------------------------- */
html, body, div, span, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
abbr, address, cite, code,
del, dfn, em, img, ins, kbd, q, samp,
small, strong, sub, sup, var,
b, i,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, dialog, figure, footer, header,
hgroup, menu, nav, section,
time, mark, audio, video {
	margin:0;
	padding:0;
	border:0;
	outline:0;
	font-size:100%;
	vertical-align:baseline;
	background:transparent;
}
.clearfix:after {
  content: "";
  display: table;
  clear: both;
}
.clear{clear:both;}
img{border:0;vertical-align:bottom;}
a {
	outline:none;
	margin:0;
	padding:0;
	border:0;
	font-size:100%;
	vertical-align:baseline;
	background:transparent;
}
hr {
    display:block;
    height:1px;
    border-top:1px dotted #333;
    margin:0 0 20px 0;
    padding:0;
}
body{
	font-size: 100%;
	line-height: 180%;
	font-family:FontAwesome, "メイリオ", Meiryo, "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
	color: #2f4d75;
	letter-spacing: 1px;
	overflow-x: hidden;
}

header,main,footer{font-family: 'Noto serif JP', sans-serif;}

/* ----------------------------------------------------
  Bootstrapの scroll-behavior: smooth; を無効化
---------------------------------------------------- */
html {scroll-behavior: auto !important;}
 
/* ----------------------------------------------------
  link
---------------------------------------------------- */
a:link,a:visited,a:hover,a:active{text-decoration:none; color:#2f4d75;}

/* ----------------------------------------------------
  main
---------------------------------------------------- */
main { line-height: 1.8em; font-size: 100%;}

/* ----------------------------------------------------
  mainimg
---------------------------------------------------- */
.mainimg{padding-top: 0px}
@media print, screen and (min-width: 768px) {.mainimg{padding-top: 0}}

/* ----------------------------------------------------
  フッター
---------------------------------------------------- */
#footer01{
	clear: both;
	width: 100%;
  color: #fff;
  background: #2f333f;
}

/* ----------------------------------------------------
  フッター　上下余白
---------------------------------------------------- */
@media only screen and (max-width: 767px) { .f_yohaku01{ padding: 30px 0 60px 0; font-size: 15px; line-height: 25px;}}
@media print, screen and (min-width: 768px) {.f_yohaku01{padding: 80px 0;}}

/* ----------------------------------------------------
  フッター　ロゴ
---------------------------------------------------- */
.f_logo {
	font-size: 22px;
	line-height: 32px;
	margin-bottom: 10px;
	}
@media print, screen and (min-width: 768px) {
.f_logo{
	font-size: 25px;
	line-height: 35px;
	margin-bottom: 20px;
	}
}

/* ----------------------------------------------------
  フッター　情報全体
---------------------------------------------------- */
.f_info{
  text-align: center;
  margin-bottom: 20px;
}
@media print, screen and (min-width: 768px) {
  .f_info{
    text-align: left;
    margin-bottom: 0;
  }
}

/* ----------------------------------------------------
  フッター　電話ボタン（スマホ）
---------------------------------------------------- */
@media only screen and (max-width: 767px) {
.footer_tel{
	color: #2f333f;
	display: block;
	border:0px;
	background-color: #fff;
	text-align: center;
	padding: 20px 0;
  font-size: 16px;
	margin-bottom: 10px;
  border-radius: 100px;
	}
}

/* ----------------------------------------------------
  フッター　メニュー
---------------------------------------------------- */
.textlink {width:100%; text-align:left;}
.textlink ul{list-style: none;}
.textlink li{line-height: 100%;	display: block;}
.textlink li a{
	display:block;
	padding: 15px 0px;
	color: #fff;
	border-bottom:1px solid #fff;
	text-align: left;
	line-height: 22px;
}

@media only screen and (max-width: 767px) {
.textlink ul li a:before{
	font-family: "Font Awesome 5 Free";
	content:" \f105";
	float: right;
	font-weight: bold;
	color: #fff;
	font-size: 18px;
	padding: 2px 10px 0 0;
	}
}

@media print, screen and (min-width: 768px) {
.textlink {
  margin: 0 0 0 auto;
	margin-bottom: 85px;
	}
.textlink ul{
  display: flex; /* 横並びに変更 */
  justify-content: flex-end; /* 右寄せ */
  gap: 30px; /* 間隔 */
  }
.textlink ul li{
  display: inline-block;
  }
.textlink li a{
	padding: 0;
	border-bottom: 0;
	}
.textlink a:link, .textlink a:visited{color:#fff !important; text-decoration:none !important;}
.textlink a:hover,.textlink a:active{color: #fff !important; text-decoration:underline !important;}
}

/* ----------------------------------------------------
  フッター　コピーライト
---------------------------------------------------- */
@media only screen and (max-width: 767px) {
.copyright{
  text-align: center;
  margin: 20px 0 0 0;
  }
}
@media print, screen and (min-width: 768px) {
  .copyright{
    text-align: right;
  }
}

/* ----------------------------------------------------
  画像
---------------------------------------------------- */
.img-c img{margin:0 auto;}
.imglink a:hover img{
    opacity: 0.5 !important;
    transition: all 0.2s ease 0s !important;
    -webkit-transition: 0.2s ease-in !important;
    filter: alpha(opacity=50) !important;
	}

@media print, screen and (min-width: 768px) {
.maru img{border-radius:0 10px 10px 0;}
.maru_02 img{border-radius: 10px 0 0 10px;}
}

/* ----------------------------------------------------
  画像並び替え
---------------------------------------------------- */
@media only screen and (max-width: 767px) {
.area_first_01{order:1;}
.area_last_01{order:2;}
}

/* ----------------------------------------------------
  上下左右中央
---------------------------------------------------- */
.area_core {
  display: flex;
  justify-content: center;
  align-items: center;
  height: 100%;
}

/* ----------------------------------------------------
  文字色
---------------------------------------------------- */
.white{color:#fff !important}

/* ----------------------------------------------------
　文字位置
---------------------------------------------------- */
.lft{text-align: left !important;}
.ctr{text-align: center !important;}
.rgt{text-align: right !important;}

/* ----------------------------------------------------
  テキスト高さ
---------------------------------------------------- */
.text01{line-height: 30px; letter-spacing: 2px;}
@media print, screen and (min-width: 992px) {.text01{line-height: 35px;}}

/* ----------------------------------------------------
  文字寄せ
---------------------------------------------------- */
/*　スマホ左寄せ　ほか中央
---------------------------------------------------- */
.ctr-text01{text-align: left;}
@media print, screen and (min-width: 768px) {.ctr-text01{text-align: center;}}

/*　スマホ中央　ほか左寄せ
---------------------------------------------------- */
.ctr-text02{text-align: center;}
@media print, screen and (min-width: 768px) {.ctr-text02{text-align: left;}}

/* ----------------------------------------------------
  余白（左右）
---------------------------------------------------- */
@media print, screen and (min-width: 768px) {.wide01{ padding:0 3%;}}
@media print, screen and (min-width: 1400px) {.wide01{ padding:0 5%;}}

@media print, screen and (min-width: 768px) {.wide02{ padding:0 3%;}}
@media print, screen and (min-width: 1400px) {.wide02{ padding:0 9%;}}

@media print, screen and (min-width: 768px) { .wide03{ padding:0 3%;}}
@media print, screen and (min-width: 1400px) {.wide03{ padding:0 15%;}}

/* ----------------------------------------------------
  余白（上下）
---------------------------------------------------- */
.pp00 {padding: 0 !important;}
@media print, screen and (min-width: 768px) {.pp00-2 {padding: 0 !important;}}

.part30{padding:30px 0;}
@media print, screen and (min-width: 768px) {.part30{padding:30px 0}}

.part60{padding:30px 0;}
@media print, screen and (min-width: 768px) {.part60{padding:30px 0}}
@media print, screen and (min-width: 992px) {.part60{padding:60px 0}}

.part80{padding:30px 0;}
@media print, screen and (min-width: 768px) {.part80{padding:60px 0}}
@media print, screen and (min-width: 992px) {.part80{padding:80px 0}}

.part100{padding:30px 0;}
@media print, screen and (min-width: 768px) { .part100{padding:60px 0}}
@media print, screen and (min-width: 992px) { .part100{padding:80px 0}}
@media print, screen and (min-width: 1200px) {.part100{padding:100px 0}}

.part120{padding:30px 0;}
@media print, screen and (min-width: 768px) { .part120{padding:60px 0}}
@media print, screen and (min-width: 992px) { .part120{padding:100px 0}}
@media print, screen and (min-width: 1200px) {.part120{padding:120px 0}}

.part150{padding:30px 0;}
@media print, screen and (min-width: 768px) { .part150{padding:60px 0}}
@media print, screen and (min-width: 992px) { .part150{padding:100px 0}}
@media print, screen and (min-width: 1200px) {.part150{padding:150px 0}}

.part170{padding:30px 0;}
@media print, screen and (min-width: 768px) { .part170{padding:60px 0}}
@media print, screen and (min-width: 992px) { .part170{padding:100px 0}}
@media print, screen and (min-width: 1200px) {.part170{padding:170px 0}}

.part200{padding:30px 0;}
@media print, screen and (min-width: 768px) { .part200{padding:60px 0}}
@media print, screen and (min-width: 992px) { .part200{padding:100px 0}}
@media print, screen and (min-width: 1200px) {.part200{padding:170px 0}}
@media print, screen and (min-width: 1400px) {.part200{padding:200px 0}}

.part_side80{padding:0 0 30px 0;}
@media print, screen and (min-width: 768px) { .part_side80{ padding:0 0 80px 0}}

.part_side100{padding:0 0 30px 0;}
@media print, screen and (min-width: 768px) { .part_side100{ padding:0 0 80px 0}}
@media print, screen and (min-width: 992px) { .part_side100{ padding:0 0 100px 0}}

.part_side150{padding:0 0 30px 0;}
@media print, screen and (min-width: 768px) { .part_side150{ padding:0 0 80px 0}}
@media print, screen and (min-width: 992px) { .part_side150{ padding:0 0 100px 0}}
@media print, screen and (min-width: 1200px) {.part_side150{padding:0 0 150px 0}}

.part_side170{padding:0 0 30px 0;}
@media print, screen and (min-width: 768px) { .part_side170{ padding:0 0 80px 0}}
@media print, screen and (min-width: 992px) { .part_side170{ padding:0 0 100px 0}}
@media print, screen and (min-width: 1200px) {.part_side170{padding:0 0 170px 0}}

.part_side200{padding:0 0 30px 0;}
@media print, screen and (min-width: 768px) { .part_side200{ padding:0 0 80px 0}}
@media print, screen and (min-width: 992px) { .part_side200{ padding:0 0 100px 0}}
@media print, screen and (min-width: 1200px) {.part_side200{padding:0 0 170px 0}}
@media print, screen and (min-width: 1400px) {.part_side200{padding:0 0 200px 0}}

.part_side100{padding:0 0 30px 0;}
@media print, screen and (min-width: 768px) { .part_side100{ padding:0 0 80px 0}}
@media print, screen and (min-width: 992px) { .part_side100{ padding:0 0 100px 0}}

.part_side120{padding:0 0 30px 0;}
@media print, screen and (min-width: 768px) { .part_side120{ padding:0 0 80px 0}}
@media print, screen and (min-width: 992px) { .part_side120{ padding:0 0 100px 0}}
@media print, screen and (min-width: 1200px) {.part_side120{padding:0 0 120px 0}}

.part_side150{padding:0 0 30px 0;}
@media print, screen and (min-width: 768px) { .part_side150{ padding:0 0 80px 0}}
@media print, screen and (min-width: 992px) { .part_side150{ padding:0 0 100px 0}}
@media print, screen and (min-width: 1200px) {.part_side150{padding:0 0 150px 0}}

.part_side170{padding:0 0 30px 0;}
@media print, screen and (min-width: 768px) { .part_side170{ padding:0 0 80px 0}}
@media print, screen and (min-width: 992px) { .part_side170{ padding:0 0 100px 0}}
@media print, screen and (min-width: 1200px) {.part_side170{padding:0 0 170px 0}}

.part_side200{padding:0 0 30px 0;}
@media print, screen and (min-width: 768px) { .part_side200{ padding:0 0 80px 0}}
@media print, screen and (min-width: 992px) { .part_side200{ padding:0 0 100px 0}}
@media print, screen and (min-width: 1200px) {.part_side200{padding:0 0 170px 0}}
@media print, screen and (min-width: 1400px) {.part_side200{padding:0 0 200px 0}}

.part_wavy80{padding:20px 0 30px 0;}
@media print, screen and (min-width: 768px) {.part_wavy80{padding:40px 0 60px 0}}
@media print, screen and (min-width: 992px) {.part_wavy80{padding:60px 0 80px 0}}

/* ----------------------------------------------------
　文字間
---------------------------------------------------- */
.mb-10-md0{ margin-bottom:10px}
@media print, screen and (min-width: 768px) {.mb-10-md0{ margin-bottom:0px}}

.mb-10-md10{ margin-bottom:10px}
@media print, screen and (min-width: 768px) {.mb-10-md10{ margin-bottom:10px}}

.mb-10-md20{ margin-bottom:10px}
@media print, screen and (min-width: 768px) {.mb-10-md20{ margin-bottom:20px}}

.mb-10-md30{ margin-bottom:10px}
@media print, screen and (min-width: 768px) {.mb-10-md30{ margin-bottom:30px}}

.mb-20-md0{ margin-bottom:20px}
@media print, screen and (min-width: 768px) {.mb-20-md0{ margin-bottom:0px}}

.mb-20-md20{ margin-bottom:20px}
@media print, screen and (min-width: 768px) {.mb-20-md20{ margin-bottom:20px}}

.mb-20-md0-lg0{ margin-bottom:20px}
@media print, screen and (min-width: 768px) {.mb-20-md0-lg0{ margin-bottom:0px}}
@media print, screen and (min-width: 992px) {.mb-20-md0-lg0{ margin-bottom:0px}}

.mb-20-md20-lg0{ margin-bottom:20px}
@media print, screen and (min-width: 768px) {.mb-20-md20-lg0{ margin-bottom:20px}}
@media print, screen and (min-width: 992px) {.mb-20-md20-lg0{ margin-bottom:0px}}

.mb-20-md30{ margin-bottom:20px}
@media print, screen and (min-width: 768px) {.mb-20-md30{ margin-bottom:30px}}

.mb-20-md30-lg0{ margin-bottom:20px}
@media print, screen and (min-width: 768px) {.mb-20-md30-lg0{ margin-bottom:30px}}
@media print, screen and (min-width: 992px) {.mb-20-md30-lg0{ margin-bottom:0px}}

.mb-20-md30-lg40{ margin-bottom:20px}
@media print, screen and (min-width: 768px) {.mb-20-md30-lg40{ margin-bottom:30px}}
@media print, screen and (min-width: 992px) {.mb-20-md30-lg40{ margin-bottom:40px}}

.mb-20-md30-lg50{ margin-bottom:20px}
@media print, screen and (min-width: 768px) {.mb-20-md30-lg50{ margin-bottom:30px}}
@media print, screen and (min-width: 992px) {.mb-20-md30-lg50{ margin-bottom:50px}}

.mb-20-md40{ margin-bottom:20px}
@media print, screen and (min-width: 768px) {.mb-20-md40{ margin-bottom:40px}}

.mb-20-md40-lg60{ margin-bottom:20px}
@media print, screen and (min-width: 768px) {.mb-20-md40-lg60{ margin-bottom:40px}}
@media print, screen and (min-width: 992px) {.mb-20-md40-lg60{ margin-bottom:60px}}

.mb-30-md0{ margin-bottom:30px}
@media print, screen and (min-width: 768px) {.mb-30-md0{ margin-bottom:0px}}

.mb-30-md30{ margin-bottom:30px}
@media print, screen and (min-width: 768px) {.mb-30-md30{ margin-bottom:30px}}

.mb-30-md50{ margin-bottom:30px}
@media print, screen and (min-width: 768px) {.mb-30-md50{ margin-bottom:50px}}

.mb-30-md50-lg0{ margin-bottom:30px}
@media print, screen and (min-width: 768px) {.mb-30-md50-lg0{ margin-bottom:50px}}
@media print, screen and (min-width: 992px) {.mb-30-md50-lg0{ margin-bottom:0px}}

.mb-40-md0{ margin-bottom:40px}
@media print, screen and (min-width: 768px) {.mb-40-md0{ margin-bottom:0px}}

.mb-40-md40-lg0{ margin-bottom:40px}
@media print, screen and (min-width: 768px) {.mb-40-md40-lg0{ margin-bottom:40px}}
@media print, screen and (min-width: 992px) {.mb-40-md40-lg0{ margin-bottom:0px}}

.mb-40-md60{ margin-bottom:40px}
@media print, screen and (min-width: 768px) {.mb-40-md60{ margin-bottom:60px}}

.mb-40-md60-lg80{ margin-bottom:40px}
@media print, screen and (min-width: 768px) {.mb-40-md60-lg80{ margin-bottom:60px}}
@media print, screen and (min-width: 992px) {.mb-40-md60-lg80{ margin-bottom:80px}}

.mb-60-md60-lg0{ margin-bottom:60px}
@media print, screen and (min-width: 768px) {.mb-60-md60-lg0{ margin-bottom:60px}}
@media print, screen and (min-width: 992px) {.mb-60-md60-lg0{ margin-bottom:0px}}

.mb-20-md40-lg60-xl80-xxxl100{ margin-bottom:20px}
@media print, screen and (min-width: 768px) { .mb-20-md40-lg60-xl80-xxxl100{ margin-bottom:40px}}
@media print, screen and (min-width: 992px) { .mb-20-md40-lg60-xl80-xxxl100{ margin-bottom:60px}}
@media print, screen and (min-width: 1200px) {.mb-20-md40-lg60-xl80-xxxl100{ margin-bottom:80px}}
@media print, screen and (min-width: 1600px) {.mb-20-md40-lg60-xl80-xxxl100{ margin-bottom:100px}}

.pb-20-md0{ padding-bottom:20px}
@media print, screen and (min-width: 768px) {.pb-20-md0{ padding-bottom:0px}}
@media print, screen and (min-width: 992px) {.pb-20-md0{ padding-bottom:0px}}

/* ----------------------------------------------------
　グーグルマップ
---------------------------------------------------- */
.map iframe{width: 100%; height:45vh; border-radius: 10px;}
@media print, screen and (min-width: 768px) {.map iframe{width: 100%; height:400px;}}
@media print, screen and (min-width: 992px) {.map iframe{width: 100%; height:450px;}}
@media print, screen and (min-width: 1200px) {.map iframe{width:100%; height:500px;}}
@media print, screen and (min-width: 1400px) {.map iframe{width:100%; height:550px;}}

/* ----------------------------------------------------
　ページトップ
---------------------------------------------------- */
#pagetop {
	position: fixed;
	bottom:10px;
	right:10px;
	z-index: 1;
}
#pagetop img{
	width: 35px;
	height: auto;
  border-radius: 5px;
}
@media print, screen and (min-width: 768px) {
#pagetop {
	bottom:20px;
	right:20px;
}
#pagetop img{
	width: 40px
	}
}
@media print, screen and (min-width: 1200px) {
#pagetop {
	position: fixed;
	bottom:20px;
	right: 20px;
	}
}

/* ----------------------------------------------------
　AOS対応
---------------------------------------------------- */
.tome{overflow: hidden !important}

/* ----------------------------------------------------
　アンカーリンク
---------------------------------------------------- */
.anchor {position: relative;}
.anchor::before {
  content: "";
  display: block;
  height: 48px;
  margin-top: -48px;
}
@media print, screen and (min-width: 768px) { .anchor::before { height: 95px; margin-top: -95px;}}
@media print, screen and (min-width: 1200px) {.anchor::before { height: 60px; margin-top: -60px;}}
@media print, screen and (min-width: 1400px) {.anchor::before { height: 60px; margin-top: -60px;}}