@charset "utf-8";
/* 基本要素 */

/* フォント指定

Ralewayの指定
h1{

font-family: 'Roboto', sans-serif;
}

notosansJPの指定
.noto100 {font-weight:100;}
.noto300 {font-weight:300;}
.noto400 {font-weight:400;}
.noto500 {font-weight:500;}
.noto700 {font-weight:700;}
.noto900 {font-weight:900;}



font-family: 'Noto Serif JP', serif;
.notoserif500 {font-weight:500;}
.notoserif600 {font-weight:600;}


*/
* {
  margin: 0;
  padding: 0;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  -ms-box-sizing: border-box;
  box-sizing: border-box;
}



body {
	font-family:'Noto Sans jp',sans-serif;
	font-weight:400 !important;
	font-size: 14px; 
	color:#3c3c3c;
	line-height: normal;
	letter-spacing: 1px;
}

a{
	color: #3c3c3c;
  text-decoration: none;
 }
a:hover {
  color: #10af9e;

}
a img { 
	transition: opacity 0.2s linear; 
}
a:hover img { 
	opacity: 0.8;
}

.spmenu{
	display:none;
}
.br-sp { 
  display:none;
}

img{
	vertical-align: bottom;
}






.mb5 {
	margin-bottom:5px !important;
}
.mb10 {
	margin-bottom: 10px !important;
}
.mb15 {
	margin-bottom: 15px !important;
}
.mb20 {
	margin-bottom:20px !important;
}
.mb30 {
	margin-bottom:30px !important;
}
.mb40 {
	margin-bottom: 40px !important;
}
.mt5 {
	margin-top:5px !important;
}
.mt10 {
	margin-top:10px !important;
}
.mt20 {
	margin-top:20px !important;
}
.mt30 {
	margin-top:30px !important;
}
.mt40 {
	margin-top:40px !important;
}
.mt50 {
	margin-top:50px !important;
}
.mt60 {
	margin-top:60px !important;
}
.mt70 {
	margin-top:70px !important;
}
.ml70 {
	margin-left:220px !important;
}

.center {
	display: block;
	text-align: center;
	margin: 0 auto;
}

.kadomaru{
border-radius: 8px;        /* CSS3草案 */  
    -webkit-border-radius: 8px;    /* Safari,Google Chrome用 */  
    -moz-border-radius: 8px;   /* Firefox用 */ 
}
.container{
	max-width: 1096px;
	margin: 0 auto;
	padding: 0;
  overflow: hidden;

}
.container_kasou{
	max-width: 1096px;
	margin: 0 auto;
  overflow: hidden;
	padding: 0 30px;
}

#back_grey{
	width:100%;
	background-color: #f7f7f7;
	padding: 0;
	margin: 0;
}




/* ヘッダー */
.head_border_top {
  max-width:100%;
	border-top:2px solid #10af9e;
}
.head_border_bottom_pc {
	border-bottom: 4px solid #10af9e;
}

.head_bar{
	font-family: 'Noto Serif JP', serif;
	font-weight: 500;
	font-size: 10px;
	padding-top: 5px;
	padding-left: 64px;
}
.head {
  display: none;
}



/* ナビゲーション */

.g_navi{
		padding-top: 5px;
		padding-bottom: 10px!important;
}
.header_logo_pc{
	width:35.4%;
	float:left;
}

#menu {
	width: 64.6%;
	float:right;

	margin: 0 auto;
	padding: 0;
	display:block;
}
#menu li{
	font-size: 16px;
	font-weight: 500;
	display: block;
	float: left;
	width: 24.8%;
	margin: 0px;
	border-left:1px solid #ccc;
}
#menu li:last-child{
	border-right:1px solid #ccc;

}

#menu li a {
	font-weight: 500;
	display: block;
	background-color: #ffffff;
	color: #000000;
	text-align: center;
	text-decoration: none;
	padding: 9%;
	-webkit-transition: all 0.3s ease;
        -moz-transition: all 0.3s ease;
        -o-transition: all 0.3s ease;
        transition: all  0.3s ease;
}

