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

/*--------------------------------------------------------------------
■共通
--------------------------------------------------------------------*/
body {
	margin: 0;
	padding: 0;
	list-style-type: none;
	font-family: "メイリオ", Meiryo, "ＭＳ Ｐゴシック", "MS PGothic", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", sans-serif;
	color: #FFF;
	font-size: 14px;
	line-height: 1.4;
	background-color: #101010;
}
img {
	vertical-align: bottom;
}
a {
	text-decoration: none;
}
.clear {
	clear: both;
}
.clearfix:after {
	content: "";
	display: block;
	clear: both;
}
.clearfix {
	overflow: hidden;
}
a[href^="tel:"] { cursor: default; color: #fff; }
/*--------------------------------------------------------------------
■スマホ以外
--------------------------------------------------------------------*/
@media only screen and (min-width: 768px) {
.pc_none {
	display: none;
}
.pc_tel {
	pointer-events: none;
}
#sp_nav{
	display: none;
}
#h_menu{
	display: none;
}
.spbr{
	display: none;
}
}
#container{
	overflow: hidden;
}
/*----------------------------------
ヘッダー
----------------------------------*/
#sp_menubox{
	display: none;
}

.pcmenu{
	position:absolute;
	bottom:0;
	width: 100%;
	left:0;
	height: 42px;
	background-image:url(../img/pc_menubg.png);
	background-repeat:repeat-x;
	padding-top: 21px;
}
.pcmenu>ul{
	display: table;
	margin-left: auto;
	margin-right: auto;
}
.pcmenu>ul>li{
	display:inline-block;
	margin-right: 60px;
	position: relative;
}
.pcmenu>ul>li:last-child{
	margin-right: 0;
}
.pcmenu>ul>li>a{
	color:#FFF;
	font-size: 15px;
	display: block;
	padding: 0 7px;
}
.pcmenu>ul>li:hover:after {
	width: 100%;
	-webkit-transition: all 0.5s ease;
	-moz-transition: all 0.5s ease;
	-ms-transition: all 0.5s ease;
	-o-transition: all 0.5s ease;
	transition: all 0.5s ease;
}
.pcmenu>ul>li::after {
	content: "";
	width: 100%;
	height: 1px;
	background: #CC941C;
	position: absolute;
	display: block;
	left: 0;
	bottom: -10px;
	opacity: 0;
}
.pcmenu>ul>li:hover::after,
.pcmenu>ul>li.current::after {
	width: 100%;
	left: 0;
	bottom: -5px;
	opacity: 1;
}
header{
	width: 100%;
}
.pcmenu02{
	width: 980px;
	margin-left: auto;
	margin-right: auto;
	overflow: hidden;
	padding-top: 14px;
	height: 56px;
}
.pcmenu02>ul{
	float: right;	
}
.pcmenu02 .h_logo02{
	float: left;
}
.pcmenu02 .h_logo02 img{
	width: 145px;
	height: auto;
}
.pcmenu02>ul>li{
	display:inline-block;
	margin-right: 30px;
	position: relative;
}
.pcmenu02>ul>li:last-child{
	margin-right: 0;
}
.pcmenu02>ul>li>a{
	color:#FFF;
	font-size: 14px;
	display: block;
	padding: 9px 7px 0 7px;
}
.pcmenu02>ul>li:hover:after {
	width: 100%;
	-webkit-transition: all 0.5s ease;
	-moz-transition: all 0.5s ease;
	-ms-transition: all 0.5s ease;
	-o-transition: all 0.5s ease;
	transition: all 0.5s ease;
}
.pcmenu02>ul>li::after {
	content: "";
	width: 100%;
	height: 1px;
	background: #CC941C;
	position: absolute;
	display: block;
	left: 0;
	bottom: -10px;
	opacity: 0;
}
.pcmenu02>ul>li:hover::after,
.pcmenu02>ul>li.current::after {
	width: 100%;
	left: 0;
	bottom: -5px;
	opacity: 1;
}
.nav {
	width: 100%;
	background: #101010;
	z-index:999999;
	display: none;	
}
.fixed {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
	display: block;
}
/*----------------------------------
レイアウト
----------------------------------*/
#top_main{
	position:relative;	
}
.mv_snow{
	width: 100%; 
	height: 900px; 
	position: relative;
}
#top_logo{
	position:absolute;
	left:50%;
	top:50%;
	margin-left: -178px;
	margin-top: -46px;
}
#top_logo img{
	width: 356px;
	height: auto;
}
#top_sec01{
	padding: 170px 0;
}
#top_sec01 .inner{
	width: 720px;
	height: 347px;
	margin-left: auto;
	margin-right: auto;
	background-image:url(../../img/top/top_sec01_inner.png);
	background-repeat:no-repeat;
	padding-top: 70px;
}
#top_sec02{
	padding: 0 0 340px 0;
}
#top_sec02 .inner{
	width: 100%;
	background-image:url(../../img/top/top_sec02_inner.png);
	background-repeat:no-repeat;
	background-size:cover;
	padding-top: 70px;
	padding-bottom: 70px;
}
#top_sec03{
	padding: 0 0 340px 0;
}
#top_sec03 .inner{
	width: 100%;
	background-image:url(../../img/top/top_sec02_inner.png);
	background-repeat:no-repeat;
	background-size:cover;
	padding-top: 70px;
	padding-bottom: 70px;
}
.mbpt01{
	margin-bottom: 40px;
}
#top_sec04{
	padding: 170px 0;
}
#top_sec04 .inner{
	width: 720px;
	height: 347px;
	margin-left: auto;
	margin-right: auto;
	background-image:url(../../img/top/top_sec01_inner.png);
	background-repeat:no-repeat;
	padding-top: 70px;
}
#top_sec05{
	background-color:#000;
	padding-top: 70px;
	padding-bottom: 70px;
}
.galleryimg img{
	width: 100%;
	height: auto;
	margin-bottom: 40px;	
}
/*----------------------------------
タイトル
----------------------------------*/
.title01{
	font-size: 30px;
	color:#CC931B;
	text-align: center;
	margin-bottom: 30px;
	font-weight: normal;
	letter-spacing:0.1em;
}
.title02{
	font-size: 30px;
	color:#000;
	text-align: center;
	margin-bottom: 30px;
	font-weight: normal;
	letter-spacing:0.1em;
}
.txt01{
	font-size: 14px;
	line-height: 200%;
	text-align: center;
}
.txt02{
	font-size: 14px;
	line-height: 180%;
	text-align: center;
	color:#000;
}
/*----------------------------------
パララックス
----------------------------------*/
.parallax_img_1 {
	background-image:url(../../img/top/parallaximg01.jpg);
	height: 900px;
}
.parallax_img_2 {
	background-image:url(../../img/top/parallaximg02.jpg);
	height: 372px;
}
.parallax_img_3 {
	background-image:url(../../img/top/parallaximg03.jpg);
	height: 372px;
}
.parallax_img_4 {
	background-image:url(../../img/top/parallaximg04.jpg);
	height: 372px;
}
.parallax_img_5 {
	background-image:url(../../img/top/parallaximg05.jpg);
	height: 372px;
}
.parallax {
	background-position: center center;
	background-repeat: no-repeat;
	background-size: cover;
	position: relative;
	background-attachment: fixed;
}
/*----------------------------------
フッター
----------------------------------*/
.ft01{
	background-image:url(../img/ft01bg.jpg);
	background-repeat: no-repeat;
	background-size: cover;
	padding: 70px 0;
}
.ft02{
	background-color: #000;
	padding: 20px 0;
	text-align: center;
}
.ft02 address{
	font-style:normal;
	font-size: 10px;
}

