@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: #222;
	letter-spacing: 1px;
	overflow-x: hidden;
}

header,main,footer{font-family: 'Noto Sans 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:#222;}

/* ----------------------------------------------------
  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}}

.mainimg02{padding-top: 50px}
@media print, screen and (min-width: 768px) {.mainimg02{padding-top: 85px}}

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

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

/* ----------------------------------------------------
  フッター　ロゴ
---------------------------------------------------- */
.f_logo {
	font-size: 25px;
	line-height: 35px;
	margin-bottom: 20px;
	}
@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: 20px;
  }
}

/* ----------------------------------------------------
  フッター　住所
---------------------------------------------------- */
.f_address{margin-bottom: 15px;}

.f_address a:link,
.f_address a:visited{color:#20a5ce !important; text-decoration:none !important;}
.f_address a:hover,
.f_address a:active{color: #20a5ce !important; text-decoration:underline !important;}

/* ----------------------------------------------------
  フッター　電話ボタン（スマホ）
---------------------------------------------------- */
@media only screen and (max-width: 767px) {
.footer_tel{
  font-family: 'Noto serif JP', sans-serif;
	color: #fff;
	display: block;
	border:0px;
	background-color: #20a5ce;
	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: #222;
	border-bottom:1px solid #222;
	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: #20a5ce;
	font-size: 18px;
	padding: 2px 10px 0 0;
	}
}

@media print, screen and (min-width: 768px) {
.textlink {
	margin-bottom:15px;
	}
.textlink li a{
	padding:0 0 15px 0;
	border-bottom: 0px solid #eee;
	text-align: left;
	}
.textlink a:link, #textlink a:visited, #textlink a:active {color:#fff;}
.textlink a:hover {color:#fff; text-decoration: underline;}
.textlink ul li a:before{
	font-family: "Font Awesome 5 Free";
	content:" \f111";
	float: left;
	font-weight: bold;
	color: #222;
	font-size: 5px;
	padding: 1px 10px 0 0;
	}
}

@media print, screen and (min-width: 768px) {
.textlink a:link,
.textlink a:visited{color:#222 !important; text-decoration:none !important;}
.textlink a:hover,
.textlink a:active{color: #222 !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: left;
  }
}

/* ----------------------------------------------------
  お問い合わせページ　連絡先ボックス
---------------------------------------------------- */
.mail-box{
	padding: 15px 20px;
	background: #fff;
	text-align: center;
	border:1px solid #222;
	}
.mail-box h3{
	font-size: 20px;
	margin-bottom: 20px;
	}
.mail-box h3 span{
	padding-bottom: 5px;
	border-bottom: 1px solid #222;
	}
@media print, screen and (min-width: 768px){
.mail-box{
	padding: 30px 10px;
	}
.mail-box h3{
	font-size: 30px;
	margin-bottom: 30px;
	}
}

/* ----------------------------------------------------
  電話ボタン　電話の見た目
---------------------------------------------------- */
.contact_btn_tel{
  font-family: 'Noto serif JP', sans-serif;  
	display:block;
	color:#fff;	
	background-color: #33b7d1;
	font-size:120%;	
	padding:15px 5px;
	text-align:center;
	font-weight: normal;
	margin-bottom: 8px;
  border-radius: 100px;
	}
.contact_btn_tel a:link,
.contact_btn_tel a:visited,
.contact_btn_tel a:hover,
.contact_btn_tel a:active{color:#fff}
.contact_btn_tel i{font-size:80%; margin:0 5px 0 0; color:#fff; vertical-align: middle;}

@media print, screen and (min-width: 768px) {
.contact_btn_tel{
	display:inline;
	background-color:transparent;
	padding:0;
	text-align:left;
	color: #30384b;
	font-size:24px;
	margin-bottom: 0;
	}
.contact_btn_tel i{margin:0 5px 0 0; color:#30384b;}
}
@media print, screen and (min-width: 992px) {
.contact_btn_tel{font-size:35px;}
.contact_btn_tel i{margin:0 8px 5px 0; font-size: 25px;}
}

/* ----------------------------------------------------
  FAXの見た目
---------------------------------------------------- */
.contact_btn_fax{
	font-weight:lighter;		
	display:block;
	font-size:120%;	
	text-align:center;
	}
.contact_btn_fax a:link,
.contact_btn_fax a:visited,
.contact_btn_fax a:hover,
.contact_btn_fax a:active{color:#fff}
.contact_btn_fax i{font-size:90%; margin:0 5px 5px 0; vertical-align: middle;}
@media print, screen and (min-width: 768px) {
.contact_btn_fax{
	display:inline;
	background-color:transparent;
	padding:0;
	text-align:left;
	font-size:24px;
	margin-bottom: 0;
	}
.contact_btn_fax i{margin:0 5px 0 0; color:#30384b;} /* アイコンの色変更 */
}
@media print, screen and (min-width: 992px) {
.contact_btn_fax{font-size:35px;}
.contact_btn_fax i{margin:0 8px 5px 0; font-size: 25px;}
}

/* ----------------------------------------------------
  お問い合わせページ　フォーム
---------------------------------------------------- */
.contact_box{ 
	background-color:#fff;
	border-left:1px solid #ccc;
	border-right:1px solid #ccc;
}
.table_form {
  width: 100%;
  border-collapse: collapse;
  border-top: 1px solid #ccc;
  margin-bottom: 30px;
}
.table_form th,
.table_form td {
  width: 100%;
  padding: 15px 15px 5px 15px;
  display: block;
  font-weight: normal;
  font-size: 1rem;
}
.table_form td {
  border-bottom: 1px solid #ccc;
  padding-top: 0;
  padding-bottom: 15px;
}
.table_form th span {
  font-size: 0.8rem;
  color: #fff;
  padding: 0 10px;
  border-radius: 3px;
  float: right;
  background-color: #d00a0a;
}

@media print, screen and (min-width: 768px) {
  .table_form {
    margin-bottom: 60px;
  }
  .table_form th {
    width: 35%;
    padding: 15px 20px;
    vertical-align: middle;
    text-align: left;
    display: table-cell;
    border-bottom: 1px solid #ccc;
  }
  .table_form td {
    width: 65%;
    padding: 15px 25px;
    display: table-cell;
    border-bottom: 1px solid #ccc;
  }
}

@media print, screen and (min-width: 992px) {
  .table_form th {
    width: 35%;
  }
}

/* ----------------------------------------------------
  お問い合わせページ　フォーム詳細
---------------------------------------------------- */
input[type="checkbox"],
input[type="radio"],
input[type="file"]{
  vertical-align: middle;
  margin: 2px 0 5px 0;
}
input:not([type="file"]),
select,
textarea {
  font-size: 1rem;
  vertical-align: middle;
  padding: 9px;
  border: 1px solid #ccc;
  border-radius: 3px;
  box-sizing: border-box;
}
input[type="file"] {
  display: block;
  max-width: 100%;
  width: 100%;
  box-sizing: border-box;
}
input[type="text"]:focus,
select:focus,
textarea:focus {
  border-color: #06c;
  outline: none;
  box-shadow: 0 0 4px rgba(0, 102, 204, 0.5);
}
textarea {
  width: 100%;
  resize: vertical;
}
input, textarea {
  font-style: normal;
  font-weight: normal;
  line-height: 1.3;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  font-family: inherit; /* 親要素のフォントを継承 */
}
input::placeholder,
textarea::placeholder {
  color: #aaa !important;
  font-size: 0.9rem;
  font-weight: normal;
  opacity: 1;
}
.table_form label{font-weight: normal !important; margin-right:20px;}

/* モバイル */
.slc1 {
  display: inline-block;
}
.nengou div,
.year div,
.month div,
.day div {
  display: inline-block;
  margin: 12px 0 0 12px;
}

/* 768px以上 */
@media print, screen and (min-width: 768px) {
  .nengou, .year, .month, .day {
    display: flex;
    align-items: flex-start;
    padding-bottom: 15px;
    margin-left: 8px;
  }
  .nengou {
    width: 150px;
    padding: 0 0 15px 0;
  }
  .year,
  .month,
  .day {
    width: 130px;
  }
  .nengou div,
  .year div,
  .month div,
  .day div {
    margin: 12px 0 0 8px;
  }
}

/* 992px以上 */
@media print, screen and (min-width: 992px) {
  .year,
  .month,
  .day {
    width: 150px;
  }
}

.w300 {width:100%; display: inline-block;}
@media print, screen and (min-width: 768px) {.w300 {width:300px;}}

.form-control {
    padding: 12px 10px;
    font-size: 14px;
    line-height: 1.6;
    background-image: none;
    border: 1px solid #ccc;
    border-radius: 4px;
    box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.075);
    transition: border-color 0.15s ease-in-out, box-shadow 0.15s ease-in-out;
}
select.form-control:not([size]):not([multiple]) {height: auto !important;}

/* ----------------------------------------------------
  お問い合わせページ　個人情報保護方針
---------------------------------------------------- */
.title_policy{
  text-align: center;
  font-size: 20px;
  margin-bottom: 15px;
}
@media print, screen and (min-width: 768px) {
  .title_policy{
    font-size: 25px;
    margin-bottom: 20px;
    }
}

/* ----------------------------------------------------
  お問い合わせページ　確認画面の送信ボタン
---------------------------------------------------- */
.btn_send {
  display: inline-block;
  width: 130px;
  padding: 20px 2px;
  margin:0 5px;
  text-align: center;
  color: #fff !important;
  background: #30384b !important;
  border: 0;
  text-decoration: none;
  cursor: pointer;
  transition: all 0.3s ease;
  border-radius: 100px;
}
@media print, screen and (min-width: 768px) {
.btn_send {
  width: 200px;
  }
}
.btn_send:visited {
  color: #fff !important;
}
.btn_send:hover,
.btn_send:active {
  background: #060b16 !important;
  color: #fff !important;
  text-decoration: none !important;
}

/* ----------------------------------------------------
  お問い合わせページ　確認画面の戻るボタン
---------------------------------------------------- */
.btn_back {
  display: inline-block;
  width: 130px;
  padding: 20px 2px;
  margin:0 5px;
  text-align: center;
  color: #fff !important;
  background: #aaa;
  border: 0;
  text-decoration: none;
  cursor: pointer;
  transition: all 0.3s ease;
  border-radius: 100px;
}
@media print, screen and (min-width: 768px) {
.btn_back {
  width: 200px;
  }
}
.btn_back:visited {
  color: #fff !important;
}
.btn_back:hover,
.btn_back:active {
  background: #666 !important;
  color: #fff !important;
  text-decoration: none !important;
}

/* ----------------------------------------------------
  お問い合わせページ　ポリシー
---------------------------------------------------- */
#policy{
	padding: 10px;
	height: 200px;
	overflow:scroll;
	overflow-x:hidden;
	background:#fff;
	border:1px solid #ccc;
	margin-bottom: 15px;
	}	
@media print, screen and (min-width: 768px) {
#policy{
	padding: 10px;
	height: 400px;
	overflow:scroll;
	overflow-x:hidden;
	border:1px solid #ccc;
	margin-bottom: 40px;
	background: #fff;
	}
}
@media print, screen and (min-width: 992px) {
#policy{
	padding: 30px;
	}
}
#policy a:link, #policy a:visited,
#policy a:hover, #policy a:active{text-decoration:underline; color:#999;}
#policy::-webkit-scrollbar{ /* スクロールバー本体 */
	width: 5px;
	background: #ccc;
}
#policy::-webkit-scrollbar:horizontal{ /* 横方向のスクロールバー本体 */
	width: 5px;
	background: #ccc;
}
#policy::-webkit-scrollbar-thumb{ /* スクロールバーの動く部分 */
	background: #999;
	border-radius: 2px;
}
#policy::-webkit-scrollbar-thumb:horizontal{ /* 横方向のスクロールバーの動く部分 */
	background: #333;
	border-radius: 2px;
}
#policy::-webkit-scrollbar-track-piece:start{ /* スクロールバーの動く部分の前 */
	background: #fff;
}
#policy::-webkit-scrollbar-track-piece:end{ /* スクロールバーの動く部分の後ろ */
	background: #fff;
}
#policy::-webkit-scrollbar-corner{ /* スクロールバー角 */
	background: transparent;
}
.con-ul{
	padding-left:20px;
	list-style:decimal;
	margin-bottom: 20px;
	}
