@charset "utf-8";
/*共通事項*/

* {
    -webkit-box-sizing: border-box;
    -moz-box-sizing: border-box;
    -o-box-sizing: border-box;
    -ms-box-sizing: border-box;
    box-sizing: border-box; }
  
    html, body, div, span, applet, object, iframe,
    h1, h2, h3, h4, h5, h6, p, blockquote, pre,
    a, abbr, acronym, address, big, cite, code,
    del, dfn, em, font, img, 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,
    figure, figcaption,
    article, section, nav, header, footer {
      margin: 0;
      padding: 0;}


body {
	position: relative;
	width: 100%;
	min-width: 320px;
	position: relative;
	margin: 0;
	font-family: 'Avenir', 'Helvetica Neue', 'Helvetica', 'Arial', "Yu Gothic", "游ゴシック Medium", "Yu Gothic Medium", "NotoSans",'メイリオ', Meiryo;
}

@font-face {
	font-family: "NotoSans";
	src: url('../font/NotoSansCJKjp-Light_min.woff') format('woff'), /* モダンブラウザ用 */ url('../font/NotoSansCJKjp-Light_min.otf') format('opentype'); /* iOS, Android用 */
	font-weight: normal;
	font-style: normal;
}

@font-face {
	font-family: "NotoSans";
	src: url('../font/NotoSansCJKjp-Medium_min.woff') format('woff'), /* モダンブラウザ用 */ url('../font/NotoSansCJKjp-Medium_min.otf') format('opentype'); /* iOS, Android用 */
	font-weight: bold;
	font-style: normal;
}

@media all and (-ms-high-contrast:none) {
body{font-family: 'Avenir', 'Helvetica Neue', 'Helvetica', 'Arial', "NotoSans", 'メイリオ', Meiryo, 'ＭＳ Ｐゴシック', 'MS PGothic';}
}

@supports (-ms-ime-align:auto) {
body{font-family: 'Avenir', 'Helvetica Neue', 'Helvetica', 'Arial', "NotoSans", 'メイリオ', Meiryo, 'ＭＳ Ｐゴシック', 'MS PGothic';}
}

.mobile{
	display: none !important;
}

ul {
	list-style: none;
	padding: 0;
	margin: 0;
}
ol {
	margin: 0;
	padding-left: 20px;
}
a {
	color: #000;
	text-decoration: none;
}

.ib{
	display: inline-block;
	vertical-align: middle;
}

.w1000 {
	max-width: 1040px;
	width: 95%;
	margin: auto;
}

.w950 {
	max-width: 950px;
	width: 95%;
	margin: auto;
}

.w800 {
	max-width: 800px;
	width: 95%;
	margin: auto;
}
.flex {
	display: -webkit-flex;
	display: -moz-flex;
	display: -ms-flexbox;
	display: flex;
}

.flex_wrap {
	-webkit-box-lines: multiple;
	-moz-box-lines: multiple;
	-webkit-flex-wrap: wrap;
	-moz-flex-wrap: wrap;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
	-webkit-box-pack: justify;/*--- Androidブラウザ用 ---*/
	-ms-flex-pack: justify;/*--- IE10 ---*/
	-webkit-justify-content: space-between;/*--- safari（PC）用 ---*/
	justify-content: space-between;
}

.flex_around {
	-webkit-box-lines: multiple;
	-moz-box-lines: multiple;
	-webkit-flex-wrap: wrap;
	-moz-flex-wrap: wrap;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
	-webkit-box-pack: justify;/*--- Androidブラウザ用 ---*/
	-ms-flex-pack: distribute;/*--- IE10 ---*/
	-webkit-justify-content: space-around;/*--- safari（PC）用 ---*/
	justify-content: space-around;
}

.flex_center{
    -webkit-box-align:center;/*--- Androidブラウザ用 ---*/
    -ms-flex-align:center;/*--- IE10 ---*/
    -webkit-align-items:center;/*--- safari（PC）用 ---*/
    align-items:center;
}

h1,h2,h3,h4,h5,p{
	margin: 0;
}

.table_style{
	border-collapse: collapse;
	width: 100%;
}

