@charset "utf-8";

/* @common
----------------------------------------------------------*/

/* @top
----------------------------------------------------------*/
/* @top-hero  */
.top-hero {
  position: relative;
  z-index: 2;
  overflow: hidden;
  padding: 1px 0;
}


.top-hero-img {
  max-width: 1650px;
  text-align: right;
  margin-left: auto;
}
.top-hero-con {
  /*position: absolute;
  inset: 0;
  padding-top: 7.5vw;
  padding-bottom: 7vw;
  -webkit-box-align: center;
  align-items: center;*/
  max-width: 100%;
}

.top-hero-con img {
  width: 100%;
}

.kv{
    width: 100%;
    height: 100vh;
    display: flex;
    background-color: rgba(0, 0, 0, 0.55);
    overflow: hidden;
    position: relative;
    justify-content: center;
    align-items: center;
}
	
.kv:before {
    content: "";
    width: 100%;
    height: 100%;
    display: block;
    background-image: url(../img/top/main01.jpg);
    background-position: center center;
    background-size: cover;
    position: absolute;
    top: 0;
    left: 0;
    z-index: 0;
    opacity: 0.5;
 
		
}
.kv_catch {
    max-width: 500px;
    border: 15px solid #1458e4;
    position: relative;
    z-index: 1;
    box-sizing: border-box;
	padding: 20px;
}
.kv_catch::after {
      content: '';
      border: 5px solid #fff;
      position: absolute;
      top: 50px;
      right: -32px;
      width: 100%;
      height: 100%;
  }
.kv_catch img {
    width: 100%;
    height: auto;
    vertical-align: bottom;
	   
}
.fadeUp {
animation-name:fadeUpAnime;
animation-duration:2.0s;
animation-fill-mode:forwards;
opacity: 0;
}

.kv_thanks{
    width: 100%;
    height: 300px;
    display: flex;
    background-color: rgba(0, 0, 0, 0.55);
    overflow: hidden;
    position: relative;
    justify-content: center;
    align-items: center;
}
	
.kv_thanks:before {
    content: "";
    width: 100%;
    height: 100%;
    display: block;
    background-image: url(../img/top/about-img.jpg);
    background-position: center center;
    background-size: cover;
    position: absolute;
    top: 0;
    left: 0;
    z-index: 0;
    opacity: 0.5;
 
		
}
@keyframes fadeUpAnime{
  from {
    opacity: 0;
	transform: translateY(100px);
  }

  to {
    opacity: 1;
	transform: translateY(0);
  }
}
/* @top-about */

.top-about {
  padding-top: 70px;
}

.top-about-con{
	margin: 2.5em auto 4.5em;
}
.top-about-con-txt {
    width: 46.3%;
    padding-top: 0.5em;
    margin-right: 2em;
}
.top-about-con-txt .lead {
    margin-bottom: .5em;
    color: #1458e4;
    font-size: 2.15rem;
    line-height: 1.75;
	font-family: 'Georgia', sans-serif;
	position: relative;
    padding:0.25em 1em;
    display: inline-block;
}
.top-about-con-txt .lead:before, .top-about-con-txt .lead:after { 
  content:'';
  width: 20px;
  height: 30px;
  position: absolute;
  display: inline-block;
}

.top-about-con-txt .lead:before {
  border-left: 5px solid #042672;
  border-top: 5px solid #042672;
  top:0;
  left: 0;
}

.top-about-con-txt .lead:after {
  border-right: 5px solid #042672;
  border-bottom: 5px solid #042672;
  bottom:0;
  right: 0;
}
.top-about-con-txt .txt {
  line-height: 2.0;
  font-size: 14px;
}
.top-about-con-txt_1 {
  width: 55%;
  padding: 2.5em;
}

.top-about-con-txt_1 .txt {
  line-height: 2.0;
}

