@charset "utf-8";

/* Base
----------------------------------------------------*/

.red {
	color: #f00;
	font-size: 12px;
}
body {
	font-family: "メイリオ", Meiryo, arial, "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", Osaka, "ＭＳ Ｐゴシック", "MS PGothic", Sans-Serif;
	color:#333;
	font-size: 14px;
}

html, body, div, span, applet, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
a, abbr, acronym, address, big, cite, code,
del, dfn, em, font, img, ins, kbd, q, s, samp,
small, strike, strong, sub, sup, tt, var,
b, u, i, center,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td{

margin:0;
padding:0;
vertical-align:baseline;
font-style:normal;
font-weight:normal;
font-family:"メイリオ", Osaka, "ヒラギノ角ゴ Pro W3",Meiryo UI,"Segoe UI Light","ＭＳ Ｐゴシック",sans-serif;
line-height:1.7;
}

h1, h2, h3, h4, h5, h6{
line-height:1.3;
font-weight:normal;
font-size:100%;
}

p,
li,
dt, dd,
th, td{
}

ul, ol{
list-style-type:none;
list-style-position:outside;
}

img{
	vertical-align: bottom;
}

a img{
	border: 0;
}

/*　　*/

.center-text {
	text-align:center;
}

.floatright {
	float: right;
}

.floatleft {
	float:left;
}

.clearboth {
	clear:both;
}

.margin_b5 {
	margin-bottom:5px;
}

.margin_b10 {
	margin-bottom:10px;
}

.margin_b12 {
	margin-bottom:12px;
}

.margin_b15 {
	margin-bottom:15px;
}

.margin_b17 {
	margin-bottom:17px;
}

.margin_b20{
	margin-bottom:20px;
}

.margin_b25{
	margin-bottom:25px;
}

.margin_b30{
	margin-bottom:30px;
}

.margin_b40{
	margin-bottom:40px;
}

.in_cont {
	clear: both;
	overflow: hidden;
}

.in_cont5 {
	clear: both;
	overflow: hidden;
	margin-bottom: 5px;
}

.in_cont10 {
	clear: both;
	overflow: hidden;
	margin-bottom: 10px;
}

.in_cont20 {
	clear: both;
	overflow: hidden;
	margin-bottom: 20px;
}

.in_cont30 {
	clear: both;
	overflow: hidden;
	margin-bottom: 30px;
}

.in_cont40 {
	clear: both;
	overflow: hidden;
	margin-bottom: 40px;
}

.in_cont50 {
	clear: both;
	overflow: hidden;
	margin-bottom: 50px;
}

img.icon:hover{
    opacity: 0.6;
    filter: alpha(opacity=60);
    -moz-opacity: 0.6;
}


.pic-left {
	float: left;
}

.pic-right {
	float: right;
	margin-bottom: 15px;
	margin-left: 15px;
	width: 50%;
	height: auto;
}

.pic-waku {
	border: 1px solid #CCC;
	padding: 3px;
}

.clearfix:before, .clearfix:after {
 display: table;
 content: " ";
}

.clearfix:after {
 clear: both;
}

.txt_indent1 {
	padding-left: 1em;
	text-indent: -1em;
}

.img100 img{
	width:100%;
	height:auto;
}


/*　共通　*/





