﻿@charset "utf-8";

/* ------------------------------------------------------
   base
------------------------------------------------------ */
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, 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,
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-size: 100%;
	vertical-align: baseline;
}

/* HTML5 display-role reset for older browsers 
------------------------------------------------------------------*/
article, aside, details, figcaption, figure, 
footer, header, hgroup, menu, nav, section {
	display: block;
}
body {
	line-height: 1;
}
ol, ul {
	list-style: none;
}
blockquote, q {
	quotes: none;
}
blockquote:before, blockquote:after,
q:before, q:after {
	content: '';
	content: none;
}
table {
	border-collapse: collapse;
	border-spacing: 0;
}

/* parts 
------------------------------------------------------------------*/
/* Margin-top of ** line */
.mt1l {margin-top: 14px !important;}
.mt2l {margin-top: 28px !important;}
.mt3l {margin-top: 42px !important;}
/* Margin-top */
.mt0 {margin-top: 0 !important;}
.mt5 {margin-top: 5px !important;}
.mt8 {margin-top: 8px !important;}
.mt10 {margin-top: 10px !important;}
.mt15 {margin-top: 15px !important;}
.mt17 {margin-top: 17px !important;}
.mt20 {margin-top: 20px !important;}
.mt25 {margin-top: 25px !important;}
.mt30 {margin-top: 30px !important;}
.mt35 {margin-top: 35px !important;}
.mt40 {margin-top: 40px !important;}
.mt45 {margin-top: 45px !important;}
.mt50 {margin-top: 50px !important;}
.mt80 {margin-top: 80px !important;}
/* Margin-bottom */
.mb0 {margin-bottom: 0 !important;}
.mb5 {margin-bottom: 5px !important;}
.mb10 {margin-bottom: 10px !important;}
.mb15 {margin-bottom: 15px !important;}
.mb20 {margin-bottom: 20px !important;}
.mb25 {margin-bottom: 25px !important;}
.mb30 {margin-bottom: 30px !important;}
.mb35 {margin-bottom: 35px !important;}
.mb40 {margin-bottom: 40px !important;}
.mb45 {margin-bottom: 45px !important;}
.mb50 {margin-bottom: 50px !important;}
/* Margin-left */
.ml0 {margin-left: 0 !important;}
.ml5 {margin-left: 5px !important;}
.ml10 {margin-left: 10px !important;}
.ml15 {margin-left: 15px !important;}
.ml20 {margin-left: 20px !important;}
.ml25 {margin-left: 25px !important;}
.ml30 {margin-left: 30px !important;}
.ml35 {margin-left: 35px !important;}
.ml40 {margin-left: 40px !important;}
.ml45 {margin-left: 45px !important;}
.ml50 {margin-left: 50px !important;}
/* Margin-right */
.mr0 {margin-right: 0 !important;}
.mr5 {margin-right: 5px !important;}
.mr10 {margin-right: 10px !important;}
.mr15 {margin-right: 15px !important;}
.mr20 {margin-right: 20px !important;}
.mr25 {margin-right: 25px !important;}
.mr30 {margin-right: 30px !important;}
.mr35 {margin-right: 35px !important;}
.mr40 {margin-right: 40px !important;}
.mr45 {margin-right: 45px !important;}
.mr50 {margin-right: 50px !important;}
/* Padding-top */
.pt0 {padding-top: 0 !important;}
.pt5 {padding-top: 5px !important;}
.pt10 {padding-top: 10px !important;}
.pt15 {padding-top: 15px !important;}
.pt20 {padding-top: 20px !important;}
.pt25 {padding-top: 25px !important;}
.pt30 {padding-top: 30px !important;}
.pt35 {padding-top: 35px !important;}
.pt40 {padding-top: 40px !important;}
.pt45 {padding-top: 45px !important;}
.pt50 {padding-top: 50px !important;}
/* Padding-bottom */
.pb0 {padding-bottom: 0 !important;}
.pb5 {padding-bottom: 5px !important;}
.pb10 {padding-bottom: 10px !important;}
.pb15 {padding-bottom: 15px !important;}
.pb20 {padding-bottom: 20px !important;}
.pb25 {padding-bottom: 25px !important;}
.pb30 {padding-bottom: 30px !important;}
.pb35 {padding-bottom: 35px !important;}
.pb40 {padding-bottom: 40px !important;}
.pb45 {padding-bottom: 45px !important;}
.pb50 {padding-bottom: 50px !important;}
/* Padding-left */
.pl0 {padding-left: 0 !important;}
.pl5 {padding-left: 5px !important;}
.pl10 {padding-left: 10px !important;}
.pl15 {padding-left: 15px !important;}
.pl20 {padding-left: 20px !important;}
.pl25 {padding-left: 25px !important;}
.pl30 {padding-left: 30px !important;}
.pl35 {padding-left: 35px !important;}
.pl40 {padding-left: 40px !important;}
.pl45 {padding-left: 45px !important;}
.pl50 {padding-left: 50px !important;}
/* Padding-right */
.pr0 {padding-right: 0 !important;}
.pr5 {padding-right: 5px !important;}
.pr10 {padding-right: 10px !important;}
.pr15 {padding-right: 15px !important;}
.pr20 {padding-right: 20px !important;}
.pr25 {padding-right: 25px !important;}
.pr30 {padding-right: 30px !important;}
.pr35 {padding-right: 35px !important;}
.pr40 {padding-right: 40px !important;}
.pr45 {padding-right: 45px !important;}
.pr50 {padding-right: 50px !important;}
/* Padding */
.pd0 {padding: 0 !important;}
.pd1 {padding: 1px !important;}
.pd2 {padding: 2px !important;}
.pd3 {padding: 3px !important;}
.pd4 {padding: 4px !important;}
.pd5 {padding: 5px !important;}
.pd6 {padding: 6px !important;}
.pd7 {padding: 7px !important;}
.pd8 {padding: 8px !important;}
.pd9 {padding: 9px !important;}
.pd10 {padding: 10px !important;}
.pd15 {padding: 15px !important;}
.pd20 {padding: 20px !important;}
/* text-align */
.aL {text-align: left !important;}
.aC {text-align: center !important;}
.aR {text-align: right !important;}
/* vertical-align */
.vT {vertical-align: text-top !important;}
.vB {vertical-align: text-bottom !important;}
.vM {vertical-align: middle !important;}
/* text */
.txL {font-size: 14px !important; font-size: 1.4rem !important;}
.txS {font-size: 10px !important; font-size: 1.0rem !important; font-weight: normal!important;}
.txBold {font-weight: bold !important;}

/* Width */
.w5 {width: 5px !important;}
.w10 {width: 10px !important;}
.w15 {width: 15px !important;}
.w20 {width: 20px !important;}
.w25 {width: 25px !important;}
.w30 {width: 30px !important;}
.w35 {width: 35px !important;}
.w40 {width: 40px !important;}
.w45 {width: 45px !important;}
.w50 {width: 50px !important;}
.w55 {width: 55px !important;}
.w60 {width: 60px !important;}
.w65 {width: 65px !important;}
.w70 {width: 70px !important;}
.w75 {width: 75px !important;}
.w80 {width: 80px !important;}
.w85 {width: 85px !important;}
.w90 {width: 90px !important;}
.w95 {width: 95px !important;}
.w100 {width: 100px !important;}
.w110 {width: 110px !important;}
.w120 {width: 120px !important;}
.w125 {width: 125px !important;}
.w130 {width: 130px !important;}
.w135 {width: 135px !important;}
.w140 {width: 140px !important;}
.w150 {width: 150px !important;}
.w155 {width: 155px !important;}
.w160 {width: 160px !important;}
.w180 {width: 180px !important;}
.w200 {width: 200px !important;}
.w205 {width: 205px !important;}
.w210 {width: 210px !important;}
.w220 {width: 220px !important;}
.w230 {width: 230px !important;}
.w250 {width: 250px !important;}
.w260 {width: 260px !important;}
.w270 {width: 270px !important;}
.w280 {width: 280px !important;}
.w290 {width: 290px !important;}
.w300 {width: 300px !important;}
.w320 {width: 320px !important;}
.w350 {width: 350px !important;}
.w380 {width: 380px !important;}
.w400 {width: 400px !important;}
.w450 {width: 450px !important;}
.w500 {width: 500px !important;}
.w510 {width: 510px !important;}
.w550 {width: 550px !important;}
.w580 {width: 580px !important;}
.w600 {width: 600px !important;}
.w602 {width: 602px !important;}
.w620 {width: 620px !important;}
.w630 {width: 630px !important;}
.w700 {width: 700px !important;}
.w730 {width: 730px !important;}