#menu li a:hover{
	background-color: #10af9e;
	color:#fff;
}




/* top_sec01 */

.top_sec01{
	max-width:100%;
  background-image: url("../img/top_main.png");
	background-repeat: no-repeat;
   -webkit-background-size: cover;
   background-size: cover;
	 background-position:50% 50%;
	position: relative;
	height: 560px;
}



.top_sec01_wrap01{
	text-align: left;
	margin: 0 auto;
	display: block;
	padding-top: 150px;
	padding-left: 362px;
}

p.top_sec01_ttl{

	font-family: 'Noto Serif JP', serif;
	font-weight: 500;	
	font-size: 36px;
	color:#fff;
	line-height: 1.2;
	text-shadow: 0px 0px 10px rgba(0, 0, 0, 0.8);
	font-feature-settings : "palt";

}
p.top_sec01_txt{
	font-weight: 500;	
	font-size: 14px;
	color:#fff;
	padding-top: 14px;
	text-shadow: 0px 0px 10px rgba(0, 0, 0, 0.8);
	font-feature-settings : "palt";

}
.top_sec01_wrap02{
	margin-top: 100px;

}

.top_sec01_wrap03{
	width:5%;
	display: block;
	float:left;
	margin-left: 20px;
	margin-top: 130px;
	padding:0;
	height:310px;

		
}
h2.jigyo_big_ttl{
	font-family: 'Noto Serif JP', serif;
	font-weight: 600;	
	font-size: 30px;
	color:#2e5652;
	letter-spacing: 3px;	
	-webkit-writing-mode: vertical-rl;
      -ms-writing-mode: tb-rl;
          writing-mode: vertical-rl;
}
.top_sec01_wrap04{
	width: 93%;
	display: block;
	float:right;
	margin: 0;
	padding:0;
}
ul.jigyo_wrap{
	display: flex;
	flex-wrap: wrap;
}
li.jigyo_waku{
	width: 30.73%;
	background-color: #fff;
	border:2px solid #10af9e;
  transition: 1s;
	margin: 10px;
	min-height: 0%;
}
li.jigyo_waku img{
	height: auto;
  width: 100%;
}
li.jigyo_waku:hover{
	background-color: #dbdcdd;
	border:2px solid #10af9e;
}
li.jigyo_waku a{
	color:#333;
}


h3.jigyo_ttl{
	font-size: 20px;
	color:#fff;
	font-weight: 500;
	width:100%;
	text-align: center;
	background-color: #10af9e;
	height: 50px;
	padding: 6px;
}
.jigyo_ph{
}





/* top_sec02 */

.top_sec02{
	max-width:100%;
  padding-top: 24px;
	margin: 0 auto;
	display: block;
}
h2.top_sec02_ttl{
	font-family: 'Noto Serif JP', serif;
	font-weight: 500;	
	color:#2e5652;
	font-size: 32px;
	display: flex;
	align-items: center;

}
h2.top_sec02_ttl:before, h2.top_sec02_ttl:after {
	content: "";
	flex-grow: 1;
	height: 4px;
	background: #cfefec;
	display: block;
}

h2.top_sec02_ttl:before {
	margin-right: .4em;
}
h2.top_sec02_ttl:after {
	margin-left: .4em;
}


p.top_sec02_txt{
	font-family: 'Noto Serif JP', serif;
	font-weight: 500;	
	font-size: 20px;
	padding-top: 10px;
	line-height: 2.2;
	text-align: center;
}

/* breadcrumb */
.breadcrumb{
	width:1096px;
	margin: 0 auto;
	font-size: 12px;
	padding: 25px 30px 20px;
}
.bread_icon{
	color:#2e5652;
}




/* kasou_common */
#main{
	width:65.95%;
	float:left;
	display: block;
}
#sidebar{
	width:31.33%;
	float:right;
	display: block;
}

