@charset "utf-8";



input[type="submit"],
input[type="button"] {
  border-radius: 0;
  -webkit-box-sizing: content-box;
  -webkit-appearance: button;
  appearance: button;
  border: none;
  box-sizing: border-box;
  cursor: pointer;
}
input[type="submit"]::-webkit-search-decoration,
input[type="button"]::-webkit-search-decoration {
  display: none;
}
input[type="submit"]::focus,
input[type="button"]::focus {
  outline-offset: -2px;
}
/* Links */
a{
	text-decoration:none;
	background:none;
	letter-spacing: 0.1em;
}
a:hover{
	cursor:pointer;
}
p{
	line-height: 1.8;
	letter-spacing: .08em;
	font-size: 1.3em;
}
dd{
	line-height: 1.8;
}

/* Images */
img{
	display:block;
	max-width:100%;
	height:auto;
}

/* Common */
body{
	position:relative;
	font-size: 16px;
    font-family: 'Noto-Sans-Japanese'!important;
    color:#333;
    overflow-x: hidden;
	}


section{
	position: relative;
	width: 100%;
}
.cleafix{
	display: block;
}

.clearfix:after {
	content: "";
	display: block;
	clear: both;
}
 
.clearfix:before {
　　　　content: "";
	display: block;
	clear: both;
}
/*span*/
.bold{
	font-weight: bold;
}

.clearfix::after {
   content: "";
   display: block;
   clear: both;
}
.flex{
    display: -webkit-box;
    display: -ms-flexbox;
    display: -webkit-flex;
    display: flex;
}
/* ------------------------------------------------------------------------------
index　#header
------------------------------------------------------------------------------ */
#header{
	position: relative;
	width: 100%;
	background: #55aabb;
}
#header .header_inner{
	max-width: 980px;
	margin: 0 auto;
	padding:10px 0;
	box-sizing: border-box;
	position: relative;
}
.header_logo{
	width: 220px;
	height:46px;
}
#nav{
	position: absolute;
	right:0;
	margin-top:5px;
}
#nav ul{}
#nav ul li{
	margin-left: 10px;
	border-left:1px solid #ddd;
	padding:10px 20px;
	font-size: 16px;
}
#nav ul li a{
	color:#fff;
}
#nav ul li:first-child{
	margin-left: 0;
}
#nav ul li:last-child{
	border-right:1px solid #ddd; 
}

#wrap{
	position: relative;
	width: 100%;
}
#top{
	background: url(../img/bg/top01.jpg)top right;
	background-repeat: no-repeat; 
	background-size: cover;
	overflow:hidden;
	height:70vh;
	position: relative;
}
#top:after{
	content: "";
	width: 100%;
	height:100%;
	top:0;
	left: 0;
	position: absolute;
	background: rgba(8, 68, 94, 0.1);
	z-index: 0;
}

.inner{
	position: relative;
	padding:7rem 0;
	max-width: 980px;
	margin:0 auto;
}

#top .inner{
	padding: 54px 0;
	box-sizing: border-box;
	z-index: 1;
}
.top_txt_box{
	width: 568px;
}
.top_ttl{
	font-size: 40px;
	color:#fff;
	text-align: left;
	line-height: 1.2;
	letter-spacing: 0.05em;
	text-shadow: 1px 1px 3px #999;
	font-family: 'Noto Serif JP', serif;
    font-family: 'Noto-Sans-Japanese'!important;
}
.top_ttl_w{
	font-size: 48px;
	color:#fff;
	text-shadow: 1px 1px 3px #999;
}
.top_ttl_b{
	font-size: 52px;
	display: block;
	color:#4781ed;
	text-shadow: 1px 1px 5px #fff;
}
.top_txt_box p{
	margin-top:10px; 
	font-size: 24px;
}
.contact_box{
	text-align: center;
	width: 300px;
	margin:0px 0 20px;
	background: #f57c00;
	padding:20px 30px;
	box-sizing: border-box;
	border-radius: 20px;
    box-shadow: 0 0 5px grey;
}
.contact_box a{
	font-size: 20px;
	color:#fff;
	font-weight: 600;
}

