@charset "utf-8";

html {
  min-height: 100%;
  position: relative;
}
.pc{ display: block!important; }
.sp{ display: none!important; }
.tb{ display: none!important; }
.ts{ display: none!important; }


/* header
---------------------------------------------------- */
header {
	width: 100%;
	height: 72px;
	position: fixed;
	z-index: 1000;
  padding: 0 50px;
	box-sizing: border-box;
	-moz-box-sizing: border-box;
	-webkit-box-sizing: border-box;
	-o-box-sizing: border-box;
	-ms-box-sizing: border-box;
	background-color: #1e1e1e;
}
header .header_logo {
	float: left;
	padding: 15px 0;
  position: relative;
  z-index: 1000;
}
header .menu1 {
  padding: 200px 0 30px 50px;  /* 2506鶴見修正　: 200px 0 30px;から*/
}
header .menu1 ul.column {
  display: flex;
  flex-flow: column wrap;
  height: 360px;    /* 2506鶴見修正　240pxから*/
}
header .menu1 ul li {
  font-size: 30px;
  line-height: 80px;
}
header .menu1 ul li a {
  color: #FFF;
}
#g-nav{
  position: fixed;
  z-index: 999;
  top:0;
  right: -120%;
  width: 100%;
  height: 100vh;/*ナビの高さ*/
  background-color: #000;
  transition: all 0.3s;
}
#g-nav.panelactive{
  right: 0;
}
#g-nav.panelactive #g-nav-list{
  position: fixed;
  z-index: 999; 
  width: 100%;
  height: 100vh;/*表示する高さ*/
  overflow: auto;
  -webkit-overflow-scrolling: touch;
}

.openbtn1{
  position:fixed;
  z-index: 9999;/*ボタンを最前面に*/
  top: 0;
  right: 30px;
  cursor: pointer;
  width: 45px;
  height:50px;
}
.openbtn1::before {
  content: "MENU";
  left: -1px;
  top: 38px;
	font-size: 16px;
  color: #FFF;
  position: absolute;
}

/*×に変化*/
.openbtn1 span{
  display: inline-block;
  transition: all .4s;
  position: absolute;
  left: 0;
  height: 3px;
  background-color: #FFF;
  width: 100%;
}
.openbtn1 span:nth-of-type(1) {
  top:13px;
}
.openbtn1 span:nth-of-type(2) {
  top:23px;
}
.openbtn1 span:nth-of-type(3) {
  top:33px;
}
.openbtn1.active span:nth-of-type(1) {
  top: 18px;
  left: 8px;
  transform: translateY(6px) rotate(-45deg);
  width: 50%;
}
.openbtn1.active span:nth-of-type(2) {
  opacity: 0;
}
.openbtn1.active span:nth-of-type(3){
  top: 30px;
  left: 8px;
  transform: translateY(-6px) rotate(45deg);
  width: 50%;
}
.openbtn1.active::before {
  content: "CLOSE";
  left: -6px;
}


/* header_cta
---------------------------------------------------- */
.header_cta {
	display: block;
	position: fixed;
	top: 0;
	right: 110px;
}
.header_cta ul li {
	float: left;
	width: 250px;
}
.header_cta ul li img:nth-child(2) {
	display: none;
}


/* contents
---------------------------------------------------- */
.contents {
	max-width: 1080px;
	margin: 0 auto;
}

.blc {
	padding: 120px 0;
}
.blc:nth-child(odd) {
	background-color: #f4f4f4;
	color: #333;
}
.blc .index_h2 {   /* 2508鶴見修正　60pxから */
	padding-bottom: 30px;
}
.blc:nth-child(odd) .index_h2 span {
  animation: blinkAnime2 1s infinite alternate;
}
.blc p span {
	color: #e2a107;
}


/* footer
---------------------------------------------------- */
footer {
	width: 100%;
  padding: 65px 0 60px;
	background-color: #1e1e1e;
}
footer .contents ul {
  text-align: center;
  margin-bottom: 60px;
  font-size: 0;
}
footer .contents ul li {
  display: inline-block;
	font-size: 20px;
}
footer .contents ul li::before {
  content: "　|　";
  color: #FFF;
}
footer .contents ul li:first-child::before {
  content: "";
}
footer .contents ul li a {
  color: #FFF;
}
footer .contents ul li a:hover {
	color: #f7ad00;
}
footer .contents .footer_copy {
	text-align: center;
  color: #FFF;
}