.side_to_contact{
	max-width: 100%;
	background-color: #cfefec;
	border-top:5px solid #10af9e;
	border-bottom:5px solid #10af9e;
	padding: 10px 22px;
	margin-top: 38px;
}

h2.side_to_contact_ttl{
	font-family: 'Noto Serif JP', serif;
	font-weight: 500;
	font-size: 22px;
	color:#2e5652;
	text-align: center;
}
p.side_txt01{
	font-size: 12px;
	color:#2e5652;
	text-align: center;
	line-height: 1.2;
}
.side_btn{
	font-weight: 500;
	width:100%;
	font-size: 18px;
	color:#fff;
	background-color: #2e5652;
	margin-top: 10px;
	padding: 3px;
	height: 34px;
	text-align: center;

	
	border-radius: 5px;        /* CSS3草案 */  
    -webkit-border-radius: 5px;    /* Safari,Google Chrome用 */  
    -moz-border-radius: 5px;   /
}
.side_btn:hover{
	color:#fff;
	background-color: #10af9e;
-webkit-transition: all 0.3s ease;
        -moz-transition: all 0.3s ease;
        -o-transition: all 0.3s ease;
        transition: all  0.3s ease;
	}
.side_tel {
	font-weight: 600;
	font-size: 24px;
	font-weight: 700;
	text-align: center;
	padding: 5px 0 0;
}
.side_tel a{
	color:#2e5652;
}
.side_tel a:hover{
	color:#10af9e;
-webkit-transition: all 0.3s ease;
        -moz-transition: all 0.3s ease;
        -o-transition: all 0.3s ease;
        transition: all  0.3s ease;
}
p.side_txt02{
	font-size: 14px;
}
.side_to_gaiyo{
	margin-top: 28px;
	text-align: center;

}

.main_ttl{
	display: block;
	padding: 25px 0 0;
	text-align: center		
}
h2.main_big_ttl{
	font-family: 'Noto Serif JP', serif;
	font-weight: 500;	
	font-size: 32px;
	color:#2e5652;
	letter-spacing: 3px;
}

h3.common_ttl{
	font-weight: 500!important;
	width:100%;
	background-color: #f6d854;
	border-bottom: 3px solid #10af9e;
	font-size: 18px;
	padding: 5px 14px;
	margin-top: 30px;
}
p.common_txt01{
	padding: 10px 0;
	text-align:left;
}
p.common_txt02{
	font-size: 17px;
	font-weight: 500;
	padding: 8px 0;
}
p.common_txt03{
	padding: 25px 0 0;
	text-align:left;
}
p.common_txt03 a{
	color: #10af9e;
}
.mainvisual_back{
	max-width:100%;
	background-color: #10af9e;
}
h2.mainvisual_sec01_ttl{
	font-family: 'Noto Serif JP', serif;
	font-weight: 500;	
	font-size: 30px;
	color:#fff;
	line-height: 1.2;
	text-shadow: 0px 0px 10px rgba(0, 0, 0, 0.8);
	font-feature-settings : "palt";
	letter-spacing: 1px;
}

/* seko */

.mainvisual_back{
	max-width:100%;
	background-color: #10af9e;

}
.mainvisual_seko{
	max-width:1096px;
	margin: 0 auto;
  background-image: url("../img/seko_main.png");
	background-repeat: no-repeat;
   -webkit-background-size: cover;
   background-size: contain;
	 background-position:0% 50%;
	background-color: #10af9e; 
	position: relative;
	height: 255px;
}


.mainvisual_seko_wrap{
	text-align: center;
	max-width:740px;
	padding-top: 72px;
}



.seko_t{
	width: 100%; 
}
.seko_t th,.seko_t td {
	padding: 6px; 
}

/* saiyo */


.mainvisual_saiyo{
	max-width:1096px;
	margin: 0 auto;
  background-image: url("../img/saiyo_main.png");
	background-repeat: no-repeat;
   -webkit-background-size: cover;
   background-size: contain;
	 background-position:0% 50%;
	background-color: #10af9e; 
	position: relative;
	height: 255px;
}

