@charset "utf-8";

/*リセットCSS（ress.css）の読み込み----------------------------------------*/
@import url("https://unpkg.com/ress/dist/ress.min.css");

/*Font Awesomeの読み込み----------------------------------------------*/
@import url("https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.15.4/css/all.min.css");

/*slick.cssの読み込み----------------------------------------------------*/
@import url("https://cdn.jsdelivr.net/npm/slick-carousel@1.8.1/slick/slick.css");

/*全体の設定-----------------------------------------------------------*/
html,body {
	font-size: 14px;	/*基準となるフォントサイズ。下の方にある「画面幅800px以上」で基準を大きなサイズに変更しています。*/
}

body {
	overflow-x: hidden;
	font-family: "ヒラギノ丸ゴ Pro", "Hiragino Maru Gothic Pro","ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;	
	-webkit-text-size-adjust: none;
	background: #fff;	
	color: #333;	
	line-height: 2;		/*行間*/
}

/*画像全般の設定*/
img {border: none;vertical-align: middle;}

/*section全般の設定*/
section + section {
	margin: 50px 0;	/*sectionの間に空けるスペース*/
}

/*フォームタグ全般の設定*/
input, textarea, select {
	border: 1px solid #999;	
	padding: 0 10px;
}

/*ress.cssでselectで矢印が消えてしまうのを戻す*/
select {
	-moz-appearance: menulist;
	-webkit-appearance: menulist;
	appearance: menulist;
}
select::-ms-expand {
    display: block;	/*IE用*/
}

ul,ol {
	margin: 0 5px 30px 25px;	
}

a {color: #333;} 
a:hover {color: #003774;} 

#container {margin: 0 auto; width: 1000px;}

header {
	display: flex;
	flex-direction: row;
	justify-content: space-between;	/*並びかたの種類の指定*/
	/*align-items: center;
	text-align: center;*/
	padding: 20px;
}

/*header #logo {
	width: 300px;	
	margin: 0;	
}*/



/*ul要素。メニュー１個１個を囲む親のボックス。*/
#menubar ul {
	margin: 0;
	list-style: none;
	display: flex;						/*flexボックスを使う指定*/
	justify-content: space-around;		/*並びかたの種類の指定*/
	border-top: 1px solid #dcdcdc;		/*上の線の幅、線種、色*/
	border-bottom: 1px solid #dcdcdc;	/*下の線の幅、線種、色*/
	line-height: 1.5;					/*行間を少しだけ狭く*/
}

/*メニュー１個あたりの設定*/
#menubar li {
	flex: 1;			/*それぞれのメニューが幅一杯に広がるように*/
	text-align: center;	/*テキストをセンタリング*/
	position: relative;
}

/*ラインアニメーションの設定*/
#menubar li::before {
	content: "";
	position: absolute;
	left: 0px;
	top: 0px;
	width: 100%;
	height: 5px;
	background: #003774;			/*線となる背景の色*/
	transition: 0.3s;				/*アニメーションの実行時間は0.3秒。*/
	transform: scaleX(0);			/*幅。最初は0にして見えなくしておく。*/
	transform-origin: center top;	/*線の出現起点が左からになるように。中央からの出現がよければこの１行削除。*/
}

/*リンクテキスト*/
#menubar li a {
	text-decoration: none;
	display: block;
	color: #333;	/*文字色*/
	padding: 12px 0px 17px 0px;	/*上、右、下、左への余白*/
}

/*アイコン画像（アイコンにはFont Awesomeを使用）*/
#menubar i {
	display: block;			/*改行が入るようにblock指定。もし横に並べたいならこの１行を削除し、下のpadding-bottomをpadding-rightに変更すればOK。*/
	padding-bottom: 10px;	/*アイコンの下に空ける余白*/
	color: #003774;			/*文字色＝アイコン色になります。*/
}

/*アイコンのマウスオン時*/
#menubar li:hover i {
	transition: 0.3s;		/*アニメーション時間。0.3秒。*/
	transform: scale(1.15);	/*サイズを1.15倍にする。*/
}

