body{
	font-size: 15px;
	font-family:"Yu Gothic", "Yu Gothic","Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ","Meiryo"," Osaka", "ＭＳ Ｐゴシック";
	color: #1f2021;
}

a{ cursor: pointer; }
a:hover{ opacity: 0.7; }

p {
	font-size: 16px;
	line-height: 37px;
	letter-spacing: 0.05em;
}

h3{
	font-size: 36px;
	font-weight: bold;
	color: #000000;
	display: inline-block;
	line-height: 1.4em;
}
h3 span{
	font-size: 15px;
	color: #ff0000;
	font-weight: initial;
	display: block;
	font-family: "Yu Mincho", "YuMincho", "Sawarabi Mincho" , "ＭＳ Ｐ明朝", "MS PMincho", "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", serif;
	line-height: 1.4em;
}

.br_sp{ display: none; }

section{
	padding-top: 100px;
	margin: 0 auto;
}

section .sub_ttl {
    font-size: 20px;
    display: block;
	font-weight: bold;
	margin-bottom: 20px;
	font-family: "Yu Mincho", "YuMincho", "Sawarabi Mincho" , "ＭＳ Ｐ明朝", "MS PMincho", "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", serif;
}

section .sub_ttl:before ,
section .sub_ttl:after {
    content: "";
    width: 20px;
    height: 20px;
    display: inline-block;
    position: relative;
    top: 6px;
    margin-right: 30px;
    background-image: url(../img/common/icon.png);
    background-size: contain;
    background-repeat: no-repeat;
    vertical-align: top;
}

section .sub_ttl:after{ margin: 0 0 0 30px; }

.ttl_red_sub::before{
    content: "";
    width: 9px;
    height: 9px;
    display: inline-block;
    position: relative;
    top: 7px;
    margin-right: 19px;
    background-image: url(../img/common/icon3.gif);
    background-size: contain;
    background-repeat: no-repeat;
    vertical-align: top;
}



@media screen and (max-width: 768px){
	section { padding-top: 60px; }
	.br_sp{ display: block; line-height: 0; }
}

@media screen and (max-width: 700px){

	p{ font-size: 15px; line-height: 30px; }
	section .sub_ttl{ margin-bottom: 10px; font-size: 18px; }
	section .sub_ttl:before, section .sub_ttl:after{ top: 4px; margin-right: 20px; }
	section .sub_ttl:after{ margin: 0 0 0 20px; }


}



/*===================================================

header

=================================================*/

body{ letter-spacing: 0.05em; }

#wrapper{
	overflow: hidden;
	transition-duration: 2s;
}

header{
	width: 100%;
	font-family: "Yu Mincho", "YuMincho", "Sawarabi Mincho" , "ＭＳ Ｐ明朝", "MS PMincho", "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", serif;
	/*height: 100px;*/
	position: fixed;
	z-index: 1000000000;
	background-color: #ffffff;
}

h1{
	display: inline-block;
	padding-left: 30px;
	font-size: 0;
	padding-top: 26px;
	float: left;
}

header h1 a{
	background: url("../img/common/h1.jpg") top left no-repeat;
	background-size: contain;
	height: 47px;
	width: 240px;
	overflow: hidden;
	display: inline-block;
}

@media screen and (max-width: 1680px){
	header h1 a{ height: 42px; width: 215px; }
	h1{ padding-left: 20px; }
}

@media screen and (max-width: 768px){

	header{ height: 72px; }

	header h1{ padding-top: 15px; }

	header h1 a{ height: 40px; width: 200px; }
}

/*===================================================

header ドロップダウン

=================================================*/

ul.dropmenu {
  list-style: none;
	width:calc(100% - 30%);
  /*width: 73%;
  height: 40px;
	padding-top: 32px;*/
	float: left;
	margin-left: 114px;
	font-family:"Yu Gothic", "Yu Gothic","Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ","Meiryo"," Osaka", "ＭＳ Ｐゴシック";
	color: #000000;
}
ul.dropmenu > li {
  position: relative;
  display: inline-block;
  vertical-align: middle;
}

ul.dropmenu li a {
  display: block;
  text-align: center;
  line-height: 20px;
  font-weight: bold;
  text-decoration: none;
  font-size: 14px;
	padding: 40px 14px;
	color: #000000;
	letter-spacing: 0.01em;
}

ul.dropmenu > li:last-child > a{ padding-right: 0; }

ul.dropmenu li ul {
  visibility: hidden;
  width: 250px;
  list-style: none;
  position: absolute;
  top: 100%;
  left: -1px;
  margin: 0;
  padding: 0;
  border-top: none;
}

ul.dropmenu li ul a{
	padding-left: 16px;
	text-align: left;
	border-bottom: 1px solid #ff0000;
	padding: 14px;
  line-height: 24px;
}