/* メインメニュー　PC用
------------------------------------------------------------*/
@media only screen and (min-width: 481px){

.spDisp {
	display:none;
}

.spHide {
	display:block;
}

/*　見出し・画像　*/

.midashi1 {
	font-size: 28px;
	margin-bottom: 30px;
	padding-bottom: 10px;
	border-bottom-width: 2px;
	border-bottom-style: solid;
	border-bottom-color: #245498;
}

.midashi2 {
	font-size: 18px;
	font-weight: bold;
	margin-bottom: 15px;
	border-left-width: 6px;
	border-left-style: solid;
	border-left-color: #1E4E94;
	padding-left: 10px;

}
.midashi3 {
	font-size: 16px;
	margin-bottom: 20px;
	background-color: #1E4E94;
	padding-top: 10px;
	padding-bottom: 10px;
	padding-left: 15px;
	color: #FFF;
	clear: both;

}


/*　ヘッダー　*/

h1 {

}

header {
	background-image: url(../img/header_back.png);
	background-repeat: repeat-x;
	background-position: bottom;
	min-width: 1200px;
	background-color: #F9F9F9;

}

.header_cont {
	width: 960px;
	margin-right: auto;
	margin-left: auto;
	padding-top: 23px;
	padding-bottom: 30px;
	overflow: hidden;

}

.header_logo {
	float: left;
	width: 320px;
}

.header_logo img{
	width: 100%;
	height:auto;
}

.header_info {
	width: 484px;
	float: right;
	padding-top: 6px;
}

.header_info img{
	float: left;
	margin-left: 10px;
}

.toph1 {
	font-size: 12px;
	color: #FFF;
	text-align: right;
	height: 29px;
	padding-top: 17px;
}

.header_nav {
	clear: both;
	background-image: url(../img/nav_back.png);
	background-repeat: repeat-x;
	background-position: bottom;
	min-width: 1200px;
}




/* メインイメージ */

.main_img {
	min-width: 1200px;
	background-image: url(../img/main_img.png);
	background-repeat: repeat;
	overflow: hidden;
	padding-top: 27px;
	padding-bottom: 27px;
}

/* トップページ */

.cont960 {
	width: 960px;
	margin-right: auto;
	margin-left: auto;	
}
.cont960-2 {
	width: 1200px;
	margin-right: auto;
	margin-left: auto;	
}

.main1 {
	text-align: center;
	padding-top: 37px;
	padding-bottom: 37px;
	min-width:1200px;
}

.main2 {
	background-color: #F9F9F9;
	padding-top: 25px;
	padding-bottom: 30px;
	min-width: 1200px;
}

.main2_c11 {
	width: 314px;
	margin-right: 9px;
	float: left;
	margin-bottom: 20px;
}

.main2_c11 img{
	width:100%;
	height:auto;
}

.main2_c12 {
	width: 314px;
	float: left;
	margin-bottom: 20px;
}

.main2_c12 img{
	width:100%;
	height:auto;
}



.main2_c21 {
	width: 300px;
	float: left;
	margin-bottom: 10px;
}

.main2_c22 {
	width: 300px;
	float: left;
	margin-bottom: 10px;
	margin-right: 30px;
	margin-left: 30px;
}

.main2_t {
	text-align: right;
	margin-bottom: 20px;
}

.main2_c3 {
	background-color: #1E4E94;
	color: #FFF;
	width: 850px;
	margin-right: auto;
	margin-left: auto;
	font-size: 16px;
	font-weight: bold;
	text-align: center;
	padding-top: 20px;
	padding-bottom: 20px;
}

.main3 {
	background-image: url(../img/main3_back.png);
	background-repeat: no-repeat;
	background-position: bottom;
	background-size: cover;
	min-width: 1200px;
	text-align: center;
	padding-top: 65px;
	padding-bottom: 65px;
}

.main3_m {
	width: 910px;
	margin-right: auto;
	margin-left: auto;
	border-bottom-width: 1px;
	border-bottom-style: solid;
	border-bottom-color: #1E4E94;
	margin-bottom: 40px;
	padding-bottom: 33px;
	text-align: center;
}

.main4 {
	background-color: #285699;
	min-width: 1200px;
	padding-top: 40px;
	padding-bottom: 50px;
	overflow: hidden;
}

.main4_m {
	text-align: center;
	margin-bottom: 37px;
}

.main4_1 {
	float: left;
	width: 466px;
	background-image: url(../img/main4_1back.png);
	background-repeat: no-repeat;
	background-position: left top;
	background-color: #FFF;
	height: 220px;
}

.main4_2 {
	float: right;
	width: 466px;
	background-image: url(../img/main4_2back.png);
	background-repeat: no-repeat;
	background-position: left top;
	background-color: #FFF;
	height: 220px;
}

.main4t {
	float: right;
	width: 265px;
	margin-top: 24px;
	margin-right: 15px;
}

.main5 {
	background-image: url(../img/main5_back.png);
	background-repeat: no-repeat;
	background-position: center top;
	text-align: center;
	height: 396px;
	min-width: 1200px;
}

.main5_m {
	padding-top: 32px;
	padding-bottom: 24px;
}

.main5_c {
	margin-bottom: 24px;
}

.main5_j {
}


.main6 {
	width: 960px;
	margin-right: auto;
	margin-left: auto;
	padding-top: 40px;
	padding-bottom: 40px;
	overflow: hidden;
}

.main6_1 {
	width: 450px;
	float: left;
}

.main6_2 {
	        float: left;
        width: 405px;
        height: 533px;
        margin-bottom: 20px;
        margin-left: 20px;
}
.main6_3 {
  float: right;
  width: 300px;
  margin-bottom: 20px;
  margin-left: 20px;
}

/* 動画を親にフィットさせる */
.main6_3 video {
  width: 100%;
  height: auto;
  display: block;
  aspect-ratio: 9 / 16; /* 縦動画なら */
  object-fit: cover;
}

/* SP対応 */
@media screen and (max-width: 767px) {
  .main6_3 {
    float: none;
    width: 100%;
    margin-left: 0;
  }
}

.main6_m {
	font-weight: bold;
	color: #1E4E94;
	margin-bottom: 10px;
	padding-bottom: 5px;
	border-bottom-width: 1px;
	border-bottom-style: solid;
	border-bottom-color: #CCC;
}

.main6_1 a{
	color: #1E4E94;
}

.main6_logo {
	margin-bottom: 25px;
}

.main_banner {
	background-color: #285699;
	clear: both;
	padding-top: 38px;
	padding-bottom: 38px;
	overflow: hidden;
	min-width: 1200px;
}

.main_banner img {
	float: left;
	margin-right: 5px;
	margin-left: 5px;
}

/* フッター・コピーライト　*/

footer {
	background-color: #F7F7F7;
	min-width: 1200px;
}

.footer_cont {
	width: 960px;
	margin-right: auto;
	margin-left: auto;
	overflow: hidden;
	padding-top: 28px;
	padding-bottom: 28px;
}

.footer_logo {
	float: left;
	width: 265px;
	margin-right: 60px;
}

.footer_navi {
	width: 635px;
	float: left;
	padding-top: 5px;
}

.footer_navi ul{
	clear: both;
}

.footer_navi li{
	float: left;
}

.footer_navi li a {
	color: #333;
	text-decoration: none;
}

.footer_navi li a:hover {
	color: #333;
	text-decoration: underline;
}


.copyright {
	clear: both;
	color: #FFFFFF;
	font-size: 12px;
	background-color: #333333;
	text-align: center;
	padding-top: 10px;
	padding-bottom: 10px;
}

.min1200 {
	min-width: 1200px;
}
.min1200.min1400 {
	min-width: 1200px;
}

   .min1400 .main6 {
        width: 1200px;
        margin-right: auto;
        margin-left: auto;
        padding-top: 40px;
        padding-bottom: 40px;
        overflow: hidden;
    }
/*　中ページ　*/


.page_cont {
	width: 960px;
	margin-right: auto;
	margin-left: auto;
	padding-top: 40px;
	padding-bottom: 80px;
	overflow: hidden;
}

.page_title{
	min-width: 1200px;
	background-image: url(../img/main_img.png);
	background-repeat: repeat;
	overflow: hidden;
	padding-top: 27px;
	padding-bottom: 27px;
	font-size: 30px;
	color: #FFF;
	text-align: center;
}

.main_cont {
	float: right;
	width: 720px;
}

.main_cont a{
	color: #333;
	text-decoration: underline;
}

.main_cont a:hover{
	color: #333;
	text-decoration: none;
}


.side_cont {
	float: left;
	width: 210px;
}

.side_m {
	background-image: url(../img/side_mb.png);
	background-repeat: no-repeat;
	background-position: left bottom;
	margin-bottom: 15px;
	padding-bottom: 9px;
}

.side_li {
	background-color: #F9F9F9;
	padding-top: 12px;
	padding-right: 12px;
	padding-bottom: 7px;
	padding-left: 12px;
	margin-bottom: 10px;
}

.side_li li{
	margin-bottom: 5px;
}

.side_banner {
	margin-bottom: 10px;
}


.plof_t {
	width: 100%;
	margin-bottom: 50px;
}

.plof_t table{
	width: 100%;
	border-collapse:collapse;
}

.plof_t th{
	padding: 15px;
	background-color: #F9F9F9;
	border: 1px solid #CCC;
	width: 20%;
}

.plof_t td{
	padding: 15px;
	border: 1px solid #CCC;
}

.prof_s1 {
	margin-bottom: 5px;
	padding-bottom: 3px;
	border-bottom-width: 1px;
	border-bottom-style: solid;
	border-bottom-color: #E5E5E5;
	color: #1E4E94;
}

.plof_t2 {
	width: 100%;
	margin-bottom: 50px;
}

.plof_t2 table{
	width: 100%;
	border-collapse:collapse;
}

.plof_t2 th{
	width: 100px;
	border-bottom-width: 1px;
	border-bottom-style: solid;
	border-bottom-color: #CCC;
	padding: 10px;
}

.plof_t2 td{
	padding: 10px;
	border-bottom-width: 1px;
	border-bottom-style: solid;
	border-bottom-color: #CCC;
}

.prof_map {
	border: 1px solid #CCC;
}

.ser_li {
	margin-bottom: 15px;
}

.ser_li li{
	list-style-type: decimal;
	list-style-position: inside;
}

.link_t {
}

.link_t table{
	border-collapse:collapse;
	width:100%;
}

.link_t th{
	border: 1px solid #CCC;
	text-align: left;
	vertical-align: middle;
	padding: 10px;
}

.link_td1{
	border: 1px solid #CCC;
	vertical-align: middle;
	padding: 10px;
}

.link_td2 {
	border: 1px solid #CCC;
	vertical-align: middle;
	padding: 10px;
	width: 258px;
}

.price_t1 {
	float: left;
	width: 50%;
	margin-bottom: 30px;
}

.price_t1 table{
	width: 100%;
}

.price_t1 th{
	text-align: left;
	padding: 10px;
	background-color: #BFD7EA;
	border-bottom-width: 1px;
	border-bottom-style: solid;
	border-bottom-color: #FFF;
}

.price_t1 td{
	padding: 10px;
	background-color: #F9F9F9;
	width: 40%;
	border-bottom-width: 1px;
	border-bottom-style: solid;
	border-bottom-color: #FFF;
}


.price_t2 {
	float: left;
	width: 50%;
	margin-bottom: 30px;
}

.price_t2 table{
	width: 100%;
}

.price_t2 th{
	text-align: left;
	padding: 10px;
	background-color: #BFD7EA;
	border-bottom-width: 1px;
	border-bottom-style: solid;
	border-bottom-color: #FFF;
}

.price_t2 td{
	padding: 10px;
	background-color: #F9F9F9;
	width: 40%;
	border-bottom-width: 1px;
	border-bottom-style: solid;
	border-bottom-color: #FFF;
}

.price_b1 {
	float: left;
	margin-bottom: 20px;
}

.price_b2 {
	float: right;
	margin-bottom: 20px;
}

.toku_t {
	width: 100%;
	margin-bottom: 50px;
}

.toku_t table{
	width: 100%;
	border-collapse:collapse;
}

.toku_t th{
	padding: 15px;
	background-color: #F9F9F9;
	border: 1px solid #CCC;
	width: 110px;
	vertical-align: middle;
	text-align: left;
}

.toku_td1{
	width: 75px;
	border-top-width: 1px;
	border-bottom-width: 1px;
	border-top-style: solid;
	border-bottom-style: solid;
	border-top-color: #CCC;
	border-bottom-color: #CCC;
	padding-top: 15px;
	padding-bottom: 15px;
	padding-left: 15px;
}

.toku_td2{
	padding: 15px;
	vertical-align: middle;
	border-top-width: 1px;
	border-right-width: 1px;
	border-bottom-width: 1px;
	border-top-style: solid;
	border-right-style: solid;
	border-bottom-style: solid;
	border-top-color: #CCC;
	border-right-color: #CCC;
	border-bottom-color: #CCC;
}

.pagetop {
	padding-top: 10px;
	padding-bottom: 10px;
	overflow: hidden;
	clear: both;
	position: fixed;
	bottom: 10px;
	right: 10px;
}

.pagetop img{
	float: right;
	padding-right: 20px;
}

.air_cont {
	background-image: url(../img/air_back.png);
	background-repeat: no-repeat;
	background-position: center top;
	padding-top: 40px;
	margin-bottom: 40px;
}


}