.con-ul li{
	padding:3px 0;
	border-bottom:1px dashed #bbb;
	}
#policy h3{
	font-size:18px;
	line-height: 28px;
	margin-bottom: 10px;
	border-left: 5px solid #333;
	padding: 10px 0 10px 10px;
}
#policy h4{
	color:#333;
	font-size:18px;
	line-height: 20px;
	margin-bottom: 10px;
}
@media print, screen and (min-width: 768px) {
#policy h3{font-size:20px}
#policy h4{font-size:18px}
.con-ul{
	padding-left:30px;
	list-style:decimal;
	margin-bottom: 30px;
	}
.con-ul li{
	padding:3px 0;
	border-bottom:1px dashed #bbb;
	}
}

/* ----------------------------------------------------
  画像
---------------------------------------------------- */
.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;
	}
.maru img{border-radius: 10px;}

@media only screen and (max-width: 767px) {.img-yoko01 img{width: 50%;}}
@media only screen and (max-width: 767px) {.img-yoko02 img{width: 70%;}}

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

/* ----------------------------------------------------
  縦横比
---------------------------------------------------- */
.photo-ofi {
	height: 0;
	display: block;
	overflow: hidden;
	position: relative;
	padding-bottom: 70%;
	background: #eee;
}
.photo-ofi img {
	max-width: inherit;
	max-height: inherit;
	width: 100%;
	height: 100%;
	object-fit: scale-down;
	font-family: 'object-fit: scale-down;';
	position: absolute;
	left: 0;
	top: 0;
}

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

