@charset "UTF-8";

/* Body
------------------------------------------------------ */
* {
	box-sizing: border-box;
}
a, input, button {
  text-decoration: underline;
  -webkit-transition: 0.2s ease-in-out;
  transition: 0.2s ease-in-out;
}
a:hover {
	text-decoration:none;
}
a:hover, input:hover, button:hover {
  opacity: 0.8;
}
#main a:after {
	font-family: 'icon-comment';
	content: '\e817';
	color: #000;
	margin: 0 3px;
}
#main #breadcrumbs a:after,
#main .btnLink01 a:after,
a[href*="tel:"]:after {
	display: none;
}

#main a[target=_blank]:after {
	content: '\f08e';
}
input, button {
	text-decoration: none;
}
button {
	cursor: pointer;
}
table th,table td {
	font-size: 1.6rem;
}

@media print, screen and (min-width: 769px) {
	.inner {
		margin-left: auto;
		margin-right: auto;
		width: 980px;
	}
}

@media only screen and (max-width: 768px) {
	.inner {
		margin:0;
		/*padding-left: 3.125%;
		padding-right: 3.125%;*/
		padding-left: 10px;
		padding-right: 10px;
	}
	table th,table td {
		font-size: 1.2rem;
	}
}

/* header
============================== */
#header {
	background-color:#fff;
}
#header .skip_link a {
	display: block;
	position: absolute;
	top: 0;
	left: 0;
	width: 100vw;
	text-align: center;
	padding: .5em;
	background-color: rgba(255, 255, 0, 0.5);
	opacity: 0;
	pointer-events: none;
}
#header .skip_link a:focus {
	opacity: 1;
	pointer-events: all;
}
#header .hd_inner {
	margin-left:auto;
	margin-right:auto;
	overflow:hidden;
	padding:50px 40px;
	/*width:1280px;*/
	max-width:1280px;
	min-width:980px;
	min-width:1060px;
}
#header .hdUpper {
	position: relative;
}
#header .logo {
	float:left;
}
#header .gnav {
	float:right;
	margin-top:10px;
	overflow:hidden;
}
#header .gnav li {
	float:left;
	margin:0 30px;
}
#header .gnav li a {
	color:#000;
	font-family: 'Ubuntu', "Century Gothic", CenturyGothic, "Arai", YakuHanJP, "Noto Sans Japanese", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "ヒラギノ角ゴシック W3", HiraginoSans-W3, "メイリオ", Meiryo, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
	font-size:1.8rem;
	text-decoration:none;
	text-align:center;
}


/*PC Layout
------------------------------------------------------ */
@media print, screen and (min-width: 769px) {
	#header .gnav li:nth-child(1) {
		display:none;
	}
}


/*SP Layout
------------------------------------------------------ */
@media only screen and (max-width: 768px) {
	#header {
		border-bottom: 1px solid #e8ece9;
		position:fixed;
		top:0;
		width:100%;
		z-index:100;
	}
	#header .hd_inner {
		min-height: 66px;
		padding:20px;
		width:100%;
	}
	#header .logo {
		width: 130px;
	}
	#header .gnav {
		float:none;
		margin-top: 50px;
	}
	#header .gnav li {
		float:none;
		padding:17px 0;
		text-align:center;
	}
	#header .gnav li a {
		font-size:2.3rem;
	}

	/*@media screen and (orientation: landscape) {
		#header .gnav ul {
			margin-top:6%;
		}
		#header .gnav ul li {
			padding:8px 0;
		}
	}*/
		
}

.drawer-trigger {
  display: none;
}

@media screen and (max-width: 768px) {
  .drawer-trigger {
    display: block;
    height: 35px;
    padding-top: 5px;
    position: absolute;
    right: 15px;
    top: 19px;
    width: 35px;
    z-index: 100;
  }
  .drawer-trigger p {
    color: #000;
    font-size: 1rem;
    line-height: 1.4;
    text-align: center;
  }
  .drawer-trigger p span {
    background-color: #000;
    display: inline-block;
    height: 1px;
    position: relative;
    width: 25px;
  }
  .drawer-trigger p:before, .drawer-trigger p:after {
    background-color: #000;
    content: "";
    height: 1px;
    left: 5px;
    position: absolute;
    width: 25px;
  }
  .drawer-trigger p:before {
    top: 14px;
  }
  .drawer-trigger p:after {
    top: 23px;
  }
  header.js-fixed .drawer-trigger p {
    color: #000;
  }
  header.js-fixed .drawer-trigger p span {
    background-color: #000;
  }
  header.js-fixed .drawer-trigger p:before, header.js-fixed .drawer-trigger p:after {
    background-color: #000;
  }
}

nav#drawer-menu .menu-upper {
  display: none;
}