/* お問い合わせ */

#formWrap {
	width: 100%;
	margin:0 auto;
	color:#555;
	line-height:120%;
	font-size:90%;
}

table.formTable{
	width: 100%;
	border-collapse: collapse;
	margin-top: 0;
	margin-right: auto;
	margin-bottom: 20px;
	margin-left: auto;
	background-color: #FFF;
}
table.formTable td,table.formTable th{
	border: 1px solid #ccc;
	padding: 12px;
}
table.formTable th{
	width: 30%;
	font-weight: normal;
	text-align: left;
	vertical-align: middle;
	border: 1px solid #CCC;
}

.pin {
	color: #F00;
}

.thanks {
	font-size: 18px;
	margin-bottom: 40px;
	border-bottom-width: 1px;
	border-bottom-style: solid;
	border-bottom-color: #F8B404;
	padding-bottom: 5px;
}

.thanks_a a{
	color: #333;
}

.ser_li li{
	list-style-type: decimal;
	list-style-position: inside;
	text-indent:-1em;
	padding-left:1em;
}

.qa_q {
	background-image: url(../img/qa_q.png);
	background-repeat: no-repeat;
	background-position: left top;
	font-size: 18px;
	color: #1E4E94;
	font-weight: bold;
	padding-left: 50px;
	padding-top: 7px;
	padding-bottom: 15px;
}