/* cta
---------------------------------------------------- */
.cta {
	display: none;
}


/* page_top
---------------------------------------------------- */
#page_top {
	width: 60px;
	height: 60px;
	position: fixed;
	bottom: 10px;
	right: 10px;
	z-index: 10000;
}
#page_top a {
	display: block;
	width: 60px;
	height: 60px;
}
#page_top a img {
	width: 60px;
	height: 60px;
}


/* anc
---------------------------------------------------- */
.anc {
   margin-top: -100px;
   padding-top: 100px;
   display: block;
}

.anc02 {
   margin-top: -100px;
   padding-top: 100px;
   display: block;
}

/* h
---------------------------------------------------- */
.ttl_h3 {
	font-size: 36px;
	color: #e2a107;
	font-weight: normal;
	margin-bottom: 20px;
}

@media screen and (max-width: 1530px){  /* 2508鶴見追加 */
.pc{ display: block!important; }
.sp{ display: none!important; }
.tb{ display: none!important; }
.ts{ display: none!important; }

/* header
---------------------------------------------------- */
header {
  width: 100%;
  height: 60px;
}

header .header_logo {
    padding: 4px 0 8px ;
}

header .header_logo img {
  height: 1.5rem;  /* 2508鶴見追加 */
}

.header_cta ul li img {
  width: 100%;
}

.header_cta {
  display: block;
  position: fixed;
  top: 0;
  right: 100px;
}
.header_cta ul li {
  float: left;
  width: 210px;
}

.openbtn1{
  width: 36px;
  height: 41px;
  top: -3px;
}
.openbtn1::before {
  content: "MENU";
  left: -1px;
  top: 31px;
  font-size: 12px;
  color: #FFF;
  position: absolute;
}

}


@media screen and (max-width: 1270px){  /* 2508鶴見追加 */
.pc{ display: block!important; }
.sp{ display: none!important; }
.tb{ display: none!important; }
.ts{ display: none!important; }

/* header
---------------------------------------------------- */
header {
  width: 100%;
  height: 50px;
}

header .header_logo {
    padding: 0px 0 11px ;
    margin: -3px;
}

header .header_logo img {
  height: 1.3rem;  /* 2508鶴見追加 */
}

.header_cta ul li img {
  width: 100%;
}

.header_cta {
  display: block;
  position: fixed;
  top: 0;
  right: 70px;
}
.header_cta ul li {
  float: left;
  width: 176px;
}

.openbtn1{
  width: 28px;
  height: 30px;
  top: -5px;
  right: 20px;
}
.openbtn1::before {
  content: "MENU";
  left: -1px;
  top: 27px;
  font-size: 10px;
  color: #FFF;
  position: absolute;
}

.openbtn1 span:nth-of-type(1) {
    top: 13px;
}

.openbtn1 span:nth-of-type(2) {
    top: 22px;
}

.openbtn1 span:nth-of-type(3) {
    top: 31px;
}

.contents {  /* 2509鶴見追加　*/
    max-width: 105%;
    margin: 0 auto;
    padding: 0 10px;
}

}


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

.pc{ display: none!important; }
.tb{ display: block!important; }
.sp{ display: none!important; }
.ts{ display: block!important; }

/* header
---------------------------------------------------- */
header {
  width: 100%;
  height: 46px;
}

header .menu1 {
  padding: 200px 0 30px 20px;  /* 2506鶴見追加　*/
}

header .header_logo {
    padding: 0px 0 8px ;
    margin: -5px;
}


header .header_logo img {
  height: 1.1rem;  /* 2508鶴見追加 */
}

.header_cta ul li img {
  width: 100%;
}

.header_cta {
  display: block;
  position: fixed;
  top: 0;
  right: 60px;
}

.header_cta ul li {
  float: left;
  width: 160px;
}

.openbtn1{
  width: 29px;
  height: 24px;
  top: -7px;
  right: 15px;
}
.openbtn1::before {
  content: "MENU";
  left: -1px;
  top: 24px;
  font-size: 0.4rem;
  color: #FFF;
  position: absolute;
}

.openbtn1 span {
    display: inline-block;
    transition: all .4s;
    position: absolute;
    left: 0;
    height: 2.5px;
    background-color: #FFF;
    width: 100%;
}

.openbtn1 span:nth-of-type(1) {
    top: 13px;
}

.openbtn1 span:nth-of-type(2) {
    top: 21px;
}

.openbtn1 span:nth-of-type(3) {
    top: 29px;
}