#about{
	background: #55aabb;
}
.about_ttl{
	font-size: 40px;
	color:#fff;
	text-align: center;
	line-height: 1.5;
	letter-spacing: 0.05em;
}
.about_ttl span{
	display: block;
	color:#eaff6f;
	font-size: 48px;
}
.about_list{
	margin-top: 50px;
}
.about_list li{
	margin-left:20px;
	width: calc(100% / 3);
	border:4px solid #fff;
	padding:20px;
	box-sizing: border-box;
	background: #fff;
}
.about_list li:first-child{
	margin-left:0px;
}
.about_list li dl{

}
.about_list li dt{
	
	margin:0 auto;	
	position: relative;
}

.about_list li dd{
	margin-top:20px;
	font-size: 20px;
	color:#333;
	font-weight: bold;
	text-align: center;
	line-height: 1.2;
}
#type{
	background: #f5f5f5;
	position: relative;
	z-index: 1;
}
#type:before{
	content: url(../img/down_arrow.png);
	width: 150px;
	height:100px;
	position: absolute;
	top:-50px;
	left: 50%;
	transform: translateX(-50%);
	z-index: 3;
}
#type:after{
	content:"";
	position: absolute;
	top:0;
	left: 0;
	width: 100%;
	height:100%;
	background-image:radial-gradient(#999 5%, transparent 0),radial-gradient(#666 10%, transparent 0);
	background-position: 0 0, 5px 5px;
	background-size: 5px 5px;
	z-index: 0;
}
.type_ttl{
	font-size: 40px;
	color:#333;
	text-align: center;
	line-height: 1.3;
	letter-spacing: 0.05em;
	position: relative;
	z-index: 2;
}
.type_ttl span{
	font-size: 48px;
	display: block;
}
.type_ttl .red{
	display: inline-block !important;
	color:#f32b67;
}
.type_box{
	position: relative;
	max-width: 980px;
	margin: 40px auto 20px;
	background: #fff;
	padding:20px 30px;
	box-sizing: border-box;
	z-index: 2;
}
.type_box h3{
	font-size: 30px;
	padding:10px 0 10px 20px;
	text-align: center;
	width: 420px;
	margin:20px auto;
	border-left:10px solid #55aabb;
	box-sizing: border-box;
}
.type_box p{
	font-size: 18px;
}
#crypto_list h2{
	font-size: 48px;
	color:#333;
	text-align: center;
	line-height: 1.3;
	letter-spacing: 0.05em;
}
.crypto_item_list{
	display: -webkit-box;
	display: -ms-flexbox;
	display: -webkit-flex;
	display: flex;
	flex-wrap: wrap;
	margin:50px auto 30px;
	max-width:980px; 
	line-height: 1.2;
}
.crypto_item{
	width: 50%;
	text-align: center;
	font-size: 18px;
	padding: 15px 0;
	color:#777;
	font-weight: 600;
	border-top: 1px solid #ddd;
	border-left: 1px solid #ddd;
	box-sizing: border-box;
}
.crypto_item:nth-child(2n){
	border-right: 1px solid #ddd;
}
.crypto_item:nth-child(11), .crypto_item:last-child{
	border-bottom:1px solid #ddd;
}
.crypto_txt{
	margin-top:50px;
	text-align: center;
	font-size: 18px;
}
.crypto_txt br{
	display: none;
}
.crypto_txt a{
	color:#55aabb;
	font-weight: 600;
}

#merit{
	background:#f8f8f8;
	position: relative;
}