/* ------------------------------------------------------
   common
------------------------------------------------------ */
.pc{ display:block}
.sp{  display: none!important;}
.pc-i{
	display:inline!important;
}
.sp-i{
	display:none!important;
}
html {
	overflow-y: scroll;
	-webkit-text-size-adjust: 100%;
	-ms-text-size-adjust: 100%;
	min-height: 100%;
	position: relative;
}
html.stop {
	overflow: hidden;
}
body {
	min-width: 320px;
	font-size: 15px;
	line-height: 1.8;
	color: #282828;
    font-family: "Hiragino Kaku Gothic ProN","メイリオ", sans-serif;
}
h1,h2,h3{
	font-family:  "Original Yu Gothic", "Yu Gothic", YuGothic, Verdana, Meiryo, "M+ 1p", sans-serif;
    font-weight:500;
}
a,a:before,a:after{
	-webkit-transition: all 0.5s ease;
	-moz-transition: all 0.5s ease;
	-o-transition: all 0.5s ease;
	transition: all  0.5s ease;
}
a:link {
	color: #282828;
	text-decoration: none;
	outline: none;
}
a:visited {
	color: #282828;
	text-decoration: none;
}
a:hover {
	color: #999c9f;
	text-decoration: none;
}
a:active {
	color: #282828;
	text-decoration: none;
}
/* other setting */
hr {display: none;}

sub, sup {
	position: relative;
	line-height: 0;
	font-size: 10px;
}
sup {top: 0em;}
sub {bottom: 0.3em; font-size: 0.4em;}
span img{ display: block;}
.small{ font-size: 12px; display: block;}
.underBold{ font-size: 22px; text-decoration: underline;}
.underLine{ text-decoration: underline;}
input{
	outline:none;
}

/* Float */
.floatL { float: left !important;}
.floatR { float: right !important;}
.noFloat { overflow: hidden !important;}
.readBlock {
	display: none;
}

::selection {
	background: #23a9db;
	color: #fff; 
}
::-moz-selection {
	background: #23a9db;
	color: #fff;
}

figure img{
	width: 100%;
	height: auto;
}

/*404*/
.top .main h1.-error404::after {
	width: 100%;
}
.intro404 {
	background: #fff;
	padding: 20px;
	border: 2px solid #000;
	border-radius: 5px;
	display: flex;
	justify-content: center;
	
	flex-wrap: wrap;
}
.intro404 p {
	width: 100%;
	margin-bottom: 30px;
	text-align: center;
	line-height: 1.4;
}
@media screen and (max-width: 767px) {
	.intro404 {
		padding: 15px 20px;
	}
	.intro404 p {
		text-align: left;
		margin-bottom: 20px;
	}
}
a.btn-black-area{
	display: block;
	height: 50px;
	box-sizing: border-box;
	background: #282828;
	border: 1px solid #282828;
	color: #fff;
	text-align: center;
	line-height: 50px;
	width: 100%;
}
a.btn-black-area.-mw400 {
	max-width: 400px;
}
a.btn-black-area span {
	padding-right: 26px;
	background: url(/parts/img/arrow_white.png) center right /6px 10px no-repeat;
}
a.btn-black-area:hover {
	background: #fff;
	border: 1px solid #ca3738;
	color: #ca3738;
}
a.btn-black-area:hover span {
	background-image: url(/parts/img/arrow_red.png);
}

a.bnr-area{
    margin-top:60px;
    display: block;
}
a.bnr-area img{
    width:100%;
}
a.bnr-area:hover img{
    opacity: 0.5 ;
    transition: 0.3s ease;
}
/* ------------------------------------------------------
   clearfix
------------------------------------------------------ */
.clearfix:after{
	content: "";
	display: block;
	clear: both;
}

.clearfix{
	zoom: 1;
}


@font-face {
  font-family: "Yu Gothic";
  src: local("Yu Gothic Medium");
  font-weight: 100;
}
@font-face {
  font-family: "Yu Gothic";
  src: local("Yu Gothic Medium");
  font-weight: 200;
}
@font-face {
  font-family: "Yu Gothic";
  src: local("Yu Gothic Medium");
  font-weight: 300;
}
@font-face {
  font-family: "Yu Gothic";
  src: local("Yu Gothic Medium");
  font-weight: 400;
}
@font-face {
  font-family: "Yu Gothic";
  src: local("Yu Gothic Bold");
  font-weight: bold;
}

/* ------------------------------------------------------
   header
------------------------------------------------------ */
.head-wrap {
	box-sizing: border-box;
	max-width: 1300px;
	height: 105px;
	margin: 0 auto;
	padding-top: 15px;
	position: relative;
	font-size: 15px;
	font-family:  "Original Yu Gothic", "Yu Gothic", YuGothic, Verdana, Meiryo, "M+ 1p", sans-serif;
	font-weight: bold;
}
.logo{
	width: 150px;
    display: block;
}
.logo{
    line-height: 1;
}
.logo img {
	width: 100%;
	height: auto;
}
.seo-text{
    font-size: 12px;
    font-weight: 300;
    margin-bottom:10px;
}

.nav-wrap {
	position: absolute;
	top: 51px;
    right: 230px;
}
.g-nav {
	display: flex;
}
.g-nav a {
	display: block;
}
.g-nav > li + li {
	margin-left: 40px;
}
.g-nav > li > a {
	padding-bottom: 6px;
	position: relative;
    letter-spacing: .02em;
}
.g-nav > li > a::after {
	content: '';
	display: block;
	width: 0;
	height: 2px;
	background: #282828;
	position: absolute;
	left: 0;
	bottom: 0;
	transition: width 0.3s ease;
}
.g-nav > li > a:hover::after {
	width: 100%;
	transition: width 0.3s ease;
}
#top .g-nav > li:nth-child(1) > a::after,
#about .g-nav > li:nth-child(2) > a::after,
#service .g-nav > li:nth-child(3) > a::after,
#work .g-nav > li:nth-child(4) > a::after,
#media .g-nav > li:nth-child(5) > a::after,
#company .g-nav > li:nth-child(6) > a::after{
	width: 100%;
}
.lower {
	display: none;
}
.contact-btn .pc {
	display: block;
	width: 190px;
	height: 48px;
	background: #ca3738;
	/* border-radius: 24px; */
	color: #fff;
	text-align: center;
	line-height: 48px;
	position: absolute;
	top: 41px;
	right: 0;
	transition: background 0.3s ease;
}
.contact-btn .pc span {
	padding: 2px 0 2px 40px;
	background: url(/parts/img/ico_foot_contact_white.png) left center /24px 23px no-repeat;
}
.contact-btn:hover .pc {
	background: #282828;
	transition: 0.3s ease;
}

/* ------------------------------------------------------
   wrap
------------------------------------------------------ */
.contents{
	overflow: hidden;
}
.bg-gray,.bg-white{
	width: 100%;
}
.bg-gray{
	background: #f8f8f8;
}
.bg-white{
	background: #fff;
}
.cont{
	/* max-width: 1300px; */
	margin: auto;
}
.wrap{
	max-width: 1080px;
	margin: auto;
	position: relative;
}
.cont .wrap{
	display:-webkit-flex;/*--- safari（PC）用 ---*/
display: flex;
}
.wrap ul.pankuzu{
	overflow: hidden;
	padding: 30px 0 35px 0;
}
.wrap ul.pankuzu li{
	display: inline-block;
	color: #282828;
	padding-right: 5px;
}
.wrap ul.pankuzu li:after{
	display: inline-block;
	content: '';
	background: url(/parts/img/arrow_gray.png) no-repeat;
	width: 6px;
	height: 10px;
	background-size: 100%;
	margin-left: 10px;
}
.wrap ul.pankuzu li a{
	font-size: 12px;
	border-bottom: 1px solid #7e7f81;
	color: #7e7f81;
}
.wrap ul.pankuzu li:last-child{
	padding-right: 0;
}
.wrap ul.pankuzu li:last-child:after{
	display: none;
}
.wrap ul.pankuzu li:hover a{
	color: #282828;
	border-bottom: 1px solid #282828;
}
.wrap ul.pankuzu li:hover:after{
	content: '';
	background: url(/parts/img/arrow_gray.png) no-repeat;
	width: 6px;
	height: 10px;
	background-size: 100%;
}

