@charset "utf-8";
/* CSS Document */

/* ### 基本 ### */

html {
  overflow-x: hidden;
}
a {
	text-decoration: none;
}
body {
  margin: 0;
  font-size: 16px;
  font-family: -apple-system, BlinkMacSystemFont, Roboto, "Segoe UI", "Helvetica Neue", HelveticaNeue, YuGothic, "Yu Gothic Medium", "Yu Gothic", Verdana, Meiryo, sans-serif;
  box-sizing: border-box;
}

b, strong, .bold{
	font-family: -apple-system, BlinkMacSystemFont, Roboto, "Segoe UI semibold", "Helvetica Neue", HelveticaNeue, YuGothic, "Yu Gothic", "Segoe UI", Verdana, Meiryo, sans-serif;
}

_:lang(x)::-ms-backdrop, body {
    font-family: "Segoe UI", Meiryo, sans-serif;
} 

ul,li {
  margin: 0;
  padding: 0;
  list-style-type: none;
}

.page {
  margin: 0;
}



img{
    height: auto;
}

/* ### ナビゲーション ### */

.globalmenu {
  position: fixed;
  background-color: #000;
  height: 100%;
  width: 100%;
  z-index: 123456;
  overflow-y: auto;
  display: none;
}

.open .globalmenu {
  display: block;
}

.globalmenu-list__logo img {
  display: block;
  width: 150px;
  height: auto;
  margin: 30px auto;
}

.globalmenu-list-item {
  position: relative;
  display: block;
  background-color: #000;
  border-bottom: solid 1px #fff;
}

.globalmenu-list-item span {
  display: block;
  text-decoration: none;
  padding: 20px 0;
  color: #fff;
  font-size: 16px;
  padding-left: 30px;
}

.globalmenu-list-item::after {
  font-family: "Font Awesome 5 Free";
  content: "\f067";
  font-weight: 600;
  display: block;
  color:#fff;
  position: absolute;
  right: 20px;
  top: 50%;
  transform: translateY(-50%);
}
.global-menu__list-item.active::after {
  content: "\f068";
}

.globalmenu .dropdown-list {
  display: block;
  background-color : #000;
  padding: 0 0 0 50px;
  border-bottom: solid 1px #fff;
  font-size: 16px;
}

.globalmenu .dropdown-list-item {
  position: relative;
  border-bottom: solid 1px #fff;
}

.globalmenu .dropdown-list-item::after {
  font-family: "Font Awesome 5 Free";
  content: "\f054";
  position: absolute;
  right: 20px;
  top: 50%;
  transform: translateY(-50%);
  color: #fff;
  font-weight: 600;
}

.globalmenu .dropdown-list-item a {
  display: block;
  padding: 20px 10px;
  color: #fff;
  text-decoration: none;
}

.globalmenu .dropdown-list-item:last-child {
  border-bottom: none;
}



/* ## ナビのボタン ## */

.globalmenu-btn,
.globalmenu-btn-close {
  position: fixed;
  display: inline-block;
  top: -2px;
  right: 0;
  z-index: 1234567;
  justify-self: start;
  aligen-self: center;
  padding: 10px 15px;
  margin: 0;
  border: solid #fff 1px;
  background-color: #000;
  color: #fff;
  font-size: 26px;
  cursor: pointer;
  overflow-y: auto;
  border-radius: 5px;
}

.globalmenu-btn-close {
  display: none;
}

.open .globalmenu-btn {
  display: none;
}

.open .globalmenu-btn-close {
  display: block;
}

.dropdown-list-item__inner span{
	display:inline-block;
}


/* ### コンタクト ### */
.contact-diamond,.tel-diamond,.line-diamond{
  display: none;
  position: fixed;
  bottom: 150px;
  right: 30px;
  z-index: 1235;
  width:200px;
  height:auto;
}

.tel-diamond{
    bottom: 90px;
}
.line-diamond{
    bottom: 30px;
}
.contact-diamond{
    bottom: 150px;
}
.contact-diamond img,.tel-diamond img,.line-diamond img {
  width: 100%;
}
@media screen and (max-width: 960px){
  .contact-diamond,.tel-diamond,.line-diamond {
      width:180px;
  }
    .tel-diamond{
        bottom: 80px;
    }
    /*.line-diamond{
        bottom: 130px;
    }*/
	.contact-diamond{
    bottom: 130px;
}
}
@media screen and (min-width: 600px){
  .contact-diamond,.tel-diamond,.line-diamond {
  display: block;
  }
}
.contact-sp {
  display: none;
  }
@media screen and (max-width: 599px){
  .contact-sp {
  display: block;
  }
}
/* ### エントリー ### */