/*spanタグ（装飾用のテキスト）*/
#menubar span {
	display: block;
	font-size: 0.5rem;	/*文字サイズ。remの単位についてはテンプレート内の解説をお読み下さい。*/
	opacity: 0.6;		/*透明度。0.6は60%色が出た状態。*/
	letter-spacing: 0.2em;	/*文字間隔を少しだけ広くとる指定*/
}

/*アニメーション結果。ライン幅が100%になる。*/
#menubar li:hover::before {
	transform: scaleX(1);
}


header address {font-style: normal; text-align: right;}
header address img {margin: 0 3px 3px 0;}
header address span {
	display: block;
	font-size: 0.7rem;
}

/*mainブロック設定---------------------*/
main {
	/*padding: 50px 20px 20px 20px;*/
	padding: 50px;
}
/*h2タグのアニメーション結果。ライン幅が100%になる。*/
main h2.linestyle::after {
	transform: scaleX(1);
}

main h2 {
	padding: 5px;
	margin-bottom: 30px;
	position: relative;
	letter-spacing: 0.1em;
}

main h2::before {
	background: #d9d9d9;
}

main h2::before ,main h2::after {
	content: "";
	position: absolute;
	bottom: 0px;
	left: 0px;
	width: 100%;
	height: 3px;	/*ラインの高さ*/
}

/*h2タグのafter（アニメーションの初期設定）*/
main h2::after {
	background: #003774;		/*線となる背景の色*/
	transition: 1s 0.5s;		/*1sはアニメーションの実行時間は1秒。0.5秒遅れてスタートする指定。*/
	transform: scaleX(0);		/*幅。最初は0にして見えなくしておく。*/
	transform-origin: left top;	/*線の出現起点が左からになるように。中央からの出現がよければこの１行削除。*/
}

main h3 {
	padding: 5px;
	margin-bottom: 30px;
	letter-spacing: 0.1em;	/*文字間隔を少しだけ広くとる設定*/
	border-bottom: 1px solid #ccc;
}

main p {
	margin: 0 5px 30px;
}

.list-container {
	display: flex;		/*flexボックスを使う指定*/
	flex-wrap: wrap;	/*折り返す指定*/
	justify-content: space-between;	/*並びかたの種類の指定*/
	padding: 0 5px;		/*上下、左右へのボックス内の余白*/
}

/*１個あたりのボックス*/
.list {
	width: 31.5%;
	margin-bottom: 25px;
	padding: 10px;
	position: relative;
	overflow: hidden;
	transition: 0.3s;		/*アニメーションにかける時間。0.3秒。*/
	box-shadow: 0px 0px 8px rgba(0,0,0,0.1);	/*ボックスの影。右へ、下へ、ぼかし幅。0,0,0は黒の事で0.2は色が20%ついた状態。*/
	background: #fff;	/*背景色*/
}
/*
.list:hover {
	box-shadow: 0px 0px 15px rgba(0,0,0,0.5);
}*/

.list a {
	text-decoration: none;
	color: #333;
}
.list h4 {
	line-height: 1.5;	/*行間を少し狭くする*/
	color: #003774;		/*文字色*/
	margin: 5px 0;		/*上下、左右に空けるスペース*/
}

.list p {
	margin: 0!important;	/*「main p」のマージンをリセットする*/
	display: -webkit-box;
	overflow: hidden;
	-webkit-box-orient: vertical;
	-webkit-line-clamp: 3;	/*表示させたい行数。変更する際は、下の「IE対策」の「height」も変更して下さい。*/
	font-size: 0.7rem;		/*文字サイズ。remの単位についてはテンプレート内の解説をお読み下さい。*/
    line-height: 1.5em;		/*IE対策。行間。１行あたりの高さの事。1.5文字分。*/
    max-height: 4.5em;		/*IE対策。最大の高さ。1.5emの3倍の4.5emになっているので、3行分という事。*/
}