/*----------------------------------
ボタン
----------------------------------*/
.btn01 a {
	border: 1px solid #CC941C;
	display: block;
	padding: 15px 0;
	text-align: center;
	font-size: 16px;
	color: #CC941C;
	width: 290px;
	margin: 0 auto;
	background-image:url(../img/arrow02.png);
	background-repeat: no-repeat;
	background-position: 250px center;
	padding-right: 0px;
	-webkit-transition: all 0.5s ease;
	-moz-transition: all 0.5s ease;
	-ms-transition: all 0.5s ease;
	-o-transition: all 0.5s ease;
	transition: all 0.5s ease;
	background-size: 8px 12px;
	overflow: hidden;
}
.btn01 a:hover {
	background-color: #CC941C;
	color: #FFF;
	background-image:url(../img/arrow01.png);
	background-position: 260px center;
	-webkit-transition: all 0.5s ease;
	-moz-transition: all 0.5s ease;
	-ms-transition: all 0.5s ease;
	-o-transition: all 0.5s ease;
	transition: all 0.5s ease;
	background-size: 8px 12px;
	border: 1px solid #CC941C;
}
.btn01 a {
	position: relative;
	z-index: 2;
}
.btn02 a {
	border: 1px solid #000000;
	display: block;
	padding: 15px 0;
	text-align: center;
	font-size: 16px;
	color: #000000;
	width: 290px;
	margin: 0 auto;
	background-image:url(../img/arrow03.png);
	background-repeat: no-repeat;
	background-position: 250px center;
	padding-right: 0px;
	-webkit-transition: all 0.5s ease;
	-moz-transition: all 0.5s ease;
	-ms-transition: all 0.5s ease;
	-o-transition: all 0.5s ease;
	transition: all 0.5s ease;
	background-size: 8px 12px;
	overflow: hidden;
	position:relative;
}
.btn02 a:before {
	background-image:url(../img/f_contact.png);
	background-repeat: no-repeat;
	background-position: left top;
	background-size: 18px 14px;
	position: absolute;
	top: 18px;
	left: 70px;
	content: "";
	width: 18px;
	height: 14px;
}
.btn02 a:hover:before  {
	background-image:url(../img/f_contact_on.png);
}
.btn02 a:hover {
	background-color: #000000;
	color: #FFF;
	background-image:url(../img/arrow01.png);
	background-position: 260px center;
	-webkit-transition: all 0.5s ease;
	-moz-transition: all 0.5s ease;
	-ms-transition: all 0.5s ease;
	-o-transition: all 0.5s ease;
	transition: all 0.5s ease;
	background-size: 8px 12px;
	border: 1px solid #CC941C;
}
.btn02 a {
	position: relative;
	z-index: 2;
}
/*----------------------------------
ぱんくず
----------------------------------*/
.bread_Area {
	padding-top: 20px;
}
.bread_Area .breadcrumb {
	width: 980px;
	margin-right: auto;
	margin-left: auto;
}
.bread_Area .breadcrumb li {
	display: inline;
	font-size: 12px;
	color: #FFF;
}
.breadcrumb li span {
	margin-right: 5px;
	margin-left: 5px;
	color: #FFF;
}
.bread_Area .breadcrumb li a {
	font-size: 12px;
	color: #CC931B;
}
.bread_Area .breadcrumb li a:hover {
	text-decoration:underline;
}

