

* {
  margin: 0;
  padding: 0;
}
html{
	scroll-behavior: smooth;
	margin:0px;
	padding:0px;
}
body{
	background:#fff;
	text-align:center;
	color:#000;
	font-size: 14px;
	line-height:1.5;
	font-family: "Helvetica Neue", "Helvetica", "Hiragino Sans", "Hiragino Kaku Gothic ProN", "Arial", "Yu Gothic", "Meiryo", sans-serif;
}
img{
	border-style:none;
	display:block;
	padding:0px 0px 0px 0px;
	margin:0px 0px 0px 0px;
}

a {
cursor:pointer;
	color:#333;
	text-decoration:none;
}
a:hover, a:focus {
	text-decoration: none;
	color:#ddd;
}

li{list-style:none;}



.box_in{
	width: 90%;
	padding: 30px 0 30px 0;
	margin: 0px auto;
	text-align: left;
}
.box_in_x{
  	width:100%;
	padding: 30px 0 30px 0;
	margin: 0px auto;
	text-align: left;
}

.bg_view01{
background-image: url(../images/bg_view01.jpg);
}
.bg_f7f7f7{background-color: #f7f7f7;}
.bg_fcefe2{background-color: #fcefe2;}

/* ---Header----*/

#header {
	background-color:#fff;
	position:fixed;
	z-index:999;
	overflow:hidden;
	width: 100%;
	height:70px;
	box-shadow: 10px 10px 10px 10px rgba(0,0,0,0.05);
}

.header_top{
display: flex;
justify-content: space-between;
align-items: center;
text-align:left;
}

.header_top_low{
	width:100%;
	margin: 0px auto 0px auto;
}

.h_logo_low{
	width:100%; 
	height:70px;
	margin:0px;

}
.h_logo_low a{
height:70px;
margin:0px;

}
.h_logo_low img{
display:inline;
height:50px;
margin:10px auto 0 auto;
}

.h_logo{
	width:100%; 
	height:70px;
	margin:0px;

}
.h_logo a{
height:70px;
margin:0px;

}
.h_logo img{
display:inline;
height:50px;
margin:10px auto 0 auto;
}


/* ここから下がハンバーガーメニューに関するCSS */
  
/* チェックボックスを非表示にする */
.drawer_hidden {
  display: none;
}

/* ハンバーガーアイコンの設置スペース */
.drawer_open {
  display: flex;
  height: 60px;
  width: 60px;
  justify-content: center;
  align-items: center;
  position: relative;
  z-index: 100;/* 重なり順を一番上にする */
  cursor: pointer;
}

/* ハンバーガーメニューのアイコン */
.drawer_open span,
.drawer_open span:before,
.drawer_open span:after {
  content: '';
  display: block;
  height: 2px;
  width: 25px;
  border-radius: 3px;
  background: #ff6f00;
  transition: 0.5s;
  position: absolute;
}

/* 三本線の一番上の棒の位置調整 */
.drawer_open span:before {
  bottom: 8px;
}
/* 三本線の一番下の棒の位置調整 */
.drawer_open span:after {
  top: 8px;
}
/* アイコンがクリックされたら真ん中の線を透明にする */
#drawer_input:checked ~ .drawer_open span {
  background: rgba(255, 255, 255, 0);
}
/* アイコンがクリックされたらアイコンが×印になように上下の線を回転 */
#drawer_input:checked ~ .drawer_open span::before {
  bottom: 0;
  transform: rotate(45deg);
}
#drawer_input:checked ~ .drawer_open span::after {
  top: 0;
  transform: rotate(-45deg);
}
  
/* メニューのデザイン*/
.nav_content {
  width: 100%;
  height: 100%;
  position: fixed;
  top: 69px;
  left: 100%; /* メニューを画面の外に飛ばす */
  z-index: 99;
  background: #fcefe2;
  transition: .5s;
}

/* メニュー黒ポチを消す */
.nav_list {
width: 86%;
margin:20px auto;
list-style: none;
}

.nav_list li{
border-bottom:1px solid #ff6f00;
color:#000;
font-size:14px;
font-weight: 600;
text-align:left;
margin:0 0 0px 0;

letter-spacing:3px;
}
.nav_list li:last-child{border-bottom:none;}
.nav_list li a{color:#000;display: block;padding:15px 0 15px 0;}

/* アイコンがクリックされたらメニューを表示 */
#drawer_input:checked ~ .nav_content {
  left: 0;/* メニューを画面に入れる */
}