/* contents
---------------------------------------------------- */
/*.contents {
  max-width: 94%;
  margin: 0 auto;
}*/

.contents {  /* 2509鶴見追加　*/
    max-width: 105%;
    margin: 0 auto;
    padding: 0 10px;
}

.contents:has(.campaign_bn) {  /* 2506鶴見追加　*/
  text-align: center;
}

}


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

.pc{ display: none!important; }
.tb{ display: block!important; }
.sp{ display: none!important; }
.ts{ display: block!important; }


/* header
---------------------------------------------------- */
header {
  width: 100%;
  height: 72px;
}

header .header_logo {
    padding: 12px 0 8px ;
    margin-left: -33px;
}

header .header_logo img {
  height: 1.4rem;  /* 2508鶴見追加 */
}

.openbtn1{
  width: 25px;
  height: 24px;
  top: -7px;
  right: 12px;
}

.openbtn1::before {
  content: "MENU";
  left: -1px;
  top: 26px;
  font-size: 0.75rem;
  color: #FFF;
  position: absolute;
}

/* header_cta
---------------------------------------------------- */
.header_cta ul li {
	width: auto;
}
.header_cta ul li img:nth-child(1) {
	display: none;
}
.header_cta ul li img:nth-child(2) {
	display: block;
}

.openbtn1{
  width: 36px;
  height: 41px;
  top: 4px;
}

/* contents
---------------------------------------------------- */
/*.contents {
  max-width: 94%;
  margin: 0 auto;
}*/

.contents {  /* 2509鶴見追加　*/
    max-width: 105%;
    margin: 0 auto;
    padding: 0 10px;
}

.contents:has(.campaign_bn) {  /* 2506鶴見追加　*/
  text-align: center;
}

/* footer
---------------------------------------------------- */
footer .footer_btn {
  margin: 0 0 50px 0;
  text-align: center;
}
footer .footer_btn li {
  float: none;
  display: inline-block;
  margin: 10px;
}


}

@media screen and (max-width:750px) {
.pc{ display: none!important; }
.tb{ display: block!important; }
.sp{ display: block!important; }
.pt{ display: none!important; }

/* header
---------------------------------------------------- */
header .header_logo {
    padding: 12px 0 8px ;
    margin-left: -33px;
}

header .header_logo img {
  height: 1.2rem;  /* 2508鶴見追加 */
}

header .menu1 {
  padding: 200px 0 30px 50px;  /* 2506鶴見修正　: 200px 0 30px;から*/
}
header .menu1 ul.column {
  display: flex;
  flex-flow: column wrap;
  height: 360px;    /* 2506鶴見修正　240pxから*/
}
header .menu1 ul li {
  font-size: 20px;
  line-height: 80px;
}
header .menu1 ul li a {
  color: #FFF;
}

header .menu1 ul.column .longtext {  /* 2508鶴見追加 */
  line-height: 1.5rem;
  padding-top: 0;
  padding-bottom: 1.14rem;
}

header .menu1 ul.column li:nth-child(6) {  /* 2508鶴見追加 */
  line-height: 1.5rem;
  padding-top: 1.8rem;
  padding-bottom: 1.06rem;
}
/*
header .menu1 ul.column .longtext {
  padding-top: 1.0rem;
  line-height: 1.5rem;
  padding-bottom: 1.0rem;

}
*/
}  /* 250912鶴見　とじが抜けてたので要注意 */


@media screen and (max-width:590px) {
.pc{ display: none!important; }
.tb{ display: none!important; }
.sp{ display: block!important; }
.pt{ display: none!important; }

header .header_logo {
    padding: 10px 0 8px ;
    margin-left: -46px;
}

header .header_logo img {
  height: 0.6rem;  /* 2508鶴見追加 */
}

}



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

.pc{ display: none!important; }
.tb{ display: none!important; }
.sp{ display: block!important; }
.pt{ display: none!important; }


body {
	margin-bottom: 0;
}


/* contents
---------------------------------------------------- */
/*.contents {
  max-width: 94%;
  margin: 0 auto;
}*/

.contents {  /* 2509鶴見追加　*/
    max-width: 105%;
    margin: 0 auto;
    padding: 0 10px;
}

.contents:has(.campaign_bn) {  /* 2506鶴見追加　*/
  text-align: center;
}

.blc {
	padding: 50px 0;
}
.blc .index_h2 {
	padding-bottom: 30px;
}