/*----------------------------------
文字フェードイン
----------------------------------*/
.fuwatAnime {
 -webkit-animation-fill-mode:both;
 -ms-animation-fill-mode:both;
 animation-fill-mode:both;
 -webkit-animation-duration:1.5s;
 -ms-animation-duration:1.5s;
 animation-duration:1.5s;
 -webkit-animation-name: fuwatAnime;
 -ms-animation-name: fuwatAnime;
 animation-name: fuwatAnime;
 visibility: visible !important;
}
@-webkit-keyframes fuwatAnime {
 0% { opacity: 0; -webkit-transform: translateY(20px); }
 100% { opacity: 1; -webkit-transform: translateY(0); }
}
@keyframes fuwatAnime {
 0% { opacity: 0; -webkit-transform: translateY(20px); -ms-transform: translateY(20px); transform: translateY(20px); }
 100% { opacity: 1; -webkit-transform: translateY(0); -ms-transform: translateY(0); transform: translateY(0); }
}

/*----------------------------------
サブページ
----------------------------------*/
.recruit #pagetitle{
	background-image:url(../../img/recruit/mainimg.jpg);
}
.experience #pagetitle{
	background-image:url(../../img/experience/mainimg.jpg);
}
.gallery #pagetitle{
	background-image:url(../../img/gallery/mainimg.jpg);
}
.access #pagetitle{
	background-image:url(../../img/access/mainimg.jpg);
}
.faq #pagetitle{
	background-image:url(../../img/faq/mainimg.jpg);
}
.contact #pagetitle{
	background-image:url(../../img/contact/mainimg.jpg);
}
.experience #pagetitle{
	background-image:url(../../img/experience/mainimg.jpg);
}
#pagetitle{
	height: 185px;
    background-repeat: no-repeat;
    background-position: center top;
	background-size: cover;
	padding-top: 65px;
}
#pagetitle .pagetitlebox{
	background-image:url(../img/pagetitlebox.png);
	background-repeat:no-repeat;
	width: 350px;
	height: 120px;
	margin-left: auto;
	margin-right: auto;	
	display:table;
}
#pagetitle .pagetitlebox>div{
	display:table-cell;
	vertical-align: middle;
}
#pagetitle .pagetitlebox h2{
	text-align: center;
	color:#CC921A;
    font-size: 30px;
	font-weight: normal;
	letter-spacing:0.1em;
}
#subpage #content{
	width: 860px;
	margin-left: auto;
	margin-right: auto;
	margin-top: 60px;
}
#subpage .box01{
	margin-bottom: 75px;
}
#subpage .box01 img{
	margin-bottom: 40px;
	display: block;
}
#subpage .box01 p{
	margin-bottom: 40px;
}
#subpage .box01 p:last-child{
	margin-bottom: 0;
}
.title03{
	font-weight: normal;
	font-size: 20px;
	color:#CC921A;
	border-bottom:1px solid #CC921A;
	padding-bottom: 5px;
}
.title03 .sml01{
	font-size: 16px;
}
.tbl01 table{
	width: 100%;
	margin-bottom: 50px;
}
.tbl01 th{
	padding: 25px 0 25px 20px;
	width: 210px;
	border-bottom: 1px solid #585858;
	font-weight: normal;
	text-align: left;
}
.tbl01 td{
	padding: 25px 20px 25px 0;
	border-bottom: 1px solid #585858;
	line-height: 160%;
}
.sub_sec01{
	margin-bottom: 100px;
}
.box02in{
	overflow: hidden;
	margin-bottom: 50px;
}
.box02in .boxleft{
	float: left;
	text-align: left;
}
.box02in .boxright{
	float: right;
	text-align: right;
}
.box02in .boxright p,.box02in .boxleft p{
	display:table-cell;
	height: 240px;
	vertical-align: middle;
}
.box02in .boxright.w410 p,
.w410{
	width: 410px;
}
.w450{
	width: 450px;
}
.map01{
	margin-bottom: 50px;
}
.faxbox{
	padding-bottom: 40px;
	margin-bottom: 40px;
	border-bottom: 1px solid #404040;
}
.faxbox.bbnone{
	border-bottom: none;
}
.faxbox .que01{
	margin-bottom: 30px;
	overflow: hidden;
}
.faxbox .ans01{
	overflow: hidden;
}
.faxbox .que01 dt,.faxbox .ans01 dt{
	font-size: 20px;
	color:#CC9219;
	width: 78px;
	float: left;
	padding-top: 8px;
	padding-bottom: 8px;
}
.faxbox .que01 dd,.faxbox .ans01 dd{
	width: 741px;
	float: left;
	padding-left: 35px;
	padding-top: 8px;
	padding-bottom: 8px;
	border-left:1px solid #9F9F9F;
	line-height: 160%;
}
.mailform .formbox{
	background-color: #fff;
	width: 100%;
	padding: 30px 0;
	margin-bottom: 40px;
}
.mailform table{
	width: 800px;
	margin-left: auto;
	margin-right: auto;
}
.mailform th{
	color:#101010;
	padding: 30px 0 30px 30px;
	text-align: left;
	width: 200px;
	vertical-align: middle;
}
.mailform td{
	color:#101010;
	padding: 30px 30px 30px 0;	
	width: 552px;
}
.mailform tr{
	border-bottom:1px solid #CCC;
}
.mailform tr:last-child{
	border-bottom:none;
}
.wid100{
	width: 552px!important;
}
.must01{
	background-color: #CC1A1A;
	color:#FFF;
	height: 18px;
	line-height: 18px;
	margin-left: 10px;
	text-align: center;
	font-size: 12px;
	font-weight: normal;
	padding: 0 13px;
}
.mailform label input[type="radio"]{
	margin: 0 5px 0 0;
	width: 16px;
	height: 16px;
	border: 1px solid #AAAAAA;
	background-color: #fff;
}
.mailform label{
	margin-right: 30px;
}
.mailform input[type="text"],.mailform input[type="email"]{
	height: 30px;
	border: 1px solid #AAAAAA;
	background-color: #F9F9F9;
}
.mailform textarea{
	border: 1px solid #AAAAAA;
	background-color: #F9F9F9;
}
.mailform .privacy{
	border:1px solid #878787;
	padding: 30px;
	background-color: #101010;
	height: 128px;
	overflow:auto;
	margin-bottom: 60px;
}