.merit_ttl{
	font-size: 40px;
	color:#333;
	text-align: center;
	line-height: 1.3;
	letter-spacing: 0.05em;
	z-index: 2;
}
.merit_ttl span{
	color:#f32b67;
	font-size: 48px;
}
.span_band{
	display: inline-block !important;
	background: linear-gradient(transparent 65%, #ffde00 65%, #ffde00 80%, transparent 80%);
	font-weight: bold;
}
.merit_box{
	position: relative;
	max-width: 980px;
	margin: 50px auto; 
	background: #fff;
	padding:80px 40px;
	box-sizing: border-box;
	z-index: 3;
}
.merit_box_ttl{
	padding:20px;
	font-size: 30px;
	border-top:4px solid #55aabb;
	border-bottom:4px solid #55aabb;
	position: relative;
	line-height: 1.2;
	font-weight: bold;
}
.merit_box li{
	position: relative;
	margin-bottom:80px;
}
.merit_box li:last-child{
	margin-bottom:20px;
}
.merit_box li:before{
	content: "";
	width: 120px;
	height: 45px;
    left: 0px;
    top: -45px;
	position: absolute;
	background: #55aabb;
	color:#fff;
	font-size: 20px;
	text-align: center;
	padding:10px 0;
	box-sizing: border-box;
	line-height: 1.5;
	font-weight: 600;
}
.merit_box li:first-child:before{
	content: "特徴１";
}
.merit_box li:nth-child(2):before {
    content: "特徴２";
}
.merit_box li:last-child:before{
	content: "特徴３";
}
.merit_box_ttl span{
	color:#f32b67;
}
.merit_flex{
	display: -webkit-box;
	display: -ms-flexbox;
	display: -webkit-flex;
	display: flex;
	margin:40px 0 40px;
}
.merit_box_dl{
	margin-bottom:120px;
}
.dd_left, .dd_right{
	width: 50%;
	font-size: 14px;
}
.dd_right{
	margin-left: 20px;
}

.dd_right_img{
	position: relative;
	width: 100%;
	box-sizing: border-box;
	overflow: hidden;
}
.notice{
	margin-top:10px;
	font-size: 12px;
}
#flow{
	background: #55aabb;
}
.flow_ttl{
	font-size: 40px;
	text-align: center;
	line-height: 1.3;
	letter-spacing: 0.05em;
	color: #fff;
}
.flow-box{
	margin:50px auto;
	max-width: 980px;
	background: #fff;
	padding:20px;
	box-sizing: border-box;
}
.flow_img{
	position: relative;
	width: 100%;
	max-width: 940px;
	padding:10px 20px;
	box-sizing: border-box;
}
.flow_img2{
	position: relative;
	width: 100%;
	display: none;
	padding:10px 0px;
	box-sizing: border-box;
}
.flow_img2 .flow_img2_a{
	display: -webkit-box;
    display: -ms-flexbox;
    display: -webkit-flex;
    display: flex;
    flex-wrap: wrap;
    -ms-flex-wrap: wrap;
      flex-wrap: wrap;
    box-sizing: border-box;
}


.flow_img2_a li{
	width: calc(100% / 3);
	box-sizing: border-box;
	padding:20px 20px 0;
	position: relative;
}
.flow_img2_a li:first-child:before, 
.flow_img2_a li:nth-child(2):before{
	content:url(../img/arrow_right.png);
	width:30px;
	height:30px;
	position: absolute;
	top:56px;
	right: -15px;
}
.flow_img2_a li dl{
	width: 100%;
	position: relative;
}

.flow_img2_a li dt{
	width: 100%;
	height:100px;
	background:#55aabb; 
	border-radius: 5px;
	padding:25px;
	box-sizing: border-box;
}
.flow_img2_a li dt span{
	height:80px;
	text-align: center;
}
.flow_img2_b li dt span{
	height:80px;
	text-align: center;
}

.flow_img2_a li dl dd{
	text-align: center;
	font-weight: 600;
	line-height: 1.3;
	margin-top:6px;
	font-size: 16px;
}
.flow_img2 .flow_img2_b{
	display: -webkit-box;
    display: -ms-flexbox;
    display: -webkit-flex;
    display: flex;
    flex-wrap: wrap;
    -ms-flex-wrap: wrap;
      flex-wrap: wrap;
    box-sizing: border-box;
    max-width:300px;
    margin:0 auto; 
}
.flow_img2 .flow_img2_b li{
	width: calc(100% / 2);
	box-sizing: border-box;
	padding:20px 20px 0;
	position: relative;
}
.flow_img2_b li dl{
	width: 100%;
	position: relative;
}
.flow_img2_b li dt{
	width: 100%;
	height:100px;
	background:#55aabb; 
	border-radius: 5px;
	padding:25px;
	box-sizing: border-box;
}
.flow_img2_b li dl dd{
	text-align: center;
	font-weight: 600;
	line-height: 1.3;
	margin-top:6px;
	font-size: 16px;
}
.flow_img2_b li:first-child:before, 
.flow_img2_b li:nth-child(2):before{
	content:url(../img/arrow_right.png);
	width:30px;
	height:30px;
	position: absolute;
	top:56px;
	left: -15px;
}
.necessary{
	margin-top:30px;
}
.necessary_ttl{
	padding:20px;
	font-size: 30px;
	border-top:4px solid #55aabb;
	border-bottom:4px solid #55aabb;
	position: relative;
	font-weight: bold;
}
.necessary_flex{
	display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    margin:20px 0;
}
.necessary_left, .necessary_right{
	width: 50%;
}
.necessary_right{
	margin-left:10px;
}
.necessary_left_img{
	width: 100%;
	box-sizing: border-box;
	border:1px solid #ddd;
}
.necessary_right ul{
	padding:0 0 0 20px;
}
.necessary_right ul li{
	margin: 20px 0;
	font-size: 20px;
	font-weight: 600;
}