.entry-diamond {
  display: none;
  position: fixed;
  top: 10px;
  right: 10px;
  z-index: 1234;
}

.entry-diamond img{
  width: 120px;
  height: 120px;
}

@media screen and (max-width: 600px){
  .entry-diamond,.entry-diamond,.line-diamond,.contact-diamond,.tel-diamond {
  	display: none!important;
  }
}


/* ### ぱんくずリスト（～1024pxまで） ### */

@media(max-width:1024px){
	.breadcrumb {
    display: block;
    margin:40px 0 0 0;
    padding: 5px 10px 5px 20px;
    font-size: 14px;
  }
  .breadcrumb li {
    display: inline;
    font-weight: bold;
  }
  .breadcrumb li:after {
    content: '>';
    padding: 0 0.2em;
    color: #999;
  }
  .breadcrumb li:last-child:after {
    content: '';
  }
  .breadcrumb li a {
    text-decoration: none;
    color: #0070A5;
  }
}
@media(max-width:480px){
	.breadcrumb {
    padding: 5px 5px 5px 12px;
  }
}
/* ### ページタイトル ### */
.pagetitle-area{
    padding-top: 140px;
}

@media (max-width: 640px) {
    .pagetitle-area{
        padding: 60px 0 30px 0;
    }
}



/* ### フッター促進メニュー ### */
.promotion-area{
    margin-top: 0;
}
.promotion {
}
.promotion ul {
  width: 100%;
  display: flex;
}

.promotion li {
  display: inline-block;
  width : 33.33333% ; /* 未対応ブラウザ用フォールバック */
  width : -webkit-calc(100% / 3) ;
  width : calc(100% / 3) ;
}

.promotion-menu-list a {
  display: block;
  outline: 1px solid #000;
  text-decoration: none;
  height: 80px;
  text-align: center;
  font-size: 12px;
  font-weight: 600;
  color: #fff;
  line-height: 80px;
  box-sizing: border-box;
  background-size: cover;
  background-position: center;
  transition: .3s;
}
@media (min-width: 600px) {
  .promotion-menu-list a{
    font-size: 14px;
    height: 120px;
    line-height: 120px;
  }
}


/* ## 項目2つの場合 ## */

.promotion2 {
}

.promotion2 ul {
  width: 100%;
  display: flex;
}

.promotion2 li {
  display: inline-block;
  width : 50% ; /* 未対応ブラウザ用フォールバック */
  width : -webkit-calc(100% / 2) ;
  width : calc(100% / 2) ;
}


/* ## 各項目の背景 ## */

.item-message a {
  background-image: url("../images/common/promotion-item-message.jpg");
}
.item-mission a {
  background-image: url("../images/common/promotion-item-mission.jpg");
}
.item-company a {
  background-image: url("../images/common/promotion-item-company.jpg");
}
.item-map a {
  background-image: url("../images/common/promotion-item-map.jpg");
}
.item-representative a {
  background-image: url("../images/common/promotion-item-representative.jpg");
}
.item-staffinterview a {
  background-image: url("../images/common/promotion-item-staffinterview.jpg");
}
.item-retrunstaff a {
  background-image: url("../images/common/promotion-item-retrunstaff.jpg");
}
.item-training a {
  background-image: url("../images/common/promotion-item-training.jpg");
}
.item-careerpath a {
  background-image: url("../images/common/promotion-item-careerpath.jpg");
}
.item-schedule a {
  background-image: url("../images/common/promotion-item-schedule.jpg");
}
.item-advantage a {
  background-image: url("../images/common/promotion-item-advantage.jpg");
}
.item-event a {
  background-image: url("../images/common/promotion-item-event.jpg");
}
.item-restaurant a {
  background-image: url("../images/common/promotion-item-restaurant.jpg");
}
.item-careerfair a {
  background-image: url("../images/common/promotion-item-careerfair.jpg");
}
.item-jobdescription a {
  background-image: url("../images/common/promotion-item-jobdescription.jpg");
}
.item-entry a {
  background-image: url("../images/common/promotion-item-entry.jpg");
}
.item-contact a {
  background-image: url("../images/common/promotion-item-contact.jpg");
}





/* ### フッター ### */

.footer-warp {
  background-color: #0070A5;
  padding: 40px 20px 60px 20px;
}

.footer__logo {
  display: block;
  text-align: center;
  margin-bottom:20px;
}

.footer__logo img {
  width: 100px;
  height: auto;
}

.footermenu {
  display: none;
}

.footermenu-sub-list span {
  color : #fff;
  font-size: 30px;
}


/* ## フッター サブメニュー ## */