.table_style th,
.table_style td{
	border: 1px solid #CBCBCB;
	padding: 7px 10px;
	text-align: left;
	font-weight: normal;
	background-color: #FFFFFF;
	vertical-align: top;
}

/*ロード画面*/
#loading{
	position: fixed;
	top:0;
	left: 0;
	width:100%;
	height: 100vh;
	z-index:9999;
	background-color: #fff;
}

#load_inner img{
    position: absolute;
	top:0;
	bottom:0;
	left:0;
	right: 0;
	margin: auto;
	width:120px;
	height: auto;
}

.ouro {
    position: absolute;
	top:0;
	bottom:0;
	left:0;
	right: 0;
	margin: auto;
	height: 200px;
    width: 200px;
    border-radius: 50%;  
    background: none repeat scroll 0 0 #fff;
    overflow:hidden;
    box-shadow: 0 0 10px rgba(0,0,0,.1) inset, 0 0 25px rgba(0,0,255,0.075);
}

.ouro:after {
    content: "";
    position: absolute;
    top: 10px; left: 10px;
    display: block;
    height: 180px; width: 180px;
    background: none repeat scroll 0 0 #fff;
    border-radius: 50%;
    box-shadow: 0 0 10px rgba(0,0,0,.1);
}
.ouro > span {
    position: absolute;
    height: 100%; width: 50%;
    overflow: hidden;
}
.left  { left:0   }
.right { left:50% }

.anim {
    position: absolute;
    left: 100%; top: 0;
    height: 100%; width: 100%;
    border-radius: 999px;
    background: none repeat scroll 0 0 #78C0FF;
    opacity: 0.8;
    animation: ui-spinner-rotate-left 3s infinite;
    transform-origin: 0 50% 0;
   animation-delay: 0s;
   animation-timing-function: linear;
}
.left .anim {
    border-bottom-left-radius: 0;
    border-top-left-radius: 0;
}
.right .anim {
    border-bottom-right-radius: 0;
    border-top-right-radius: 0;
    left: -100%;
    transform-origin: 100% 50% 0;
   animation-name: ui-spinner-rotate-right;
   animation-delay:0;
}

@keyframes ui-spinner-rotate-left{
  0%{transform:rotate(0deg)}
  25%{transform:rotate(180deg)}
  50%{transform:rotate(180deg)}
  75%{transform:rotate(360deg)}
  100%{transform:rotate(360deg)}
}
@keyframes ui-spinner-rotate-right{
  0%{transform:rotate(0deg)}
  25%{transform:rotate(0deg)}
  50%{transform:rotate(180deg)}
  75%{transform:rotate(180deg)}
  100%{transform:rotate(360deg)}
}

/*ヘッダー*/
header{
	background-color: rgba(38,107,175,0.8);
	color: #fff;
	height: 70px;
	font-size: 0;
}


.index_head{
	background-color: transparent;
}

#header_inner{
	height: 70px;
	position: relative;
}

#header_inner h1 img{
	width:260px;
}

#header_inner p img{
	max-width:260px;
	width: 100%;
}

#nav ul li{
	vertical-align: middle;
	display: inline-block;
	text-align: center;
	width: 110px;
}

#nav ul li a{
	display: inline-block;
	width: 110px;
	font-size: 16px;
	color: #fff;
	padding: 10px 0;
}

.index_head #nav ul li a{
	color: #000;
}

#nav ul li a:after{
  content: "";
	width:0%;
  display: block;
	height: 1px;
	margin: auto;
	background-color: #fff;
	transition-duration: .3s;
	transition-property: width;
}

.index_head #nav ul li a:after{
	background-color:#000;
}

.hover #nav ul li a:hover:after{
	width:80%;
}

#overray{
	position: fixed;
	top:0;
	left: 0;
	width: 110vw;
	height: 100vh;
	background-color: rgba(0,0,0,0.5);
	z-index: 5;
	visibility: hidden;
	opacity: 0;
	transition: .5s all;
}

/*トップページスライドショー*/
#index_slide {
	position: fixed;
	top:0;
	left: 0;
	width:100%;
	margin: 0;
	height: 100vh;
	z-index: -1;
}

.slide-child{
	width:100%;
	height: 100vh;
	background-size: cover;
}

.slide1{
	background-image: url(../img/back1.jpg);
	background-position: 60% 50%;
}