.h_links02{
	width: 86%;
	margin:0px auto;
}
.h_links02 a img{
width: 100%;
}




.s-fade-wrap{
width:100%;
overflow: hidden;
margin:0px 0 0 0;
padding:70px 0 0 0;
}

.s-fade-wrap_in{
width:100%;
margin:0px auto 0 auto;
}
.mv_view_box01{
width:100%;
}

.mv_view01{width:100%;margin: 0 auto;}
.mv_view01 img{width:100%;}


.mv_none{
padding: 100px 0 0 0;
}

/* ---title---*/

.title_text_c {
width:100%;
max-width: 1100px;
margin:0px auto;
text-align: center;
display: flex;
align-items: center;
justify-content: center;
}

.title_text_c h2{
font-size:20px;
color:#000;
text-align:center;
font-weight:700;
line-height: 1.5;
letter-spacing:1px;
display: inline-block;
}
.title_text_c h2 span{
color:#ff6600;
}
.title_text_c img{
height: 40px;
margin: 0 15px;
display: inline-block;
}

/* ---t_text---*/
.t_text{
border: 3px solid #ff6600;
box-sizing: border-box;
border-radius: 30px;
max-width: 1100px;
padding:25px;
margin: 0 auto;
}

.title_t_text{
width:200px;
margin:-50px auto 0 auto;
background-color: #fff;
}
.title_t_text img{
width: 100%;
}
.t_text_body p{
font-size:14px;
line-height: 1.7;
margin:20px auto 0 auto;
}
.t_text_body p span{
font-size:12px;
color:red;
}


/* ---t_six---*/
.t_six{
padding:20px 0px 0px 0px;
width:100%;
max-width: 600px;
margin:0 auto;
text-align: center;
}

.t_six ul{
width:100%;
display: flex;
justify-content:space-between;
flex-wrap: wrap;
}

.t_six ul li{
width: 48%;
background-color: #fff;
border-radius: 20px;
padding: 15px;
box-sizing: border-box;
margin: 0 0 4% 0;
}
.t_six ul li img{width: 100%;}
.t_six ul li h3{
font-size: 13px;
font-weight: 600;
}

/* ---t_one---*/
.t_one{
padding:20px 0px 0px 0px;
width:100%;
max-width: 600px;
margin:0px auto;
text-align:center;
}

.t_one_in01 img{
width: 100%;
margin:0px 0 0px 0;
}

.t_one_in02{width:100%;}
.t_one_in02 img{
width: 100%;
margin:20px 0 0px 0;
}

/* ---t_two---*/
.t_two{
padding:0px 0px 0px 0px;
width:100%;
max-width: 600px;
margin:0px auto;
}

.t_two_in{
margin:0px 0 0 0;
}

.t_two_in_box{
width:100%;
position: relative;
background-color: #fff;
border: 5px solid #f5f1dc;
border-radius: 20px;
margin:20px 0 0px 0;
}
.t_two_in_icon{
width:25%;
position: absolute;
top:15px;
left: 50%;
transform: translateX(-50%);
}
.t_two_in_icon img{width:100%;}
.t_two_in_view{width:100%;}
.t_two_in_view img{width:88%;margin: 30px auto 0px auto;border-radius:10px;}

.t_two_in_text{
padding: 15px 0;
text-align: center;
}

.t_two_in_text h3{
letter-spacing:1px;
line-height: 1.5;
font-size: 16px;
font-weight: 600;
text-align: center;
margin: 0 auto;
display: block;
}
.t_two_in_text h3 span{
color:red;
}
.t_two_in_text p{
line-height: 1.5;
font-size: 13px;
font-weight: 400;
text-align: center;
margin: 5px auto;
display: block;
}

/* ---t_three---*/
.t_three{
width:100%;
max-width: 600px;
margin:0px auto;
}
.t_three_top_text{
text-align:left;
font-size:14px;
padding:20px 0px 30px 0px;
}
.t_three_in{
padding:20px;
margin: 0px 0 0px 0;
position: relative;
background-image: url(../images/t_three_bg.png);
background-size: 20px;
border: 5px solid #e7d56f;
border-radius: 20px;
}