.qa_a {
	background-image: url(../img/qa_a.png);
	background-repeat: no-repeat;
	background-position: 15px 15px;
	background-color: #F9F9F9;
	padding: 15px;
	margin-bottom: 30px;
}

.qa_ac {
	padding-top: 10px;
	padding-left: 50px;
}

.air_li li{
	text-indent:-1em;
	padding-left:1em;
	list-style-position: inside;
}
.tx-p10 {
	margin-left: 10px;
	display: block;
	margin-top: 10px;
}
/* =========================
   共通
========================= */
.movieBlock {
  margin: 20px auto 30px;
  padding: 0 10px;
  max-width: 1200px;
}

/* 動画 */
.movieBlock__video video {
  width: 100%;
  aspect-ratio: 9 / 16;
  object-fit: cover;
  border-radius: 10px;
}

/* バナー */
.movieBlock__banners {
  margin-top: 12px;
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.movieBlock__banners img {
  width: 100%;
  border-radius: 8px;
  display: block;
}

/* =========================
   PC：2カラム
========================= */
@media screen and (min-width: 768px) {
  .movieBlock {
	display: flex;
	gap: 24px;
	padding: 0 20px;
	margin-bottom: 30px;
  }

  .movieBlock__video {
    flex: 0 0 52%;
  }

  .movieBlock__banners {
    flex: 0 0 46%;
    margin-top: 0;
  }
}