/* ------------------------------------------------------
   main
------------------------------------------------------ */
.main{
	width: 825px;
	float: left;
	counter-reset: num;
	position: relative;
	padding: 60px 0 35px 0; 
}
.main.single-column {
	max-width: 100%;
	width: 100%;
}
.main div.head-img:not(.-message) {
	position: relative;
	left: -110px;
	width: calc(100% + 110px);
	height: 173px;
	@media(max-width:1080px) {
		left: 0;
		width: 100%;
	}
}
.main div.head-img img{
	width: 100%;
	height: 100%;
}
.main h1 span{
	background: #f8f8f8;
	z-index: 2;
	position: relative;
}
.main h1 span.t-yellow{
	color: #f1bd40;
}
.main h1 span+span{
	padding-right: 40px;    
}
.main h1{
	font-size: 50px;
	text-align: left;
	text-shadow: #282828 1px 1px 0px, #282828 -1px 1px 0px,
			 #282828 1px -1px 0px, #282828 -1px -1px 0px;
	color: #fff;
	line-height: 1.2;
	position: relative;
	letter-spacing:.1em;
}
.main h1:after{
	content: '';
	display: block;
	width: 100%;
	height: 2px;
	background: url(/parts/img/line_horizontal.png) repeat-x;
	background-size: 6px 2px;
	top: 24px;
	position: absolute;
}
.top .main h1::after,
#work.single .main h1::after {
	width: 200%;
}
.main h2.title-line,
.main h3.title-line {
	font-size: 28px;
	border-bottom: dotted 2px #282828;
	position: relative;
	margin: 0 0 1em 0;
	font-weight: 500;
	line-height: 1.4;
	padding-bottom: 14px;
	*+& {
		margin-top: 4em;
	}

	.-yellow {
		color: #e48c10;
		font-weight: bold;
	}
}
.main h2.num, .main h3.num {
	padding-left: 54px;
}
.main section h3.title-line:first-child{
	margin-top: 0;
}
.main h2.title-line:after,.main h3.title-line:after{
	position: absolute;
	content: " ";
	display: block;
	border-bottom: solid 2px #f1bd40;
	bottom: -2px;
	left: 0;
	width: 50px;
}
.main h2.title-ico,.main h3.title-ico{
	font-size: 20px;
	font-weight: bold;
	margin-bottom: 25px;
	padding: 5px 0 0 35px;
	position: relative;
	line-height: 1.4;
	*+&{
		margin-top: 65px;
	}
}

.main h2.title-ico .-smaller {
	font-size: 0.8em;
}
.main p.sub-title + h2.title-ico,.main p.sub-title + h3.title-ico{
	margin-top: 0;
}
.main h2.title-ico span.main-title,.main h3.title-ico span.main-title{
	/* padding-left: 35px; */
}
.main p.sub-title{
	display: block;
	font-size: 14px;
	font-weight: normal;
	margin-bottom: 0;
}
.main p.sub-title:before{
	content: '[';
	display: inline-block;
	margin-right: 10px;
}
.main p.sub-title:after{
	content: ']';
	display: inline-block;
	margin-left: 15px;
}
.main h2.title-ico:before,.main h3.title-ico:before{
	display: inline-block;
	position: absolute;
	left: 0;
	bottom: 10px;
	content: '';
	background: url(/parts/img/ico_h3_01.png) no-repeat;
	width: 20px;
	height: 20px;
	background-size: 100%;
	margin-right: 15px;
	top: 8px;
}
.main h3.num:before{
	counter-increment: num;
	content: "0" counter(num) ". ";
	color: #f1bd40;
	display: inline-block;
	padding: 0px 7px;
	width: 40px;
	position: absolute;
	top: 0;
	left: 0;
}
.main  {
	> section {
		margin-top: 8em;
		> section, > div {
			margin-top: 4em;
		}
	}
	> .head-img + section {
		margin-top: 4em;
	}
}
.main > .full-list + section{
	margin-top: 110px;
}
/*
.main p{
	margin-bottom: 45px;
}
.main section p{
	margin-bottom: 45px;
}
*/
.main figure.img-full {
	margin-top: 45px;
}
.main figure + p{
	margin-top: 35px;
}
.main .txt-harf {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 1.6em;
	justify-content: space-between;
	flex-wrap: wrap;
	margin-top: 45px;
	@media (max-width:767px) {
		grid-template-columns: auto;
		gap: 1em;
	}
}
.main .txt-harf > li{
	background: #fff;
	padding: 2em 1.8em;
	overflow: hidden;
	border-radius: 5px;
}
.main .txt-harf > li h4{
	font-size: 17px;
	margin-bottom: 25px;
	padding-bottom: 15px;
	font-weight: bold;
	color: #f1bd40;
	border-bottom: 1px dotted #d8d8d8;
}
.main .txt-harf > li p{
	margin-bottom: 0;
}
.main figure.img-full img{
	width: 100%;
	height: auto;
	border-radius: 5px;
	display: block;
}
.main ul.full-list{
	border-radius: 5px;
	padding: 4px 15px;
	background: #fff;
}
.main ul.full-list li{
	display: block;
	background: #fff;
	border-bottom: 1px dotted #999c9f;
	position: relative;
}
.main ul.full-list li a{
	display: block;
	padding: 15px 30px;
	font-size: 16px;
	position: relative;
}
.main ul.full-list li a span {
	height: 28px;
	position: absolute;
	top: 0;
	left: 0;
	bottom: 0;
	margin: auto;
}
.main ul.full-list li:last-child{
	border: none;
}
.main ul.full-list li a:after{
	content: '';
	background: url(/parts/img/arrow_list_red.png) no-repeat;
	width: 14px;
	height: 12px;
	background-size: 100%;
	display: block;
	position: absolute;
	right: 5px;
	top: 0;
	bottom: 0;
	margin: auto;
}
.main ul.full-list li a:hover{
	color: #ca3738;
}
.main ul.full-list li a:hover:after{
	background: url(/parts/img/arrow_list_black.png) no-repeat;
	width: 14px;
	height: 12px;
	background-size: 100%;
}
/* ------------------------------------------------------
   side
------------------------------------------------------ */
aside{
	max-width: 255px;
	float: right;
	padding: 48px 0 0 75px;
}
aside.side:before {
	content: '';
	width: 2px;
	height: 10000px;
	display: block;
	position: absolute;
	background: #f8f8f8;
	right: 227px;
	z-index: 1;
	top: -9863px;
}
aside img.line-top,aside img.line-bottom{
	display: none;
}
aside img.line-top.scroll{
	display: block;
	position: absolute;
	right: 228px;
	width: 24px;
	height: 27px;
	top: 110px;
}
aside img.line-bottom.scroll{
	display: block;
	position: absolute;
	right: 205px;
	width: 24px;
	height: 27px;
	top: 13px;
}
aside .side-nav{
	width: 180px;
	float: right;
	position: relative;
}
aside .side-nav.border:before{
	content: '';
	position: absolute;
	width: 70px;
	height: 2px;
	left: -71px;
	top: 36px;
	margin: 0 3px 0 0;
	background: url(/parts/img/line_horizontal.png) repeat-x;
	background-size: contain;
}
aside .side-nav.n-margin{
	margin-top: -150px;
}
aside .side-nav:after {
	content: '';
	position: absolute;
	background: url(/parts/img/line_horizontal.png) repeat-x;
	background-size: contain;
	display: block;
	width: 1000%;
	height: 2px;
	top: 37px;
	left: 290px;
}
aside .side-nav p.title{
	font-size: 18px;
	position: absolute;
	z-index: 3;
}
aside .side-nav div.side-img{
	width: 290px;
	height: 69px;
	position: absolute;
	top: 0;
	z-index: 2;
}
aside .side-nav div.side-img img{
	width: 100%;
}
aside .side-nav.line-plus div.side-img:before{
	content: '';
	display: block;
	background: url(/parts/img/line_horizontal.png) repeat-x;
	width: 22px;
	height: 2px;
	background-size: contain;
	position: absolute;
	top: 36px;
	left: -23px;
}
nav.side-nav.line-plus:before {
	content: '';
	display: block;
	height: 10000px;
	width: 2px;
	position: absolute;
	background: url(/parts/img/line_ertical.png) repeat-y;
	background-size: contain;
	top: -9991px;
	padding-bottom: 4px;
	left: -49px;
}
aside .side-nav ul{
	counter-reset: li;
	margin: 99px 0 30px 0;
}
aside .side-nav ul li{
	margin: 17px 0;
	position: relative;
}
aside .side-nav ul li a{
	display: block;
	padding-left: 40px;
	color: #999c9f;
	line-height: 1.3em;
}
aside .side-nav ul li a:hover{
	color: #282828;
}
aside .side-nav ul li:before{
	counter-increment: li;
	content: "0" counter(li) ". ";
	color: #f1bd40;
	font-size: 10px;
	display: block;
	position: absolute;
	top: 10%;
}
aside .side-nav ul li:nth-child(n + 11):before{
	counter-increment: li;
	content: counter(li) ". ";
}
aside .side-nav ul li.side-active a{
	color: #282828;
}
aside .side-nav ul li.side-active:before{
	content: '';
	width: 16px;
	height: 10px;
	background: url(/parts/img/ico_active.png) no-repeat;
	background-size: 100%;
	display: inline-block;
	margin: 3px 20px 0 0;
}
aside .side-nav p.link-tel{
	font-size: 19px;
	font-weight: bold;
	margin-left: 5px;
	line-height: 1;
}
aside .side-nav p.link-tel:before{
	content: '';
	display: inline-block;
	background: url(/parts/img/ico_tel_black.png) no-repeat;
	background-size: 100%;
	margin-right: 8px;
	width: 12px;
	height: 16px;
}
aside .side-nav .side-info{
	font-size: 13px;
	text-align: center;
	font-weight: bold;
}
aside .side-nav .bnr{
	margin-top: 10px;
}
aside .side-nav .bnr a{
    display: block;
    text-align: center;
	background: #fff;
    position: relative;
    padding: 0;
    margin-top: 8px;
	transition: all 0.5s ease;
    border: 1px solid rgba(0,0,0,0);
	width: calc(100% + 2px);
}
aside .side-nav .bnr a:hover{
    background: none;
    border: 1px dotted #009944;
}
aside .side-nav .bnr a img{
    display: block;
    margin: 0 auto;
	width: 180px;
}