.necessary_notice{
	background: #f5f5f5;
	padding:30px 20px;
	box-sizing: border-box;
}
.necessary_notice h4{
	text-align: center;
	font-size: 24px;


}
.necessary_notice p{
	font-size: 16px;
	margin-top:20px;
}
.necessary_notice p span{
	display: block;
	color:#c1272d;
}

.necessary_list{
	margin:30px auto;
	padding-bottom:10px;
	box-sizing: border-box;
}
.necessary_list dt{
	font-size: 24px;
	padding:15px 0 15px 55px;
	box-sizing: border-box;
	border-top:3px solid #999;
	border-bottom:3px solid #999;
	background-image: radial-gradient(#666 10%, transparent 0),radial-gradient(#666 10%, transparent 0);
    background-position: 0 0, 5px 5px;
    background-size: 5px 5px;
	margin-bottom:20px;
	position: relative;
	font-weight: 600;

}
.necessary_list dt:before{
	content: "";
	width: 30px;
	height: 30px;
	font-size: 48px;
	font-weight: bold;
	top:50%;
	left:15px;
	transform: translateY(-50%);
	position: absolute;
	line-height: .7;
	font-family: 'Great Vibes', cursive;
	color:#4781ed;
}
.necessary_list_item_num01:before{
	content: "1." !important;
}
.necessary_list_item_num02:before{
	content: "2."!important;
}
.necessary_list_item_num03:before{
	content: "3."!important;
}
.necessary_list_item_num04:before{
	content: "4."!important;
}
.necessary_list_item_num05:before{
	content: "5."!important;
}
.necessary_list dd{
	margin-bottom:30px;
	font-size: 16px;
	padding:0 15px;
	box-sizing: border-box;

}
.necessary_list dd a{
	color:#333;
	font-weight: bold;
}
.necessary_list dd span{
	display: block;
}
.necessary_list dt span{
	display: inline-block;
	font-size: 30px;
}
#contact{

}

#form_input dt{
    color: #222;
    font-size: 16px;
    font-weight: bold;
    padding: 15px;
    line-height: 2;
}
#form_input dt br{
	display: none;
}
#form_input dt .required{
	font-size: 14px;
    background: #c0392b;
    color: #fff;
    padding: 5px 10px 3px;
    border-radius: 3px;
    margin-left: 15px;
}
#form_input dt .any{
	font-size: 14px;
    background: #c0392b;
    color: #fff;
    padding: 5px 10px 3px;
    border-radius: 3px;
    margin-left: 15px;
}
#form_input dd {
    padding: 10px 10px 20px;
    margin-bottom: 30px;
    box-sizing: border-box;
    border-bottom: 1px solid #e1e1e1;
    position: relative;
}
.flex_type_table {
    display: -webkit-box;
    display: -webkit-flex;
    display: -ms-flexbox;
    display: flex;
    -webkit-flex-wrap: wrap;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
}
#form_input li {
    padding-top: 10px;
    width: calc(100% / 3);
    font-size: 15px;
}
.contact_ttl{
	font-size: 40px;
	color:#333;
	text-align: center;
	line-height: 1.3;
	letter-spacing: 0.05em;
}
#form_input input[type="text"], #form_input input[type="tel"], #form_input input[type="email"], #form_input select {
    height: 40px;
    line-height: 40px;
    font-size: 16px;
    padding: 0 10px;
    max-width: 568px;
    width: 100%;
}
#form_input input[type="file"]{
	font-size: 16px;

}
#form_input textarea {
    width: 100%;
    max-width: 100%;
    min-width: 100%;
    height: 250px;
    min-height: 250px;
}
#contact p{
	font-size: 16px;
}
.agree__box {
    text-align: center;
    margin: 0 auto 30px;
    font-size: 14px;
    line-height: 1.8em;
}
#contact form p.contact__btn input {
    max-width: 320px;
    width: 100%;
    padding: 15px 0;
    font-size: 18px;
    font-weight: bold;
    border: #527bcc solid 3px;
    background: #527bcc;
    color: #fff;
    cursor: pointer;
    border-radius: 5px;
    transition: .5s;
}
#form_input input[type="checkbox"]{
	margin-right:10px;
}
.sendBtn{
	max-width: 320px;
	margin: 0 auto;
}
.contact_txt_box{
	background:#f5f5f5;
	padding:30px;
	box-sizing: border-box;
	text-align: center;
	margin: 50px 0;
}
.file01 p, .file02 p{
	color: #c0392b;
    font-size: 12px !important;
    font-weight: 600;
    margin-top: 5px;
}
#footer{
	position: relative;
	bottom:0;
	background: #303c42;
}
.copy-right{
	text-align: center;
	color:#fff;
	padding:10px 0;
	box-sizing: border-box;
}