/*NEW,UPアイコン 共通*/
.newicon, .upicon {
	display: inline-block;
	text-align: center;
	padding: 0 5px;
	border-radius: 3px;
	transform: scale(0.7);
}

.newicon {
	background: #f00;		/*背景色*/
	color: #fff;			/*文字色*/
}

/*upiconへの追加指定。*/
.upicon {
	background: #257dce;	/*背景色*/
	color: #fff;			/*文字色*/
}
/*option帯リボン------------------------------------*/
/*option1~4 共通*/
.option1, .option2, .option3, .option4 {
	font-size: 0.7rem;	/*文字サイズ。remの単位についてはテンプレート内の解説をお読み下さい。*/
	display: inline-block;
	width: 200px;
	text-align: center;
	position: absolute;
	top: 0px;
	left: 0px;
	transform: translate(-60px, 20px) rotate(-30deg);	/*translateは配置場所の指定。rotateは回転。*/
	box-shadow: 0px 3px 2px rgba(0,0,0,0.2);			/*影*/
	color: #fff;
	
}

/*h2タグ内で使った場合のoption1~4 共通（※CMS用）*/
h2 .option1, h2 .option2, h2 .option3, h2 .option4 {
	width: auto;
	position: relative;
	transform: translate(0px, -4px) rotate(0deg);
	padding: 5px 20px;
	margin-left: 10px;
}

/*option1~4への追加指定。*/
.option1 {
	background: #ff0000;
}

.option2 {
	background: #2EA7E0;
}

.option3 {
	background: #22AC38;
}

.option4 {
	background: orange;
}

#footermenu {
	background: #003774;	
	color: yellow;		
	font-size: 0.7rem;	/*文字サイズ。remの単位についてはテンプレート内の解説をお読み下さい。*/
	padding: 10px 25px;	/*上下、左右へのボックス内の余白*/
	display: flex;		/*flexボックスを使う指定*/
	justify-content: space-between;	/*並びかたの種類の指定*/
}


/*フッター設定-------------------------------*/
footer small {font-size: 100%;}

footer {
	clear: both;
	font-size: 0.6rem;		/*文字サイズ。remの単位についてはテンプレート内の解説をお読み下さい。*/
	background: #C4D6EC;	/*背景色*/
	color: #fff;			/*文字色*/
	text-align: center;		/*内容をセンタリング*/
	padding: 8px;			/*ボックス内の余白*/
}