.t_three_in_view{
position: absolute;
top:-20px;
left:-10px;
width:20%;
max-width:70px;
}
.t_three_in_view img{width:100%;margin: 0 auto;}
.t_three_in_text{width:100%;}

.t_three_in_text h3{
text-align: center;
font-size: 18px;
line-height: 18px;
letter-spacing:1px;
font-weight:600;
padding:10px 0; 
}
.t_three_in_text p{
font-size:14px;
letter-spacing:0px;
line-height:1.7;
margin: 5px 0;

}

.t_three_arrow{width:8%; margin:0px auto 0 auto;}
.t_three_arrow img{width: 100%;margin: 0 auto;}


/* ---t_four---*/
.t_four{
width:100%;
max-width: 600px;
margin:0px auto;
padding:0px 0px 0px 0px;
}

.t_four_in{
width:100%;
background-color: #f7f7f7;
border-radius:20px;
margin: 20px 0 0px 0;
padding:0px;
overflow: hidden;
}
.t_four_view{
width:100%;
height:250px;
overflow: hidden;
}
.t_four_view img{
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  }

.t_four_in_box{
width:100%;
padding:20px;
box-sizing: border-box;
margin:0px 0 0 0;
}

.t_four_in_box div{
background-color: #ff6600;
padding: 10px 20px;
font-size: 12px;
line-height: 12px;
color:#fff;
font-weight: 600;
display: inline-block;
border-radius: 5px;
}
.t_four_in_box h3{
font-size: 18px;
line-height:1.5;;
letter-spacing:1px;
font-weight:600;
padding:10px 0; 
text-align:left;
border-bottom: 3px solid #eae6e6;
}
.t_four_in_box p{
font-size: 14px;
line-height:1.7;
letter-spacing:1px;
padding:10px 0 0px 0;
}

/* ---t_five---*/
.t_five{
width:100%;
max-width: 600px;
margin:0px auto;
padding:20px 0px 0px 0px;
list-style:none;
}
.t_five dl+dl {
    margin-top:15px;
}

.t_five 
dt,
dd {
    padding: 10px;
}

.t_five dl {
    position: relative;
    overflow: hidden;
}

.t_five dl>input {
    display: none;
}

.t_five dt {
    position: relative;
    z-index: 1;
    padding-right:30px;
    background: #ff6600;
	color:#fff;
	font-size: 14px;
	font-weight:500;
	letter-spacing:1px;
}

.t_five dd {
    position: absolute;
    visibility: hidden;
    transform: translateY(-100%);
    transition: .4s;
    background: #fff;
	font-size: 13px;
	font-weight:500;
	letter-spacing:1px;
}

.t_five dl>input:checked+label+dd {
    position: relative;
    visibility: visible;
    transform: translateY(0);
}

.t_five dt::before {
    content: '';
    position: absolute;
    width: 15px;
    height: 3px;
    top: 50%;
    right: 15px;
    background: #fff;
    transform: translateY(-50%);
}

.t_five dt::after {
    content: '';
    position: absolute;
    top: 50%;
    right: 15px;
    width: 15px;
    height: 3px;
    background: #fff;
    transition: .4s;
    transform: translateY(-50%) rotate(90deg);
}

.t_five dl>input:checked+label>dt::after {
    transform: translateY(-50%) rotate(180deg);
}


/* ---form---*/

.form_top_text{
padding:20px 0px 20px 0px;
text-align:left;
font-size:14px;
letter-spacing:1px;
}


.form_box{
margin:0 auto;
padding:0px 0px 0px 0px;
}
.form_box table {
width: 100%;
border-collapse:collapse;
border-spacing:0;
}
.form_box th {
font-size:15px;
font-weight:600;
width:100%;
padding:15px 0 0 0;
text-align: left;
display: block;
vertical-align: middle;
}
.form_box th span{
background-color: red;
color:#fff;
font-size:11px;
border-radius:3px;
line-height:11px;
padding:4px 7px;
display: inline-block;
margin:0 0 0 10px;
vertical-align: middle;
}
.form_box td  {
padding:10px 0 15px 0;
text-align: left;
display: block;
vertical-align:top;
border-bottom: 2px solid #fdc89e;
}
 