aside .side-nav .bnr a:after{
    content: '';
    background: url(../img/target_blank_black.png) 0 0 no-repeat;
    background-size:10px auto;
    display: block;
    height: 10px;
    width: 10px;
    position: absolute;
    right: 7px;
    top: 7px;
}
aside .side-nav .contact-btn{
    display: block;
    width: 100%;
    height: 48px;
    background: #ca3738 !important;
    color: #fff;
    text-align: center;
    line-height: 48px;
    position: static;
    transition: background 0.3s ease;
}
aside .side-nav .bnr a.contact-btn:after{
    display: none;
}
aside .side-nav .contact-btn:hover {
	background: #282828 !important;
	transition: 0.3s ease;
}
aside .side-nav .contact-btn span {
    padding: 4px 0 4px 40px;
    background: url(/parts/img/ico_foot_contact_white.png) left center /24px 23px no-repeat;

}
/* ------------------------------------------------------
   実績紹介リンク
------------------------------------------------------ */
.list-item{
	padding: 120px 0;
}
.list-item .example {
	overflow: hidden;
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
}
.list-item h2.large-style{
	font-size: 50px;
	text-align: center;
	text-shadow: #282828 1px 1px 0px, #282828 -1px 1px 0px,
			 #282828 1px -1px 0px, #282828 -1px -1px 0px;
	color: #fff;
	border: none;
	margin-bottom: 30px;
	line-height: 1;
	letter-spacing: 8px;
}
.list-item h2.large-style span{
	color: #f1bd40;
}
.list-item h2.large-style:after{
	display: none;
}

.list-item .example li {
	margin-right: 30px;
	min-width: 340px;
}
.list-item .example li:last-child{
	margin-right: 0;
}
.list-item .example li a {
	display: block;
	text-align: center;
}
.list-item .example li figure{
	/*background: #f8f8f8 url(/parts/img/bg_example.png) no-repeat;
	background-size: 177px 136px;
	width: 176px;
	height: 136px;
	padding: 60px 82px;
	background-position: 80px 60px;*/
	background: #f8f8f8;
	padding: 0;
}
.list-item .example li figure .window {
	width: 92%;
	height: 220px;
	padding: 10px 0px 0;
	overflow: hidden;
}
.list-item .example li figure img{
	width: 100%;
}
.list-item .example li span{
	display: inline-block;
	padding: 15px 26px 15px 0;
	background: url(/parts/img/arrow_black.png) right center /6px 10px no-repeat;
	text-align: left;
}
.list-item .example li a:hover span{
	color: #ca3738;
	background: url(/parts/img/arrow_red.png) right center /6px 10px no-repeat;
}
.list-item .example li a:hover figure {
	/* box-shadow: 0 0 20px rgba(0,0,0,0.1); */
}
.list-item a.btn-black{
	clear: both;
	display: block;
	background: #282828;
	color: #fff;
	text-align: center;
	height: 50px;
	line-height: 50px;
	position: relative;
	box-sizing:border-box;
	margin-top: 30px;
	border: 1px solid #282828;
}
.list-item a.btn-black:after{
	display: inline-block;
	content: '';
	background: url(/parts/img/arrow_white.png) no-repeat;
	width: 6px;
	height: 10px;
	background-size: 100%;
	margin-left: 20px;
}
.list-item a.btn-black:hover{
	background: #fff;
	color: #ca3738;
	border: 1px solid #ca3738;
}
.list-item a.btn-black:hover:after{
	content: '';
	background: url(/parts/img/arrow_red.png) no-repeat;
	width: 6px;
	height: 10px;
	background-size: 100%;
}
/* ------------------------------------------------------
   footer
------------------------------------------------------ */
/* ---------お問い合わせ------------- */
footer{
	overflow: hidden;
	position: relative;
	padding-top: 75px;
    font-family: "Original Yu Gothic", "Yu Gothic", YuGothic, Verdana, Meiryo, "M+ 1p", sans-serif;
}
footer .foot-contact{
	position: absolute;
	top: 0px;
	right: 0;
	left: 0;
	width: 1080px;
	/* height: 235px; */
	margin: 30px auto 0;
	line-height: 1;
}
footer .foot-contact h2 span{
    color:#f1bd40;
}
footer .foot-contact h2{
    text-align:center;
    font-size: 50px;
    text-shadow: #282828 1px 1px 0px, #282828 -1px 1px 0px, #282828 1px -1px 0px, #282828 -1px -1px 0px;
    color: #fff;
    line-height: 1.2;
    position: relative;
    letter-spacing: .1em;
    margin-bottom:15px;
}
footer .foot-contact .wrap{
	padding: 40px 0;
	background: #fff;
	border: 2px dotted #282828;    
}
footer .foot-contact p strong{
	display: block;
    text-align:center;
	margin: 0 0 40px;
	color: #282828;
	font-weight: bold;
	font-size: 24px;
	letter-spacing: 2px;
	font-family:  "Original Yu Gothic", "Yu Gothic", YuGothic, Verdana, Meiryo, "M+ 1p", sans-serif;
}
footer .foot-contact .cv-area{
	display:-webkit-flex;/*--- safari（PC）用 ---*/
	display: flex;
    justify-content: center; 
}
footer .foot-contact .cv-area .foot-tel .tel-link {
	width: 270px;
	overflow: hidden;
	padding-right: 50px;
	font-size: 31px;
	font-weight: bold;
}
footer .foot-contact .cv-area .foot-tel{
	border-right: 1px solid #282828;
}
footer .foot-contact .cv-area .foot-tel .tel-link span:first-child{
	font-size: 20px;
	padding-right: 15px;
}
footer .foot-contact .foot-tel p:last-child{
	margin: 10px 0 0 54px;
	font-size: 14px;
	font-weight: normal;
}
footer .foot-contact .cv-area .link-area{
	width: 175px;
	height: 50px;
	position: relative;
	float: right;
	margin: 0 0 0 65px;
	padding: 0 40px;
	background: #ca3738;
	color: #fff;
	text-align: right;
	line-height: 50px;
	font-family:  "Original Yu Gothic", "Yu Gothic", YuGothic, Verdana, Meiryo, "M+ 1p", sans-serif;
 	border: 1px solid #ca3738;
   
}
footer .foot-contact .cv-area .link-area:before{
	display: inline-block;
	position: absolute;
	content: '';
	background: url(/parts/img/ico_foot_contact_white.png) no-repeat;
	width: 24px;
	height: 23px;
	background-size: 100%;
	margin-right: 20px;
	left: 45px;
	top: 12px;
}
footer .foot-contact .cv-area .link-area:hover{
	background: #fff;
	color: #ca3738;
	border: 1px solid #ca3738;

}
footer .foot-contact .cv-area .link-area:hover:before{
	display: inline-block;
	position: absolute;
	content: '';
	background: url(/parts/img/ico_foot_contact_red.png) no-repeat;
	width: 24px;
	height: 23px;
	background-size: 100%;
	margin-right: 20px;
	left: 45px;
	top: 12px;
}
/* ---------サイトマップ・コピーライト------------- */
footer .foot-nav{
	overflow: hidden;
	padding: 300px 0 80px 0;
	/* background: #f8f8f8; */
}
footer .foot-nav .wrap{
	display:-webkit-flex;/*--- safari（PC）用 ---*/
	display: flex;
	flex-flow: row wrap;
}
footer .foot-nav .nav-box:nth-child(1){
	flex-basis: 270px;
}
footer .foot-nav .nav-box:nth-child(2){
	flex-basis: 195px;
}
footer .foot-nav .nav-box:nth-child(3){
	flex-basis: 465px;
}
footer .foot-nav .nav-box:nth-child(4),footer .foot-nav .nav-box:nth-child(5){
	flex-basis: 150px;
}
footer .foot-nav .nav-box .foot-logo img{
	width: 152px;
	height: 34px;
	display: block;
}
footer .foot-nav .nav-box .foot-logo span{
	display: block;
	font-size: 11px;
	color: #a4a4a4;
	margin-top: 7px;
}
footer .foot-nav .nav-box .corp-name{
	display: block;
	font-weight: bold;
	font-size: 16px;
	margin: 18px 0 10px;
}
footer .foot-nav .corp-data p{
	margin-bottom: 15px;
    line-height: 1.3    
}
footer .foot-nav .nav-box ul li{
	display: block;
	font-weight: bold;
	font-size: 16px;
	position: relative;
}
footer .foot-nav .nav-box ul li ul li{
	font-weight: normal;
	font-size: 13px;
}