.top-about-con-image {
    -webkit-box-flex: 1;
    flex: 1;
    margin-right: calc(50% - 50vw);
}
.top-about-con-image .txt a{
  text-decoration: none;
}
.top-about-con-image .txt {
  line-height: 1.6;
}
.top-about-con-img{
	margin: 0 auto;
}
.c-image {
    position: relative;
    padding-top: 58.25%;
}
.c-image .image_thumb {
    position: absolute;
    top: -1px;
    left: -1px;
    right: -1px;
    bottom: -1px;
    cursor: pointer;
}
.c-image .image_thumb img{
    width: 100%;
    height: 580px;
    object-fit: cover;
}

/* @top-message */
.top-message {
  padding-top: 70px;
}
.message-list-item {
  width: 100%;
  min-height:530px; 
  /*margin: 2% auto;*/
  padding: 3em 2.5em;
  background: url("../img/top/president.png") no-repeat ;
  background-position: right 50px bottom 0 ,center; 
}

.message-list-item .ttl {
  font-size: 1.5rem;
}
.message-list-item .txt {
  margin-bottom: 0;
  padding: 2%;
  font-size: 15px;
  width: 60%;
  box-sizing: border-box;
  font-family: 'Noto Serif Japanese', serif;
}
.message-list-item .txt  span.post {
    display: block;
    margin-top: 30px;
    margin-bottom: 10px;
    font-size: 14px;
    font-weight: bold;
    text-align: right;
	
}
.message-list-item .txt span.top_name {
    display: block;
    font-size: 30px;
    font-weight: bold;
    text-align: right;
}


/* @top-business */
.top-business {
  padding-top: 70px;
  padding-bottom: 70px;
}
.top-business .ttl {
    font-weight: bold;
    font-size: 1.4rem;
    line-height: 1.4;
    text-align: center;
	border: none;
}
.top-business .ttl_sub {
    font-size: 1.3rem;
	font-weight: 600;
	border: none;
	margin-top: 10px;
	text-align: center;
}
.top-business .inner::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: -1;
  opacity: .2;
  background: url(../img/top/bg-ozo.svg) no-repeat center top 10.5vw;
}
.business-list {
  width: 95%;
  margin: 0 auto;
  padding: 20px;
  background: rgba(242, 251, 255, .7);
}
.business-list-item {
  -webkit-box-align: start;
  align-items: flex-start;
  margin-bottom: 1rem;
  padding: 2.2em 5em;
  border: 2px solid #ccc;
  border-radius: 20px 0 20px 0;
}
.business-list-item .icon {
  margin-right: 2.5em;
}
.business-list-item .con {
  -webkit-box-flex: 1;
  flex: 1;
  padding-top: .25em;
}
.business-list-item .con-ttl {
  font-weight: bold;
  font-size: 1.4rem;
  line-height: 1.6;
}
.business-list-item .con-txt {
  margin: .5em 0;
}


/* @top-company */
.top-company {
  background: url("../img/top/bg_img.jpg") no-repeat;
  background-position: bottom;
  background-size: cover;
  padding-top: 70px;
  padding-bottom: 70px;
  
}

.top-company .secttl::before {
	opacity: .5;
    color: #fff;
}
.top-company .con-txt {
  width:80%;
  text-align: left;
  margin: 1.5em auto;
  padding: 20px;
  background-color: rgba( 255, 255, 255, 0.9 );
}
.box_table {
    width: 80%;
    box-sizing: border-box;
    margin: 15px auto 0px auto;
    text-align: left;
    padding: 10px 0 0px 0;
}

.cptable {
    width: 100%;
    border: 1px solid #888;
    margin: 15px 0;
    background-color: rgba( 255, 255, 255, 0.9 );

}
.cptable dl {
    display: flex;
    flex-wrap: wrap;
    justify-content: left;
    text-align: center;
    font-size: 12px;
    border-bottom: 1px solid #ccc;
}
.cptable dl:last-child {
    border-bottom: none;
}
.cptable dl dd {
    padding: 10px 0;
}
.cptable .row1 {
    width: 20%;
    background-color: rgba( 222,222,222, 0.6 );
    font-size: 14px;
}
.cptable .row2 {
    width: 80%;
    box-sizing: border-box;
    border-left: 1px solid #ccc;
    text-align: left !important;
    padding: 10px;
    font-size: 14px;
}


