﻿@charset "utf-8";
body, div, dl, dt, dd, ul, ol, li, h1, h2, h3, h4, h5, h6, pre, form, input, textarea, p, th, td {margin:0;padding:0;}
address, caption, em, strong, th {font-style:normal;}
table {border-collapse:collapse;border-spacing:0;}
caption, th {text-align:left;}
q:before ,q:after {content:'';}
object, embed {vertical-align:top;}
h1, h2, h3, h4, h5, h6 {font-size:100%;}
img, abbr {border:0;vertical-align:bottom;}
li {list-style-type:none;}
/*body {font-family:"メイリオ",meirio,verdana,"ヒラギノ角ゴ Pro W3","Hiragino Kaku Gothic Pro",Osaka,"ＭＳ Ｐゴシック","MS PGothic",Sans-Serif;font-size:75%;line-height:150%;letter-spacing:0.1em;color:#333;}*/
/*body {font-family:"ヒラギノ角ゴ Pro W3","Hiragino Kaku Gothic Pro","メイリオ","Meiryo","ＭＳ Ｐゴシック",sans-serif;line-height:170%;color:#111;}*/

.spOnly {
  display: none; }
  @media only screen and (max-width: 599px) {
    .spOnly {
      display: block; } }

@media only screen and (max-width: 599px) {
  .spNone {
    display: none; } }

@media only screen and (max-width: 959px) {
  .pcOnly {
    display: none; } }

@media only screen and (min-width: 960px) {
  .pcNone {
    display: none; } }