footer .foot-nav .nav-box ul li.cell2 ul{
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap
}
footer .foot-nav .nav-box ul li.cell2 ul li{
    width: 48%;
}

@media screen and (max-width: 1080px) {
	footer .foot-nav .nav-box ul li.cell2 ul{
		display: block;
	}
	footer .foot-nav .nav-box ul li.cell2 ul li{
		width: auto;
	}
}


footer .foot-nav .nav-box ul li:nth-child(3){
	margin-top: 25px;
}
footer .foot-nav .nav-box ul li li + li:nth-child(3){
	margin-top: 0;
}
footer .foot-nav small{
	clear: both;
	font-size: 12px;
	color: #c4c4c4;
}
footer .foot-nav .nav-box .lower{
    margin-top:10px;
}
/* ---------インスタグラム・他リンクエリア------------- */
footer .foot-link{
	padding: 30px 0;
	background: #f5f5f5;
	font-size: 13px;
	overflow: unset;
}
footer .foot-link ul{
	display:-webkit-flex;/*--- safari（PC）用 ---*/
	display: flex;
	flex-wrap: wrap;
	max-width: 1080px;
}
footer .foot-link ul li:after{
	display: inline-block;
	content: '';
	width: 1px;
	height: 9px;
	background: #282828;
}
footer .foot-link ul li:first-child:after,footer .foot-link li:last-child:after{
	display: none;
}
footer .foot-link ul li a{
	padding: 0 25px;
}
footer .foot-link ul li:first-child a{
	width: 23px;
	height: 23px;
	padding: 0 5px 0 0;
}
footer .foot-link ul li:last-child a{
	padding-right: 0;
}
footer .foot-link .link-inst img{
	width: 23px;
	height: 23px;
}
/* ---------ページアップボタン------------- */
#page-top{
	width: 100px;
	overflow: hidden;
	position: absolute;
	bottom: 17px;
	right: 0;
}
#page-top a{
	width: 100px;
	height: 90px;
	display: block;
	transition: 0.5s;
	background-position: center top!important;
	background: url(/parts/img/ico_pageup.png) no-repeat;
	background-size: 33px auto;
}
#page-top a:hover{
	padding-top: 15px;
	width: 100px;
}
#page-top a span {
	display: block;
	position: absolute;
	bottom: 0;
	padding-top: 10px;
	background: #f8f8f8;
	font-size: 14px;
	width: 100px;
	height: 17px;
	font-weight: bold;
}

/* ------------------------------------------------------
	PC専用
------------------------------------------------------ */
@media screen and (min-width: 768px) {
	header .head-wrap nav ul.g-nav li.main-link{
		display: inline-block!important;
	}
	nav.side-nav.start {
		top: 0px!important;
	}
}