/* ------------------------------------------------------------------------------
index　drawer
------------------------------------------------------------------------------ */

.drawer{
	position: absolute;
    right: 5px;
    top: 2px;
    display: none;
}
.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: 3px;
  width: 25px;
  border-radius: 3px;
  background: #fff;
  transition: 0.5s;
  position: absolute;
}

.drawer-open span:before {
  bottom: 8px;
}

.drawer-open span:after {
  top: 8px;
}

#drawer-check:checked ~ .drawer-open span {
  background: rgba(255, 255, 255, 0);
}

#drawer-check:checked ~ .drawer-open span::before {
  bottom: 0;
  transform: rotate(45deg);
  background:#55aabb;
}

#drawer-check:checked ~ .drawer-open span::after {
  top: 0;
  background:#55aabb;
  transform: rotate(-45deg);
}
  
.drawer-content {
  width: 100%;
  height: 100%;
  position: fixed;
  top: 0;
  left: 100%;  z-index: 99;
  background: #fff;
  transition: .5s;
  padding: 50px 30px;
  box-sizing: border-box;
}

#drawer-check:checked ~ .drawer-content {
  left: 0;
}
.drawer_logo{
	margin:20px 0;
	width: 260px;
	height:50px;
	
}
.drawer-list{
	margin-top:50px;
	
}
.drawer-item{
	margin:20px 0;
	border-bottom:1px dashed #55aabb;
	padding:10px 15px;
	box-sizing: border-box;
	font-size: 18px;
}
.drawer-item a{
	color:#55aabb;
}

#company{
	background: #f5f5f5;
}
.company_ttl{
	padding:20px;
	font-size: 30px;
	position: relative;
	font-weight: bold;
	text-align: center;
	}
.company_list{
	margin-top:50px;
	background: #fff;
	box-sizing: border-box;
	border:1px solid #ddd;
}
.company_list_item{

}

.li_p1{
	width: 195px;
	padding:15px 20px;
	box-sizing: border-box;
	position: relative;
}
.li_p1:after{
	content: "";
	width: 1px;
	height: 80%;
	background: #000;
	position: absolute;
	right:0;
	top:50%;
	transform: translateY(-50%);

}
.li_p2{
	padding:15px 20px;
	box-sizing: border-box;
	display: block;
}
.li_s{
	display: block;
}
.office_box{
	position: relative;
	display: block;
	margin-top:10px;
}
.office_img{
	width: 50%;
	height:298px;
	box-sizing: border-box;
	border:1px solid #ddd;
	overflow: hidden;
}
.office_img img{
	width: 100%;
}
.iframe{
	width: 50%;
	height:298px;
}
.map_img{
	margin-top:20px;
	border-top:1px solid #ddd;
	padding:20px;
	box-sizing: border-box;
}

.modal{
    display: none;
    height: 100vh;
    position: fixed;
    top: 0;
    width: 100%;
}
.modal__bg{
    background: rgba(0,0,0,0.8);
    height: 100vh;
    position: absolute;
    width: 100%;
}
.modal__content{
    background: #fff;
    left: 50%;
    height:70vh;
    padding: 40px;
    position: absolute;
    top: 50%;
    transform: translate(-50%,-50%);
    width: 60%;
    overflow: scroll;
}