/* アクセス*/

.top-access {
  padding-top: 70px;
}
.top-access-con{
	margin: 2.5em auto 4.5em;
}
.access-list-item {
  width: 48%;
    margin: 2% 0;
    padding: 3em 2.5em;
    text-align: center;
    box-shadow: 0 4px 0 rgba(65,73,77,.05);
    border-radius: 20px 0 20px 0;
    border: 1px solid #ccc;
}
.access-list-item .txt {
  margin-bottom: 0;
  text-align: left;
}

.access-list-item .img {
  width: 100%;
  aspect-ratio: 16/9;
}
iframe {
  width: 100%;
  aspect-ratio: 16/9; 
}

/* @top-recruit */
.top-recruit {
    background: rgba(242, 251, 255, .7);
    padding-top: 70px;
    padding-bottom: 70px;
}
.recruit_message .txt{
	text-align: center;
}

/* @top-contact */
.top-contact {
  padding-bottom: 70px;
  background: #f3f3f3;
}
.top-contact .secttl{
	padding-top: 2.9em 
} 
.top-contact .secttl::before {
	padding-top: 70px;
	opacity: .1;
    color: #888;
}
.top-contact .welcome {
	max-width: 800px;
    width: 100%;
    margin: 0 auto;
    line-height: 2;
    font-weight: 700;
}
.top-contact .welcome p{
	font-size: 14px;
}
.container {
    max-width: 1420px;
    width: 100%;
    margin: auto;
}
#info {
    flex-wrap: wrap;
    background-color: #fff;
	max-width: 800px;
	width: 70%;
    box-sizing: border-box;
    margin: 15px auto 0px auto;
    text-align: left;
}
.container {
	margin: 15px auto;
	border: solid 1px #CCC;
	padding: 15px;
	border-radius: 3px;
}
.container form#mailformpro dl dt {
	float: none;
	width: auto;
	clear: both;
	font-size: 14px;
	padding: 10px 0 0 10px;
	text-align: left;
	border-top: none;
	margin: 0px;
}
.container form#mailformpro dl dt,
.container form#mailformpro dl dt span {
	vertical-align: middle;
	line-height: 1em;
}
.container form#mailformpro dl dt span {
	margin-top: -0.3em;
}
.container form#mailformpro dl dd {
	border: none;
	margin: 0px;
	padding: 15px;
	font-size: 16px;
	line-height: 1.5em;
	text-align: left;
}
.mfp_rows {
	clear: both;
}
.mfp_rows:after {
	content: "";
	clear: both;
	height: 0;
	display: block;
	visibility: hidden;
}
.mfp_rows input[type="text"],
.mfp_rows input[type="email"],
.mfp_rows input[type="tel"],
.mfp_rows input[type="number"],
.mfp_rows input[type="date"],
.mfp_rows input[type="file"],
.mfp_rows select,
.mfp_rows button,
.mfp_rows textarea,
form#mailformpro .mfp_rows label {
	width: 100%;
	min-width: 100%;
	margin: 3px auto;
	padding: 5px;
	word-break: break-all;
	white-space: normal;
	border: solid 1px #CCC;
	border-radius: 3px;
	box-shadow: 0px 0px 5px #CCC inset;
	vertical-align: middle;
}


.mfp_rows .mfp_col1,.mfp_rows .mfp_col2,.mfp_rows .mfp_col3,.mfp_rows .mfp_col4,.mfp_rows .mfp_col5,.mfp_rows .mfp_col6,.mfp_rows .mfp_col7,.mfp_rows .mfp_col8,.mfp_rows .mfp_col9,.mfp_rows .mfp_col10 {
	float: left;
	padding: 0 1.5%;
}
.mfp_rows .mfp_col1 {width: 10%;}
.mfp_rows .mfp_col2 {width: 20%;}
.mfp_rows .mfp_col3 {width: 30%;}
.mfp_rows .mfp_col4 {width: 40%;}
.mfp_rows .mfp_col5 {width: 50%;}
.mfp_rows .mfp_col6 {width: 60%;}
.mfp_rows .mfp_col7 {width: 70%;}
.mfp_rows .mfp_col8 {width: 80%;}
.mfp_rows .mfp_col9 {width: 90%;}
.mfp_rows .mfp_col10 {width: 100%;}