.form_box td p{
padding:10px 0px 5px 0px;
margin:0px 0 0 0px;
}
.form_box p span{color:red;font-size:12px;}


/* ---service---*/
.service{
width:100%;
margin:0px auto;
}

.service li{
border-bottom: 1px solid #5aaf00;
padding:30px 0;
}
.service li:last-child{
border-bottom: none;
}
.service_box_left{width:30%;margin:0 auto;}
.service_box_left img{width:100%;}
.service_box_right{width:100%;}
.service_box_right h3{
letter-spacing:1.5px;
font-size:20px;
font-weight:600;
padding:0 0 10px 0;
text-align: center;
color:#5aaf00;
}
.service_box_right p{
letter-spacing:1.5px;
font-size:14px;
font-weight:400;
}


/* ---company---*/

.company{
width:100%;
margin:0 auto;
padding:15px 0px 0px 0px;
}

.company li{
border-bottom: 1px solid #ccc;
padding:20px 0;
}
.company li:last-child{
border-bottom: none;
}
.company h3{width:100%;padding:0 0 10px 0;}
.company p{

}


/* ---pp---*/
.pp{
width:100%;
margin:0 auto;
padding:20px 0px 55px 0px;
}
.pp h3{padding:30px 0 10px 0;}
.pp p{}


/* ---footer---*/

.footer{
width:100%;
background-color: #000;
text-align:center;
padding:20px 0 20% 0;
overflow: hidden;
}
.f_logo{
width:70%;
max-width: 250px;
margin: 0 auto 0px auto;
}
.f_logo img{
width:100%;
}
.footer_in{
margin:0 auto;
}


.f_copy{
width:100%;
margin:0px auto;
text-align:center;
padding:0px 0 0px 0;
}
.f_copy_in{
	width:100%;
	margin:0 auto;
}
.copy{
letter-spacing:1px;
text-align:center;
font-size:12px;
font-weight:500;
color:#fff;
margin:5px auto 0px auto;
}

    #pageTop {
    display: none;
	position:fixed;
	bottom:42px;
	right:10px;
	width:35px;	
	margin:0px auto 0px auto;
	z-index:10;
    }
    #pageTop a img {
	width:100%;
	margin:0px auto 0px auto;
	-webkit-transition: 0.3s ease-in-out;
	   -moz-transition: 0.3s ease-in-out;
	     -o-transition: 0.3s ease-in-out;
	        transition: 0.3s ease-in-out;
    }
    #pageTop a img:hover {
      opacity: 0.7;
    }



.sp-none{
display:none !important;
}
.pc-br{
display:none !important;
}
.link_pc{
display:none !important;
}
.contact_btn02{
display:none !important;
}

.mt80{margin-top:80px;}


/* ---t_cv---*/

.t_cv_box{
position: fixed;
bottom: 0;
z-index: 99;
width: 100%;

}
.t_cv_box_in{
width:90%;
max-width:600px;
margin: 0px auto;
display: flex;
align-items: center;
justify-content:space-between;
}

.t_cv_view01{
width:49%;
padding:0px 0 10px 0;
position: relative;
}
.t_cv_view01 div img{width:100%;}

.t_cv_view02{
width:48%;
padding:0px 0 10px 0;
position: relative;
}
.t_cv_view02 div img{width:100%;}


/* ---login---*/

.login_box {
width: 100%;
margin: 30px auto 30px auto;
}
.login_box table{
width: 100%;
}
.login_box th{
	padding: 0 0px 5px 0px; 
    display: block;
    border: none;
	text-align:left;
	color:#333;
	font-weight:bold;
    }
.login_box th span{color:red;font-size:12px;}
.login_box td{
	padding: 0 0px 20px 0px; 
    display: block;
    border: none;
	text-align:left;
    }
.login_box p{display:inline;padding:0px 0px 0px 0px;}

.login_forget_pass a{
text-decoration: underline;
}

/* ---register---*/

.register_box {
width: 100%;
margin: 30px auto 30px auto;
}
.register_box table{
width: 100%;
}
.register_box th{
	padding: 0 0px 5px 0px; 
    display: block;
    border: none;
	text-align:left;
	color:#333;
	font-weight:bold;
    }