.slide2{
	background-image: url(../img/back2.jpg);
	background-position:10% 50%;
}

.slide3{
	background-image: url(../img/back3.jpg);
	background-position: 50% 100%;
}

/*トップページコンテンツ*/
#index_copy{
	height:100vh;
	position: relative;
}

.copy_inside{
	position: absolute;
	top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    -webkit-transform: translate(-50%, -50%);
    -ms-transform: translate(-50%, -50%);
	text-align: center;
	width: 90%;
}

.copy_inside p{
	font-size: 36px;
	color: white;
	font-family: "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", serif;
	text-shadow: 1px 2px 3px #000000;
}

#index_copy img{
	max-width: 500px;
	width: 100%;
	height: auto;
}

#mission h2{
	font-size: 24px;
}

#mission h2 span{
	font-size: 20px;
}
 
.back_b{
	background-color: white;
	padding: 50px;
	margin: 30px auto;
	width: 100%;
	max-width:580px;
	font-size: 18px;
	position: relative;
}

.back_inside{
	position: relative;
}

.back_inside img{
	position: absolute;
	top: -100%;
	left: 50%;
	transform: translateX(-50%);
}

#top_work_link{
	font-size: 0;
}

#top_work_link img{
	width:100%;
	opacity: 0.6;
	transition-duration: 0.3s;
	z-index: 1;
}

#top_work_link>div{
	max-width:300px;
	width: 100%;
	margin-bottom: 15px;
	background-color: black;
	overflow: hidden;
	position: relative;
}

#top_work_link a:hover img{
	opacity: 1;
	transform: scale(1.2);
	transition-duration: 0.3s;
	overflow: hidden;
}

#top_work_link p{
	position: absolute;
	color: white;
	font-size: 24px;
	z-index: 2;
	font-family: "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", serif;
	-ms-writing-mode: tb-rl;
	writing-mode: vertical-rl;
	top: 50%;
	left: 5%;
	transform: translateY(-50%);
	height: fit-content;
	text-shadow: 1px 2px 3px #000000;
	letter-spacing: 0.5rem;
	white-space: nowrap;
}

.chatchPhrase{
	background-color: #14345E !important;
}

.chatchPhrase p{
	left: 50% !important;
	transform: translate(-50%, -50%) !important;
	writing-mode: lr-tb !important;
	-ms-writing-mode: lr-tb !important;
	font-size: 1.4rem !important;
	letter-spacing: 0 !important;
	width: fit-content !important;
}

.arrow {
    display: block;
    width: 100%;
    height: 1px;
    background-color: #B59800;
    position: relative;
    transform: scale(1, 1);
    transform-origin: top left;
    margin:0 auto 10px auto;
}

.arrow::after {
    content: "";
    display: block;
    width: 0;
    height: 0;
    border-style: solid;
    border-width: 6px 0 0 12px;
    border-color: transparent transparent transparent #B59800;
    position: absolute;
    bottom: 0.8px;
    right: 0.5px;
}

.chatchPhrase2{
	background-color: #B59800 !important;
}

.chatchPhrase2 p{
	left: 50% !important;
	transform: translate(-50%, -50%) !important;
	writing-mode: lr-tb !important;
	-ms-writing-mode: lr-tb !important;
	font-size: 1.4rem !important;
	letter-spacing: 0 !important;
	width: fit-content !important;
}

.arrow2 {
    display: block;
    width: 100%;
    height: 1px;
    background-color: #14345E;
    position: relative;
    transform: scale(1, 1);
    transform-origin: top left;
    margin:0 auto 10px auto;
}

.arrow2::after {
    content: "";
    display: block;
    width: 0;
    height: 0;
    border-style: solid;
    border-width:  0 0 6px 12px;
    border-color: transparent transparent #14345E transparent;
    position: absolute;
    bottom: 0.8px;
}

/*トップページ会社情報*/
#intro{
	background-color: #EEF4F6;
	border-top: 10px solid #78C0FF;
	padding-bottom: 40px;
}

h2{
	text-align: center;
	margin-bottom: 24px;
}

.back_w{
	padding: 25px 25px 10px 25px;
	background-color: #fff;
	border-radius: 15px; 
	margin-bottom: 30px;
}