.mainvisual_saiyo_wrap{
	text-align: left;
	padding-top: 72px;
	padding-left: 308px;
}

.saiyo_t{
	width: 100%;
	border-top:solid 3px #ccc;
	border-bottom:solid 3px #ccc;
	margin-top: 30px;
}
.saiyo_t th{
	background-color: #e7f7f5;
}
.saiyo_t th,.saiyo_t td {
	border-top:1px solid #ccc;
	border-bottom:1px solid #ccc;
	padding: 10px 20px;
	vertical-align: middle;
}
.side_saiyo_hukuri{
	max-width: 100%;
	border:4px solid #ccc;
	padding: 5px 10px 15px;
	margin-top: 60px;
}
.side_saiyo_hukuri_ttl{
	font-family: 'Noto Serif JP', serif;
	font-weight: 500;	
	font-size: 25px;
	color:#2e5652;
	padding-bottom: 5px;
	border-bottom:2px solid #2e5652;
	text-align: center;
	margin-bottom: 15px;
}
.side_saiyo_hukuri p{
	margin: 10px 0;
}
.side_saiyo_hukuri ph{
	max-width: 100%;
}




/* gaiyo */


.mainvisual_gaiyo{
	max-width:1096px;
	margin: 0 auto;
  background-image: url("../img/gaiyo_main.png");
	background-repeat: no-repeat;
   -webkit-background-size: cover;
   background-size: contain;
	 background-position:0% 50%;
	background-color: #10af9e; 
	position: relative;
	height: 255px;
}

.mainvisual_gaiyo_wrap{
	text-align: left;
	padding-top: 72px;
	padding-left: 290px;
}



.gaiyo_t{
	width: 100%;
	border-top:solid 3px #ccc;
	border-bottom:solid 3px #ccc;
	margin-top: 25px;
}
.gaiyo_t th{
	background-color: #e7f7f5;
}
.gaiyo_t th,.gaiyo_t td {
	border-top:1px solid #ccc;
	border-bottom:1px solid #ccc;
	padding: 10px 20px;
	vertical-align: middle;
}
.side_gaiyo{
	margin-top: 38px;
	display: block;
}
.side_gaiyo_ph2{
	margin-top: 28px;
}
.googlemap {
	margin-top: 60px;
    position: relative;
    width: 100%;    /* 左右に余白が必要なら値を変更してもOK */
    height: 0;
    padding-bottom: 56.25%;    /* padding-topでもOK */
    overflow: hidden;
}
.googlemap iframe {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;    /* 必要であれば!importantを付けてください */
    height: 100%;    /* 必要であれば!importantを付けてください */
}

/* form */
#form {
	margin-top: 80px;
}
.formTtl{
	margin-bottom: 20px;
}
.formTable{
	width: 100%;
	border-top:solid 3px #ccc;
	border-bottom:solid 3px #ccc;
	margin-top: 25px;
}

.form_h{
	border-top:1px solid #ccc;
	border-right:1px solid #ccc;
	border-bottom:1px solid #ccc;
	padding: 20px 10px;
	vertical-align: middle;
	font-weight: 700;
	font-size: 16px;
	width:22%;
}
.form_d{
	border-top:1px solid #ccc;
	border-bottom:1px solid #ccc;
	padding: 20px 30px;
	vertical-align: middle;
font-size: 16px;
}
.form_d_b{
	font-weight: 700;

}
.form_required{
	padding:5px;
	color:#fff;
	font-weight: 700;
	font-size: 15px;
	background-color: #ea1c24;
	border-radius: 5px;	
 }