@media screen and (max-width: 768px) {
  nav#drawer-menu {
    background-color: rgba(255, 255, 255, 1);
    color: #fff;
    display: none;
    height: 100%;
    overflow: auto;
    position: fixed;
    left: 0;
    top: 0;
    width: 100%;
    z-index: 99;
  }
  nav#drawer-menu.block {
    display: block;
    z-index: 101;
  }
  nav#drawer-menu .menu-upper {
    display: block;
		padding: 20px;
  }
  nav#drawer-menu .close span {
    position: relative;
  }
  nav#drawer-menu .close span:before, nav#drawer-menu .close span:after {
    background-color: #000;
    content: "";
    display: block;
    height: 1px;
    left: -22px;
    position: absolute;
    top: 50%;
    width: 20px;
  }
  nav#drawer-menu .close span:before {
    -webkit-transform: rotate(-45deg);
    transform: rotate(-45deg);
  }
  nav#drawer-menu .close span:after {
    -webkit-transform: rotate(-135deg);
    transform: rotate(-135deg);
  }
  nav#drawer-menu.block .menu-upper {
    /*height: 50px;*/
    position: relative;
  }
  nav#drawer-menu.block .menu-upper .close {
    background-color: transparent;
    height: 30.5px;
    margin-top: 0;
    position: absolute;
    right: 15px;
    top: 25px;
    width: 30.5px;
    z-index: 300;
  }
  nav#drawer-menu.block .menu-upper .close p {
    height: auto;
  }
  nav#drawer-menu.block .menu-upper .close span {
    display: inline-block;
    height: 30.5px;
    width: 30.5px;
    -webkit-transform: translate(-10%, -20%);
    transform: translate(-10%, -20%);
  }
  nav#drawer-menu.block .menu-upper .close span:before, nav#drawer-menu.block .menu-upper .close span:after {
    left: 0;
    width: 30.5px;
  }
}

@media screen and (-ms-high-contrast: active), (-ms-high-contrast: none) {
  nav#drawer-menu.block-ie10 {
    transition: .3s ease;
  }
}

@media screen and (max-width: 768px) {
  #overlay {
    width: 100%;
    height: 100%;
    position: fixed;
    left: 0;
    top: 0;
    z-index: -1;
    transition: 0.3s;
    background: rgba(255, 255, 255, 0.5);
    filter: progid:DXImageTransform.Microsoft.Alpha(Opacity=0);
    opacity: 0;
  }
  #overlay.block {
    z-index: 9;
    filter: progid:DXImageTransform.Microsoft.Alpha(enabled=false);
    opacity: 1;
  }
  #overlay-android {
    width: 100%;
    height: 100%;
    position: fixed;
    left: 0;
    top: 0;
    display: none;
    background: rgba(255, 255, 255, 0.5);
    z-index: 8;
  }
}




/* main
============================== */
#main section,
#main .box_section,
#main > .service_wrap,
#main > .contact_wrap {
	padding-top:60px;
	padding-bottom:60px;
}

/* breadcrumbs */
#breadcrumbs {
	background-color:#fafafa;
	padding:20px 0;
	width:100%;
}
#breadcrumbs ul {
	letter-spacing:-0.4em;
	margin-left:auto;
	margin-right:auto;
	width:980px;
}
#breadcrumbs ul li {
	color:#2b2b2b;
	display:inline-block;
	line-height:1;
	letter-spacing:normal;
	margin-left:15px;
	position:relative;
}
#breadcrumbs ul li:first-child {
	margin-left:0;
}
#breadcrumbs ul li:last-child {
	padding-right:0;
}
#breadcrumbs ul li:after {
	color:#999;
	content:"/";
	margin-left:15px;
}
#breadcrumbs ul li:last-child:after {
	content:"";
	margin:0;
}
#breadcrumbs ul li a {
	color:#999;
}


/*PC Layout
------------------------------------------------------ */
@media print, screen and (min-width: 769px) {
	
	
}


/*SP Layout
------------------------------------------------------ */
@media only screen and (max-width: 768px) {
	#main {
		padding-top:66px;
	}
	#main section,
	#main .box_section,
	#main > .service_wrap,
	#main > .contact_wrap {
		padding-top:30px;
		padding-bottom:30px;
	}
	
	/* breadcrumbs */
	#breadcrumbs {
		display:none;
	}
	
}