/* ------------------------------------------------------
	1080以下
------------------------------------------------------ */
@media screen and (max-width: 1080px) {
	/* ------------------------------------------------------
		header
	------------------------------------------------------ */
    .head-wrap{
        height: 110px;
    }
	.logo {
        padding-top:20px;
		margin-left: 3%;
	}
    
    .seo-text{
		margin:0 3%;
        line-height: 1.1;
    }
	.nav-wrap {
		top: 40px;
		right: 200px;
	}
	.g-nav {
		width: 335px;
		flex-wrap: wrap;
		font-size: 13px;
	}
	.g-nav > li {
		margin-bottom: 8px;
	}
	.g-nav > li + li {
		margin-left: 30px;
	}
	.g-nav > li:nth-child(4) {
		margin-left: 0;
	}
	.g-nav > li > a {
		padding-bottom: 0;
	}
	.contact-btn .pc {
		right: 3%;
	}
	.main {
		padding-left: 4%;
	}
	.main.single-column {
		width: 92%;
		margin: 0 auto;
		padding-left: 0;
	}
	.main div.head-img {
		left: auto;
		right: 0;
	}
	.main div.head-img img {
		width: 100%;
		height: 100%;
		object-fit: cover;
	}
	.main div.head-img.-message img {
		width: 100%;
		height: 100%;
        object-fit: cover;
	}
	aside {
		padding-right: 4%;
	}
	aside img.line-top.scroll {
		right: calc(228px + 4%);
	}

	.list-item .example li {
		margin: 0 10px;
		min-width: inherit;
	}
	.list-item .example li figure {
		box-sizing: border-box;
		width: 100%;
		height: 247px;
		background-position: center 60px;
		position: relative;
	}
	.list-item .example li figure .window {
		position: absolute;
		top: 60px;
		right: 0;
		left: 0;
		margin: auto;
	}
	
	.list-item a.btn-black {
		width: 92%;
		margin: 30px auto 0;
	}
	
	footer {
		padding-top: 0;
	}
	footer .foot-contact {
		box-sizing: border-box;
		width: 92%;
		margin-top: 0;
		padding: 0;
		background-size: 100% auto;
		background-color: #f1bd40;
		position: relative;
		background: none;
	}
	footer .foot-contact h2 {
		font-size: 30px;
		line-height: 1.6;
	}
	footer .foot-contact p strong {
		width: auto;
		margin: 0 auto 40px;
		text-align: center;
	}
	footer .foot-contact .cv-area {
		justify-content: center;
	}
	footer .foot-contact .cv-area .foot-tel .tel-link {
		padding-right: 30px;
	}
	footer .foot-contact .cv-area .link-area {
		margin-left: 30px;
	}
	footer .foot-nav {
		padding: 70px 4%;
	}
	footer .foot-nav .wrap{
		justify-content: space-between;
	}
	footer .foot-nav .nav-box:nth-child(1){
		flex-basis: auto;
	}
	footer .foot-nav .nav-box:nth-child(2){
		flex-basis: auto;
	}
	footer .foot-nav .nav-box:nth-child(3){
		flex-basis: auto;
	}
	footer .foot-nav .nav-box:nth-child(4),footer .foot-nav .nav-box:nth-child(5){
		flex-basis: auto;
	}
	footer .foot-nav .nav-box ul li {
		font-size: 14px;
	}
	footer .foot-nav .nav-box ul li ul li {
		font-size: 14px;
		font-weight: bold;
	}
	footer .foot-link {
		padding: 30px 4%;
	}
}
/* ------------------------------------------------------
   sp 800以下
------------------------------------------------------ */
@media screen and (max-width: 800px) {
	header .pc,footer .pc{
		display:none !important;
	}
	header .sp,footer .sp{
		display:block!important;
	}
	header .pc-i,footer .pc-i{
		display:none !important;
	}
	header .sp-i,footer .sp-i{
		display:inline!important;
	}
	/* ------------------------------------------------------
		header
	------------------------------------------------------ */
	header {
		width: 100%;
		background: #fff;
		border-bottom: 1px dotted #282828;
		position: fixed;
		top: 0;
		z-index: 999;
	}
	header.on::before {
		content: '';
		display: block;
		width: 40px;
		height: 62px;
		background: url(/parts/img/bg_spnav_bottom.png) no-repeat;
		background-size: cover;
		position: absolute;
		right: 2.1%;
		bottom: -17px;
		z-index: 1;
	}
	header::after {
		content: '';
		display: block;
		width: 49px;
		height: 23px;
		background: url(/parts/img/bg_spnav.png) no-repeat;
		position: absolute;
		right: 3%;
		background-size: 100%;
		bottom: -23px;
	}
    .seo-text{
        padding-bottom:10px;
    }
	.head-wrap {
		height: auto;
		min-height: 50px;
		padding-top: 50px;
		margin: 0 auto;
	}
	.nav-wrap {
		display: none;
		max-height: calc(100vh - 90px);
		padding: 0 5%;
		position: relative;
		top: 0;
		right: auto;
		overflow-y: scroll;
	}
	.g-nav {
		display: block;
		width: 100%;
	}
	.g-nav > li {
		margin-bottom: 0;
		position: relative;
	}
	.g-nav > li + li {
		margin-left: 0;
	}
	.g-nav > li a {
		padding-bottom: 0;
		height: 50px;
		line-height: 50px;
		padding-left: 15px;
	}
	.g-nav > li + li a {
		border-top: 1px dotted #7d7f81;
	}
	.g-nav > li > a::after {
		display: none!important;
	}
	.g-nav .lower{
		background: #f8f8f8;
		width: 84%;
		margin: 0px auto 15px;
		padding: 10px 4%;
		border-radius: 5px;
	}
	.g-nav .lower li:first-child a{
		border-top: none;
	}
	.lower li a {
		padding-right: 50px;
		background: url(/parts/img/arrow_black.png) right 20px center /6px 10px no-repeat;
	}
	.logo {
		width: 100px;
		margin-left: 0;
		position: absolute;
		top: 12px;
		left: 4%;
        padding-top:0;
	}
    .logo .label {
        display: none;        
    }    
    .logo .img {
        width: 100%;
        padding-top:0;
    }    

    .head-btn {
		display: flex;
		position: absolute;
		top: 10px;
		right: 4%;
	}
	.head-btn > a {
		display: block;
	}
	.head-btn img {
		width: 100%;
	}
	.tel-sp {
		width: 34px;
		height: 27px;
	}
	.contact-btn {
		width: 28px;
		height: 27px;
		margin: 0 0 0 24px;
	}
	.menu-trigger {
		width: 27px;
		height: 21px;
		margin: 4px 4px 0 30px;
		position: relative;
	}
	.menu-trigger span {
		display: block;
		width: 27px;
		height: 3px;
		background: #282828;
		border-radius: 1.5px;
		position: absolute;
	}
	.menu-trigger span:nth-child(1) {
		top: 0;
		transform: rotate(0);
		transition: transform 0.5s ease, 0.5s top 0.5s ease;
	}
	.menu-trigger span:nth-child(2) {
		top: calc(50% - 1.5px);
		opacity: 1;
		transition: 0.5s opacity 0.5s ease;
	}
	.menu-trigger span:nth-child(3) {
		top: calc(100% - 3px);
		transform: rotate(0);
		transition: transform 0.5s ease, 0.5s top 0.5s ease;
	}
	.menu-trigger.active span:nth-child(1) {
		top: calc(50% - 1.5px);
		transform: rotate(45deg);
		transition: top 0.5s ease, 0.5s transform 0.5s ease;
	}
	.menu-trigger.active span:nth-child(2) {
		opacity: 0;
		transition: 0.5s ease;
	}
	.menu-trigger.active span:nth-child(3) {
		top: calc(50% - 1.5px);
		transform: rotate(-45deg);
		transition: top 0.5s ease, 0.5s transform 0.5s ease;
	}
	.overlay.on {
		display: block;
		width: 100%;
		height: 100%;
		background: #fff;
		position: fixed;
		top: 0;
		left: 0;
		z-index: 99;
	}
	/* ------------------------------------------------------
		footer
	------------------------------------------------------ */
	footer {
		padding-top: 0;
	}
	footer .foot-contact {
		box-sizing: inherit;
		position: relative;
		top: 0px;
		right: 0;
		left: 0;
		width: 92%;
		overflow: hidden;
		margin: 0 auto -200px;
		padding: 10px 4%;
		line-height: 1;
	}
	footer .foot-contact h2 {
		font-size: 26px;
	}
	footer .foot-contact .wrap {
		padding: 30px 0;
	}
	footer .foot-contact .wrap > p {
		margin-bottom: 50px;
	}
	footer .foot-contact .cv-area {
		display: block;
		position: relative;
	}
	footer .foot-contact .cv-area .foot-tel {
		float: none;
		width: 90%;
		overflow: hidden;
		margin: 0 auto;
		padding-right: 0;
		font-size: 30px;
		font-weight: bold;
		border-right: none;
	}
	footer .foot-contact p strong {
		margin: 0;
		display: block;
		color: #282828;
		font-weight: bold;
		font-size: 16px;
		text-align: center;
		top: 37px;
		line-height: 1.5em;
		letter-spacing: 3px;
	}
	footer .foot-contact .cv-area .link-area {
		width: 90%;
		height: 50px;
		display: block;
		position: relative;
		float: none;
		background: #c53a3b;
		line-height: 50px;
		margin: 0 auto;
		padding: 0;
		color: #fff;
		text-align: center;
        border: 1px solid #c53a3b
	}
	footer .foot-contact .cv-area .link-area span{
		display: inline-block;
		padding-left: 32px;
		background: url(/parts/img/ico_foot_contact_white.png) left top 14px /20px 19px no-repeat;
	}
	footer .foot-contact .cv-area .link-area:hover {
		background: #fff;
		color: #c53a3b;
        
	}
	footer .foot-contact .cv-area .link-area:hover span {
		background-image: url(/parts/img/ico_foot_contact_red.png);
	}
	footer .foot-contact .cv-area .link-area:before,footer .foot-contact .cv-area .link-area:hover:before{
		display: none;
	}
	footer .foot-contact .cv-area .foot-tel .tel-link{
		display: block;
		font-size: 16px;
		width: 100%;
		line-height: 50px;
		background: #fff;
		text-align: center;
		font-weight: normal;
		padding-right: 0;
		margin: 0 auto 10px;
	}
	footer .foot-contact .cv-area .foot-tel .tel-link a {
		display: block;
	}
	footer .foot-contact .cv-area .foot-tel .tel-link .tel-num {
		display: inline-block;
		padding-left: 24px;
		background: url(/parts/img/ico_tel_black.png) left center /12px 16px no-repeat;
	}
	footer .foot-contact .foot-tel p:last-child {
		margin: 10px 0 0;
		font-size: 14px;
		text-align: center;
		font-weight: normal;
		position: absolute;
		top: -50px;
		width: 90%;
	}
	footer .foot-nav .nav-box:nth-child(1),
	footer .foot-nav .nav-box:nth-child(2),
	footer .foot-nav .nav-box:nth-child(3),
	footer .foot-nav .nav-box:nth-child(4){
		flex-basis: unset;
	}

	footer .foot-nav{
		padding: 235px 0 0 0;
	}
	footer .foot-nav .wrap{
		display: block;
		padding-bottom: 262px;
	}
	footer .foot-nav .nav-box ul li:nth-child(3){
		margin-top: 0;
	}
	footer .foot-nav .nav-box ul li a{
		display: block;
		padding: 12px 0 10px 4%;
		background-position: right 10px center;
		border-top: 1px solid #d8d8d8;
		position: relative;
	}
	footer .foot-nav .nav-box:last-child ul li a {
	/*	border-bottom: 1px solid #d8d8d8; */
	}
	footer .foot-nav .nav-box:last-child > ul {
		border-bottom: 1px solid #d8d8d8;
	}
	footer .foot-nav .nav-box:last-child > ul > li > a {
		border-bottom: none;
	}
	footer .foot-nav .nav-box:last-child .lower ul li:last-child a {
		border-bottom: none;
	}
	footer .foot-nav .nav-box ul li.lower {
		display: none;
	}
	footer .foot-nav .nav-box ul li ul {
		background: #f8f8f8;
		width: 84%;
		margin: 0 auto 15px;
		padding: 10px 4%;
		border-radius: 5px;
	}
	footer .foot-nav .nav-box ul li ul li a{
		position: relative;
		padding-left: 0;
	}
	/*
	footer .foot-nav .nav-box ul li ul li a:after{
		display: inline-block;
		content: '';
		background: url(/parts/img/arrow_black.png) no-repeat;
		width: 6px;
		height: 10px;
		background-size: 100%;
		margin-left: 20px;
		position: absolute;
		right: 10px;
		top: 18px;
	}
	*/
	footer .foot-nav .nav-box ul li ul li:first-child a{
		border: none;
	}
	footer .foot-nav .nav-box ul li ul li:last-child a {
		border-top: 1px solid #d8d8d8;
	}
	footer .foot-nav .nav-box .corp-name {
		font-size: 14px;
		margin-top: 0;
	}
	footer .foot-nav .corp-data p {
		font-size: 12px;
		margin-bottom: 15px;
	}
	footer .foot-nav .corp-data p.foot-logo {
		margin-bottom: 5px;
	}
	footer .foot-nav .nav-box .foot-logo img {
		width: 102px;
		height: auto;
	}
	footer .foot-nav .nav-box .foot-logo span {
		font-size: 7px;
	}
	footer .foot-nav small {
		font-size: 10px;
		margin-top: 0;
	}
	footer .foot-link ul li:last-child a {
		padding-left: 0;
	}
	#page-top {
		width: 40px;
		overflow: hidden;
		position: absolute;
		bottom: 220px;
		right: 20px;
	}
	#page-top a:hover {
		padding-top: 0px;
		width: 40px;
	}
	#page-top a {
		width: 40px;
		height: 40px;
		display: block;
		transition: none;
		background-position: center!important;
		background: #282828 url(/parts/img/arrow_up.png) no-repeat;
		background-size: 10px 6px;
		border-radius: 30px;
	}
	footer .foot-link {
		padding: 20px 4% 14px;
		font-size: 11px;
		overflow: hidden;
		background: #fff;
		bottom: 179px;
		position: absolute;
		width: 92%;
	}
	footer .foot-link ul li:nth-child(2),footer .foot-link ul li:nth-child(3),footer .foot-link ul li:nth-child(4){
		padding-top: 3px;
	}
	footer .foot-link ul li a {
		padding: 0 15px;
	}
	footer .foot-nav .nav-box:nth-child(1) {
		background: #f8f8f8;
	}
	.nav-box.corp-data {
		width: 92%;
		padding: 20px 4%;
		position: absolute;
		bottom: 0;
		background: #fff;
	}
	.corp-data p.foot-logo {
		width: 160px;
		margin-bottom: 20px;
		display: block;
	}
	.corp-data p.foot-logo img{
		width: 100%;
	}
	.corp-data p.foot-logo span{
		font-size: 10px;
		color: #c4c4c4;
	}
	.corp-data span.corp-name {
		font-weight: bold;
		display: block;
		font-size: 16px;
	}
	.corp-data small{
		color: #999c9f;
		font-size: 12px;
		margin-top: 20px;
		display: block;
	}
	p#page-topsp {
		width: 50px;
		height: 50px;
		position: absolute;
		bottom: 155px;
		background: #282828;
		border-radius: 25px;
		line-height: 50px;
		text-align: center;
		right: 5%;
	}
	#page-topsp img{
		width: 20px;
		height: 12px;
	}
	/* ------------------------------------------------------
		トグルスイッチ
	------------------------------------------------------ */
	.switch,.side-switch,.head-switch {
		display: block;
		width: 100%;
		height: 100%;
		position: absolute;
		top: 1px;
		right: 0;
		cursor: pointer;
	}
	.head-switch {
		height: 50px;
		z-index: 20;
	}
	.switch:after,.head-switch:after {
		content: '';
		display: block;
		box-sizing: border-box;
		background: url(/parts/img/ico_plus.png) no-repeat;
		width: 12px;
		height: 12px;
		background-size: 100%;
		position: absolute;
		top: 19px;
		right: 17px;
	}
	span.side-switch.on:after,span.switch.on:after,span.head-switch.on:after{
		content: '';
		display: block;
		box-sizing: border-box;
		background: url(/parts/img/ico_minus.png) no-repeat;
		width: 12px;
		height: 2px;
		background-size: 100%;
		position: absolute;
		top: 24px;
		right: 17px;
	}
	.lower.side-lower{
		display: none;
	}
}