body {font-family:"Hiragino Kaku Gothic Pro W3","Hiragino Kaku Gothic ProN",Meiryo,sans-serif; /*font-size:75%;*/line-height:170%;color:#111;}
html>/**/body {font-size:12px;}
.clearfix:after {content:".";display:block;clear:both;height:0;visibility:hidden;}
.clearfix {min-height:1px;}
* html .clearfix {height:1px;/*\*//*/height:auto;overflow:hidden;/**/}
.inner {width:1100px;margin:0 auto;}
header div.inner {position:relative;height:145px;}
header .logo {position:absolute;bottom: 20px;}
header h1 {position:absolute;top:0; font-weight: lighter;}
header .char {position:absolute;top: 16px;right: 360px;}
header .office {position:absolute;bottom:20px;right:170px;min-width:155px;}
header .contact {position:absolute;bottom:20px;right:0px;min-width:155px;}
header .btn a {background:#444;color:#FFF;text-decoration:none;display:table-cell;padding:0;border-radius:5px;white-space:nowrap;text-align:center;vertical-align:middle;height:50px;width:150px;font-weight:bold;}
header .office a {font-size:18px;}
header .office a:hover {background:#D90000;}
header .contact a {font-size:18px;}
header .contact a:hover {background:#D90000;}
header .btn a img {vertical-align:middle;}
header .navi {/*border-top:5px solid #000;*/border-bottom:5px solid #000;}
header .navi .line-body {background: #f2f2f2;background: -webkit-linear-gradient(#FFF 0%,#f2f2f2 100%);background: linear-gradient(#FFF 0%,#f2f2f2 100%);padding:6px 0;}
/*header .navi .line-body .line-inner {border-top:2px solid #E50012;border-bottom:2px solid #E50012;}*/
header .navi ul {display:table;}
header .navi ul li {display:table-cell;vertical-align:middle;/*padding:3px 0;*/}
header .navi ul li a {display:block;text-align:center;font-size:24px; letter-spacing: 1px; color:#000;text-decoration:none;font-weight:bold;line-height:100%;border-left:1px solid #ddd;padding:10px 0 13px;}
header .navi ul li a:hover{color:#999;}
/*header .navi ul li:nth-child(4) a,header .navi ul li:nth-child(5) a {font-size:25px;padding:15px 0;line-height:100%;}*/
header .navi ul li:last-child {border-right:1px solid #ddd;}
header .navi ul li a span {font-size:11px;color:#888;display:block;letter-spacing:0;line-height:100%;font-weight: lighter; margin: 6px 0 0 0;}
header .navi ul li a:hover span {color:#ccc;}
header #menu-btn {position:absolute;top:38px;left:67.5%;display:none;}
header .sp-menu {width:100%;display:none;}
header .sp-menu td {border:1px solid #D80C18;background:#FFF;width:50%;}
header .sp-menu td a {padding:1em 0 1em 2em;text-indent:-1.5em;display:block;font-size:11px;text-decoration:none;color:#000;vertical-align:middle;line-height:120%;}
header .sp-menu .b-cell td a {padding:1.5em 0 1.5em 2em;}

#h-menu {position:relative;width:100px;height:30px;cursor:pointer;display:block;border:1px solid #CCC;border-radius:4px;text-align:center;background-color:#444;}
#h-text {color:#FFF;text-align:center;font-size:15px;font-weight:bold;display:block;margin:5px 0 0 0;}
#h-icon {position:relative;display:block;width:23px;height:17px;top:5px;left:7px;background-color:#FFF;float:left;}
#h-icon:before, #h-icon:after {position:absolute;left:0;content:"";width:100%;border-top:4px solid #444;}
#h-icon:before {top:3px;}
#h-icon:after {bottom:3px;}

#container {max-width:1100px;margin:0 auto;padding:0 0 50px 0;position:relative;}

#container .pankuzu { background: #f2f2f2; padding: 15px 15px ; font-size: 12px;}
#container .pankuzu li {float:left;}
#container .pankuzu li a {color:#333;text-decoration:none;}

#footer-link {background:#FFFAEB;border-bottom:8px solid #000;}
#footer-link .inner {padding:18px 0 0 0;}
#footer-link ul {padding:0 0 0 100px;}
#footer-link ul:before {content:"　|　";}
#footer-link ul li {display:inline-block;padding:0 0 18px 0;}
#footer-link ul li a {color:#444;text-decoration:none;display:block;}
#footer-link ul li a:hover{color:#D80C18;}
#footer-link ul li a:after {content:"　|　";}
#copyright {background:#D80C18;color:#FFF;font-size:14px;text-align:center;padding:1em 0;}
.new_menu { display: none;}

#cookie {background:#333;opacity:0.9;width:340px;padding:25px 20px 15px 20px;position:fixed;bottom:20px;left:20px;z-index:1000;}
#cookie p {color:#FFF;font-size:14px;margin:0 0 0.5em 0;font-family:"Yu Gothic", "游ゴシック", YuGothic, "游ゴシック体", "ヒラギノ角ゴ Pro W3", "メイリオ", sans-serif;}
#cookie a {color:#FFF;}
#cookie input {background:#FFF;border:none;display:block;width:100%;text-align:center;padding:5px 0;font-size:16px;font-weight:bold;cursor:pointer;}
#cookie:hover {opacity:1;}
#cookie:hover input {background:#D6B452;}
@media screen and (max-width: 768px) {
  #cookie {width:100%;left:0;box-sizing:border-box;bottom:0;padding:10px;}
  #cookie p {font-size:12px;}
  #cookie input {font-size:14px;padding:3px 0;}
}

@media only screen and (max-width:959px){
	.inner {width:100%;}
	header #menu-btn {display:block;}
	header div.inner {height:60px;}
	header h1 {top:-2px; left:2.3%; font-size:9px; color: #666;}
	header .logo_sp {position:absolute;top:16px;left:2.3%;bottom: 20px;}
	header .logo_sp a img {width:62%;height:auto;}
	header .char {display:none;}
	header .office {display:none;}
	header .contact {display:none;}
	header .navi {display:none;}

	#container .pankuzu {padding:8px 5px; color: #666;}

	#footer-link ul {padding:0;}
	#footer-link ul:before {content:none;}
	#footer-link ul li {display:block;padding:0;}
	#footer-link ul li a {padding:0.5em 0 0.5em 1em;background:#FFF;border-top:1px solid #D80C18;border-left:1px solid #D80C18;border-right:1px solid #D80C18;}
	#footer-link ul li a:after {content:none;}
	#copyright {font-size:11px;letter-spacing:0;}
	
	.new_menu{
		display: flex;
		width: 141px;
		position: absolute;
		right: 49px;
		top: 3px;
	}
	.new_menu li{
		width: 44px;
		margin: 0 0 0 3px;
	}
	
.modal{
    display: none;
    height: 100vh;
    position: fixed;
    top: 0;
    width: 100%;
	z-index: 888;
}
.modal__bg{
    background: rgba(0,0,0,0.4);
    height: 100vh;
    position: absolute;
    width: 100%;
}

	#modal01 .modal__content .modal_op{
		position: fixed;
		z-index: 999;
		top: 32px;
		right: 155px;
	}
	#modal02 .modal__content .modal_op{
		position: fixed;
		z-index: 999;
		top: 32px;
		right: 106px;
	}
	#modal03 .modal__content .modal_op{
		position: fixed;
		z-index: 999;
		top: 32px;
		right: 57px;
	}
	.modal__content .modal_op img{
		width: auto;
		height: 18px;
	}
	
.modal__content{
    background: #fff;
	border: 2px solid #000;
	padding: 15px 20px 0 20px;
    position: absolute;
    top: 50px;
	right: 10px;
    /*left: 50%;
    transform: translateX(-50%);
    -webkit-transform: translateX(-50%);
    -ms-transform: translateX(-50%);*/
	width: 280px;
	height: auto;
}	
	.modalinset{
		
	}	
	.modalinset li{
		border-bottom: 1px solid #ccc;
		padding: 0 0 20px;
		margin: 0 0 20px;
	}
	.modalinset li:last-child{
		border-bottom: none;
		padding: 0;
	}
	.modalinset li p{
		font-size: 10px !important;
		line-height: 1.4em;
		margin: 5px 0 7px;
	}
	.modalinset li span.time{
		font-size: 10px !important;
		line-height: 1.2em;
		display: block;
		text-align: center;
		margin: 5px 0 0 0;
	}
	.modalinset li .modal_title{
		font-weight: bold;
		font-size: 14px;
		letter-spacing: 1px;
		line-height: 28px;
		height: 28px;
		padding:  0 0 0 34px;
	}
	.modalinset li .mticon_a{
		background: url("../files/img/index/mticon_a.png") no-repeat left center;
		background-size: 28px;
	}
	.modalinset li .mticon_b{
		background: url("../files/img/index/mticon_b.png") no-repeat left center;
		background-size: 28px;
	}
	.modalinset li .mticon_c{
		background: url("../files/img/index/mticon_c.png") no-repeat left center;
		background-size: 28px;
	}
	.modalinset li .mticon_d{
		background: url("../files/img/index/mticon_d.png") no-repeat left center;
		background-size: 28px;
	}
	.modalinset li .mticon_e{
		background: url("../files/img/index/mticon_e.png") no-repeat left center;
		background-size: 28px;
	}
	.modalinset li .mticon_f{
		background: url("../files/img/index/mticon_f.png") no-repeat left center;
		background-size: 28px;
	}
	.modalinset li .mticon_g{
		background: url("../files/img/index/mticon_g.png") no-repeat left center;
		background-size: 28px;
	}
	.modalinset li a{
		display: block;
		width: 80%;
		color: #fff;
		font-weight: bold;
		line-height: 50px;
		height: 50px;
		font-size: 14px;
		text-align: center;
		text-decoration: none;
		margin: 0 auto;
		border-radius: 5px;
	}
	.modalinset li a.mb01{ background: #0068b7;}
	.modalinset li a.mb02{ background: #0b3779;}
	.modalinset li a.mb03{ background: #eb6100;}

	.modalinset li a span{
		padding: 0 0 0 30px;
		position: relative;
	}
	.modalinset li a span:before{
		content: "";
		position: absolute;
		top: 2px;
		left: 0;
		width: 18px;
		height: 14px;
		background: url("../files/img/index/icon_win.svg");
		background-size: 18px 14px;
	}
	.modalinset li a.telno{
		font-size: 26px;
		font-weight: bold;
		color: #0068b7;
		height: auto;
		line-height: 1em;
	}
	
}


@media only screen and (max-width:599px){

.inner {width:100%;}
header #menu-btn {display:block;}
header div.inner {height:60px;}
header h1 {top:-2px; left:2.3%; font-size:9px; color: #666;}
header .logo {top:16px;left:2.3%;}
header .logo a img {width:62%;height:auto;}
header .char {display:none;}
header .office {display:none;}
header .contact {display:none;}
header .contact {width:70px;min-width:inherit;top:12px;right: 47px;}
header .contact a {font-size:11px;padding:8px 0;width:100%;display:block;height:inherit;}
header .contact a img {width:25px;height:25px;}
header .navi {display:none;}

#container .pankuzu {padding:8px 5px; color: #666; font-size: 10px;}

#footer-link ul {padding:0;}
#footer-link ul:before {content:none;}
#footer-link ul li {display:block;padding:0;}
#footer-link ul li a {padding:0.5em 0 0.5em 1em;background:#FFF;border-top:1px solid #D80C18;border-left:1px solid #D80C18;border-right:1px solid #D80C18;}
#footer-link ul li a:after {content:none;}
#copyright {font-size:11px;letter-spacing:0;}

}


footer .choei {
  background: #f2f2f2;
  padding: 50px 0 15px; }
  @media only screen and (max-width: 959px) {
    footer .choei {
      padding: 20px 0; } }
  footer .choei .logo {
    width: 1100px;
    margin: 0 auto 40px; }
    @media only screen and (max-width: 959px) {
      footer .choei .logo {
        width: auto;
        margin: 0 20px 20px; } }
    @media only screen and (max-width: 959px) {
      footer .choei .logo img.img_logo {
        width: 140px; } }
  footer .choei .sitemap {
    width: 1100px;
    margin: 0 auto;
    display: flex;
    justify-content: space-between; }
    @media only screen and (max-width: 959px) {
      footer .choei .sitemap {
        width: auto;
        margin: 0 20px; } }
    @media only screen and (max-width: 599px) {
      footer .choei .sitemap {
        display: block; } }
    footer .choei .sitemap li {
      width: 23%; }
      @media only screen and (max-width: 599px) {
        footer .choei .sitemap li {
          width: auto;
          margin: 0 0 20px; } }
      footer .choei .sitemap li span {
        font-size: 14px;
        font-weight: bold;
        display: block;
        margin: 0 0 8px; }
      footer .choei .sitemap li a {
        display: block;
        margin: 0 0 8px;
        color: #222;
        text-decoration: none; }
        footer .choei .sitemap li a:hover {
          text-decoration: underline; }
        footer .choei .sitemap li a span {
          font-size: 12px;
          font-weight: lighter;
          display: inline; }
        footer .choei .sitemap li a.tb:after {
          content: url(../files/img/icon_tb.png);
          margin: 0 0 0 5px; }
  footer .choei .baselink {
    width: 1100px;
    border-top: 1px solid #ccc;
    padding: 15px 0 0 0;
    margin: 15px auto 0;
    display: flex;
    justify-content: center; }
    @media only screen and (max-width: 959px) {
      footer .choei .baselink {
        width: auto;
        border: none;
        margin: 20px 0 0 0;
        padding: 0; } }
    @media only screen and (max-width: 599px) {
      footer .choei .baselink {
        flex-direction: column;
        margin: 0; } }
    footer .choei .baselink a {
      margin: 0 25px;
      color: #666; }
      @media only screen and (max-width: 959px) {
        footer .choei .baselink a {
          margin: 0 10px; } }
      @media only screen and (max-width: 599px) {
        footer .choei .baselink a {
          display: block;
          padding: 7px 10px;
          border-bottom: 1px solid #ccc; } }
      footer .choei .baselink a:hover {
        text-decoration: underline; }
footer .copyright {
  text-align: center;
  background: #444;
  color: #999;
  padding: 5px 0;
  font-size: 12px; }
  @media only screen and (max-width: 959px) {
    footer .copyright {
      font-size: 10px;
      letter-spacing: 0.1em; } }

/*footerend*/


/*ヘッダーまわりはサイトに合わせて調整してください*/
.spmenu {
	padding:0;
	/*background: #ccc;*/
	display: block;
	width: 44px;
	position: absolute;
	top: 3px;
	right: 5px;
}

#nav-drawer {
  position: relative;
	text-align: right;
}

/*チェックボックス等は非表示に*/
.nav-unshown {
  display:none;
}

/*アイコンのスペース*/
#nav-open {
  display: inline-block;
  width: 44px;
  height: 50px;
  vertical-align: middle;
}

/*ハンバーガーアイコンをCSSだけで表現*/
#nav-open span, #nav-open span:before, #nav-open span:after {
  position: absolute;
  height: 3px;/*線の太さ*/
  width: 22px;/*長さ*/
  border-radius: 3px;
  background: #222;
  display: block;
  content: '';
  cursor: pointer;
}
#nav-open span:before {
  bottom: -8px;
}
#nav-open span:after {
  bottom: -16px;
}

/*閉じる用の薄黒カバー*/
#nav-close {
  display: none;/*はじめは隠しておく*/
  position: fixed;
  z-index: 99;
  top: 0;/*全体に広がるように*/
  right: 0;
  width: 100%;
  height: 100%;
  background: black;
  opacity: 0;
  transition: .3s ease-in-out;
}

/*中身*/
#nav-content {
  overflow: auto;
  position: fixed;
  top: 0;
  right: 0;
  z-index: 9999;/*最前面に*/
  width: 80%;/*右側に隙間を作る（閉じるカバーを表示）*/
  max-width: 300px;/*最大幅（調整してください）*/
  height: 100%;
  background: #fff;/*背景色*/
  transition: .3s ease-in-out;/*滑らかに表示*/
  -webkit-transform: translateX(105%);
  transform: translateX(105%);/*左に隠しておく*/
}

/*チェックが入ったらもろもろ表示*/
#nav-input:checked ~ #nav-close {
  display: block;/*カバーを表示*/
  opacity: .5;
}

#nav-input:checked ~ #nav-content {
  -webkit-transform: translateX(0%);
  transform: translateX(0%);/*中身を表示（右へスライド）*/
  box-shadow: 6px 0 25px rgba(0,0,0,.15);
}

#nav-content .spinner{
	background: #220000;
	padding: 0 20px;
}
#nav-content .spinner li{
	text-align: left;
	border-top: 1px solid #635b5b;
}
#nav-content .spinner li a{
	display: block;
	line-height: 1.2em;
	color: #fff;
	font-size: 14px;
	font-weight: bold;
	text-decoration: none;
	padding: 20px 0;
}
#nav-content .spinner li a span{
	font-size: 10px;
	padding: 0 0 0 10px;
	color: #635b5b;
}
#nav-content .spinner .subinner{
	margin: 0 0 10px;
}
#nav-content .spinner .subinner li{
	border-top: none;
}
#nav-content .spinner .subinner li a{
	padding: 5px 0 15px;
	color: #222;
}
#nav-content .spinner .subinner li a span{
	font-size: 12px;
	position: relative;
	display: inline-block;
	padding: 0 0 0 16px;
	vertical-align: middle;
	text-decoration: none;
	color: #fff;
}
#nav-content .spinner .subinner li a span::before,
#nav-content .spinner .subinner li a span::after{
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    margin: auto;
    content: "";
    vertical-align: middle;
}
#nav-content .spinner .subinner li a span::before{
    left: 3px;
    width: 4px;
    height: 4px;
    border-top: 1px solid #999;
    border-right: 1px solid #999;
    -webkit-transform: rotate(45deg);
    transform: rotate(45deg);
}

@media only screen and (min-width:959px){
	.spmenu {
		display: none;
	}
	#nav-open {
		display:none;
	}
}

@media print{
    .new_menu{
        display: none;
    }
	.modal__content{
		display: none;
	}
	.logo_sp{
		display: none;
	}
	.spmenu{
		display: none;
	}
}