.rule{
	height: 260px;
	padding: 15px;
	border: 1px solid #10af9e;
	box-sizing: border-box;
	margin-top: 30px;
	overflow-y: scroll;	
}
.rule p{
	font-size: 16px;
	margin-bottom: 24px;
}
.indent-1 {
text-indent: 1em;
display: block;
}
.rule b{
	font-size: 16px;
	font-weight: 700;
	display: block;
}
.pribacycheck{
	text-align: center;
	margin-top: 25px;
}
.pribacycheck b{	
	font-weight: 700;
	font-size: 18px;
}
.kakunin input[type="submit"] {
	display: block;
	margin: 50px auto;
	width: 50%;
	height: 86px;
	padding: 22px;
	border: none;
	color: #fff;
	font-size: 28px;
	font-weight: 500;
	background-color: #4bb113;
	cursor: pointer;
	outline: none;
	border-radius: 8px;        /* CSS3草案 */  
    -webkit-border-radius: 8px;    /* Safari,Google Chrome用 */  
    -moz-border-radius: 8px;   /
}
.kakunin input[type="submit"]:hover {
	color:#fff;
	background-color: #10af9e;
-webkit-transition: all 0.3s ease;
        -moz-transition: all 0.3s ease;
        -o-transition: all 0.3s ease;
        transition: all  0.3s ease;
	}

input[type="text"],
input[type="email"],
textarea,
select {
  /* general style for input elements */
  padding: 12px;
  border: 1px solid #cfd9db;
  background-color: #ffffff;
  border-radius: 0.25em;
  box-shadow: inset 0 1px 1px rgba(0, 0, 0, 0.08);
	font-size: 16px;
}

input[type="text"]:focus,
input[type="email"]:focus,
textarea:focus,
select:focus {
  outline: none;
  border-color: #2c97de;
  box-shadow: 0 0 5px rgba(44, 151, 222, 0.2);
}

input[type="checkbox"]{
vertical-align: bottom;
margin-left: 20px;
width:26px;
height: 26px;
}

/* kakunin_page */

#kakunin {
	margin-top: 30px;
}
#kakunin p{
	font-size:18px;
	text-align:center;
	margin:30px auto;
}
p.thanks{
	font-size:18px;
	text-align:center;
	margin:30px auto;
}

.formTable02{
	width: 80%;
	border-top:solid 3px #ccc;
	border-bottom:solid 3px #ccc;
	margin-top: 25px;
}
.formTable02 th{
	border-top:1px solid #ccc;
	border-right:1px solid #ccc;
	border-bottom:1px solid #ccc;
	padding: 20px 10px;
	vertical-align: middle;
	font-weight: 700;
	font-size: 16px;
	width:22%;
}
.formTable02 td{
	border-top:1px solid #ccc;
	border-bottom:1px solid #ccc;
	padding: 20px 30px;
	vertical-align: middle;
font-size: 16px;
}
.center02{
	width:45%;
	margin:50px auto 0;
	text-align:center;
	display: flex;
}

li.modoru input[type="submit"] {
	width: 90%;
	height: 86px;
	margin-right:30px;
	padding: 22px;
	border: none;
	color: #fff;
	font-size: 28px;
	font-weight: 500;
	background-color: #2e5652;
	cursor: pointer;
	outline: none;
	border-radius: 8px;        /* CSS3草案 */  
    -webkit-border-radius: 8px;    /* Safari,Google Chrome用 */  
    -moz-border-radius: 8px;   /
}
li.modoru input[type="submit"]:hover {
	color:#fff;
	background-color: #10af9e;
-webkit-transition: all 0.3s ease;
        -moz-transition: all 0.3s ease;
        -o-transition: all 0.3s ease;
        transition: all  0.3s ease;
	}

li.soshin input[type="submit"] {
	width: 90%;
	height: 86px;
	margin-left:30px;
	padding: 22px;
	border: none;
	color: #fff;
	font-size: 28px;
	font-weight: 500;
	background-color: #4bb113;
	cursor: pointer;
	outline: none;
	border-radius: 8px;        /* CSS3草案 */  
    -webkit-border-radius: 8px;    /* Safari,Google Chrome用 */  
    -moz-border-radius: 8px;   /
}
.soshin input[type="submit"]:hover {
	color:#fff;
	background-color: #10af9e;
-webkit-transition: all 0.3s ease;
        -moz-transition: all 0.3s ease;
        -o-transition: all 0.3s ease;
        transition: all  0.3s ease;
	}