.footermenu-sub {
  font-size: 14px;
  text-align: center;
  margin-top: 1em
}

.footermenu-sub ul {
  display: flex;
  justify-content: center;
  flex-wrap:wrap;
}

.footermenu-sub li {
  line-height: 40px;
  padding-left: 10px;
}

.footermenu-sub-list a {
  color: #fff;
  text-decoration: none;
}

.footermenu-sub-list img {
  height: 40px;
  width: auto;
}

.footermenu-sub-list i {
  font-size: 20px;
}

.footer__copy {
  font-size: 12px;
  color: #fff;
  text-align: center;
  margin-top: 15px;
}

.footermenu-sub .sns-icon {
	width: 18px;
	height: 18px;
}





/* ### ボタンのデザイン ### */

.btn-white {
  display: block;
  position: relative;
  color: #0070A5;
  background-color: #fff;
  border: solid 1px #0070A5;
  padding: 15px 20px;
  font-weight: 600;
  font-size: 14px;
  text-decoration: none;
  width: 200px;
  margin: 0 auto;
}

.btn-white::after {
  font-family: "Font Awesome 5 Free";
  content: "\f054";
  font-weight: 600;
  position: absolute;
  color: #0070A5;
  font-size: 14px;
  right: 20px;
  top: 50%;
  transform: translateY(-50%);
}


.btn-black {
  display: block;
  position: relative;
  color: #fff;
  background-color: #000;
  border: solid 1px #000;
  padding: 15px 40px 15px 20px;
  font-weight: 600;
  font-size: 14px;
  text-decoration: none;
  max-width: 250px;
  margin: 0 auto;
}

.btn-black::after {
  font-family: "Font Awesome 5 Free";
  content: "\f054";
  font-weight: 600;
  position: absolute;
  color: #fff;
  font-size: 14px;
  right: 20px;
  top: 50%;
  transform: translateY(-50%);
}





/* ### タイトル ### */

/*.pagetitle-area {
  margin: 0;
  padding: 50px 0;
  text-align: center;
}

.page-title img {
  height: 50px;
}
*/

.page-title h1 {
  margin: 10px auto 0 auto;
  padding: 0;
  display: block;
  font-size: 14px;
}
 /*追加　募集要項から持ってきた*/
.pagetitle-area {
  margin: 0 auto;
  padding: 140px 0 50px 0;
  text-align: center;
  width: 90%;
}

.page-title img {
  width: 90%;
  max-width: 450px;
  height: 30px;
}

.page-title h2 {
  margin: 10px auto 0 auto;
  padding: 0;
  display: block;
  font-size: 14px;
}

@media (max-width: 640px) {
    .pagetitle-area{
        padding: 60px 0;
        padding-bottom: 30px;
    }
}
@media (min-width: 600px) {
  .pagetitle-area {
    width: 100%;
  }
  .page-title img {
    width: auto;
    max-width: initial;
    height: 35px;
  }
}

@media (min-width: 1025px) {
  .page-title img {
    width: auto;
    max-width: initial;
    height: 50px;
  }
}
/*追加　募集要項から持ってきたここまで*/



/* ### ふわっと表示用 ### */

.effect-fade-up {
  opacity: 0;
  transform: translate(0, 50px); /* フェードインで動く高さを指定 */
  transition: all 1000ms; /* フェードインにかかる時間を指定 */
}

.effect-fade-up2 {
  opacity: 0;
  transform: translate(0, 50px); /* フェードインで動く高さを指定 */
  transition-duration: 1000ms; /* フェードインにかかる時間を指定 */
  transition-delay: 0.2s;
}

.effect-fade-up3 {
  opacity: 0;
  transform: translate(0, 50px); /* フェードインで動く高さを指定 */
  transition-duration: 1000ms; /* フェードインにかかる時間を指定 */
  transition-delay: 0.4s;
}

.effect-fade-up4 {
  opacity: 0;
  transform: translate(0, 50px); /* フェードインで動く高さを指定 */
  transition-duration: 1000ms; /* フェードインにかかる時間を指定 */
  transition-delay: 0.6s;
}
.effect-fade-up5 {
  opacity: 0;
  transform: translate(0, 50px); /* フェードインで動く高さを指定 */
  transition-duration: 1000ms; /* フェードインにかかる時間を指定 */
  transition-delay: 0.8s;
}

.effect-fade-left {
  opacity: 0;
  transform: translate(-50px, 0); /* フェードインで動く高さを指定 */
  transition: all 1000ms; /* フェードインにかかる時間を指定 */
}

.effect-fade-right {
  opacity: 0;
  transform: translate(50px, 0); /* フェードインで動く高さを指定 */
  transition: all 1000ms; /* フェードインにかかる時間を指定 */
}