#privacyPolicy h2{
	padding:20px;
	font-size: 30px;
	position: relative;
	font-weight: bold;
	text-align: center;
	line-height: 1.2;
	}
#privacyPolicy h3{
	font-size: 24px;
	padding:20px 0 10px;
}
#privacyPolicy dl{
	margin:10px 0;
}
#privacyPolicy dt{
	padding:5px 0 5px 10px;
	font-size: 20px;
	border-bottom:1px solid #55aabb;
	margin-bottom:10px;
	line-height: 1.2;
}
#privacyPolicy dd{
	margin-bottom:20px;
	font-size: 15px;
}
#privacyPolicy dd p{
	font-size: 14px;
}
#privacyPolicy ul {
	margin:10px 0;
}
#privacyPolicy ul li{
	font-size: 18px;
	padding:10px;
	box-sizing: border-box;
	font-weight: 600;
}
.js-modal-close{

}
.modal_close_botton{
	max-width: 280px;
	margin: 40px auto 20px;
	background: #333;
	padding:10px;
	box-sizing: border-box;
	text-align: center;
	font-size: 16px;
}
.modal_close_botton a{
	color:#fff;
	display: block;
}

#form_message{
	height: 85vh;
}
.form_message_ttl{
	padding:20px;
	font-size: 30px;
	position: relative;
	font-weight: bold;
	text-align: center;
	}
.form_message_ttl br{
	display: none;
}
.form_message_message{
	position: relative;
	margin:50px auto 0;
	max-width: 568px;
}
@media screen and (max-width: 1024px){
	#top{
	    background-size: cover;
	}
	#privacyPolicy h2{
		font-size: 26px;
	}
}

