@charset "utf-8";

/*===============================================
●smart.css  画面の横幅が768pxまで
===============================================*/
@media screen and (max-width:767px){

	/*ハンバーガーメニュー開始*/
	.drawer--right.drawer-open .drawer-hamburger {
		right:0 !important;
	}
	
	.drawer-hamburger{
		display: block !important;
	}
	
	.drawer-nav{
		background: #003961 !important;
	}
	
	.drawer-menu-item{
		color:#fff !important;
	}
	
	.drawer-menu{
		padding: 10px!important;
	}
	
	.drawer-open .drawer-hamburger-icon:before{
		background:#fff!important;
	}
	
	.drawer-open .drawer-hamburger-icon:after{
		background:#fff!important;
	}
	
	.nav {
    	display: none;
	}
	/*ハンバーガーメニュー終了*/
	
	
	/*ヘッダー開始*/	
	.header{
		background:#ffffff;
		z-index: 9999;
		position: fixed;
		width: 100%;
		border-bottom:1px solid #003961;
		box-shadow: 1px 2px 4px rgba(0,0,0,0.15);
	}
	
	.header_in{
		padding: 15px;
	}
	
	.header_right{
		display: none;
	}
	
	.header_right a{
		font-display: block;
		border-radius: 10px;
		padding:10px 50px;
		color:#ffffff;
		background: #F98410;
		box-shadow: 3px 3px 5px 1px #b5b5b5;
	}
	
	.header_img{
		display: none;
	}
	
	.header_spimg{
		padding-top:77px;
		display: block;;
	}
	
	.form_header_li{
		display: block;
	}
	
	.mail_img{
		margin-right:4px;
		vertical-align: middle;
		width: 18px;
	}
	
	.logo{
		width:150px;
	}
	
	.logo_sp{
		margin: auto;
		margin-top:20px;
		width: 80%;
		display: block;
	}

	.dropmenu li a{
		font-weight: bold;
		color:#003961;
		font-size:100%;
		display: block;
		text-decoration: none;
	}
	
	.dropmenu li ul{
		position: absolute;
		z-index: 9999;
		top: 100%;
		left: 0;
	}
	
	.header_spwrap{
		margin-top:20px;
		padding: 0 10px;
		display: block;
	}
	
	.header_spwrap a{
		padding: 10px;
		background: #F98410;
		border-radius: 5px;
		text-align: center;
		color: #fff;
		font-size: 120%;
		display: block;
	}
	/*ヘッダー終了*/
	
	/*ネガティブマージン開始*/
	#solution ,#plan ,#campaign ,#question ,#company_overview{
		margin-top:-61px;
		padding-top:61px;
	}
	/*ネガティブマージン終了*/
	
	.strategy{
		margin-top:20px;
		background: #003961;
		padding: 20px 10px;
		text-align: center;
	}
	
	.strategy_pc{
		display: none;
		font-size: 150%;
		line-height: 1.8;
		color:#ffffff;
	}
	
	.strategy_sp{
		line-height: 1.8;
		font-size: 90%;
		color:#fff;
		display: block;
	}
	
	.featherlight-sample {
		display: none;
	}
	
	.request{
		padding: 20px 10px;
	}
	
	.request_title{
		color:#003961;
		font-weight: bold;
		font-size:120%;
		border-bottom: 1px solid #003961;
		text-align: center;
	}
	
	.request_sp{
		margin-top:10px;
		display: block;
	}
	
	.request_pc{
		display: none;
	}
	
	.request_dw_menu_wrap{
		text-align: center;
	}
	
	.request_dw_menu{
		margin-top:30px;
	}
	
	.request_p{
		margin-top:20px;
		color:#003961;
		font-weight: bold;
		text-align: center;
	}
	
	.request_menu_left{
		margin-top:20px;
		padding:10px 0 20px 0;
		text-align: center;
	}
	
	.request_menu_right{
		margin-top:20px;
		padding:10px 0 20px 0;
		text-align: center;
	}
	
	.request_menu1_p{
		font-weight: bold;
		color:#13A0CC;
	}
	
	.request_menu2_p{
		margin-top:5px;
		font-size: 84%;
	}
	
	.request_menu3_p a{
		margin: auto;
		display: block;
		margin-top:10px;
		border-radius:10px;
		padding:10px;
		font-weight: bold;
		font-size: 120%;
		color:#ffffff;
		background: #F98410;
	}
	
	.fas{
		margin-left:5px;
	}
	
	h2{
		text-align: center;
		font-size: 130%;
		font-weight: bolder;
		color:#003961;
	}
	
	.request li{
		width:100%;
		margin-bottom:5px;
	}
	
	.solution{
		text-align: center;
		background: #F5F5F5;
		padding:20px 10px;
	}
	
	.solution_ac_p {
		text-align: center;
		border-radius: 5px;
		background: #add8e6;
		padding: 10px;
		font-weight: bold;
		color: #003961;
		font-size: 120%;
	}
	
	h3{
		text-align: center;
		color:#003961;
		font-size:120%;
		font-weight:bold;
		
	}
	
	.solution_h3{
		border-bottom:2px solid #e9967a;
		font-size:98%;
	}
	
	.solution_cnt ul{
		margin-top:20px;
		padding-bottom:20px;
	}
	
	.solution_txt01{
		margin-top:10px;
		font-weight: bold;
		font-size: 95%;
		margin-bottom:20px;
	}
	
	.solution_txt02{
		margin-top:10px;
		font-size: 90%;
		margin-bottom:5px;
		text-align: left;
	}
	
	.solution_img{
		margin:auto;
		margin-bottom:10px;
		display: block;
		width:100px;
	}
	
	.top_menu_box_menu {
      	display: none;
      }

	.smart_cnt{
		clear: both;
	}
	
	.top_menu_box_menu p{
		padding-top:10px;
		text-align: left;
		margin-bottom:5px;
		line-height: 1.8;
		color:#003961;
		font-size: 90%;
	}
	
	.qa_dl{
		font-size: 80%;
		text-align: center;
		display: block;
		padding:10px;
		color:#ffffff;
		background :#003961;
		border-radius: 10px;
	}
	
	.plan{

		background: #f0f8ff;
	}
	
	.plan{
		padding:20px 0 20px 0;
		text-align: center;
	}
	
	.plan_txt01{
		margin-top:10px;
		font-weight:bold;
	}
	
	.plan_txt02{
		margin-top:10px;
		font-weight:bold;
	}
	
	.plan_txt02 span{
		color: #003961;
	}
	
	.planimg01{
		width:101px;
	}
	
	.planimg02{
		display: none;
	}
	
	.plan_cnt{
		padding:20px;
		background:#ffffff;
		margin-top:20px;
	}
	
	.plan_cnt_ul{
		display: none;
	}
	
	.plan_sp_cnt_ul{
		display: block;
	}

	.plan_li{
		margin-bottom:10px;
		width:100%;
	}
	
	.plan_cnt li:nth-child(3) { 
  		margin-right:0;
	}
	
	.plan_text01{
		background:#003961;
		font-size: 110%;
		font-weight: bold;
		text-align: center;
		padding: 5px 0;
		color:#ffffff;
	}
	
	.online_cnt{
		margin-top:30px;
	}
	
	.oline_right{
		display: block;
		margin:auto;
		width: 202px;
	}

	.oline_right img {
		display: block;
		margin-top: 20px;
	}
	
	.oline_left{
		margin-top:10px;
	}
	
	.plan_text02{
		font-size: 90%;
		text-align: left;
	}
	
	.reference_wrap{
		text-align: center;
		padding: 20px 0;
	}
	
	.reference_wrap table{
		margin-top:20px;
		border-collapse: collapse;
		box-sizing: border-box;
		width: 100%;
		border: 2px solid #003961;
		font-size: 70%;
	}
	
	.reference_th{
		color:#003961;
		font-weight: bold;
		background: #D9EDF3;
		padding:10px;
		width:25%;
		border: 1px solid #003961;
	}
	
	.td1{
		color:#003961;
		background: #D9EDF3;
	}
	
	.td2{
		background: #ffffe0;
	}
	
	.reference_td{
		border: 1px solid #003961;
		font-weight: bold;
		padding:10px;
		width:25%;
	}
	
	.campaign_spimg{
		display: block;
		margin-top:10px;
	}
	
	.campaign_img{
		display: none;
	}
	
	.campaign_wrap{
		padding: 0 10px 10px;
		text-align: center;
		margin-top:20px;
	}
	
	.question_wrap{
		padding: 20px 10px 20px;
		text-align: center;
		padding-bottom: 40px;
	}
	
	.top_menu_box_ttl{
		margin-top:10px;
		padding: 5px;
		overflow: hidden;
		border-bottom: 1px solid #dcdcdc;
	}
	
	.qa_svg{
		float:left;
	}
	
	.title_h3.title_left_h3{
		width:80%;
		float:left;
		text-align: left;
		font-size: 90%;
		background: none;
		color: #003961;
		padding:0;
		font-weight:300;
	}
	
	.title_h3.title_left_h3:hover{
		cursor: pointer;
	}
	
	.top_menu_box_ttl img{
		vertical-align: middle;
		width:25px;
	}
	
	.question{
		padding-top:20px;
	}
	
	.question_right{
		margin-top:50px;
	}
	
	.qa_cnt{
		padding:20px 20px 40px;
		background: #f5fffa;
	}
	
	.qa_p{
		color:#003961;
		font-weight: bold;
		font-size:90%;
	}
	
	.qa_wrap{
		margin-top:20px;
		
	}
	
	.ac_p{
		width: 88%;
	}
	
	.eco_cnt_right{
		margin-top:20px;
	}
	
	.plan_svg{
		margin: auto;
		display: block;
	}
	
	.plan_sp03_svg{
		margin:20px 0;
		display: block;
	}
	
	.plan01_svg{
		display: none;
	}
	
	.plan01_sp_svg{
		width:60%;
		margin: auto;
		display:block;
	}
	
	.plan02_svg{
		display: block;
	}
	
	.plan03_svg{
		display: none;
	}
	
	.a_img{
		padding-top:5px;
		padding-left:5px;
		width:25px;
		display: block;
		text-align: left;
	}
	
	.plan_svg{
		margin-top:10px;
	}
	
	.company_cnt{
		padding:0 10px 20px;
		
	}
	
	.company_table{
		font-size:90%;
		margin-top:20px;
		text-align: left;
		width:100%;
	}
	
	.company_table th{
		display:block;
		background: #f0f8ff;
		padding:5px;
	}
	
	.company_table td{
		display:block;
		padding:10px 0 30px 10px;
	}
	
	.pagetop {
	    right: -80px;
	    bottom: 20px;
	    position: fixed;
}
	
    .pagetop a{
		opacity: 0.8;
	    border-radius: 70px;
	    color: #003961;
	    display: block;
	    font-size: 16px;
	    height: 50px;
	    line-height: 50px;
	    text-align: center;
	    text-decoration: none;
	    width: 50px;
		background: #ffffff;
		border:1px solid #003961;
		
	}
	
	.telarea{
		padding: 0 10px;
		text-align: center;
	}
	
	.formbtn a{
		padding:10px;
		background:#EB8015;
		color:#ffffff;
		font-size:150%;
		max-width:360px;
		display: block;
		margin: auto;
		border-radius: 10px;
	}
	
	.mail_icon{
		margin-right:4px;
		vertical-align: middle;
		margin-bottom:5px;
		width: 25px;
	}
	
	.telbox{
		margin-top:20px;
	}
	
	.telcontact{
		font-weight: bold;
		color:#003961;
		font-size: 148%;
	}
	
	.telephone{
		margin-top:-10px;
		font-weight: bold;
		color:#003961;
		font-size: 225%;
	}
	
	.reception{
		max-width: 360px;
		font-size: 90%;
		padding:5px;
		color:#003961;
		font-weight: bold;
		/* background:#003961; */
		display: block;
		margin: auto;		
		border-top: 5px solid #2f7aaf;
		border-bottom: 5px solid #2f7aaf;
		/* border-radius: 10px; */
	}
	
	.footer{
		margin-top:40px;
	}
	
	.footer_inner{
		font-size: 10px;
		padding: 15px 10px 30px;
		background: #003961;
		color:#ffffff;
	}
	
	.footer_inner a{
		text-decoration:underline;
		color:#ffffff;
	}
	
	.copyright{
		padding: 10px;
		text-align: center;
		color: #ffffff;
		background: #9F9E9E;
		font-size: 10px;
	}
	
	
	/*お問い合わせ開始*/	
	.contact_wrap{
		padding-top:100px;
	}
	
	.table_form{
		text-align: left;
		width:100%;
		margin: auto;
	}
	
	.form_wrap{
		margin-top:30px;
		max-width: 700px;
		margin: auto;
		padding: 20px 10px;
		/*background:#f0f8ff;*/
	}
	
	.form_h2{
		margin-bottom: 20px;
	}
	
	.table_form th{
		display: block;
		vertical-align:middle;
		font-size: 90%;
		padding:5px 0;
		color:#003961;
		font-weight: normal;
	}
	
	.table_form td{
		display: block;
		vertical-align:middle;
		padding:0 0 5px 0;
		margin-bottom: 10px;
	}
	
	.table_form input{
		padding: 5px 0;
		border-radius: 3px;
		width:100%;
		border: 1px solid #003961;
	}
	
	.table_form input:focus {
  		border: 2px solid #1e90ff;
  		outline: 0;
		box-shadow: 0 1px 1px rgba(0,0,0,.075), 0 0 8px rgba(102,175,233,.6)
	}
	
	.table_form textarea {
		border-radius: 3px;
		border: 1px solid #003961;
		padding: 5px 0;
		width: 100%;
		min-height: 80px;
		vertical-align: top;
		resize: vertical;
		overflow: auto;
		height: 100px;
		margin-top:30px;
}
	
	.table_form textarea:focus {
  		border: 2px solid #1e90ff;
  		outline: 0;
		box-shadow: 0 1px 1px rgba(0,0,0,.075), 0 0 8px rgba(102,175,233,.6)
	}
	
	.iframe {
		border: solid 1px #808080;
		margin: 0 auto;
		width: 90%;
		height: 180px;
		padding: 5px;
		overflow: auto;
		background: #fff;
		color: #000;
		text-align: left;
}
	
	.privacy_wrap{
		margin-top:40px;
	}
	
	.privacy_p{
		margin-bottom: 10px;
		text-align: center;
		font-weight: bold;
	}
	
	.pr{
		margin-bottom:5px;
		font-size: 75%;
	}
	
	.pr_box{
		margin-top:20px;
		text-align: center;
		font-weight: bold;
		margin-bottom:10px;
	}
	
	.submit {
		display: block;
		background: #286BB5;
		color: #fff;
		margin:auto;
		width: 80%;
		font-size: 18px;
		font-weight: bold;
		cursor: pointer;
		margin-bottom:50px;
		height:60px;
		border: none;
	}
	
	.form_red{
		margin-left: 5px;
		background: #ff7f50;
		padding: 2px 4px;
		color:#fff;
		font-size: 80%;
		text-align: center;
		border-radius: 3px;
	}
	/*お問い合わせ終了*/
	



	*:focus {
outline: none;
}

	



	
	/*お問い合わせ新デザイン*/
	
	
	.cp_iptxt {
	position: relative;
	width: 94%;
	margin: 40px 3% 0;
}
.cp_iptxt input[type='text'] {
	font: 15px/24px sans-serif;
	box-sizing: border-box;
	width: 100%;
	letter-spacing: 1px;
	padding-left: 10px;
}
.cp_iptxt input[type='text']:focus {
	outline: none;
}
.ef {
	padding: 8px 0;
	border: 0;
	border-bottom: 1px solid #1b2538;
	background-color: transparent;
}
.ef ~ .focus_line {
	position: absolute;
	z-index: 99;
	bottom: 0;
	left: 0;
	width: 100%;
	height: 2px;
}
.ef ~ .focus_line:before,
.ef ~ .focus_line:after {
	position: absolute;
	bottom: 0;
	left: 0;
	width: 0;
	height: 100%;
	content: '';
	transition: 0.4s;
	background-color: #1e97bf;
}
.ef ~ .focus_line:after {
	right: 0;
	left: auto;
}
.ef:focus ~ .focus_line:before,
.ef:focus ~ .focus_line:after,
.cp_iptxt.ef ~ .focus_line:before,
.cp_iptxt.ef ~ .focus_line:after {
	width: 50%;
	transition: 0.4s;
}
.ef ~ label {
	position: absolute;
	z-index: -1;
	top: 4px;
	left: 0;
	width: 100%;
	transition: 0.3s;
	letter-spacing: 0.5px;
	color: #aaaaaa;
}
.ef:focus ~ label,
.cp_iptxt.ef ~ label {
	font-size: 12px;
	top: -16px;
	transition: 0.3s;
	color: #1e97bf;
}

	.checform {
		margin: 30px 3%;
	}
.submit{
	margin-top:10px;
	margin-bottom:40px;
	cursor: pointer;
	font-size: 130%;
	width:300px;
	height: 55px;
	display: block;
	margin: auto;
	padding:5px;
	background:#003961;
	color:#ffffff;
}
.backForm {
	background: #333;
	margin-bottom: 20px;
}
#description {
	padding: 10px;
	width: 88%;
}
	.ef{
		border-radius: 0;
	}
	.f_chkError {
    margin-bottom: 30px;
}
	
}