.effect-scroll {
  opacity: 1;
  transform: translate(0, 0);
}
/*フッター　グループバナーについて*/
.banner {
	display:flex;
	justify-content:center;
	flex-wrap:wrap;
	width:90%;
	max-width:960px;
	margin:auto;
}
.banner a{
	width:20%;
	min-width:170px;
	margin:5px;
}
.banner img{
	width:100%;
}
@media(max-width:1024px){
.banner {
	width:99%;
	max-width:660px;
}
.banner a{
	width:20%;
	min-width:150px;
	margin:5px;
}
}
@media(max-width:480px){
.banner {
	width:100%;
}
.banner a{
	width:45%;
	min-width:140px;
	margin:3px;
}
}
/* 福利厚生 
===================================*/
#welfare {
	background: #f3f3f3;
	padding: 60px 0;
}
.Welfare {
	width: 30%;
	margin: auto;
}
.Welfare img {
	height: auto;
	width: 100%;
}
.welfare_content {
	background: #fff;
	display: grid;
	max-width: 800px;
	margin: auto;
	grid-template-columns: 1fr 1fr 1fr 1fr;
	justify-items: center;
	justify-content: center;
	padding: 40px;
}
.welfare_list {
	margin-bottom: 20px;
}
.welfare_list li {
	color: #0070a5;
	margin: 10px 0 0px;
	font-size: 1.3rem;
	font-weight: bold;
	text-align: center;
}
.welfare_list li img {
	background: #f3f3f3;
	border-radius: 20px;
	height: auto;
	padding: 15px;
	width: 65%;
}
@media(max-width:748px){
	#welfare {
		padding: 60px 20px;
	}
	.Welfare {
		width: 51%;
		margin: auto;
	}
	.welfare_content {
		grid-template-columns: 1fr 1fr;
		padding: 20px;
	}
	.welfare_list li {
		font-size: 1.1rem;
	}
}



/*スマホ用固定ボタン*/
.btn-fixed-sp {
	position:fixed;
	z-index:9999;
	width:100%;
	bottom:0;
	right:0;
	display:none;
}
@media(max-width:600px){
.btn-fixed-sp {
	position:fixed;
	z-index:9999;
	width:100%;
	bottom:0;
	right:0;
	display:block;
}	
}
.fixed-sp2 {
	display:flex;
	justify-content:space-between;
	background-color:#fff;
}
.sp-fixed-web1, .sp-fixed-line1, .sp-fixed-tel1{
	width:49.9%;
	border-top:solid 2px #fff;
	border-right:solid 2px #fff;
}
.sp-fixed-tel1{
	border-right:none;
}
.sp-fixed-web1 a, .sp-fixed-line1 a, .sp-fixed-tel1 a{
	margin:0;
	display:block;
	width:100%;
	text-align:center;
	font-size:18px;
	padding:10px 0;
	color:#fff;
	background-color:#000;
	text-decoration:none;
    font-weight:bold;
	height:100%;
	
}
.sp-fixed-web1 a:hover, .sp-fixed-line1 a:hover, .sp-fixed-tel1 a:hover{
	color:#000;
	background-color:#fff;
}
@media(max-width:480px){
.sp-fixed-web1 a, .sp-fixed-line1 a, .sp-fixed-tel1 a{
	margin:0;
	display:block;
	width:100%;
	text-align:center;
	font-size:15px;
	padding:10px 0;
	color:#fff;
	background-color:#000;
	text-decoration:none;
    font-weight:bold;
	height:100%;
}
}
@charset "utf-8";
/* CSS Document */