/* footer
============================== */
#footer {
	background-color:#e8ece9;
}
#footer .ft_inner {
	margin-left:auto;
	margin-right:auto;
	padding-top:60px;
	padding-bottom:60px;
	width:980px;
	text-align: center;
}
#footer .list_bunner {
	overflow:hidden;
}
#footer .list_bunner li {
	display: inline-block;
	/*float:left;*/
	margin-left:17px;
	width:315px;
}
#footer .list_bunner li:first-child {
	margin-left:0;
}
#footer .list_bunner li img {
	height: auto;
	min-width: inherit;
	width: 100%;
}
#footer .ft_lower {
	margin-top:40px;
	overflow:hidden;
}
#footer .license_icn {
	float:left;
	letter-spacing:-0.4em;
	text-align:center;
	width:310px;
}
#footer .license_icn p {
	display:inline-block;
	letter-spacing:normal;
	margin-top:0;
	margin-left:20px;
	vertical-align:top;
	width:60px;
}
#footer .license_icn p:first-child {
	margin-left:0;
}
#footer .footer_link {
	/*float:right;*/
	letter-spacing:-0.4em;
	overflow:hidden;
}
#footer .footer_link li {
	border-right:1px solid #000;
	display:inline-block;
	letter-spacing:-0.5px;
	line-height:1;
	padding:0 15px;
	vertical-align:middle;
	text-align:center;
}
#footer .footer_link li:first-child {
	padding-left:0;
}
#footer .footer_link li:last-child {
	border-right:0;
	padding-right:0;
}
#footer .footer_link li a {
	color:#000;
	font-size:1.4rem;
}

#footer .footer_text {
	text-align: left;
	margin-top: 40px;
	display: table;
	width: 100%;
}
#footer .footer_text > * {
	font-size: 1.4rem;
	display: table-cell;
	vertical-align:bottom;
}
#footer .footer_text > * dt {
	font-weight: 500;
}
#footer .footer_text > * dd {
	font-size: 1.3rem;
}
#footer .footer_text .copyright {
	font-size: 1.3rem;
	text-align: right;
	/*float:right;*/
	margin-top:20px;
}

.pagetop {
}
.pagetop span {
  background-color: #ccc;
	cursor: pointer;
  display: block;
  height: 50px;
  position: relative;
  text-align: center;
	text-indent: -999em;
  text-decoration: none;
}
.pagetop span:before {
  content: "";
  position: absolute;
  border-right: 1px solid #FFF;
  border-top: 1px solid #FFF;
  height: 12px;
  left: 50%;
  top: 50%;
  width: 12px;
  -webkit-transform: translate(-50%, -30%) rotate(-45deg);
  transform: translate(-50%, -30%) rotate(-45deg);
}
.pagetop:hover {
  opacity: 0.8;
	-webkit-transition: 0.2s ease-in-out;
  transition: 0.2s ease-in-out;
}


/*PC Layout
------------------------------------------------------ */
@media print, screen and (min-width: 769px) {
	
	
}


/*SP Layout
------------------------------------------------------ */
@media only screen and (max-width: 768px) {
	#footer {
	}
	#footer .ft_inner {
		padding-top:30px;
		padding-bottom:20px;
		width:100%;
	}
	#footer .list_bunner {
		padding:0 10px;
	}
	#footer .list_bunner li {
		float:none;
		margin-left:0;
		margin-top:10px;
		width:100%;
	}
	#footer .list_bunner li:first-child {
		margin-top:0;
	}
	#footer .ft_lower {
		margin-top:30px;
	}
	#footer .license_icn {
		float:none;
		margin-top:15px;
		width:100%;
	}
	#footer .license_icn p {
		margin-left:15px;
		width:40px;
	}
	#footer .footer_link {
		border-top:1px solid #ccc;
		float:none;
	}
	#footer .footer_link li {
		border-bottom:1px solid #ccc;
		border-right:1px solid #ccc;
		padding:0;
		width:50%;
	}
	#footer .footer_link li:nth-child(2n) {
		border-right:none;
	}
	#footer .footer_link li a {
		display:block;
		font-size:1rem;
		padding:10px 0;
	}
	

#footer .footer_text {
	margin-top: 4vw;
	display: block;
}
#footer .footer_text > * {
	text-align: center;
	display: block;
}
#footer .footer_text > * dd {
	font-size: 1.2rem;
}
#footer .footer_text .copyright {
		font-size:1.2rem;
	text-align: center;
}
	
	.pagetop {
		bottom: 10px;
		height: auto;
		position: fixed;
		right: 10px;
		z-index: 10;
	}
	.pagetop span {
		background-color: rgba(204,204,204,.7);
		border-radius: 100%;
		height: 40px;
		width: 40px;
	}
	.pagetop:hover {
    opacity: 1;
  }
}



/* not Found
============================== */
.notFound {
	text-align: center;
}
.notFound .heading01-jp {
	font-size: 2.4rem;
	font-weight: bold;
}
.notFound .heading01-jp span {
	color: #666;
	display: block;
	font-size: 1.4rem;
	font-weight: normal;
}
.notFound .sorry {
	font-size: 1.8rem;
	line-height: 2;
	margin-top: 30px;
}


/*SP Layout
------------------------------------------------------ */
@media only screen and (max-width: 768px) {
	.notFound {
	}
	.notFound .heading01-jp {
		font-size: 1.4rem;
	}
	.notFound .heading01-jp span {
		font-size: 1.1rem;
	}
	.notFound .sorry {
		font-size: 1.2rem;
		line-height: 1.5;
		margin-top: 15px;
	}
}



/* Clearfix
------------------------------------------------------ */
dummy:after {
	content: "";
	display: block;
	clear: both;
}