.register_box th span{color:red;font-size:12px;}
.register_box td{
	padding: 0 0px 20px 0px; 
    display: block;
    border: none;
	text-align:left;
    }
.register_box p{display:inline;padding:0px 0px 0px 0px;}

.policy_tit{
font-weight:bold;
padding:0px 0px 5px 0px;
}
.form_policy_box{
border: 1px solid #ccc;
width: 100%;
height: 200px;
padding: 25px;
box-sizing: border-box;
overflow-x:scroll;
}

.privacy_block{
padding:0px 0px 15px 0px;
}

.agree_box{
text-align: center;
margin: 20px auto 0px auto;
}


/* ---contact---*/

.contact_box {
width: 100%;
margin: 20px auto 0px auto;
}
.contact_box table{
width: 100%;
}
.contact_box th{
	padding: 15px 0px 0px 0px; 
    display: block;
    border: none;
	text-align:left;
	color:#333;
	font-weight:bold;
    }
.contact_box th span{color:red;font-size:12px;}
.contact_box td{
	padding: 5px 0px 20px 0px; 
    display: block;
    border: none;
	text-align:left;
	border-bottom:1px solid #dddddd;
    }
.contact_box p{padding:0px 0px 20px 0px;}

.form_01{
width: 96%;
padding:10px 2% 10px 2%;
font-size:14px;
border:solid 1px #ccc;
margin:0 auto;
}
.form_02{
width: 96%;
padding:10px 2% 10px 2%;
font-size:14px;
border:solid 1px #ccc;
margin:0 auto;
}
.form_03{
padding:10px 2% 10px 2%;
font-size:14px;
border:solid 1px #ccc;
margin:0 auto;
width: 96%;
height:200px;
resize: vertical;
}
.form_04{
width: 46%;
padding:10px 2% 10px 2%;
font-size:14px;
border:solid 1px #ccc;
margin:0 auto;
}
input.btn_f1{
	font-weight:bold;
	letter-spacing:5px;
	font-size:16px;
	color:#fff;
	width: 100%;
	text-align: center;
	display: block;
	padding:15px 0px 15px 0px;
	margin: 20px auto 0px auto;
	border-radius:5px;
	background-color:#ff6f00;
	border: 3px solid #ff6f00;
	box-sizing: border-box;
	border-bottom: 3px solid #c25603;
	-webkit-transition: 0.3s ease-in-out;
	-moz-transition: 0.3s ease-in-out;
	 -o-transition: 0.3s ease-in-out;
	transition: 0.3s ease-in-out;
	cursor:pointer ; 
	}

input.btn_f2{
	font-weight:bold;
	letter-spacing:5px;
	font-size:16px;
	color:#555;
	width: 100%;
	text-align: center;
	display: block;
	padding:15px 0px 15px 0px;
	margin: 20px auto 0px auto;
	border-radius:5px;
	background-color:#dddddd;
	border: 3px solid #dddddd;
	box-sizing: border-box;
	border-bottom: 3px solid #ccc;
	-webkit-transition: 0.3s ease-in-out;
	-moz-transition: 0.3s ease-in-out;
	 -o-transition: 0.3s ease-in-out;
	transition: 0.3s ease-in-out;
	cursor:pointer ; 
	}


.btn_f3{
	font-weight:bold;
	letter-spacing:1px;
	font-size:18px;
	color:#fff;
	width: 100%;
	text-align: center;
	display: block;
	padding:20px 0px 20px 0px;
	margin: 20px auto 0px auto;
	border-radius:5px;
	background-color:#ff6600;
	border:none;
	cursor:pointer ; 
	}



/* ---コンテンツ表示アニメーション---*/
.animate {
  opacity: 0;
  transition: opacity 0.8s ease 0.2s, transform 0.8s ease 0.2s; /* 0.5秒の遅延 */
  will-change: opacity, transform;
}

.fade-in-from-bottom {
  transform: translateY(30px); /* 下から */
}

.fade-in-from-top {
  transform: translateY(-30px); /* 上から */
}

.fade-in-from-left {
  transform: translateX(-15px); /* 左から */
}

.fade-in-from-right {
  transform: translateX(15px); /* 右から */
}

.animate.visible {
  opacity: 1;
  transform: translateY(0) translateX(0); /* 元の位置に */
}