/* ##### 画面の横幅1025px以上 ###### */
.is_flow {
	display: none;
}
@media (min-width: 1110px) {
  
  
  /* ### 基本 ### */
  
  a:hover {
    opacity: 0.8;
  }

  
  
  
  /* ### ナビゲーション ### */
  
  .globalmenu {
  height: 80px;
  overflow-y: visible;
  display: block;
  }
  
  .globalmenu ul {
    display: block;
    text-align: center;
  }
  
  .globalmenu li {
    display: inline-block;
    vertical-align: top;
  }
  
  .globalmenu-list__logo img {
    display: block;
    width: 200px;
    height: auto;
    margin-top: 16px;
    margin-right: 30px;
  }
  
  .globalmenu-list-item {
  position: relative;
  display: block;
  border-bottom: none;
  }
  
  .globalmenu-list-item span {
    display: block;
    text-decoration: none;
    padding:0 20px;
    color: #fff;
    font-size: 16px;
    /*width: 161px;*/
    height: 80px;
    line-height: 80px;
    cursor: pointer;
  }
  
  .globalmenu-list-item::after {
  display: none;
  }
  
  .globalmenu .dropdown-list {
  display: none;
  background-color : transparent;
  padding: 0;
  border-bottom: none;
  font-size: 16px;
  }
  
  .globalmenu .dropdown-list ul {
    padding: 0;
  }
  
  .globalmenu .dropdown-list li {
    display: block;
  }
  
  .globalmenu .dropdown-list-item {
  position: relative;
  border-bottom: none;
  }
  
  .globalmenu .dropdown-list-item::after {
  display: none;
  }
  
  .globalmenu .dropdown-list-item a {
    width: 150px;
    display: block;
    padding: 20px 10px;
    /*margin-top: 3px;*/
	margin:3px auto 0 auto;
    color: #fff;
    text-decoration: none;
    box-sizing: border-box;
    background-color: #000;
  }

.globalmenu .dropdown-list-item:last-child {
  border-bottom: none;
}
  
  

/* ## ナビのボタン ## */

.globalmenu-btn,
.globalmenu-btn-close {
  display: none;
}
  



  
/* ### エントリー ### */

.entry-diamond {
  display: block;
  position: fixed;
  top: 90px;
  right: 30px;
  z-index: 1234;
}

.entry-diamond img {
  width: 120px;
  height: 120px;
}

  

  
  
  /* ### ぱんくずリスト ### */
  
  .breadcrumb {
    display: block;
    margin:80px 0 0 0;
    padding: 5px 0 5px 20px;
    font-size: 12px;
    background: #0070A5;
  }
  .breadcrumb li {
    display: inline;/*横に並ぶように*/
    font-weight: bold;/*太字*/
  }
  .breadcrumb li:after {/* >を表示*/
    content: '>';
    padding: 0 0.2em;
    color: #fff;
  }
  .breadcrumb li:last-child:after {
    content: '';
  }
  .breadcrumb li a {
    text-decoration: none;
    color: #fff;
  }
  
  
  
  
  
   /* ### 促進メニュー ### */

.bottom-menu {
  margin-top: 100px;
}

.promotion {
}

.promotion ul {
}

.promotion li {
}

.promotion-menu-list a {
  height: 150px;
  font-size: 16px;
  line-height: 150px;
}
  
  
  
  
  
/* ### フッター ### */

.footer-warp {
  background-color: #0070A5;
  padding: 80px 20px;
}

.footer__logo {
  display: block;
  text-align: center;
  margin-bottom:30px;
}

.footer__logo img {
  width: 100px;
  height: auto;
}

  /* ## フッターメインメニュー ## */
  
  .footermenu {
    display: flex;
    color: #fff;
    text-align: center;
    margin-top: 20px;
    justify-content: center;
  }

  .footermenu a {
    text-decoration: none;
    color: #fff;
  }

  .footermenu ul {
    /* display: inline-block; */
    vertical-align: top;
    text-align: left;
    list-style-type: disc;
  }
  
  .footermenu-list {
    width: 160px;
    font-size: 14px;
  }
  
  .footermenu-list span {
    font-weight: 600;
  }
  
  .footermenu-dropdown-list {
    margin: 5px 10px;
    
  }
  
  .footermenu-dropdown-list-item {
    position: relative;
    display: block;
    text-align: left;
    font-size: 12px;
    margin-top: 10px;
    line-height: 16px;
  }
  
  .footermenu-dropdown-list-item::before {
    position: absolute;
    content: "";
    background: #fff;
    width: 3px;
    height: 1px;
    margin: auto;
    top:0;
    bottom:0;
    left:-10px;
  }

  /* ## フッターサブメニュー ## */
  
  .footermenu-sub {
  font-size: 14px;
  text-align: center;
  margin-top: 20px;
  }

.footermenu-sub ul {
  display: flex;
  justify-content: center;
}

.footermenu-sub li {
  line-height: 40px;
  padding-left: 10px;
}

.footermenu-sub-list a {
  color: #fff;
  text-decoration: none;
}

  .footermenu-sub-list span {
  color : #fff;
  font-size: 30px;
}
  
.footermenu-sub-list img {
  height: 40px;
  width: auto;
}

.footer__copy {
  font-size: 12px;
  color: #fff;
  text-align: center;
  margin-top: 15px;
}

  
  
  
 
  
  
  
  
  /* ### タイトル ### */
  
 /* .pagetitle-area {
    padding: 60px 0;
  }
  
  .page-title img {
    height: 50px;
  }
  
  .page-title h1 {
    margin: 15px auto 0 auto;
    font-size: 16px;
  }*/

  
  
  /* ### ボタンのデザイン ### */
  
  .btn-white {
  display: block;
  position: relative;
  color: #0070A5;
  background-color: #fff;
  border: solid 1px #0070A5;
  padding: 15px 20px;
  font-weight: 600;
  font-size: 14px;
  text-decoration: none;
  width: 200px;
  margin: 0 auto;
  }

  .btn-white::after {
  font-family: "Font Awesome 5 Free";
  content: "\f054";
  font-weight: 600;
  position: absolute;
  color: #0070A5;
  font-size: 14px;
  right: 20px;
  top: 50%;
  transform: translateY(-50%);
  }

  
  .btn-black {
  display: block;
  position: relative;
  color: #fff;
  background-color: #000;
  border: solid 1px #000;
  padding: 15px 40px 15px 20px;
  font-weight: 600;
  font-size: 14px;
  text-decoration: none;
  max-width: 250px;
  margin: 0 auto;
  }

  .btn-black::after {
  font-family: "Font Awesome 5 Free";
  content: "\f054";
  font-weight: 600;
  position: absolute;
  color: #fff;
  font-size: 14px;
  right: 20px;
  top: 50%;
  transform: translateY(-50%);
  }
	.footer_column {
		display: flex;
		flex-direction: column;
		gap: 20px;
	} 
  
  
  
  /* ふわっと表示は省略 */
 
}
/*フッター改行位置調整*/
.footermenu-dropdown-list-item span{
	display:inline-block;
}
@charset "utf-8";
/* CSS Document */
#site_entrance{
	height:96vh;
	position:relative;
	padding-top:80px;
}
.entrance-back1{
	background-image: url("../images/index/new2025/back1.jpg");
	height:32vh;
	width:100%;
	background-position:110% 15%;
	background-size:65%;
}
.entrance-back2{
	background-image: url("../images/index/new2025/back2.jpg");
	background-position:100% 5%;
	height:32vh;
	width:100%;
	background-size:80%;
}
.entrance-back3{
	background-image: url("../images/index/new2025/back3.jpg");
	background-position:75% 15%;
	height:32vh;
	width:100%;
	background-size:80%;
}
@media(max-width:1109px){
#site_entrance{
	height:100vh;
}
.entrance-back1{
	height:33vh;
}
.entrance-back2{
	height:33vh;
}
.entrance-back3{
	height:34vh;
}
}
@media(max-width:1300px){
.entrance-back1{
	background-position:130% 10%;
	background-size:80%;
}
.entrance-back2{
	background-position:135% 5%;
	background-size:85%;
}
.entrance-back3{
	background-position:70% 15%;
	background-size:90%;
}	
}
@media(max-width:1200px){
.entrance-back1{
	background-position:130% 10%;
	background-size:cover;
}
.entrance-back2{
	background-position:135% 5%;
	background-size:cover;
}
.entrance-back3{
	background-position:70% 15%;
	background-size:cover;
}	
}
@media(max-width:960px){
.entrance-back1{
	background-position:130% 10%;
	background-size:cover;
}
.entrance-back2{
	background-position:135% 5%;
	background-size:cover;
}
.entrance-back3{
	background-position:70% 15%;
	background-size:cover;
}	
}
@media(max-width:768px){
.entrance-back1{
	background-position:center top;
	background-size:cover;
}
.entrance-back2{
	background-position:center top;
	background-size:cover;
}
.entrance-back3{
	background-position:center top;
	background-size:cover;
}	
}
@media(max-width:520px){
.entrance-back1{
	background-position:55% top;
	background-size:cover;
}
.entrance-back2{
	background-position:center top;
	background-size:cover;
}
.entrance-back3{
	background-position:center top;
	background-size:cover;
}	
}
.entrance-content{
	position:absolute;
	top:0;
	left:0;
	z-index:2;
	padding-top:110px;
	padding-left:50px;
}
.entrance-content h1{
	width:90%;
	max-width:1000px;
}
.entrance-content h1 img{
	width:100%;
	margin-bottom:15px;
}
.entrance-content h1 .catch3{
	display:none;
}
.entrance-content h1 .catch4{
	display:none;
}
.entrance-btn{
	margin-top:50px;
}
.entrance-btn ul{
	margin-left:0px;
}
.entrance-btn ul li{
	margin-bottom:40px;
}
.entrance-btn ul li a{
	font-weight:bold;
	color:#fff;
	font-size:25px;
	line-height:27px;
}
.entrance-btn ul li a:hover{
	opacity:1;
}
.entrance-btn ul li::before{
	content:"●";
	margin-right:5px;
	color:#1CBDF1;
	font-size:30px;
}
.entrance-btn ul .btn2::before{
	color:#0070A5;
}
.entrance-btn ul .btn3::before{
	color:#004A6D;
}
.entrance-btn ul li a span{
	margin-left:24px;
	font-size:20px;
}
.entrance-btn ul li a .top-menu-arrow {
  position: relative;
  display: inline-block;
  width: 30px;
  height: 2px;
  margin: 5.7px 8px;
  border-radius: 9999px;
  background-color: #fff;
}