ul.dropmenu li a:hover , ul.dropmenu li ul a:hover{ color: #ff0000; }

ul.dropmenu li:hover ul {
  visibility: visible;
}
ul.dropmenu li ul li {
  background: #fff;
  transition: all .2s ease;
}

@media screen and (max-width: 1880px){
	ul.dropmenu li a{ padding: 40px 8px; }
	ul.dropmenu{ margin-left: 5%; }
}

@media screen and (max-width: 1740px){
	ul.dropmenu{
		margin-left: 2%;
		width:calc(100% - 26%);
	}
}

@media screen and (max-width: 1640px){
	ul.dropmenu{
		margin-left: 2%;
		width:calc(100% - 25%);
	}
}

@media screen and (max-width: 1600px){
	ul.dropmenu{ display: none; }
}

/*===================================================

 header （ハンバーガーメニュー）

=================================================*/

.hamburger {
	background-color: #ff0000;
	width: 110px;
	height: 100px;
	float: right;
}

.hamburger div {
	display: block;
	width: 60px;
	height: 23px;
	position: fixed!important;
	z-index: 10001;
	cursor: pointer;
	right: 25px;
	top: 32px;
}

.hamburger div span:nth-child(1) { margin-top: 0px; }
.hamburger div span:nth-child(2) {
	margin-top: 15px;
	margin-right: 0px;
}
.hamburger div span:nth-child(3) { margin-top: 30px; }

.hamburger div span {
	display: block;
	position: absolute;
	height: 5px;
	width: 100%;
	background: #ffffff none repeat scroll 0% 0%;
	opacity: 1;
	right: 0px;
	transition: all 0.25s ease-in-out 0s;
	transform: rotate(0deg);
}
.hamburger div span.color { background: #ffffff none repeat scroll 0% 0%; }

.hamburger div.opened span:nth-child(1) {
	transform: rotate(135deg);
	margin-top: 10px;
	background: #ffffff!important;
}
.hamburger div.opened span:nth-child(2) {
	opacity: 0;
	right: -75px;
}
.hamburger div.opened span:nth-child(3) {
	transform: rotate(-135deg);
	margin-top: 10px;
	background: #ffffff!important;
}

/*------ hamburger menu clickの時の LIST ------*/

ul.inner {
	width: 100%;
	height: 100%;
	background-color: #ff0000;
	position: fixed;
	-webkit-transition: .5s ease-in-out;
	-moz-transition: .5s ease-in-out;
	transition: .5s ease-in-out;
	z-index: 10000;
	top: 0;
	opacity: 0;
	right: -100%;
	display: block;
	overflow-y: scroll;
}

ul.inner li {
	padding: 0 0 30px;
    text-align: center;
	display: block;
    border: none;
}

ul.inner li:nth-child(1) { margin-top: 125px; }

ul.inner li a {
	text-decoration: none;
	font-size: 20px;
	letter-spacing: 0.09em;
	font-family: "Arial", "Gadget", "sans-serif";
	color: #fff;
	line-height: 1.3em;
}

ul.inner li .sub_list a{ font-size: 16px; }

ul.inner li a span{ font-size: 13px; }

.on { right: 0!important; display: block;}

ul.inner li a.accordion{ margin-left: 32px; }

ul.inner li a.accordion span{
	background: url(../img/common/arrow.png)top center no-repeat;
	overflow: hidden;
	display: inline-block;
	height: 13px;
	width: 14px;
	margin-left: 20px;
}

ul.inner li { padding: 18px 0; }
ul.inner li ul.sub_list li{ background-color: #e90000; }
ul.inner li ul.sub_list li a{ color: #f5f5f5; }

ul.inner li ul.sub_list{ padding-top: 18px; }

ul.inner li ul.sub_list li { border-bottom: 1px solid #ffffff; }
ul.inner li ul.sub_list li:nth-child(1){ margin-top: 0 ; }

@media screen and (max-width: 1260px){

}

@media screen and (max-width: 1024px){

}

@media screen and (max-width: 768px){

	.hamburger{
		width: 72px;
		height: 72px;
	}

	.hamburger div{
		width: 40px;
		right: 16px;
		top: 22px;
	}

	.hamburger div span{ height: 4px; }
	.hamburger div span:nth-child(2){ margin-top: 12px; }
	.hamburger div span:nth-child(3){ margin-top: 24px; }

	.hamburger a:hover{ opacity: 1; }
	ul.inner > li:nth-child(1) { margin-top: 85px; }
	ul.inner > li:last-child { padding-bottom: 60px; }

}

@media screen and (max-width: 700px){

	.hamburger { top: 27px; right: 22px; }
	a:hover{ opacity: 1; }

}

/*===================================================

#header

=================================================*/

#header{
	z-index: -1;
	margin-top: 100px;
	width: 100%;
	overflow: hidden;
	padding: 0;
}

#header span {
  height: 440px;
  display: block;
  width: 90%;
  float: right;
}

#header div{
	height: 177px;
	display: block;
	width: 773px;
	float: left;
	margin: -310px auto 0;
	z-index: 1111111111111111;
}

@media screen and (max-width: 1000px){

	#header div{ width: 80%; }

	#header span {
		height: 240px;
		display: block;
		width: 90%;
		float: right;
	}
	#header div{
		height: 140px;
		margin: -190px auto 0;
	}

}