#greeting p{
	margin-bottom: 10px;
}

.philosophy{
	background-color: #14345E;
	color: white;
}

#fleet{
	background-color: white;
	padding: 40px 0;
}

#mainImg{
	max-width: 600px;
	width: 100%;
	max-height: 400px;
	height: 100%;
	margin: 0 auto;
	overflow: hidden;
}

#mainImg img{
	width: 100%;
	height: auto;
	object-fit: cover;
}

#subImg{
	display: flex;
	margin: 10px auto 0 auto;
	justify-content:space-between;
    padding:0;
	max-width: 600px;
	width: 100%;
	cursor: pointer;
}

#subImg li{
	margin-right: 10px;
	width: 33.33%;
}

#subImg li:last-child {
	margin-right: 0;
}

#subImg li img{
	width: 100%;
	object-fit: cover;
}

#company{
	background-color: #EEF4F6;
	padding: 40px 0;
}

#company_table{
	max-width:500px;
	width: 100%;
	margin: 0 auto 50px auto;
}

#company_table th{
	width:120px;
	background-color: #E6E6E6;
}

#company_table tr:first-of-type th{
	border-top: 7px solid #3881E1;
}

#company_table tr:first-of-type td{
	border-top: 7px solid #bbb;
}

#company_table td .ib{
	margin-right: 15px;	
}

#map{
	width: 100%;
}

#initmap{
	width:100%;
	height: 460px;
	border: 1px solid #bbb;
	box-sizing: border-box;
}

.works_table thead th{
	background-color: #3881E1;
    color: #fff;
    font-weight: bold;
}

.works_table tbody th{
	background-color: #E6E6E6;
}

.works_table tbody td{
	min-width: 150px;
}

#index_link{
	margin-top: 40px;
	padding-bottom: 40px;
	display: flex;
}

#index_link a{
	width: 40%;
	margin: 5%;
	font-size: 36px;
	font-weight: bold;
	color: white;
	text-align: center;
	padding: 20px;
}

#index_link a:hover{
	opacity: 0.6;
}

.works_link{
	background-color: #B59800;
}

.recruit_link{
	background-color: #0080B2;
}

/*コンテンツページ共通*/

.sp{
	display: none;
}
.contents_head{
	height:260px;
	background-size: cover;
	display: block;
	border-bottom: 10px solid #78C0FF;
}

.contents_head h1{
	text-align: center;
	margin-top: 80px;
	font-size: 28px;
	color:#fff;
	text-shadow: 0px 3px 6px rgba(0,0,0,0.6);
}

.contents_main{
	margin-top: 20px;
}

.contents_main h2{
	text-align:center;
	font-size: 26px;
	margin-bottom: 15px;
}

.contents_main h2:after{
	content: "";
	display: block;
	width:50px;
	height: 3px;
	margin:5px auto;
	background-color: #6AB2E1;
}

.contents_main h3{
	font-size: 22px;
	color: #063A7D;
	border-bottom: 2px solid #063A7D;
	margin: 15px 0 10px 0;
}

.tel{
	cursor: default;
}

/*事業内容*/
#works_head{
	background-image: url(../img/works_head.jpg);
	background-position:50% 75%;
}

#works_main{
	margin-top: 0;	
}

.works_child{
	padding: 40px 0;
}

.works_child:nth-of-type(2n){
	background-color: #EEF4F6
}

.works_child:last-of-type{
	padding-bottom: 40px;
}

.works_child .flex_around>div{
	width: 48%;
	max-width: 430px;
}

.works_child span{
	font-size: 18px;
	color: #104981;
}


.works_child a{
	pointer-events: all;
}

.works_child img{
	max-width: 430px;
	width: 100%;
	margin-bottom: 10px;
}

/*採用情報*/

#recruit_head{
	background-image: url(../img/recruit_head.jpg);
	background-position:center;
}

#recruit_catch{
	height: 180px;
	margin: 30px 0;
	background-image: url(../img/recruit_catch.jpg);
	background-size: cover;
	background-position: 50% 70%;
	-webkit-box-pack: center;/*--- Androidブラウザ用 ---*/
	-ms-flex-pack: center;/*--- IE10 ---*/
	-webkit-justify-content: center;/*--- safari（PC）用 ---*/
	justify-content: center;
}