.mailform .privacy::-webkit-scrollbar {
  all:unset;
  width: 15px;
  background: transparent;
  padding-right: 10px;
}
 
.mailform .privacy::-webkit-scrollbar-track {
  all:unset;
  background: transparent;
}
 
.mailform .privacy::-webkit-scrollbar-thumb {
  all:unset;
  background: #FFF;
}

.mailform .privacy p{
	font-size: 14px;
	line-height: 160%;
	margin-bottom: 20px;
}
.mailform .privacy p:last-child{
	margin-bottom: 0;
}
.mailform #send_btn .btn02 button{
	width: 290px;
	margin:0 auto;
	display: block;
	background-color: #101010;
	border: 1px solid #CC941C;
	color:#CC941C;
	padding: 13px 0;
}
#mfp_button_send{
	width: 290px;
	margin:0;
	display: block;
	float: right;
	background-color: #101010;
	border: 1px solid #CC941C;
	color:#CC941C;
	padding: 13px 0;
}
.mailform #send_btn .btn02 button:hover,#mfp_button_send:hover{
	background-color: #CC941C;
	color: #FFF;
	-webkit-transition: all 0.5s ease;
	-moz-transition: all 0.5s ease;
	-ms-transition: all 0.5s ease;
	-o-transition: all 0.5s ease;
	transition: all 0.5s ease;
	border: 1px solid #CC941C;
}
.mailform #send_btn{
	overflow: hidden;
}
.mailform #send_btn .btn02{
	width: 290px;
    margin: 0 auto;
}    
div.mfp_buttons button{
	width: 290px;
    float: left;
    display: block;
    background-color: #101010;
    color: #FFF;
	border:1px solid #FFF;
    padding: 13px 0;
}
.tellink a{
	color:#FFF;
	padding-right: 20px;
}
/*--------------------------------------------------------------------
■タブレットのみ
--------------------------------------------------------------------*/
@media (max-width: 1020px) and (min-width: 768px) {
.parallax{
	background-size: cover;
	background-attachment:scroll;
	width: 1020px;
}
footer{
	width: 1020px;
}
body{
	width: 1020px;
}
}
/*--------------------------------------------------------------------
■mailformpro 修正
--------------------------------------------------------------------*/
ul#mfp_phase_stat {
    display: none;
}
form#mailformpro label{
	border:none!important;
	float: left;
	margin-right: 30px;
}
form#mailformpro textarea {
    width: 552px!important;
	height: 100px!important;
}
div#mfp_phase_confirm h4{
	font-size: 30px;
	color:#CC931B;
	text-align: center;
	margin-bottom: 30px;
	font-weight: normal;
	letter-spacing:0.1em;
}
table#mfp_confirm_table tr th{
    border-top: none;
	color: #101010;
	padding: 30px 0 30px 30px;
}
table#mfp_confirm_table tr td{
	border-top: none;
	color: #101010;
	padding: 30px 30px 30px 0;	
}
table#mfp_confirm_table tr{
	border-bottom:1px solid #CCC;
}
table#mfp_confirm_table tr.mfp_colored {
	background-color: #FFF;
}
/*div#mfp_phase_confirm div#mfp_phase_confirm_inner {
    padding: 30px;
    background: #FFF;
}*/
div.mfp_buttons{
	overflow: hidden;
}
.mf_checkbox{
	overflow: hidden;
}
div#mfp_thanks strong{
	color:#FFF;
}
/*--------------------------------------------------------------------
■コロナ休業対応
--------------------------------------------------------------------*/
#info2021 {
    position: relative;
    top: 1%;
    width: 460px;
    margin: 0 auto;
}
.info2021_title {
    background: #fc0000;
    padding: 5px 20px;
    font-size: 18px;
    text-align: center;
    font-weight: bold;
    margin-bottom: 5px;
}
.info2021_content {
    line-height: 1.6;
    margin-bottom: 12px;
    background: #000000b3;
}
.info2021_kikan {
    text-align: center;
    font-size: 18px;
    font-weight: bold;
    background: #00000061;
}