@media screen and (max-width: 768px){
	#header {
    position: fixed;
    top:0;
    z-index: 999;
	}
	#top, #top .inner{
		height:80vh;
	}
	#wrap{
		margin-top:66px;
	}
	#nav ul{
		display: none;
	}
	#header .header_inner{
		padding:10px;
	}
	.drawer {
    	display: block;
	}
	#top .inner{
		padding:3rem 20px;
	}
	.contact_box{
	   margin: 0px 0 10px;
	}
	.inner{
		padding:7rem 20px;
		box-sizing: border-box;
	}
	.about_list li{
		padding:20px 10px;
	}
	.about_list li dd{
		font-size: 18px;
	}
	.office_img{
		height: 230px;
	}
	.iframe{
		height:230px;
	}
	.iframe iframe{
		width: 100%;
		height:100%;
	}
	#privacyPolicy h2{
		font-size: 26px;
	}

}
@media screen and (max-width: 568px){
	
	#top .inner{
		padding:5em 20px;
	}
	.top_txt_box{
		width: 480px;
	}
	.top_ttl{
		font-size: 32px;
	}
	.top_ttl_w{
		font-size: 36px
	}
	.top_ttl_b{
		font-size: 42px;
	}
	.top_txt_box p{
		margin-top:0;
	}
	.contact_box{
		padding: 10px 15px;
	}
	
	.about_ttl{
		line-height: 1.3;
	}
	.about_ttl, 
	.type_ttl, 
	.about_ttl, 
	#crypto_list h2, 
	.flow_ttl, 
	.contact_ttl{
		font-size: 36px;
	}
	.about_ttl span, 
	.type_ttl span{
		font-size: 42px;
	}
	.merit_ttl{
		font-size: 6.5vw;
	}
	.merit_ttl span{
		font-size: 7.5vw;
	}
	.merit_flex{
		display: block;
	}
	.dd_left, .dd_right{
		width: 100%;
	}
	.dd_left{
		margin-bottom:20px;
	}
	.dd_right{
		margin-left: 0;
	}
	.contact_txt_box{
		padding:30px 20px;
	}
	.flex_type_table{
		display: block;
	}
	#form_input li{
		width: 100%;
	}
	#form_input input[type="text"], #form_input input[type="tel"], #form_input input[type="email"], #form_input select{
		max-width: 480px;
	}
	.flow_img{
		padding:10px 0;
	}
	.necessary_right ul li{
		font-size: 15px;
	}
	.necessary_flex{
		display: block;
	}
	.necessary_left, .necessary_right{
		width: 100%;
	}
	.necessary_right ul li{
		font-size: 18px;
	}
	.li_p1{
		width: 150px;
		font-size: 14px;
	}
	.li_p2{
		font-size: 14px;
	}
	.map_img{
		display: block;
	}
	.office_img{
		width: 100%;
		margin-bottom:10px;
		height: 324px;
	}
	.iframe{
		width: 100%;
		height: 324px;
	}
	.modal__content{
		padding:20px;
		box-sizing: border-box;
	}
	.modal__content{
		width: 80%;
	}

	.banner{
		margin-top:40px;
	}

}
@media screen and (max-width: 480px){
	
	.about_list{
		display: block;
	}
	.about_list li{
		width: 100%;
		margin-bottom:10px;
		margin-left: 0;
	}
	.about_list li dt{
		width: 80%;
	}
	.about_ttl, .type_ttl, .contact_ttl, .flow_ttl{
		line-height: 1.2;
		font-size: 34px;
	}
	.about_ttl span, .type_ttl span{
		font-size: 40px;
	}
	.type_box h3{
		width: 100%;
		font-size: 28px;
	}
	.crypto_item_list{
		display: block;
	}
	.crypto_item{
		width: 100%;
	}
	.crypto_item:nth-child(odd){
		border-right:1px solid #ddd;
	}
	.crypto_item:nth-child(11){
		border-bottom:none;
	}
	.crypto_txt br{
		display: block;
	}
	.merit_box{
		padding: 80px 20px;
	}
	.merit_box_ttl{
		font-size: 26px;
	}
	.contact_txt_box{
		text-align: left;
	}
	#form_input dt br{
		display: block;
	}
	#form_input input[type="text"], #form_input input[type="tel"], #form_input input[type="email"], #form_input select{
		max-width: 390px;
	}
	.flow-box{
		padding: 20px 0;
	}
	.necessary_flex{
		display: block;
	}
	.necessary_left, .necessary_right{
		width: 100%;
	}
	.necessary_right ul{
		padding:0 0 0 10px;
	}
	.necessary_right ul li{
		font-size: 18px;
	}
	.flow_img{
		display: none;
	}
	.flow_img2{
		display: block;
	}
	.flow-box{
		padding: 0;
	}
	.span_band{
		display: inline !important;
	}
	.li_p1, .li_p2{
		padding:5px 10px;
	}

	.office_img, .iframe{
		height:266px;
	}
	.company_list{
		margin-top:30px;
	}
	.top_txt_box{
		max-width: 440px;
		width: 100%;
	}
	#top .inner{
	    padding: 2em 20px;
	}
	#top, #top .inner{
		height:70vh;
	}
}
@media screen and (max-width: 428px){
	#top, #top .inner{
	    height: 54vh;
	}
	.top_txt_box {
    width: 390px;
	}
	.about_ttl, .type_ttl, .contact_ttl, .flow_ttl{
		font-size: 30px;
	}
	.about_ttl span, .type_ttl span{
		font-size: 36px;
	}
	.type_box h3 {
	   font-size: 23px;
	}
	.li_p1 {
    width: 100px;
   }
}