.error{
	color:#ea1c24;

}
.modoru02 input[type="submit"] {
	display: block;
	margin:0 auto;
	width: 40%;
	height: 86px;
	padding: 22px;
	border: none;
	color: #fff;
	font-size: 28px;
	font-weight: 500;
	background-color: #2e5652;
	cursor: pointer;
	outline: none;
	border-radius: 8px;        /* CSS3草案 */  
    -webkit-border-radius: 8px;    /* Safari,Google Chrome用 */  
    -moz-border-radius: 8px;   /
}
.modoru02 input[type="submit"]:hover {
	color:#fff;
	background-color: #10af9e;
-webkit-transition: all 0.3s ease;
        -moz-transition: all 0.3s ease;
        -o-transition: all 0.3s ease;
        transition: all  0.3s ease;
	}



/* pagetop */
#pageTop {
	position: fixed;
  bottom: 20px;
  right: 20px;
}
#pageTop a {
  display: block;
  z-index: 999;
	padding-top:15px;
  border-radius: 8px;
  width: 100px;
  height: 65px;
  background-color: #666666;
  color: #fff;
  font-weight: bold;
  text-decoration: none;
  text-align: center;
	font-size: 16px;
	opacity: 0.7;
}
#pageTop a:hover {
  text-decoration: none;
  opacity: 0.5;
}

/* footer */
.foot_border{
	width:100%;
	margin-top: 70px;
	border-top: 2px solid #10af9e;
}
.foot_wrap{
	max-width: 1096px;
	margin: 30px auto 26px;
}
.foot_logo{
	width:36%;
	margin-right: 30px;
	float:left;	
}
.foot_logo img{	
	padding-left: 20px;
}
p.foot_s{
	font-weight: 400;
	font-size: 12px;
	padding: 5px 0 0 88px;
}

.foot_button{
	width:20%;
	margin-right: 35px;
	float:left;	
}
.foot_btn{
	width:100%;
	font-size: 18px;
	font-weight: 500;
	color:#fff;
	background-color: #2e5652;
	padding: 12px;
	height: 55px;
	text-align: center;
	
	border-radius: 8px;        /* CSS3草案 */  
    -webkit-border-radius: 8px;    /* Safari,Google Chrome用 */  
    -moz-border-radius: 8px;   /
}
.foot_btn:hover{
	color:#fff;
	background-color: #10af9e;
-webkit-transition: all 0.3s ease;
        -moz-transition: all 0.3s ease;
        -o-transition: all 0.3s ease;
        transition: all  0.3s ease;
	
}
.foot_tel {
	font-family: 'Noto Serif JP', serif;
	font-size: 28px;
	font-weight: 500;
	text-align: center;
	padding-top: 12px;
}
.foot_tel a{
	color:#2e5652;
}
.foot_tel a:hover{
	color:#10af9e;
-webkit-transition: all 0.3s ease;
        -moz-transition: all 0.3s ease;
        -o-transition: all 0.3s ease;
        transition: all  0.3s ease;
}

.foot_txt01{
	width:12%;
	margin-right: 30px;
	float:left;	
}
p.foot_ttl{
	font-size: 13px;
	font-weight: 600;
	color:#2e5652;	
}
p.foot_ct {
	font-size: 12px;
	line-height: 2;
	padding-top: 10px;
	letter-spacing: 0px;

}
p.foot_ct a{
	color:#3c3c3c;
}
p.foot_ct a:hover{
	color:#3c3c3c;
	text-decoration: underline;
}
p.foot_ct i {
 padding-right: 4px;
color:#10af9e;
}


.foot_txt02{
	width:7%;
	margin-right: 30px;
	float:left;	
}
.foot_txt03{
	width:12%;
	float:left;	
}


.foot_copy02{
	width:100%;
	font-size: 12px;
	font-weight: 300;
	color:#fff;
	text-align: center;
	padding: 6px;
	background-color: #d3d3d3;
	border-top:solid 1px #ccc; 
}