.area_core {
  display: flex;
  justify-content: center;
  align-items: center;
  height: 100%;
}

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

/* ----------------------------------------------------
  テキストリンク
---------------------------------------------------- */
.text01 a:link, .text01 a:visited,
.text01 a:hover, .text01 a:active{
  text-decoration:underline;
  color: #402012;
}

/* ----------------------------------------------------
　フォントサイズ
---------------------------------------------------- */
.fs130	{font-size: 130%;}
.fs110	{font-size: 110%;}
.fs90	{font-size: 90%;}
.fs80	{font-size: 80%;}

/* ----------------------------------------------------
　頭文字
---------------------------------------------------- */
.kasiramoji::first-letter{color:#0053ba}

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

/* ----------------------------------------------------
　リスト
---------------------------------------------------- */
/* 中黒つき
------------------------- */
.ul_disc {list-style:disc; text-align: left; padding-left:5px; margin-left: 15px;}
.ul_disc li{padding: 0;}

/* 任意のマークつき
------------------------- */
.icon_list {
  list-style: none;
  padding-left: 0;
}
.icon_list li {
  position: relative;
  padding-left: 1.2em;
  margin-bottom: 0.4em;
}
.icon_list li::before {
  content: "※";
  position: absolute;
  left: 0;
  top: 0;
  font-weight: bold;
}

/* ナンバーつき
------------------------- */
.num_list {
  list-style: none;
  counter-reset: num;
  padding-left: 0;
}
.num_list li {
  counter-increment: num;
  padding-left: 2em;
  position: relative;
  margin-bottom: 0.6em;
}
.num_list li::before {
  content: counter(num) ".";
  position: absolute;
  left: 0;
  top: 0;
  font-weight: bold;
}

/* ol
------------------------- */
.ol-01{padding-left: 20px; margin-bottom: 30px;}
.ol-01 li{ border-bottom: 1px dashed #ccc; padding: 5px 0;}

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

.text02{line-height: 30px; letter-spacing: 2px;}
@media print, screen and (min-width: 768px) {.text02{line-height: 35px; letter-spacing: 3px;}}
@media print, screen and (min-width:1200px) {.text02{line-height: 45px;}}

/* ----------------------------------------------------
  文字寄せ
---------------------------------------------------- */
/*　スマホ左寄せ　ほか中央
---------------------------------------------------- */
.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;}}