#recruit_catch img{
	max-width: 580px;
	width: 95%;
}

#recruit_main .table_style th{
	width:100px;
	background-color: #E6E6E6;
}

.recruit_tbl .th,
.recruit_tbl .td{
	border:1px solid #054497;
	margin-bottom: 20px;
	box-sizing: border-box;
	min-height: 110px;
}

.recruit_tbl .th{
	color: #fff;
	background-color: #054497;
	width: 180px;
	font-size: 24px;
	padding-left: 20px;
	font-weight: bold;
	position: relative;
	
}

.recruit_tbl .th:after{
	content:"";
	position: absolute;
	display: block;
	top:0;
	bottom:0;
	margin: auto;
	right:-35px;
	width: 0;
	height: 0;
	border-style: solid;
	border-width: 40px 0 40px 35px;
	border-color: transparent transparent transparent #054497;
}

.recruit_tbl .td{
	width: calc(100% - 180px);
	padding-left: 45px;
}

.recruit_tbl .td img{
	margin: 10px;
	height: auto;
}

.recruit_tbl .td strong{
	font-size:22px;
	line-height: 1.4;
}

.recruit_tbl .td span{
	width: 100%;
	font-size: 18px;
	line-height: 1.3;
	color: #602215;
	font-weight: bold;
}

.recruit_tbl .td span:first-of-type{
	margin-top: 1em;
}

.recruit_tbl .td p{
	width: 100%;
	font-size: 18px;
	margin-bottom: 1em;
	line-height: 1.3;
}

.recruit_tbl strong b{
	font-weight: normal;
	font-size: 28px;
	font-weight: bold;
}

#app{
	margin: 20px 0;
}

#app div,
#app>a{
	width:50%;
	text-align: center;
}

#app strong{
	font-size:40px;
	font-weight: normal;
}


#app>a{
	/*background-image: url(../img/お問い合わせリンク.png);
	background-size: cover;
	background-position: right;
	min-height: 100px;
	transition: .3s opacity;*/
	width: 40%;
	margin: 5%;
	font-size: 36px;
	font-weight: bold;
	color: white;
	text-align: center;
	padding: 20px;
	background-color: #14345E;
}


.hover #app>a:hover{
	opacity: 0.75;
}

.benefits{
	margin: 50px auto;
}

.benefits>.w950{
	width: 100% !important;
}

.benefit_first,
.benefit_second{
	position: relative;
	display: flex;
	margin: 40px auto;
}

.benefit_first>.benefit_img{
	max-width: 400px;
	width: 100%;
	margin-bottom: 100px;
	position: relative;
	z-index: 11;
}

.benefits img{
	width: 100%;
}

.benefit_first>.benefit_text{
	position: absolute;
	bottom: 0;
	left: 40%;
	background-color: #EEF4F6;
	padding: 30px 30px 30px 125px;
	max-width: 500px;
	width: 100%;
	z-index: 10;
}

.benefit_first>.benefit_img{
	max-width: 400px;
	width: 100%;
	margin-bottom: 100px;
	position: relative;
	z-index: 11;
}

.benefit_second>.benefit_text{
	position: absolute;
	bottom: 0;
	right: 40%;
	background-color: #EEF4F6;
	padding: 30px 125px 30px 30px;
	max-width: 500px;
	width: 100%;
	z-index: 10;
}

.benefit_second>.benefit_img{
	max-width: 400px;
	width: 100%;
	margin-left: auto;
	margin-bottom: 100px;
	position: relative;
	z-index: 11;
}


/*お問い合わせ*/
#contact_head{
	background-image: url(../img/contact_head.jpg);
	background-position:50% 70%;
	margin-bottom: 40px;
}

#contact_tel{
	padding: 30px 0;
	text-align: center;
	background-color: #EEF4F6;
}

#contact_tel strong{
	font-size: 38px;
	vertical-align: middle;
}

#contact_tel span{
	font-size: 18px;
	margin-left: 1em;
}

.formTable{
	margin: 15px auto;
}

.formTable th{
	padding: 10px;
	line-height: 1;
}