.container .mfp_thanks {
	padding: 10px;
}
.container .mfp_thanks p {
	font-size: 12px;
	line-height: 1.7em;
}
.container .mfp_thanks ul.mfp_caution {
	list-style-type: disc;
}
.container .mfp_thanks ul.mfp_caution li {
	font-size: 12px;
	margin: 0 1.5em;
	font-weight: bolder;
}

div#example_selector {
	padding: 10px 0px;
	text-align: left;
}
div#example_selector span {
	color: #666;
	display: block;
	font-size: 14px;
	padding: 5px 0px;
}
div#example_selector select {
	display: block;
	font-size: 18px;
	border-radius: 3px;
	border: solid 1px #CCC;
	padding: 5px 10px;
	box-shadow: 0px 0px 5px #CCC inset;
	box-sizing: border-box;
	width: 100%;
	max-width: 100%;
	outline: none;
}
.mbt10 {
    margin-bottom: 10px !important;
}





/* レスポンシブ
----------------------------------------------------------*/
@media screen and (min-width: 1280px) {
  /* @top
  ----------------------------------------------------------*/
  .top-hero-img {
    margin-top: -3.8vw;
    margin-bottom: -5vw;
  }
  .top-hero-con .h_btn_list li {
    font-size: 1.125rem;
  }

}

/* 960px 以上 (PC・タブレット横) */
@media screen and (min-width: 960px) {
  /* @top
  ----------------------------------------------------------*/
  

}


/* 1024px 以下 */
@media screen and (max-width: 1024px) {
  .facility-list > li {
    width: 22%;
  }
  .facility-list .txt {
    font-size: .9375rem;
  }
}

/* 959px 以下 (タブレット縦以下) */
@media screen and (max-width: 959px) {

  /* @common
  ----------------------------------------------------------*/

  /* @top
  ----------------------------------------------------------*/
  /* @top-hero */
  /*.top-hero {
    padding-top: 120px;
  }*/
  .top-hero-con {
    position: static;
    padding: 0;
  }
  .top-hero-con_inner {
    width: 80%;
    max-width: 500px;
    margin: 0 auto;
  }
  .top-hero-con .h_btn_list {
    position: absolute;
    left: 0;
    right: 0;
    bottom: 0;
    width: 80%;
    max-width: 600px;
    margin: 0 auto;
    padding: 0 0 5.5vw;
    font-size: 1.2rem;

  }
  .top-hero-img {
    position: relative;
    margin: -20vw 0 -10vw;
    z-index: -1;
  }


  /* @top-about */
  /*.top-about {
    padding-bottom: 40px;
  }*/
  .top-about-con {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    flex-direction: column;
    margin: 1em auto ;
  }
  .top-about-con-txt {
    width: 100%;
    max-width: 100%;
    margin-right: 0;
	padding: 0 0.5em;
  }
  .top-about-con-txt .lead {
    font-size: 2rem;
	margin-left: 35%;
  }

  .top-about-con-movie {
    margin-right: 0;
    -webkit-box-ordinal-group: 0;order: -1;
	width:100%;
  }
  .top-about-con-txt_1{
	width:100%;
	padding:0.5rem;
	}
	
   .top-about-con-image{
	margin-right: 0;
	}
  .c-image{
	 padding-top: 0;
	}
  .c-image .image_thumb{
    position: static;
  } 
  .c-image .image_thumb img {
    width: 100%;
    height: auto; 
    object-fit: cover;
   }
	
	
/* @top-message */	
 .message-list-item .ttl {
  font-size: 1.4rem;
  line-height: 1.3;
  }
 .message-list-item {
  padding: 1.5em;
  background-size: 50%;
  background-position: right 0 bottom -70px;
  }
	
  .message-list-item .txt {
	width: 60%;	
  }
	
  .message-list-item .txt  span.post {
    text-align: left;
	
  }
  .message-list-item .txt span.top_name {
    text-align: left;
	font-size: 26px;
  }
	
	
  /* @top-business */
  .top-business .ttl {
    font-size: 1.4rem;
	line-height: 1.3;
  }
  .top-business .ttl_sub {
	text-align: left;
	}
  .business-list-item {
    padding-left: 3em;
    padding-right: 3em;
  }
  .business-list-item .con {
    padding-top: .5em;
  }
  .business-list-item .con-ttl {
    font-size: 1.4rem;
  }


  /* @top-access */
  .access-list-item {
    padding: 2em 1.5em;
  }
  .access-list-item .ttl {
    font-size: 1.3rem;
  }
  .access-list-item_1 {
    width: 100%;
  }
	

  /* @top-contact */
  .top-contact {
    padding-bottom: 1em;
  }
  


}

