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



/*------------------------------------------------------------
base
-------------------------------------------------------------*/


html, body, div, span, applet, object, iframe,
h1, h2, h3, h4, h5, h6, h7, p, blockquote, pre,
a, abbr, acronym, address, big, cite, code,
del, dfn, em, ins, kbd, q, s, samp,
small, strike, strong, sub, sup, tt, var,
b, u, i, center,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, embed,
figure, figcaption, footer, header, hgroup,
menu, nav, output, ruby, section, summary,
time, mark, audio, video {
	margin: 0;
	padding: 0;
	border: 0;
	font-style:normal;
	font-weight: normal;
	font-size: 100%;
	vertical-align: baseline;
}

body{
	font-family: YakuHanJPs_Noto, 'Noto Sans JP', sans-serif;
	font-style: normal;
	color:#333;
}
article, aside, details, figcaption, figure,
footer, header, hgroup, menu, nav, section {
	display: block;
}

html{
    overflow-y: scroll;
  -ms-text-size-adjust: 100%;
  -webkit-text-size-adjust: 100%;
    font-size: clamp(12px, 2vw, 18px);
  line-height:1.8em;
}
 

blockquote, q {
	quotes: none;
}

blockquote:before, blockquote:after,
q:before, q:after {
	content: '';
	content: none;
}

input, textarea{
	margin: 0;
	padding: 0;
}

ol, ul{
    list-style:none;
}

table{
    border-collapse: collapse; 
    border-spacing:0;
}

caption, th{
    text-align: left;
}

a:focus {
	outline:none;
}

sup{
font-size: 65%;
vertical-align: top;
position: relative;
top: -0.1em;
}

.clearfix:after {
	content: "."; 
	display: block;
	clear: both;
	height: 0;
	visibility: hidden;
}

.clearfix {
	min-height: 1px;
}

* html .clearfix {
	height: 1px;
	/*¥*//*/
	height: auto;
	overflow: hidden;
	/**/
}

.clearboth{
	clear:both;
}

.inline_block {  
	display: inline-block;  
	*display: inline;  
	*zoom: 1;  
}

.sup{
	font-size: 75.5%;
vertical-align: top;
position: relative;
top: -0.1em;
}

.dnone{display: none;}

.overfh{
overflow: hidden;
}

/* 個別パーツ*/

img, canvas, iframe, video, svg  {
	max-width:100%;
	height: auto;
	vertical-align: middle;
	-ms-interpolation-mode: bicubic;
	border: 0;
    z-index: 2;
}


a img	{border: none;}



/*a,a:hover {
	-webkit-transition: 0.7s;
	-moz-transition: 0.7s;
	-o-transition: 0.7s;
	transition: 0.7s;
}*/

a img:hover {
	filter: alpha(opacity=70);
	-moz-opacity:0.70;
	opacity:0.70;
}

.border_non{
	border:none !important;}
	
.border_nonB{
	border-bottom:none!important;}

.border_box{
border: 1px solid #cccccc;
}

.text-shadow{
	text-shadow: 1px 1px 3px #000;
}

.box-shadow01 {
	-moz-box-shadow: 1px 1px 3px #000;
	-webkit-box-shadow: 1px 1px 3px #000;
	box-shadow: 1px 1px 3px #000;
}

.box-shadow02{/* 影内側*/
	-moz-box-shadow: inset 1px 1px 3px #000;
	-webkit-box-shadow: inset 1px 1px 3px #000;
	box-shadow: inset 1px 1px 3px #000;
}

.radius {
	border-radius: 8px; 
	-webkit-border-radius: 8px;
	-moz-border-radius: 8px; 
}

.transition{
	-webkit-transition: 1.5s;
	-moz-transition: 1.5s;
	-o-transition: 1.5s;
	transition: 1.5s;
}

.alpha {
	filter: alpha(opacity=25);
	-moz-opacity:0.25;
	opacity:0.25;
}