/* header
---------------------------------------------------- */
header {
	width: 100%;
	height: 50px;
  padding: 0 10px;
}
header .header_logo {
	padding: 10px 0 0 45px;
}
header .header_logo img {
  height: 0.82rem;
}

header .menu1 {
  padding: 80px 0 30px 30px;  /* 2506鶴見修正　:  80px 0 30px;から*/
}
header .menu1 ul.column {
  height: 250px;  /* 2506鶴見修正　160pxから */
}

header .menu1 ul.column .longtext {  /* 2508鶴見追加 */
  line-height: 1.5rem;
  padding-top: 0;
  padding-bottom: 1.14rem;
}

header .menu1 ul.column li:nth-child(6) {  /* 2508鶴見追加 */
  line-height: 1.5rem;
  padding-top: 0.9rem;
  padding-bottom: 1.3rem;
}

header .menu1 ul li {
  font-size: 18px;
  line-height: 50px;
}
.openbtn1 {
  top: 0;
  right: 10px;
  width: 30px;
}
.openbtn1::before {
	display: none;
}
.openbtn1.active span:nth-of-type(1) {
  top: 18px;
  left: 0px;
  width: 100%;
}
.openbtn1.active span:nth-of-type(3) {
  top: 30px;
  left: 0;
  width: 100%;
}
.header_cta {
	right: 50px;
}
.header_cta ul li img:nth-child(2) {
	width: 50px;
}


/* footer
---------------------------------------------------- */
footer {
  padding: 50px 0 50px;
}
footer .contents ul {
  text-align: center;
  margin-bottom: 60px;
  font-size: 0;
}
footer .contents ul li {
  display: block;
	font-size: 16px;
	margin-bottom: 12px;
}
footer .contents ul li::before {
  content: "";
}
footer .contents .footer_copy {
	font-size: 10px;
}


/* cta
---------------------------------------------------- */
.cta {
	display: block;
	position: fixed;
	bottom: 0;
	left: 0;
	padding: 10px 0;
	background-color: rgba(0,0,0,0.8);
	border-top: 1px solid #f7ad00;
	width: 100%;
	z-index: 100;
}
.cta p {
	color: #f7ad00;
	text-align: center;
	padding-bottom: 10px;
	font-weight: bold;
}
.cta ul li {
	float: left;
	width: 50%;
}
.cta ul li a {
	display: block;
	width: 96%;
	padding: 8px 0;
	border-radius: 5px;
	margin: 0 auto;
	text-align: center;
	background-color: #f7ad00;
}
.cta ul li a span {
	display: inline-block;
	font-weight: bold;
}


/* page_top
---------------------------------------------------- */
#page_top {
	width: 50px;
	height: 50px;
	bottom: 10px;
	right: 10px;
}
#page_top a {
	width: 50px;
	height: 50px;
}
#page_top a img {
	width: 50px;
	height: 50px;
}


/* h
---------------------------------------------------- */
.ttl_h3 {
	font-size: 24px;
	margin-bottom: 20px;
}


}

@media screen and (max-width: 402px){    /* 2509鶴見追加 */

header .header_logo img {
  height: 0.7rem;  /* 2509鶴見修正　0.82remから */
}

}


@media screen and (max-width: 390px){    /* 2508鶴見追加 */

header .header_logo img {
    height: 0.75rem;
}

header .header_logo {
    padding: 9px 0 0 0;
    margin-left: -5.5px;
}

.openbtn1 {
    top: 2px;
}

}


@media screen and (max-width: 375px){    /* 2508鶴見追加 */

header .header_logo img {
    height: 0.65rem;
}

header .header_logo {
    padding: 9px 0 0 0;
    margin-left: -5.5px;
}

.openbtn1 {
    top: 2px;
}

}


@media screen and (max-width: 320px){    /* 2508鶴見追加 */

header {
    width: 100%;
    height: 40px;
    padding: 0 10px;
}

header .menu1 {
    padding: 80px 0 30px 9px;
}

header .menu1 ul li {
  font-size: 17.5px;
  line-height: 50px;
  width: 49%;
}

header .header_logo img {
    height: 0.58rem;
}

header .header_logo {
    padding: 4px 0 0 0;
    margin-left: -5.8px;
}

.header_cta ul li img:nth-child(2) {
    width: 40px;
}

.openbtn1 {
    top: -3px;
    right: 12px;
    width: 25px;
}


}




@media only screen and (min-width: 1251px) {

.panel {
    display: block!important;
}

}