/* 599px 以下 (スマホ)  */
@media screen and (max-width: 599px) {
  /* @common
  ----------------------------------------------------------*/
 

  /* @top
  ----------------------------------------------------------*/
  /* @top-hero */
  /*.top-hero {
    padding-top: 100px;
  }*/
  .top-hero-con .h_lead {
    margin-top: 1.5em;
  }
  .top-hero-con .h_btn_list {
    width: 90%;
    font-size: 1rem;
  }
  .top-hero-img {
    margin: -16vw 0 0;
  }
  .kv:before {
    background-image: url(../img/top/about-img_sp.jpg);
  }
 .kv_catch {
    max-width: 280px;
    border-width: 5px;
 }
  .kv_catch::after {
    content: '';
    border: 5px solid #fff;
    position: absolute;
    top: 25px;
    right: -22px;
    width: 100%;
    height: 100%;
}
  /* @top-about */
  .top-about {
    padding-top: 10px;
  }
  .top-about-con-txt .lead {
    font-size: 1.5rem;
	margin-left: 25%;
  }
  
  /* @top-message */
   .top-message {
    padding-top: 10px;
  }
   .message-list-item .txt {
	width:100%;	
  }
   .message-list-item {
    padding: 1.5em;
    background-size: 60%;
    background-position: right 0 bottom -70px;
  }
	
	
  /* @top-business */
  .top-business{
	padding-bottom:1.8em;
	padding-top: 1.0em;
  }
  .business-list {
    padding-top: 1px;
  }
  .business-list-item {
    position: relative;
    padding: 4.2em 1em 2em;
    margin-top: 50px;
    text-align: center;
  }
  .business-list-item .icon {
    margin-right: 2.5em;
    position: absolute;
    top: -40px;
    left: 0;
    right: 0;
    width: 94px;
    margin: 0 auto;
  }
  .business-list-item .con-ttl {
    margin-bottom: .75em;
  }
	
	

  /* @top-company */
  .top-company .con-txt{
	width:100%;
	padding: 5px;
	text-align: left;
  }
  .top-company{
	padding-top: 1.0em;
	padding-bottom: 30px;	
  }
  
  .box_table {
	width:100%;	
	}
  .cptable .row1 {
	  width: 30%;
	}
  .cptable .row2 {
	  width: 70%;
	}
	
	
 /* @top-lineup */
  .top-access{
	padding-bottom:1.8em;
	padding-top: 1.0em;
  }
  .access-list-item {
    width: 100%;
    margin: 5% 0 0;
  }
  .access-list-item_1{
	width:100%;
	padding: 0.5em;
  }
  .access-list-item_1 .h_btn_list li{
	width:100%;
	margin: 1% auto;
 }
	
 
	
	
  /* @top-recruit */
  .top-recruit {
    padding-top: 1em;
    padding-bottom: 30px;
}
	
	
 
	
 /* お問い合わせ */
.top-contact .secttl::before {
	padding-top: .1em;
}
#info{
   width: 100%;	
	}	
	
	
}