.bg-alpha {
	background-color:rgba(255,255,255,0.2);
}

.gradient {
	filter: progid:DXImageTransform.Microsoft.gradient(startColorstr = '#ffffff', endColorstr = '#000000');
	-ms-filter: "progid:DXImageTransform.Microsoft.gradient(startColorstr = '#ffffff', endColorstr = '#000000')";
	background-image: -moz-linear-gradient(top, #ffffff, #000000);
	background-image: -ms-linear-gradient(top, #ffffff, #000000);
	background-image: -o-linear-gradient(top, #ffffff, #000000);
	background-image: -webkit-gradient(linear, center top, center bottom, from(#ffffff), to(#000000));
	background-image: -webkit-linear-gradient(top, #ffffff, #000000);
	background-image: linear-gradient(top, #ffffff, #000000);
}

.leftbox{
	float:left;
}

.rightbox{
	float:right;
}


.nojustify{ text-align:left !important;}


/*---リンク色 ----*/
a:link {
    color: #0041a5;
    text-decoration: none;
}
a:visited {
    color: #0041a5;
    text-decoration: none;
}
a:hover {
    color: #0041a5;
    text-decoration: underline;
	
}


/* 点滅 */
.blinking{
	-webkit-animation:blink 1.5s ease-in-out infinite alternate;
    -moz-animation:blink 1.5s ease-in-out infinite alternate;
    animation:blink 1.5s ease-in-out infinite alternate;
}
.opacity1 {opacity:1;}

/* 幅 */
.w125{width:145px;}
.w70{width:70px;}
.w300{width:270px;}
.w500{width:500px!important;}
.w600{width:600px;}
.w650{width:650px;}
.w700{width:700px;}

.w50per{width:50%!important;}
.w47per{width:47%!important;}


/*------------------------------------------------------------
margin・・・周りのブロックからの距離
-------------------------------------------------------------*/

.m0{ margin: 0!important; }/*周りからのmarginを0に*/
.m0-t{ margin-top: 0!important; }/*上からのmarginを0に*/
.m0-r{ margin-right: 0!important; }/*右からのmarginを0に*/
.m0-b{ margin-bottom: 0!important; }/*下からのmarginを0に*/
.m0-l{ margin-left: 0!important; }/*左からのmarginを0に*/

.m5{ margin: 5px!important; }
.m5-t{ margin-top: 5px!important; }
.m5-r{ margin-right: 5px!important; }
.m5-b{ margin-bottom: 5px!important; }
.m5-l{ margin-left: 5px!important; }

.m10{ margin: 10px!important; }
.m10-t{ margin-top: 10px!important; }
.m10-r{ margin-right: 10px!important; }
.m10-b{ margin-bottom: 10px!important; }
.m10-l{ margin-left: 10px!important; }

.m15{ margin: 15px!important; }
.m15-t{ margin-top: 15px!important; }
.m15-r{ margin-right: 15px!important; }
.m15-b{ margin-bottom: 15px!important; }
.m15-l{ margin-left: 15px!important; }

.m20{ margin: 20px!important; }
.m20-t{ margin-top: 20px!important; }
.m20-r{ margin-right: 20px!important; }
.m20-b{ margin-bottom: 20px!important; }
.m20-l{ margin-left: 20px!important; }

.m25{ margin: 25px!important; }
.m25-t{ margin-top: 25px!important; }
.m25-r{ margin-right: 25px!important; }
.m25-b{ margin-bottom: 25px!important; }
.m25-l{ margin-left: 25px!important; }

.m30{ margin: 30px!important; }
.m30-t{ margin-top: 30px!important; }
.m30-r{ margin-right: 30px!important; }
.m30-b{ margin-bottom: 30px!important; }
.m30-l{ margin-left: 30px!important; }

.m35-b{ margin-bottom: 35px!important; }

.m40{ margin: 40px!important; }
.m40-t{ margin-top: 40px!important; }
.m40-r{ margin-right: 40px!important; }
.m40-b{ margin-bottom: 40px!important; }
.m40-l{ margin-left: 40px!important; }

.m45{ margin: 45px!important; }
.m45-t{ margin-top: 45px!important; }
.m45-r{ margin-right: 45px!important; }
.m45-b{ margin-bottom: 45px!important; }
.m45-l{ margin-left: 45px!important; }

.m50{ margin: 50px!important; }
.m50-t{ margin-top: 50px; }
.m50-r{ margin-right: 50px!important; }
.m50-b{ margin-bottom: 50px!important; }
.m50-l{ margin-left: 50px!important; }

.m60{ margin: 60px!important; }
.m60-t{ margin-top: 60px!important; }
.m60-r{ margin-right: 60px!important; }
.m60-b{ margin-bottom: 60px!important; }
.m60-l{ margin-left: 60px!important; }

.m70{ margin: 70px!important; }
.m70-t{ margin-top: 70px!important; }
.m70-r{ margin-right: 70px!important; }
.m70-b{ margin-bottom: 70px!important; }
.m70-l{ margin-left: 70px!important; }

.m80{ margin: 80px!important; }
.m80-t{ margin-top: 80px!important; }
.m80-r{ margin-right: 80px!important; }
.m80-b{ margin-bottom: 80px!important; }
.m80-l{ margin-left: 80px!important; }

.m90{ margin: 90px!important; }
.m90-t{ margin-top: 90px!important; }
.m90-r{ margin-right: 90px!important; }
.m90-b{ margin-bottom: 90px!important; }
.m90-l{ margin-left: 90px!important; }

.m100{ margin: 100px!important; }
.m100-t{ margin-top: 100px!important; }
.m100-r{ margin-right: 100px!important; }
.m100-b{ margin-bottom: 100px!important; }
.m100-l{ margin-left: 100px!important; }

.m120-t{ margin-top: 120px!important; }
.m130-t{ margin-top: 130px!important; }
.m140-t{ margin-top: 140px!important; }

.m150{ margin: 150px!important; }
.m150-t{ margin-top: 150px!important; }
.m150-r{ margin-right: 150px!important; }
.m150-b{ margin-bottom: 150px!important; }
.m150-l{ margin-left: 150px!important; }

.m250-b{ margin-bottom: 250px!important; }


/*------------------------------------------------------------
padding・・・周りのブロックからの距離（padding）
-------------------------------------------------------------*/

.p0{ padding: 0!important; }
.p0-t{ padding-top: 0!important; }
.p0-r{ padding-right: 0!important; }
.p0-b{ padding-bottom: 0!important; }
.p0-l{ padding-left: 0!important; }

.p5{ padding: 5px!important; }
.p5-t{ padding-top: 5px!important; }
.p5-r{ padding-right: 5px!important; }
.p5-b{ padding-bottom: 5px!important; }
.p5-l{ padding-left: 5px!important; }

.p10{ padding: 10px!important; }
.p10-t{ padding-top: 10px!important; }
.p10-r{ padding-right: 10px!important; }
.p10-b{ padding-bottom: 10px!important; }
.p10-l{ padding-left: 10px!important; }

.p15{ padding: 15px!important; }
.p15-t{ padding-top: 15px!important; }
.p15-r{ padding-right: 15px!important; }
.p15-b{ padding-bottom: 15px!important; }
.p15-l{ padding-left: 15px!important; }

.p20{ padding: 20px!important; }
.p20-t{ padding-top: 20px!important; }
.p20-r{ padding-right: 20px!important; }
.p20-b{ padding-bottom: 20px!important; }
.p20-l{ padding-left: 20px!important; }

.p25{ padding: 25px!important; }
.p25-t{ padding-top: 25px!important; }
.p25-r{ padding-right: 25px!important; }
.p25-b{ padding-bottom: 25px!important; }
.p25-l{ padding-left: 25px!important; }

.p30{ padding: 30px!important; }
.p30-t{ padding-top: 30px!important; }
.p30-r{ padding-right: 30px!important; }
.p30-b{ padding-bottom: 30px!important; }
.p30-l{ padding-left: 30px!important; }

.p40{ padding: 40px!important; }
.p40-t{ padding-top: 40px!important; }
.p40-r{ padding-right: 40px!important; }
.p40-b{ padding-bottom: 40px!important; }
.p40-l{ padding-left: 40px!important; }

.p50{ padding: 50px!important; }
.p50-t{ padding-top: 50px!important; }
.p50-r{ padding-right: 50px!important; }
.p50-b{ padding-bottom: 50px!important; }
.p50-l{ padding-left: 50px!important; }

.p60{ padding: 60px!important; }
.p60-t{ padding-top: 60px!important; }
.p60-r{ padding-right: 60px!important; }
.p60-b{ padding-bottom: 60px!important; }
.p60-l{ padding-left: 60px!important; }

.p70{ padding: 70px!important; }
.p70-t{ padding-top: 70px!important; }
.p70-r{ padding-right: 70px!important; }
.p70-b{ padding-bottom: 70px!important; }
.p70-l{ padding-left: 70px!important; }

.p80{ padding: 80px!important; }
.p80-t{ padding-top: 80px!important; }
.p80-r{ padding-right: 80px!important; }
.p80-b{ padding-bottom: 80px!important; }
.p80-l{ padding-left: 80px!important; }

.p90{ padding: 90px!important; }
.p90-t{ padding-top: 90px!important; }
.p90-r{ padding-right: 90px!important; }
.p90-b{ padding-bottom: 90px!important; }
.p90-l{ padding-left: 90px!important; }

.p100{ padding: 100px!important; }
.p100-t{ padding-top: 100px!important; }
.p100-r{ padding-right: 100px!important; }
.p100-b{ padding-bottom: 100px!important; }
.p100-l{ padding-left: 100px!important; }

.p250-b{ padding-bottom: 250px!important; }

/*------------------------------------------------------------
font-size・・・フォントサイズの設定
-------------------------------------------------------------*/

.b{ font-weight: bold!important; }/*太字*/
.normal{ font-weight: normal!important; }/*太字を解除*/

.big{ font-size: 1.2em!important; }
.big2{ font-size: 1.5em!important; }
.big3{ font-size: 1.8em!important; }
.small{ font-size: 0.8em!important; }

.f08em{ font-size: 0.8em!important; }
.f09em{ font-size: 0.9em!important; }
.f10em{ font-size: 1.0em!important; }
.f11em{ font-size: 1.1em!important; }
.f12em{ font-size: 1.2em!important; }
.f13em{ font-size: 1.3em!important; }
.f14em{ font-size: 1.4em!important; }
.f15em{ font-size: 1.5em; }
.f16em{ font-size: 1.6em; }
.f17em{ font-size: 1.7em; }
.f18em{ font-size: 1.8em; }
.f19em{ font-size: 1.9em; }
.f20em{ font-size: 2.0em; }
.f21em{ font-size: 2.1em; }
.f22em{ font-size: 2.2em; }
.f23em{ font-size: 2.3em; }
.f24em{ font-size: 2.4em; }

.lh12em{ line-height: 1.2em !important;}
.lh14em{ line-height: 1.4em!important;}
.lh16em{ line-height: 1.6em!important;}

.fnt_green{ color:rgba(24,147,59,1.00);}
.fnt_blue{ color:#1c96d4;}
.fnt_dblue{ color:#032D6D;}
.fnt_pink{ color:#dd007f;}

.fnt_greenB{ color:rgba(24,147,59,1.00)!important; font-weight:bold;}
.fnt_blueB{ color:#1c96d4;font-weight:bold;}
.fnt_pinkB{ color:#dd007f!important;font-weight:bold;}

.red{color:#d60a00 !important;}
.dorenge{ color: #E7410B;}
.orenge{ color: #E7410B;}
.purple{ color: #9E6DAB;}
.dpurple{ color: #693584!important;}
.green{color:#45B035;}
.blue{ color: #29ABE2;}
.white{color:#fff!important;}
.black{ color:#000!important;}
.gray{ color:#999;}


/*--背景色--*/
.bg_white{ background:#fff!important;}
.bg_blue{ background: rgba(41,171,226,1.00);}
.bg_orenge{ background: rgba(243,160,70,1.00);}
.bg_blue{ background:  rgba(41,171,226,1.00)!important;}
.bg_green{ background: #45B035;}

.bg_lyellow{ background: #fffce4;}
.bg_lgray{ background: #F0F0EF;}
.lineh{line-height:1.3em;}

.pink_line{
background: linear-gradient(transparent 60%, rgba(255,255,102,0.6) 60%);
font-weight: bold;}

/*------------------------------------------------------------
align・・・文字の横位置
-------------------------------------------------------------*/

.al-c{ text-align: center!important; }/*中央寄せ*/
.al-r{ text-align: right!important; }/*右寄せ*/
.al-l{ text-align: left !important; }/*左寄せ*/

/* Rules for sizing the icon. */
.material-icons.md-14 { font-size: 14px; }
.material-icons.md-18 { font-size: 18px; }
.material-icons.md-24 { font-size: 24px; }
.material-icons.md-36 { font-size: 36px; }
.material-icons.md-48 { font-size: 48px; }

/*flex*/
.flex-container{
display: -moz-box;
display: -ms-box;
display: -webkit-flexbox;
display: -moz-flexbox;
display: -ms-flexbox;
display: -webkit-flex;
display: -moz-flex;
display: -ms-flex;
display: flex;
-webkit-box-lines: multiple;
-moz-box-lines: multiple;
-webkit-flex-wrap: wrap;
-moz-flex-wrap: wrap;
-ms-flex-wrap: wrap;
flex-wrap: wrap;
flex-direction: row;            /*横並び・左から右（デフォルト）*/
}

.sp-bt { justify-content: space-between;}

.flexbox-vertical-center {
    display: flex; /* 子要素をflexboxで揃える */
    flex-direction: column; /* 子要素をflexboxにより縦方向に揃える */
    justify-content: center; /* 子要素をflexboxにより中央に配置する */
    align-items: center;  /* 子要素をflexboxにより中央に配置する */
	margin-bottom:0 auto 30px auto;
}

.flex-2com,
.flex-3com{
display: flex;
justify-content: space-between;
}

.flex-2com div{
width: calc(96% / 2);
}

.flex-2com-1com{
display: flex;
justify-content: space-between;
}
.flex-2com-1com .flex-2com-1com--2com{
width: 66%;
}

.flex-2com-1com .flex-2com-1com--1com{
width: calc(96% / 3);
}

.flex-3com_inner{
width: calc(95% / 3);
}

.flex-3com .flex-3com_inner_s30per{
width: 34%;
}

.flex-3com .flex-3com_inner_s25per{
width: 25%;
}

.z-index10{
    z-index: 100;
}

/*--注釈--*/
.note{ font-size:0.8em; padding-left:1em; text-indent:-1em; line-height: 1.3em;}

/* ------ アンカーリンクの調整------ */
.anchor{
  display: block;
   margin-top:-100px;
   padding-top:100px;
  }
.screen_pc {display: block;}  
.screen_sp {display:none;}
@media
only screen and (max-width : 786px){
	.screen_sp {display: block;}
    .screen_pc {display:none;}
}


/* --- wrapper --- */

.wrapper{
	width:100%;
	z-index:0;
	position:relative;
}

#top{display:block !important;}


.container{
	width: 100% !important;
	position:relative;
	padding:0!important;
	margin:0!important;
    z-index: 1;
    padding-top: 100px;
    margin-top: -100px;
}


h2{
	font-size:1.6em ;
	font-weight:bold;
	margin-bottom:30px ;
	text-align:center;
}

h2.line_before span {
	display: flex;
	align-items: center;
	color: rgba(108,10,110,0.8);
	font-size: 18px;
	text-transform: uppercase;
}

h2.line_before span::before {
	content: '';
	display: inline-block;
	margin-right: 20px;
	width: 50px;
	height: 1px;
	background-color: rgba(108,10,110,0.8);
}

h2 span.sab-title{
font-size: 0.5em;
line-height: 1.5;
display: block;
color: rgba(231,65,11,0.5);
}


h3{
    font-weight: bold;
	margin: 0px auto 20px auto;
    font-size: 1.3em;
    color: #fe7e01;
}

.bottom-border{
padding-bottom: 10px;
line-height: 1.6em;
}

.bottom-border::after {
	content: '';
	display: block;
	width: 60px;
	height: 3px;
    background: rgba(24,147,59,1.0);
}

.black_box{
padding: 10px;
color: #ffffff;
background-color: #000000;
}

.black_box_s{
padding: 5px 10px;
color: #ffffff;
background-color: #000000;
display: inline;
}

.head-border {
    position: relative;
    display: inline-block;
    padding: 0 55px;
}

.head-border:before,
.head-border:after {
    content: '';
    position: absolute;
    top: 50%;
    display: inline-block;
    width: 50px;
    height: 1px;
    background-color: #666;
}

.head-border:before {
    left: 0;
}

.head-border:after {
    right: 0;
}

.head-border02{
    display: flex;
    align-items: center;
    text-transform: uppercase;
}

.head-border02::before {
    content: '';
    display: inline-block;
    margin-right: 10px;
    width: 20px;
    height: 3px;
    background-color: #E7410B;
}

	
h4{	font-size:1em;
	font-weight:bold;
	margin-bottom:0.5em;
	text-align:left;
	}

@media
only screen and (max-width : 786px){
	h2{ margin-bottom:20px!important;}
}

.style01{
	font-weight:bold;
	border-bottom:2px solid #008C22;
	padding-bottom:0.3em;
}

.style02{
	font-weight:bold;
	color:#008C8C;
	border-bottom:2px solid #008C8C;
	padding:0 0.8em 0.3em 0.8em ;
}

.style02a{
	font-weight:bold;
	color:#008C8C;
	font-size:1.5em;
	text-align:center;
	margin-bottom:0.2em;
}

.style02b{
	font-weight:bold;
	color:#fff;
	font-size:1em;
	text-align:center;
	line-height:2em;
	height:2em;
	background-color:#0079AF;
		border-radius: 20px; 
	-webkit-border-radius: 20px;
	-moz-border-radius: 20px;
	padding:0.2em 1em;
}


.style03{
	font-weight:bold;
	color:#1B99C1;
	border-bottom:2px solid #1B99C1;
	padding:0 0.8em 0.3em 0.8em ;
}

.style04{
	font-weight:bold;
	color:#333333;
	border-bottom:2px solid #333333;
	padding:0 0.8em 0.3em 0.8em ;
}
	
.contents{
	width:900px;
	margin:0 auto;
	padding:70px 0;
    z-index: 10;}
    
.contents_800{
	width:800px;
}

.contents_1000{
	width:1000px;
}

.contents_1100{
	width:1100px;
}

.contents_1200{
	width:  1200px;
}
    
	
@media
only screen and (max-width : 786px){
	.contents{ width:90% !important;padding:30px 0 !important;}
    .contents_800,
    .contents_1000,
    .contents_1100,
    .contents_1200{
	width:90%;
}
}

/* ヘッダー*/
.header{
  position: fixed;
  left: 0;
  top: 0;
  width: 100%;
  height: 60px;
  background: rgba(255,255,255,0.7);
 z-index: 200;
}
.header_inner {
  position: relative;
  padding: 15px;
}
.logo{
  position: absolute;
  top: 0;
  left: 0;
  padding: 10px 15px
}


/* header固定のため余白をつける。メニューのCSSには関係ない */
.main{  
  margin-top: 60px;
}


@media only screen and (min-width: 769px) {
  .header_inner{
    max-width: 980px;
    width: 100%;
    padding: 0px;
    height: calc( 60px - 30px);
    margin: 0 auto;
    display: flex;
    justify-content: space-between;
    position: relative;
  }
  .logo{
  position: static;
  top:auto;
  left: auto;
    padding: 15px 0;
  }
  }
 
/*==============*/
/*メインビジュアル*/
.bg_img{
background: url( "../img/bg_main.jpg") no-repeat;
background-position: top 135px center;
}

.bg_img_com{
background: url( "../img/bg_company.jpg") no-repeat;
background-position: top 50px center;
}

#top_main .contents{
padding: 100px 0;
text-align: center;
}


@media
only screen and (max-width : 786px){
	#top_main .contents { text-align: left; margin-top: 65px;}
	#top_main .contents h2{ margin: 0 auto 20px auto !important; text-align: left;}
}



/*サービスnavi*/
.icon_box{
display: flex;
justify-content: center;
flex-wrap: wrap;
margin: 30px auto 0 auto;
}

.icon_box div{
margin: 10px;
width: calc( calc(100% - 100px) / 3 );
}

/*サービス contents*/
.service_box{
overflow: hidden;
margin: 0 auto 70px auto;
display: flex;
justify-content: space-between;
}

.flex-d_revierse{
flex-direction: row-reverse;
}
.service_box_com{
width: 45%;
}


.service_box_img{
  display: flex;
  justify-content: center;
  align-items: center;
  width: 45%;
}
#service_content blockquote:last-child{
margin-bottom: 0;
}
@media
only screen and (max-width : 786px){
.service_box{
margin: 0 auto 40px auto;
display: block;
}

.service_box_com,
.service_box_img{
width: auto;
}
.service_box_com{
margin-bottom: 15px;
}
}

table.mailform_tb{
margin: 0 auto;
width: 90%;
border: 0;
}

table.mailform_tb tr{
padding: 10px;
border-bottom: 1px solid rgba(184,184,184,1.00);
}

table.mailform_tb tr th,
table.mailform_tb tr td{
padding: 10px;
line-height: 1.2em;
font-size: 0.95em;
}

table.mailform_tb tr td{
vertical-align: middle;
}


table.mailform_tb th{
width: 35%;
vertical-align: top;
}

@media
only screen and (max-width : 786px){
table.mailform_tb tr th,
table.mailform_tb tr td{
display: block;
width: auto;
padding: 10px;
}

table.mailform_tb tr td{
padding: 0px 0px 10px 0px;
}
}

table.mailform_tb th .text_en{
font-size: 0.8em;
color: rgba(111,111,111,1.00);
}

.Form-Item-Label-Required {
  border-radius: 6px;
  padding-top: 2px;
  padding-bottom: 2px;
  margin-left: 1em;
  width: 48px;
  display: inline-block;
  text-align: center;
  background: #5bc8ac;
  color: #fff;
  font-size: 0.7em;;
}

.Form-Item-Input {
  border: 1px solid #ddd;
  border-radius: 6px;
  padding-left: 1em;
  padding-right: 1em;
  height: 48px;
  flex: 1;
  width: 100%!important;
  max-width: 410px;
  background: #ffffff;
}
@media
only screen and (max-width : 786px){
  .Form-Item-Input {
    margin-left: 0;
    height: 40px;
    flex: inherit;
    width: calc(100% - 2em)!important;
  }
}
.Form-Item-Textarea {
  border: 1px solid #ddd;
  border-radius: 6px;
  padding: 0.5em 1em;
  flex: 1;
  width: 100%!important;
  max-width: 410px;
  background: #ffffff;
}
@media
only screen and (max-width : 786px){
  .Form-Item-Textarea {
    margin-left: 0;
    height: 200px;
    flex: inherit;
    width: calc(100% - 2em)!important;
  }
}

.Form-Btn {
  border-radius: 6px;
  padding-top: 15px;
  padding-bottom: 15px;
  width: 280px;
  display: block;
  letter-spacing: 0.05em;
  background: #fe7e01;
  color: #fff;
  font-weight: bold;
  border: none;
}

.Form-Btn:hover {
  background: #5bc8ac;
  cursor:pointer
}

.btn{margin: 0 auto ; text-align: center;}

.btn a {
  border-radius: 6px;
  padding-top: 15px;
  padding-bottom: 15px;
  width: 280px;
  display: block;
  letter-spacing: 0.05em;
  background: #fbc73b;
  color: #fff;
  font-weight: bold;
  border: none;
  margin: 0 auto;
}

.btn a:hover {
  background: #5bc8ac;
  cursor:pointer;
  text-decoration: none;
}

.btn_box{ 
display:flex;
justify-content:space-between;
width:80%;
margin:30px auto 0 auto;}

@media
only screen and (max-width : 786px){
  .Form-Btn {
    margin: 15px auto 0 auto;
    padding-top: 8px;
    padding-bottom: 8px;
  }
.btn_box{ 
display: block;
width:auto;
margin:20px auto 0 auto;
text-align: center;
}

}



.nolink a,
.nolink{
background: rgba(184,182,182,1.00) !important;
pointer-events: none!important;
	cursor: default;
	opacity: 0.9;
}





/* PageTop Style
-------------------------------------------------------- */



#page-top a {
 position: fixed;
    right: 10px;
    bottom: 10px;
    font-size: 2em;
    background: rgba(107,106,106,1.00);
    color: #ffffff;
    padding: 10px;
    border-radius: 50%;
	z-index:500;
    width: 30px;
    height: 30px;
    text-align: center;
    display: flex;
    align-items: center;
    justify-content: center;
    
}
#page-top a:hover{
text-decoration: none;
background: rgba(24,147,59,0.8);
}


/* Footer Area Style
-------------------------------------------------------- */

#footer{
	width:100%;
	background-color:#fbc73b;
}

.copyright{
	font-size: 12px;
	font-weight: bold;
	color: #fff;
	text-align: center;
	clear: both;
	width: 700px;
	padding:10px 0;
	margin:0 auto;
}

@media
only screen and (max-width : 786px){
	.copyright{ width:100%;}
}
/*——　短いページを100％表示　——*/
.wrap {
  display: flex;
  flex-direction: column;
  min-height: 100vh;
}
.main_flex1 {
  flex: 1;
}


/*—— スクロールすると下からふわっとさせるためのコード ——*/
.inview {
  /* 30px下げる */
  transform: translateY(50px);
  /* 要素を透明にする */
  opacity: 0;
  /* 2秒かけて、変化させる */
  transition: transform 2s, opacity 2s;
}

.inview.show {
  transform: translateY(0);
  opacity: 1;
}

/*—— スクロールすると下からふわっとさせるためのコード２ ——*/
.slidein {
    opacity: 0;
    transform: translate(0,0);
    transition: all 2.0s;
    }
  .slidein-left{
      transform: translate(-100%,0);
  }
  .slidein-right{
      transform: translate(100%,0);
  }
  .slidein-up{
      transform: translate(0,-100%);
  }
  .slidein-bottom{
      transform: translate(0,100%);
  }
  .scrollin{
    transform: translate(0, 0)!important;
    opacity: 1!important;
  }