@media screen and (max-width: 425px){
	.top_txt_box {
    	width: 380px;
	}
	#top, #top .inner{
	    height: 62vh;
	}
	#top{
		background-position-x: -22rem;
	}
	.inner{
	    padding: 5rem 20px;
	}
	.about_ttl, .type_ttl, .contact_ttl, .flow_ttl, .company_ttl{
		font-size: 28px;
	}
	.contact_ttl br{
		display: block;
	}
	.about_ttl span, .type_ttl span{
		font-size: 32px;
	}
	.type_box{
		padding: 20px 15px;
	}
	.type_box h3{
	    font-size: 22px;
	    padding: 10px 0 10px 15px;
	}
	.merit_box{
		padding: 80px 20px 30px;
	}
	.flow_img2_a li dt{
		height:88px;
	}
	.flow_img2_b li dt{
		height:88px;
	}
	.flow_img2 .flow_img2_b{
		max-width: 260px;
	}
	.necessary_ttl{
		font-size:24px;
		text-align: center; 
	}
	.necessary_notice h4{
		font-size: 20px;
	}
	.necessary_list dt{
	    font-size: 20px;
    	padding: 15px 0 15px 50px;
	}
	.necessary_list dt:before{
		font-size: 40px;
	}
	#form_input input[type="text"], #form_input input[type="tel"], #form_input input[type="email"], #form_input select{
		max-width: 330px;
	}
	.li_p1{
		width: 130px;
	}
	.li_p2{
		width: 256px;
	}
	.office_img, .iframe {
    height: 230px;
	}
	#privacyPolicy h2{
		font-size:23px; 
	}
	#privacyPolicy h3{
		font-size: 20px;
	}
	#privacyPolicy ul li{
		font-size: 17px;
	}
}
@media screen and (max-width: 375px){
	.top_txt_box {
    	width: 315px;
	}

	.about_ttl, .type_ttl, .about_ttl, #crypto_list h2, .flow_ttl, .contact_ttl .company_ttl{
		font-size: 26px;
	}
	.about_ttl span, .type_ttl span{
		font-size: 32px;
	}
	.type_box h3{
		font-size: 22px;
	}
	.merit_ttl {
    font-size: 6.3vw;
	}
	.merit_box_ttl{
		font-size: 24px;
	}
	.merit_box{
		padding: 80px 10px 30px;
	}
	.flow_img2_a li{
		padding: 20px 10px 0;
	}
	.flow_img2_a li:first-child:before, .flow_img2_a li:nth-child(2):before{
	    width: 20px;
    	height: 20px;
    	position: absolute;
    	top: 49px;
   		right: -6px;
    	z-index: 2;
	}	
	.flow_img2_b li:first-child:before, .flow_img2_b li:nth-child(2):before{
		width: 20px;
    	height: 20px;
    	position: absolute;
    	top: 49px;
    	left: -12px;
    	z-index: 2;
	}
	.flow_img2_a li dl dd, .flow_img2_b li dl dd{
		font-size: 14px;
	}
	.flow_img2 .flow_img2_b li{
		padding: 20px 10px 0;
	}
	.flow_img2 .flow_img2_b{
		width: 228px;
	}
	#form_input input[type="text"], #form_input input[type="tel"], #form_input input[type="email"], #form_input select{
		max-width: 292px;
	}
	#contact p{
		font-size: 15px;
	}
	.crypto_item{
		font-size: 16px;
	}
	.company_list_item{
		display: block;
	}
	.li_p1, .li_p2{
		width: 100%;
	}
	.li_p1{
		background: #ddd;
		font-weight: bold;
		font-size: 16px;
	}
	.li_p1:after{
		display: none;
	}
	.map_img{
		padding:10px;
	}
	.office_img, .iframe {
    	height: 210px;
	}
	.copy-right{
		font-size: 13px;
	}
	.modal__content{
		width: 90%;
		height:80vh;
	}
	#contact p br{
		display: none;
	}
	#contact p{
		text-align: left;
	}
	.contact_box {
    margin: 10px 0 10px;
	}
	#top, #top .inner {
    height: 64vh;
}
}
@media screen and (max-width: 320px){
	
	.top_txt_box{
		width: 250px;
	}
	.inner {
    	padding: 3rem 10px;
	}
	.about_ttl, .type_ttl, .about_ttl, #crypto_list h2, .flow_ttl, .contact_ttl{
		font-size: 22px; 
	}
	.about_ttl span, .type_ttl span{
		font-size: 26px;
	}
	.about_list{
		margin-top:25px;
	}
	.type_box h3 {
    	font-size: 17px;
	}
	.type_box p{
		font-size: 15px;
	}
	.merit_box_ttl {
    	font-size: 20px;
	}
	p{
		font-size: 15px;
	}
	.necessary_ttl {
    	font-size: 20px;
	}
	.necessary_notice h4 {
    	font-size: 18px;
	}
	.necessary_list dd{
		font-size: 15px;
	}
	#form_input dt{
		font-size: 15px;
	}
	#form_input input[type="text"], #form_input input[type="tel"], #form_input input[type="email"], #form_input select {
    max-width: 250px;
	}
	#contact p{
		font-size: 14px;
	}
	.office_img, .iframe {
   		 height: 186px;
	}
	#privacyPolicy h2{
		font-size: 19px;
	}
	#privacyPolicy h3 {
    font-size: 18px;
	}
	.contact_box{
		width: 100%;
	}
}