/* ----------------------------------------------------
  文字サイズ
---------------------------------------------------- */
.fz90{font-size: 90%;}
.fz120{font-size: 120%;}

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

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

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

@media print, screen and (min-width: 768px) { .wide04{ padding:0 3%;}}
@media print, screen and (min-width: 1400px) {.wide04{ 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}}

.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:450px;}}
@media print, screen and (min-width: 1400px) {.map iframe{width:100%; height:500px;}}

/* ----------------------------------------------------
　ページトップ
---------------------------------------------------- */
#pagetop {
	position: fixed;
	bottom:10px;
	right:10px;
	z-index: 100;
}
#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;
	z-index: 100;
	}
}

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

/* ----------------------------------------------------
　アンカーリンク
---------------------------------------------------- */
.anchor {scroll-margin-top: 90px;}
@media screen and (min-width: 768px) { .anchor {scroll-margin-top: 100px;}}
@media screen and (min-width: 1200px) {.anchor {scroll-margin-top: 90px;}}
@media screen and (min-width: 1400px) {.anchor {scroll-margin-top: 90px;}}

/* ----------------------------------------------------
　アンカーリンク 2
---------------------------------------------------- */
.anchor02 {scroll-margin-top: 100px;}
@media screen and (min-width: 768px) { .anchor02 {scroll-margin-top: 120px;}}
@media screen and (min-width: 1200px) {.anchor02 {scroll-margin-top: 120px;}}
@media screen and (min-width: 1400px) {.anchor02 {scroll-margin-top: 100px;}}