.entrance-btn ul li a .top-menu-arrow::before,
.entrance-btn ul li a .top-menu-arrow::after {
  content: "";
  position: absolute;
  top: calc(50% -1px);
  right: 0;
  width: 10px;
  height: 2px;
  border-radius: 9999px;
  background-color: #fff;
  transform-origin: calc(100% - 1px) 50%;
}

.entrance-btn ul li a .top-menu-arrow::before {
  transform: rotate(45deg);
}

.entrance-btn ul li a .top-menu-arrow::after {
  transform: rotate(-45deg);
}
/* 左から右に下線 */
.move-line-left {
  position: relative;    /* 擬似要素の基準 */
  padding-bottom:7px;
}

.move-line-left::before {
  content: ""; 
  position: absolute;
  left: 0;  /* 左端スタート */
  bottom: 0; /* テキスト下に配置 */
  width: 0;  /* 初期幅0 */
  height: 2px; /* 下線の太さ */
  background-color: #fff; 
  transition: all 0.4s ease; /* アニメーション */margin-top:5px;
}

.move-line-left:hover::before {
  width: 120%; /* ホバー時に全幅に広がる */
}

.entrance1 {
    margin: 0;
    overflow: hidden;
    background-image: url("../images/index/new2025/grade7.webp");
	background-position:right top;
	background-size:cover;

  background-attachment: fixed;
	clip-path: polygon(0% 0px, 100% 0px, 20% calc(100% - 0px), 0 100%);
	height:100%;
	width:50%;
	position:absolute;
	top:0;
	left:0;
	padding-top:100px;
	padding-left:50px;
	box-sizing: border-box;
	z-index:2;
}