.formTable th{
	background-color: #054497;
	color:#fff;
	border: 1px solid #162D8A;
	width: 251px;
}

.formTable select{
	height:30px;
}

.must:after{
	content:"必須";
	background-color: #e00;
	margin-left: 10px;
	font-size: 0.9em;
	padding:2px 5px;
	border-radius: 5px;
}

.form_btn{
	margin:10px auto 20px auto;
	text-align: center;
}

.form_btn button{
	display: inline-block;
	border-radius: 5px;
	color: #fff;
	background-color: #4E8FE5;
	border: none;
	font-size: 20px;
	padding: 10px;
	width: 120px;
	cursor: pointer;
	box-sizing: border-box;
	border: 2px solid #4E8FE5;
	transition: .3s;
	text-align: center;
}

.form_btn input{
	display: inline-block;
	border-radius: 5px;
	color: #fff;
	background-color: #4E8FE5;
	border: none;
	font-size: 20px;
	padding: 10px;
	width: 120px;
	cursor: pointer;
	box-sizing: border-box;
	border: 2px solid #4E8FE5;
	transition: .3s;
	text-align: center;
}

.hover .form_btn button:hover{
	background-color: #fff;
	color: #4E8FE5;
}

#form2{
}

.estimate{
	display: none;
}

/*会社概要*/

#company_head{
	background-image: url(../img/company_head.png);
	background-position:center;
}

.greeting{
	position: relative;
	width: 100%;
	background: url("../img/company_back.png")
	  center / cover;
}

.greeting_back{
    background-color: rgba(0, 0, 0, 0.3);
    display: flex;
    justify-content: center;
    align-items: center;
	padding: 100px 0;
}

.greeting_inner{
	background-color: rgba(252, 252, 252, 0.9);
	border-radius: 20px;
	padding: 50px;
	width: 50%;
}

.name{
	margin-top: 20px;
	text-align: right;
}

.company_child{
	padding-top: 40px;
}

.philosophy_img,
.philosophy_txt{
	width: 50%;
	position: relative;
}

.philosophy_img{
    font-size: 0;
    position: relative;
    overflow: hidden;
	margin: 0 0 50px 0;
}

.philosophy_img img{
	object-fit: cover;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translateX(-50%) translateY(-50%);
    width: 100%;
}

.philosophy_txt{
	padding: 50px;
	max-width: 500px;
    width: 100%;
	height: fit-content;
	-webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
}

.philosophy_block{
	margin-bottom: 20px;
}

.philosophy_inside{
	display: inline-block;
    text-align: center;
}

.philosophy_inside span{
	color: #6AB2E1;
	font-size: 12px;
	margin-right: auto;
	width: 100%;
	font-family: 'Baskerville Old Face','Times New Roman', 'Noto Serif JP', serif;
}

.philosophy_title{
	width: auto;
	font-size: 28px;
	font-weight: bold;
	margin-bottom: 10px;
}

/*エラーページ*/
#error_head{
	height: 70px;
	border: none;
}

/*フッター*/

#footer {
	position: relative;
	background-color: #343434;
	color: #fff;
}

#foot_info{
	margin: 25px 0;
}

#foot_info img {
	max-width: 300px;
	width:80%;
}

#foot_info p{
	line-height: 1.3;
}

#foot_list{
	margin-top: 40px;
}

#foot_list ul,
#foot_list a{
	display: inline-block;
	vertical-align: top;
}

#foot_list li {
	margin-right: 30px;
	display: inline-block;
	color: #fff;
}
#foot_list li a {
	color: #fff;
}
#foot_list li:last-of-type {
	margin: 0;
}

#copyright{
	background-color: #054497;
	text-align: center;
	padding: 10px 0;
}

.sns_icon{
	position: fixed;
	top: 50%;
	transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
	right: 0;
	background-color: #054497;
	padding: 10px;
	z-index: 999;
}

.sns_icon p{
	color: white;
	font-weight: bold;
	-ms-writing-mode: tb-rl;
	writing-mode: vertical-rl;
	margin: 0 auto;
	padding: 15px 0;
}

.sns_iconSP{
	display: none;
}

.mail{
	margin-bottom: 10px;
}

.line img{
	max-width: 40px;
	width: 100%;
}