@media screen and (max-width: 768px){

	#header{margin-top: 72px;}

}

@media screen and (max-width: 700px){

	#header div{ display: none; }
	#header span {
		height: 200px;
		display: block;
		width: 100%;
		float: initial;
    	position: initial;
	  }

}

/*===================================================

footer

=================================================*/

footer{
	width: 100%;
	overflow: hidden;
	background-color: #ff0000;
	padding: 60px 0 30px;
	font-family: "Yu Mincho", "YuMincho", "Sawarabi Mincho" , "ＭＳ Ｐ明朝", "MS PMincho", "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", serif;
}

footer div{
	width: 1200px;
	overflow: hidden;
	margin: 0 auto;
	font-size: 0;
}

footer div p{
	font-size: 14px;
	color: #ffffff;
}

footer div .company{
	width: 300px;
	float: left;
}

footer div .company a{
	color: #ffffff;
	text-decoration: none;
	font-size: 14px;
}

footer > ul{
	overflow: hidden;
	font-size: 0;
	margin: 0 auto;
	text-align: center;
}

footer > div > ul > li{
	overflow: hidden;
	display: inline-block;
	padding: 0 2.4%;
	text-align: left;
	vertical-align: top;
		font-family:"Yu Gothic", "Yu Gothic","Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ","Meiryo"," Osaka", "ＭＳ Ｐゴシック";
}

footer div ul li .footer_link{ padding-left: 17px; margin-bottom: 30px; }

footer .footer_link li{ text-align: left; }

footer div ul li .footer_link li a{ font-size: 14px; }
footer ul li:last-child{ padding-right: 0; }

footer ul li a{
	text-decoration: none;
	color: #ffffff;
	font-size: 16px;
	cursor:pointer;
	line-height: 1.3em;
}

footer ul li a span{
	font-size: 13px;
	overflow: hidden;
}

footer small{
	color: #ffffff;
	width: 100%;
	text-align: center;
	overflow: hidden;
    display: block;
	margin-top: 70px;
}


@media screen and (max-width: 1260px){
	footer div{ width: 94%; }
	footer > div > ul > li{ padding: 0px 0.8%; }
	footer div .company{
		float: inherit;
		width: auto;
		text-align: center;
	}

}

@media screen and (max-width: 1000px){

	footer div{ width: 90%; }
	footer > div > ul > li{ padding: 0px 5%; width: 39%; }

}

@media screen and (max-width: 768px){

	footer small{ margin-top: 20px; }
	footer{ padding: 60px 0 40px; }
	footer ul li a{ font-size: 15px; }
}

@media screen and (max-width: 700px){

	footer > div > ul > li{ padding: 0; width: 100%; }

}

/*===================================================

ページTOP

=================================================*/

#page_top {
	width: 50px;
  	height: 50px;
    position: fixed;
    bottom: 30px;
    right: 20px;
	background: #000000;
}
#page_top a {
	position: relative;
  	display: block;
  	width: 50px;
  	height: 50px;
	text-decoration: none;
}

#page_top a::before{
    font-family: "Font Awesome 5 Free";
    content: '\f106';
    font-weight: 900;
    font-size: 25px;
    color: #fff;
    position: absolute;
    width: 25px;
    height: 25px;
    top: 10px;
    bottom: 10px;
    right: 0;
    left: 0;
    margin: auto;
	text-align: center;
}

/*===================================================

白ttl

=================================================*/

.ttl_white{
	font-size: 16px;
	display: block;
	font-weight: bold;
	margin-bottom: 12px;
}

.ttl_white::before {
    content: "";
    width: 8px;
    height: 8px;
    display: inline-block;
    position: relative;
    top: 7px;
    margin-right: 10px;
    background-image: url(../img/common/icon7.png);
    background-size: contain;
    background-repeat: no-repeat;
    vertical-align: top;
}

/*===================================================

.arrow

=================================================*/

.arrow {
    position: relative;
    padding: 0 0 0 16px;
}

.arrow::after {
    content: "";
    width: 10px;
    height: 10px;
    position: absolute;
    top: 42%;
    right: 15px;
    margin: auto;
    box-sizing: border-box;
    border: 5px solid transparent;
        border-left-color: transparent;
        border-left-style: solid;
        border-left-width: 5px;
    border-left: 6px solid #ff0000;
}