/* ------------------------------------------------------
   sp 767以下
------------------------------------------------------ */
@media screen and (max-width: 767px) {

	/* ------------------------------------------------------
		common
	------------------------------------------------------ */
	.pc{
		display:none !important;
	}
	.sp{
		display:block!important;
	}
	.pc-i{
		display:none !important;
	}
	.sp-i{
		display:inline!important;
	}
	/* ------------------------------------------------------
		contents
	------------------------------------------------------ */
	.contents {
        min-width: 320px;
		padding-top: 72px;
	}
	.main{
		width: 90%;
		margin: auto;
		float: none;
		padding: 20px 0 0 0;
		max-width: unset;
	}
	.main h1 {
		line-height: 1.5em;
		padding: 15px 0 10px 0;
	}
	.main h1 span{
		padding-right: 0;
	}
	.main h1 span + span {
		padding-right: 0;
	}
	.main h1,.list-item h2.large-style{
		font-size: 25px;
		font-weight: bold;
		letter-spacing: .1em;
		text-align: center;
	}
	.main h1:after{
		display: none;
	}
	.main h2.title-line, .main h3.title-line{
		margin: 60px 0 30px;
		padding-bottom: 8px;
		line-height: 1.4em;
		font-size: 20px;
	}
	.main h2.title-ico, .main h3.title-ico {
		font-size: 16px;
		margin-bottom: 20px;
		padding: 7px 0 0 32px;
	}
	.main h2.title-ico:before, .main h3.title-ico:before{
		display: inline-block;
		position: absolute;
		top: 6px;
		left: 0;
		bottom: 10px;
		content: '';
		background: url(/parts/img/ico_h3_01.png) no-repeat;
		width: 20px;
		height: 20px;
		background-size: 100%;
		margin-right: 15px;
	}
	.main h2.title-line:after, .main h3.title-line:after{
		width: 40px;
	}
	.main h2.title-line br, .main h3.title-line br, .main h2.title-ico br, .mainh3.title-ico br {
		display: none;
	}
	.main h2.num, .main h3.num {
		padding-left: 44px;
	}
	.main h3.num:before {
		width: 30px;
	}
	.main p {
		margin-bottom: 15px;
	}
	.main figure.img-full{
		margin-top: 10px;
	}
	.main figure + p{
		margin-top: 25px;
	}
	.main section {
		margin-top: 60px;
	}
	.main section p {
		margin-bottom: 15px;
	}
	.main p.sub-title {
		margin-top: 40px;
	}
	.main div.head-img{
		left: -62%;
		height: 30vw;
	}
	.main div.head-img img {
		width: 100%;
		height: 100%;
		object-fit: cover;
	}
    .main div.head-img.-message {
        left: 0%;
        height: auto;
    }
	.main div.head-img.-message img {
		width: 100%;
		height: auto;
	}
	/* .main .head-img + h2 {
		margin-top: 45vw;
	} */
	.list-item{
		padding: 120px 0 70px;
	}
	.list-item a.btn-black{
		width: 90%;
		margin: auto;
	}
	.main .txt-harf li h4 {
		padding-bottom: 10px;
		margin-bottom: 15px;
	}
	.main .full-list + section {
		margin-top: 60px;
	}
	.main ul.full-list li a {
		font-size: 14px;
		line-height: 1.4;
	}
	.main ul.full-list li a span {
		height: 20px;
	}
	.list-item .example{
		margin-bottom: 25px;
	}
	/* ------------------------------------------------------
		side
	------------------------------------------------------ */
	aside{
		width: 88%;
		margin: auto;
		float: none;
		padding: 0;
		max-width: unset;
		position: absolute;
		top: 7vw;
		left: 4%;
	}
	aside.side:before{
		display: none;
	}
	aside .side-nav:after{
		display: none!important;
	}
	aside .side-nav.n-margin{
		margin: 38vw 0 0 0!important;
	}
	aside .side-nav {
		top: 0!important;
		width: 104%;
		float: none;
		position: absolute;
		margin: 0;
		margin-top: calc(19vw + 46px);
		background: #fff;
		border-radius: 5px;
		box-shadow: 0px 8px 18px -2px rgba(0, 10, 15, 0.2);
		z-index: 10;
		overflow: hidden;
	}
    aside .side-nav.-message {
		margin-top: 26vw;        
    }
	.p-message aside .side-nav.-message {     
		margin-top: 30px;   
	}
	aside .side-nav .bnr {
		margin-top: 0;
		padding: 0 15px;
		display: none;
	}
	aside .side-nav .bnr a:after {
		top: 0;
		right: 0;
		bottom: 0;
		margin: auto;
	}
	aside .side-nav p.title{
		position: relative;
		margin: 0;
		padding: 15px;
		font-weight: normal;
		font-size: 14px;
		border-radius: 5px;
	}
	aside .side-nav ul {
		margin: 0 0 15px 0;
		display: none;
	}
	aside .side-nav ul li{
		margin: 0;
		padding: 0 15px;
	}
	aside .side-nav ul li a {
		padding: 15px 15px 15px 0;
		color: #282828;
		border-top: 1px dotted #d8d8d8;
	}
	aside .side-nav ul li:last-child a {
		border-bottom: 1px dotted #d8d8d8;
	}
	aside .side-nav ul li a:after{
		display: inline-block;
		content: '';
		background: url(/parts/img/arrow_black.png) no-repeat;
		width: 6px;
		height: 10px;
		background-size: 100%;
		position: absolute;
		right: 20px;
		top: 0;
		bottom: 0;
		margin: auto;
	}
	aside .side-nav ul li a br {
		display: none;
	}
	aside .side-nav ul li:before,aside .side-nav ul li.side-active:before{
		display: none;
	}
	aside .side-nav:before{
		display: none;
	}
    aside .side-nav .contact-btn{
        margin:0 0 20px 0;
    }

	.list-item .example li span {
		font-size: 12px;
	}
	.side-switch:after{
		content: '';
		display: block;
		box-sizing: border-box;
		background: url(/parts/img/ico_plus.png) no-repeat;
		width: 12px;
		height: 12px;
		background-size: 100%;
		position: absolute;
		top: 19px;
		right: 17px;
	}
}