.entrance1-dash {
    margin-top:80px;
    overflow: hidden;
	/*background-image: radial-gradient(at 20% 80%, #27d0ff, #006797 78%);*/
	clip-path: polygon(100% 0px, 100% 0px, 100% calc(100% - 0px), 0 100%);
	height:40%;
	width:20%;
	position:absolute;
	bottom:0;
	right:0;
	background-image: url("../images/index/new2025/grade6.webp");
	background-position:center;
	background-size:cover;
}
.entrance-logo {
	display:none;
}
@media(max-width:1109px){
	#site_entrance{
	height:100vh;
	position:relative;
	padding-top:0px;
}
	.entrance-content{
	padding-top:80px;
	padding-left:15px;
}
.entrance-logo {
	width:160px;
	display:block;
	position:absolute;
	top:7px;
	left:7px;
}
.entrance-logo img{
	width:100%;
}
}
/*@media(max-width:768px){
.entrance-content{
	padding-top:40px;
	padding-left:30px;
}
}*/
@media(max-width:520px){
.entrance1 {
    margin: 0;
    overflow: hidden;
	clip-path: polygon(0% 0px, 100% 0px, 20% calc(100% - 0px), 0 100%);
	height:100%;
	width:70%;
	position:absolute;
	top:0;
	left:0;
	padding-top:100px;
	padding-left:50px;
	box-sizing: border-box;
	z-index:2;
}
.entrance1-dash {
    margin-top:80px;
    overflow: hidden;
	clip-path: polygon(100% 0px, 100% 0px, 100% calc(100% - 0px), 0 100%);
	height:40%;
	width:20%;
	position:absolute;
	bottom:0;
	right:0;
}	
.entrance-content{
	position:absolute;
	top:0;
	left:0;
	z-index:2;
	padding-top:80px;
	padding-left:25px;
	box-sizing: border-box;
}
.entrance-content h1{
	width:98%;
	max-width:1100px;
	box-sizing: border-box;
}
.entrance-content h1 img{
	width:100%;
	margin-bottom:10px;
}
.entrance-content h1 .catch2{
	display:none;
}
.entrance-content h1 .catch3{
	display:block;
	margin-bottom:20px;
}
.entrance-content h1 .catch4{
	display:block;
}
.entrance-btn{
	margin-top:50px;
}
.entrance-btn ul{
	margin-left:0px;
}
.entrance-btn ul li{
	margin-bottom:30px;
}
.entrance-btn ul li a{
	font-weight:bold;
	color:#fff;
	font-size:20px;
	line-height:27px;
}
.entrance-btn ul li a span{
	margin-left:24px;
	font-size:17px;
}
.entrance-btn ul li a .top-menu-arrow {
  width: 20px;
  height: 2px;
  margin: 5.7px 8px;
  border-radius: 9999px;
  background-color: #fff;
}

.entrance-btn ul li a .top-menu-arrow::before,
.entrance-btn ul li a .top-menu-arrow::after {
  content: "";
  position: absolute;
  top: calc(50% -1px);
  right: 0;
  width: 8px;
  height: 2px;
  border-radius: 9999px;
  background-color: #fff;
  transform-origin: calc(100% - 1px) 50%;
}

.entrance-btn ul li a .top-menu-arrow::before {
  transform: rotate(45deg);
}

.entrance-btn ul li a .top-menu-arrow::after {
  transform: rotate(-45deg);
}
}