/*リンクテキスト*/
footer a {color: #fff;text-decoration: none;}

/*リンクテキストのマウスオン時*/
footer a:hover {color: #fff;}

/*著作部分*/
footer .pr {display: block;}



/*PAGE TOP（↑）設定-------------------------------*/
.pagetop-show {display: block;}

.pagetop a {
	display: block;text-decoration: none;text-align: center;
	width: 35px;		/*幅*/
	line-height: 35px;	/*高さ*/
	position: fixed;
	right: 30px;		/*右からの配置場所指定*/
	bottom: 30px;		/*下からの配置場所指定*/
	color: #fff;		/*文字色*/
	background: rgba(0,0,0,0.4);	/*背景色。0,0,0は黒色の指定で0.4は色が40%出た状態。*/
	/*border: 1px solid #fff;*/	/*枠線の幅、線種、色*/
}

/*マウスオン時*/
.pagetop a:hover {
	background: rgba(0,0,0,0.8);	/*背景色。0,0,0は黒色の指定で0.8は色が80%出た状態。*/
}


/*テーマカラーの背景色の slideボックス--------------------------------------*/
/*ボックスの設定*/
.bg1 {
	background: #C4D6EC;
	padding: 8px;			/*ボックス内の余白*/
	color: #003774;
}

/*ボックス内のリンクテキスト*/
.bg1 > a {
	color: #fff;
}

/*ボックス内のh2タグ*/
.bg1 h2 {
	text-align: center;		/*テキストをセンタリング*/
	margin: 0 !important;
}

/*ボックス内のh2タグのbefor（下線のデフォルトの状態の設定）*/
.bg1 h2::before {
	background: transparent;		/*線となる背景の色。transparentは透明の事。*/
}

/*ボックス内のh2タグのafter（アニメーションの初期設定）*/
.bg1 h2::after {
	height: 2px;
	width: 93.6%;
	margin: 0 28px;
	background: #003774;				/*線となる背景の色*/
	transform-origin: center top;	/*線の出現起点が中央からになるように。*/
}

/*pickupスライドショー（slickを使用）
-----------------------------------*/
/*スライドショー全体を囲むボックス*/
.pickup {
	position: relative;
	display: flex;			/*flexボックスを使う指定*/
/*１個あたりのボックス*/
	/*margin: 20px;*/
	padding: 20px 20px 0 20px;
}

/*マウスオン時の設定。
マウスオンでスライドがストップしてしまうので、それがわかりやすいようにopacityを設定しました。
もしマウスオンでストップさせたくない場合は、slick.cssの「//pauseOnHover: false,」の行の冒頭の「//」を外して適用して下さい。*/
.pickup .list:hover figure {
	/*opacity: 0.8;*/	/*透明度。色が80%出た状態。*/
}

/*１個あたりのボックス*/
.pickup .slick-slide {
	margin: 5px !important;
	width: auto;
}

/*ボックス内のh4タグ*/
.pickup .list h4 {
	display: -webkit-box;
	overflow: hidden;
	-webkit-box-orient: vertical;
	-webkit-line-clamp: 1;	/*表示させたい行数。変更する際は、下２行のIE対策も変更して下さい。*/
    line-height: 1.5em;		/*IE対策。行間。１行あたりの高さの事。1.5文字分。*/
    height: 1.5em;			/*IE対策。高さ。slick内で高さを統一できなかったので、応急措置でheightのみ指定。*/
}

/*ボックス内のpタグの最大の高さ。
max-heightにするとslick内で高さを統一できなかったので、応急措置でheightのみ指定。
3行分を確保したかったので、1.5emの3倍で本来なら「4.5em」なのですが、
なぜか画面幅によってほんの少しテキストのかけらが見えてしまったので「4.4em」にしました。*/
.pickup .list p {
    height: 4.4em;
}

/*ボックス内の画像*/
.pickup .list img {
	object-fit: cover;	/*トリミングのタイプ*/
	height: 120px;		/*画像の高さ*/
	width: 100%;		/*画像の幅*/
	font-family: 'object-fit: cover;';	/*IE対策*/
}
/*ボックス内の間隔*/
.pickup .list {
	margin-left: 8px;
	margin-right: 8px;
}

/*左右の三角矢印の共通設定*/
.slick-arrow {
	position: absolute;
	bottom: 45%;	/*下からの配置場所*/
}

/*左右の三角矢印の共通設定。マウスオン時。*/
.slick-arrow:hover {
	cursor: pointer;
	opacity: 0.8;
}

/*左右の三角矢印の形、色、サイズ*/
.slick-prev::after,
.slick-next::after {
	display: block;
	content: "▼";		/*この形を出力する。このままだと下向き矢印になってしまうので、下の方の設定でそれぞれ90度回転させています。*/
	color: #003774;		/*三角の色*/
	font-size: 1rem;	/*三角のサイズ。remの単位についてはテンプレート内の解説をお読み下さい。*/
}

/*左側の三角*/
.slick-prev {
	left: 2px;	/*左からの配置場所*/
}

/*左側の三角を回転させる指定*/
.slick-prev::after {
	transform: rotate(90deg);
}

/*右側の三角*/
.slick-next {
	right: 2px;	/*右からの配置場所*/
}

/*右側の三角を回転させる指定*/
.slick-next::after {
	transform: rotate(-90deg);
}

/*スライドショー（slickを使用）--------------------*/
.mainimg {
	position: relative;
	padding: 0 !important;
}

/*マウスオン時の設定。
マウスオンでスライドがストップしてしまうので、それがわかりやすいようにopacityを設定しました。
もしマウスオンでストップさせたくない場合は、slick.cssの「//pauseOnHover: false,」の行の冒頭の「//」を外して適用して下さい。*/
.mainimg:hover {
	opacity: 0.8;	/*透明度。色が80%出た状態。*/
}


/*丸いページナビボタン全体を囲むブロック*/
.slick-dots {
	text-align: center;
	width: 100%;
	margin:0;
	line-height: 1;
	position: absolute;
	bottom: 10px;	/*下からの配置場所指定*/
}

/*丸いページナビボタン１個あたりの設定*/
.slick-dots li {
	display: inline-block;
	margin: 0 10px;
	cursor: pointer;
}

/*buttonタグ*/
.slick-dots li button {
	display: block;
	text-indent: -9999px;	/*デフォルトで文字が出るので画面の外に追い出す指定*/
	width: 12px;			/*ボタンの幅*/
	height: 12px;			/*ボタンの高さ*/
	border-radius: 50%;		/*丸くする指定*/
	cursor: pointer;		/*クリックで画像へジャンプするので、わかりやすいようhover時にpointerになるように。*/
	background: #E3E3E3;		/*背景色。薄いgray。*/
}

/*buttonのアクティブ時（現在表示されている画像を示すボタン）*/
.slick-dots li.slick-active button {
	background: #FFF100;
}


/* footer 問合せバナー */
a:hover{opacity: 0.8;}


/*  fix bnr  -----------------*/
#fixbnr {
	position:fixed;
	bottom: 300px;
	right: 0px;
	display:block;	
}

.fixR {
  -webkit-transition: width ease-in-out 0.5s;
  	 -moz-transition: width ease-in-out 0.5s;
  	   -ms-transition: width ease-in-out 0.5s;
         -o-transition: width ease-in-out 0.5s;
              transition: width ease-in-out 0.5s;
	outline:none;
	display: block;
	position: relative;
	width:30px;
	height:190px;
	left:0px;
	background: url("../images/otoiawase.png") no-repeat scroll 0 0 transparent;  }

.fixR:hover {
	background-position:0px 0px; 
	width:230px;
}


/*  問合せフォーム  -----------------*/
form {
	margin-top: 70px;
}

.form-group {
	margin: 30px 0px;
}

label {
    display: inline-block;
	float: left;
	width: 18%; 
	font-size: 20px;
	line-height: 1.8em;
    font-weight: bold;
	text-align: right;
	margin-right: 50px; /*#txt margin-rightと*/
}

textarea {
	box-sizing: border-box;
	display: flex;
	margin-left: 212px;
	resize: vertical;
	
	min-width: 50%;
	max-width: 70%;
	
	min-height: 500px;
	max-height: 700px;
}

.form-control {
	display: block;
    width: 70%;
    height: 50px;
    padding: 5px 10px;
    font-size: 14px;
    line-height: 1.428571429;
    color: #555;
    vertical-align: middle;
    background-color: #fff;
    border: 1px solid #000;
    /*border-radius: 2px;*/
    -webkit-box-shadow: inset 0 1px 1px rgb(0 0 0 / 8%);
    box-shadow: inset 0 1px 1px rgb(0 0 0 / 8%);
    -webkit-transition: border-color ease-in-out .15s,box-shadow ease-in-out .15s;
    transition: border-color ease-in-out .15s,box-shadow ease-in-out .15s;
}

.btn {
	display: inline-block;
    padding: 6px 0px 4px 22px;
	/*clear: both;*/
	

	/*右寄せ*/
	float: right;
	margin: 0px 58px 0 0;
	
    font-size: 22px;
    font-weight: normal;
    line-height: 1.3;
	letter-spacing: 0.3em;
    white-space: nowrap;
    vertical-align: middle;
    cursor: pointer;
	
	background: #003774; 
	color: #fff;
    border: 1px solid transparent;
    border-color: rgb(53, 126, 189);
    border-radius: 5px;
	
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    -o-user-select: none;
    user-select: none;
	margin-bottom: 100px;
}


.btn:hover {
	background: #0057B8;
    /*background: #6EAA00; #F18E00*/
}