@media screen and (max-width: 640px) {
    aside .side-nav.-message {
		margin-top: 34vw;        
    }
	
	.p-message aside .side-nav.-message {     
		margin-top: 54px;   
	}
	.p-message .main h1 {
		padding-bottom: 30px;
	}
}
@media screen and (max-width: 560px) {

	aside .side-nav {
		margin-top: calc(28vw + 46px);
	}
}

/* ------------------------------------------------------
   sp 480以下
------------------------------------------------------ */
@media screen and (max-width: 480px) {
	/* ------------------------------------------------------
		header
	------------------------------------------------------ */
	header::after {
		right: 3%;
	}
	.contact-btn {
		margin: 0 0 0 25px;
	}
	.menu-trigger {
		margin: 4px 4px 0 30px;
	}
	.lower li a {
		font-size: 12px;
		padding-left: 8px;
	}
	
    aside .side-nav.-message {
		margin-top: calc(42vw + 46px);        
    }	
	
	/* ------------------------------------------------------
		footer
	------------------------------------------------------ */
	footer .foot-link ul li a {
		padding: 0 10px;
	}
}
@media screen and (max-width: 460px) {

	aside .side-nav {
		margin-top: calc(43vw + 46px);
	}
}
.ex-items{
    display: flex;
    justify-content: space-around;
}
.ex-items li{
    width: 340px;
    box-sizing: border-box;
    text-align: center;
}
.ex-items li figure{
    background: #fff;
    padding: 10px;
    margin-bottom:5px;
}
.ex-items li:hover figure{
	box-shadow: 0 0 20px rgba(0,0,0,0.1);
	transition: 0.5s ease;
}
.ex-items li span{
    display: inline-block;
    padding: 15px 26px 15px 0;
    line-height: 1.3;
    background: url(/parts/img/arrow_black.png) right center /6px 10px no-repeat;
    text-align: left;
    width: 90%;
    box-sizing: border-box;    
}
.ex-items li:hover span{
    color: #ca3738
}
.ex-items img{
    width: 100%;
    height: auto;
    display: block;
}
.inquiry aside{
	display: none;
}
@media screen and (max-width: 767px){
.ex-items{
    justify-content:space-between;
}
    
    .ex-items li{
        width: calc((100% - 10px * 1) / 2);
    }
	.form-sec{
		padding-bottom: 80px;
	}
}

blockquote {
	margin: 1em auto;
	background: #efefee;
	padding: 2em;
	border-radius: 8px;
	ul {
		li {
			display: flex;
			align-items: flex-start;
			&::before {
				content: '●';
			}
		}
	}
	>*+* {
		margin-top: 1em;
	}
}
q {
	display: block;
	*+& {
		margin-top: 2em;
	}
}
cite {
	display: block;
	*+& {
		margin-top: .5em;
		font-size: 88%;
		text-align: right;
	}
}

b {
	font-weight: bold;
}

.p-list-faqs {}
.p-list-faqs_item {
	background: #eff1ef;
	padding: 1.6em;
	border-radius: 8px;
	*+& {
		margin-top: 1em;
	}
	dt {
		display: grid;
		font-weight: bold;
		grid-template-columns: 2em auto;
		gap: 1em;
		align-items: center;
		&::before {
			content: 'Q';
			color: #fff;
			width: 2em;
			aspect-ratio: 1/1;
			display: flex;
			justify-content: center;
			align-items: center;
			line-height: 0;
			background: #368d3e;
			border-radius: 50%;
		}

	}
	dd {
		margin-top: 1em;
		display: grid;
		grid-template-columns: 2em auto;
		gap: 1em;
		&::before {
			content: 'A';
			width: 2em;
			aspect-ratio: 1/1;
			display: flex;
			justify-content: center;
			align-items: center;
			line-height: 0;
			background: #fff;
			border-radius: 50%;
			color: #368d3e;
		}

	}
}

.p-supplementary-explanation {
	border: 2px solid #333;
	border-radius: 5px;
	h4 {
		text-align: center;
		background: #333;
		color: #fff;
		font-size: 17px;
		padding: .5em;
	}
	> div {
		padding: 2em;
	}
	*+& {
		margin-top: 3.2em;
	}
}

.p-table-common {
	width: 100%;
	*+& {
		margin: 1.6em auto;
	}

	th, td  {
		padding: .64em 1em;
		border: 1px solid #eee;
	}
	thead {
		th {
			background: #368d3e;
			color: #fff;
			font-weight: bold;
		}
	}
	tbody {
		th, td  {
			background: #fff;
			vertical-align: middle;
		}
		th {
			white-space: nowrap;
			text-align: left;
		}
		tr:nth-of-type(2n+1) {
			th, td  {
				background: #fdfdfd;
			}	
		}
	}

	caption {
		font-weight: bold;
		margin-bottom: .5em;
	}

	.c-cell-effect {
		text-align: center;
		vertical-align: middle;
		font-size: 1.6em;
	}
}

.p-table-simple {
	
}

.p-grid-figrues {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 2em;
	figure {
		margin-top: 0!important;
	}
	.c-img {
		border: 1px solid #ccc;
		overflow: hidden;
		border-radius: 8px;
		img {
			display: block;
			max-width: none;
			width: 100%;
			height: 100%;
			object-fit: cover;
		}
	}
	figcaption {
		margin: 1em;
		h4 {
			font-weight: bold;
		}
	}	
	*+& {
		margin-top: 1.6em;
	}
}