/*フェードイン*/
/* 下から上にフェードイン */
.top-fade-up1{
	opacity: 0;
    transform: translateY(100px);
    animation-name: top-fadeIn;
    animation-duration: 1s;
    animation-fill-mode: forwards;
}
.top-fade-up2 { animation-delay: 0.2s; }
.top-fade-up3 { animation-delay: 0.4s; }


/* 左からフェードイン */
.top-fade-left1 {
    opacity: 0;
    transform: translateX(-100px);
    animation-name: top-fadeIn;
    animation-duration: 1s;
    animation-fill-mode: forwards;
}
.top-fade-left2 { animation-delay: 0.2s; }
.top-fade-left3 { animation-delay: 0.4s; }

@keyframes top-fadeIn {
    0% {
    }
    100% {
        opacity: 1;
        transform: translate(0);
    }
}



/*ボタン*/
.entrance-btn2{
	margin-top:30px;
}
.entrance-btn2 ul li {
 position: relative;
 display: flex;
 justify-content: center;
 align-items: center;
 border-radius: 5px;
 /*background: #183153;*/
 background: #183153;
 box-shadow: 0px 6px 24px 0px rgba(0, 0, 0, 0.2);
 overflow: hidden;
 border: none;
 margin-bottom:10px;
 /*width:40%;
 max-width:270px;*/
 width:270px;
 box-sizing:border-box;
 backdrop-filter: blur(10px);
 /*background-color: rgb(255,255,255,0.3);*/
}

.entrance-btn2 ul .btn-color1 {
 background: #1CBDF1;
 background-color: rgb(28,189,241,0.5);
}
.entrance-btn2 ul .btn-color2 {
 background: #0070A5;
 background-color: rgb(0,112,165,0.5);
}
.entrance-btn2 ul .btn-color3 {
 background: #004A6D;
 background-color: rgb(0,74,109,0.5);
}


.entrance-btn2 ul li:after {
 content: " ";
 width: 0%;
 height: 100%;
 /*background: #FFD400;*/
 background: #fff;
 position: absolute;
 transition: all 0.4s ease-in-out;
 right: 0;
}

/*.entrance-btn2 ul .btn-color1:after {
 background: #1CBDF1;
}
.entrance-btn2 ul .btn-color2:after {
 background: #0070A5;
}
.entrance-btn2 ul .btn-color3:after {
 background: #004A6D;
}*/

.entrance-btn2 ul li:hover::after {
 right: auto;
 left: 0;
 width: 100%;
}

.entrance-btn2 ul li a {
 text-align: left;
 text-decoration: none;
 width: 100%;
 padding: 15px 20px;
 /*color: #fff;*/
 color: #183153;
 color: #fff;
 font-size: 1.125em;
 font-weight: 700;
 letter-spacing: 0.3em;
 z-index: 20;
 transition: all 0.3s ease-in-out;
}
.entrance-btn2 ul li a::before {
 content:"●";
}
.entrance-btn2 ul .btn-color1 a::before {
 color:#59D6FF;
}
.entrance-btn2 ul .btn-color2 a::before {
 color:#0A597e;
}
.entrance-btn2 ul .btn-color3 a::before {
 color:#03212F;
}
.entrance-btn2 ul li:hover a {
 color: #183153;
 animation: scaleUp 0.3s ease-in-out;
}

@keyframes scaleUp {
 0% {
  transform: scale(1);
 }

 50% {
  transform: scale(0.95);
 }

 100% {
  transform: scale(1);
 }
}
@media(max-width:480px){
.entrance-btn2 ul li {
 width:230px;
}
.entrance-btn2 ul li a {
 font-size: 16px;
}
.entrance-btn2 ul li a {
 padding: 12px 10px;
}
}

