@charset "UTF-8";
.d-flex {
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flex;
  display: -o-flex;
  display: flex; }

#head-key .btn1 {
  text-align: left; }
#head-key .btn_t {
  position: absolute;
	top:92px;
	left:300px;
}
.key-tt{
	width: 1000px;
	margin: 0 auto;
}
#key-box .ttl2{
	text-align:right;
    margin-top: 160px;
}


.btn-fix {
  position: fixed;
  right: 0;
  top: 85px;
  z-index: 100; }
  .btn-fix .btn1 {
    margin-bottom: 15px; }

footer {
  background-color: #000;
  padding-top: 46px;
  padding-bottom: 74px; }
  footer address span a {
    text-decoration: underline; }
    footer address span a:hover {
      text-decoration: none; }

.fz22 {
  font-size: 22px; }

.btn-cus {
  position: relative; }
  .btn-cus:before {
    content: '';
    background-color: #af201e;
    width: 100%;
    height: 100%;
    position: absolute;
    top: 7px;
    left: 7px;
    z-index: 0; }
  .btn-cus a, .btn-cus .span_wrap {
    display: -webkit-flex;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: flex;
    width: 100%;
    height: 100%;
    align-items: center;
    justify-content: center;
    font-size: 18px;
    letter-spacing: 0.15em;
    background-color: #fff;
    color: #000;
    position: relative;
    z-index: 10; }
    .btn-cus a:after, .btn-cus .span_wrap:after {
      content: '';
      background: url("../img/shared/arow-of.png") 0 0 no-repeat;
      width: 8px;
      height: 11px;
      top: 50%;
      transform: translateY(-50%);
      right: 20px;
      z-index: 3;
      position: absolute; }
    .btn-cus a:hover, .btn-cus .span_wrap:hover {
      text-decoration: none;
      color: #fff;
      background-color: #000;
      opacity: 1; }
      .btn-cus a:hover:after, .btn-cus .span_wrap:hover:after {
        background: url("../img/shared/arow-on.png") 0 0 no-repeat; }

.toggle .toggle-link {
  pointer-events: none; }
.toggle .toggle-main {
  display: block; }

.wrap-menu .row {
  justify-content: space-between; }
.wrap-menu .col-menu {
  width: 320px; }
  .wrap-menu .col-menu h3 {
    font-size: 19px;
    line-height: 20px;
    border: 1px solid #fff;
    text-align: center;
    padding-top: 12px;
    padding-bottom: 14px;
    margin-bottom: 6px; }
  .wrap-menu .col-menu .menu-itenm {
    margin-bottom: 11px; }
    .wrap-menu .col-menu .menu-itenm dl {
      display: -webkit-flex;
      display: -moz-flex;
      display: -ms-flex;
      display: -o-flex;
      display: flex;
      justify-content: space-between;
      font-size: 16px;
      line-height: 20px;
      border-bottom: 1px solid #9b9b9b;
      margin-bottom: 7px;
      padding-top: 8px;
      padding-bottom: 5px; }
      .wrap-menu .col-menu .menu-itenm dl dd {
        text-align: right; }
    .wrap-menu .col-menu .menu-itenm .dl_cus {
      display: block; }
      .wrap-menu .col-menu .menu-itenm .dl_cus dt {
        letter-spacing: 0;
        font-size: 15px; }
      .wrap-menu .col-menu .menu-itenm .dl_cus dd {
        text-align: right; }
    .wrap-menu .col-menu .menu-itenm .dl_2 dd {
      margin-top: -20px; }
    .wrap-menu .col-menu .menu-itenm p.txt1 {
      font-size: 16px;
      line-height: 20px;
      border-bottom: 1px solid #fff;
      margin-bottom: 7px;
      padding-top: 10px;
      padding-bottom: 7px; }
    .wrap-menu .col-menu .menu-itenm .img {
      margin-bottom: 10px; }

dl.tt {
  font-family: "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "メイリオ", Meiryo, "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif; }
  dl.tt dt {
    color: #000;
    font-size: 28px;   
    letter-spacing: 0.1em;
    display: table;
		 line-height: 40px;	
}
    dl.tt dt span {
      background-color: #fff;
      margin-bottom: 10px;
      padding-left: 55px;
      padding-right: 50px;
      display: inline-block;
			
		
}
  dl.tt dd {
    font-size: 28px;   
    letter-spacing: 0.1em;
    color: #fff;
    text-align: right;
		 line-height: 40px;		
}
    dl.tt dd span {
      background-color: #af201e;
      display: inline-block;
      padding-left: 50px;
      padding-right: 50px;
			
}
      dl.tt dd span em {
        font-style: normal;
        font-size: 22px; }

#sec1 {
  background: url("../img/index/sec1_bg1.png") center top no-repeat; }
  #sec1 #sec1_1 {
    padding-top: 206px;
    position: relative; }
    #sec1 #sec1_1 h2 {
      width: 133px;
      margin-left: 191px;
      margin-bottom: 110px; }
    #sec1 #sec1_1 .img1 {
      position: absolute;
      background: url("../img/index/sec1_img1.png") center 0/cover no-repeat;
      top: 265px;
      right: 0;
      width: calc(50% + 400px);
      height: 800px; }
    #sec1 #sec1_1 .txt1 {
      margin-bottom: 41px; }
    #sec1 #sec1_1 .txt {
      margin-top: -7px;
      margin-left: 14px; }
  #sec1 #sec1_2 .wrap {
    padding-bottom: 178px; }
  #sec1 #sec1_2 .sub {
    margin-left: 713px; }
  #sec1 #sec1_2 .tt {
    position: absolute;
    left: 50%;
    transform: translateX(-50%);
    bottom: 257px; }
  #sec1 #sec1_2 .btn-cus {
    width: 314px;
    height: 64px; }
  #sec1 #sec1_2 .btn2 {
    position: absolute;
    left: 411px;
    bottom: 129px; }
  #sec1 #sec1_2 .btn1 {
    margin-left: 32px; }

#sec2 {
  background: url("../img/index/sec2_deco1.png") center 550px no-repeat; }
  #sec2 #sec2_1 {
    background: url("../img/index/sec2_bg1.jpg") center 0/cover no-repeat;
    padding-top: 289px;
    padding-bottom: 172px;	
    position: relative; }
    #sec2 #sec2_1 h2 {
      width: 752px;
      margin: 0 auto; }
	  #sec2 #sec2_1 .ttl2{
		  position: absolute;
    right: 220px;
    top: 50px;
	  }
	  #sec2 #sec2_1 .ttl3{
		  position: absolute;
    left: 50px;
    top: 180px;
	  }
  #sec2 #sec2_2 .wrap {
    padding-top: 71px;
    padding-bottom: 65px; }
  #sec2 #sec2_2 h3 {
    margin-bottom: 235px;
    margin-left: 73px; }
  #sec2 #sec2_2 .txt {
    margin-left: 351px;
    margin-bottom: 50px; }
  #sec2 #sec2_2 .sub {
    text-align: right; }
  #sec2 #sec2_2 .wrap-sl {
    height: 430px;
    width: 782px;
    position: absolute;
    top: 170px;
    left: -19px; }
  #sec2 #sec2_2 .sec2-sl .box .row {
    display: -webkit-flex;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: flex; }
    #sec2 #sec2_2 .sec2-sl .box .row dl {
      margin-left: -11px;
      position: relative;
      z-index: 2;
      top: 30px; }
      #sec2 #sec2_2 .sec2-sl .box .row dl dd {
        margin-left: auto;
        margin-right: 0;
        display: -webkit-flex;
        display: -moz-flex;
        display: -ms-flex;
        display: -o-flex;
        display: flex;
        justify-content: flex-end; }
  #sec2 #sec2_3 {
    background: url("../img/index/sec2_img1.png") center 0 no-repeat;
    padding-bottom: 10px; }
    #sec2 #sec2_3 h3 {
      position: relative;
      margin-bottom: 50px; }
      #sec2 #sec2_3 h3:before {
        content: '';
        background: url("../img/index/sec2_tt3-deco.png") 0 0 no-repeat;
        width: 340px;
        height: 425px;
        position: absolute;
        top: 0;
        left: -184px; }
    #sec2 #sec2_3 .content {
      width: 472px;
      position: absolute;
      top: 0;
      right: 0; }
      #sec2 #sec2_3 .content h4 {
        text-align: center;
        font-size: 28px;
        line-height: 43px;
        letter-spacing: 0.1em;
        margin-bottom: 20px; }
      #sec2 #sec2_3 .content .tt1 {
        margin-bottom: 20px; }
      #sec2 #sec2_3 .content dl.tt dt {
        display: -webkit-flex;
        display: -moz-flex;
        display: -ms-flex;
        display: -o-flex;
        display: flex;
        justify-content: flex-end; }
        #sec2 #sec2_3 .content dl.tt dt span {
          padding-left: 20px;
          padding-right: 20px;
          display: inline-block;
          box-sizing: border-box; }
      #sec2 #sec2_3 .content dl.tt dd {
        display: -webkit-flex;
        display: -moz-flex;
        display: -ms-flex;
        display: -o-flex;
        display: flex;
        justify-content: flex-end; }
  #sec2 #sec2_4 {
    background: url("../img/index/sec1_img2.png") center 0 no-repeat;
    padding-bottom: 81px; }
    #sec2 #sec2_4 .txt-sub {
      text-align: right;
      padding-right: 8px;
      margin-bottom: 16px; }
    #sec2 #sec2_4 .content {
      position: relative;
      height: 692px; }
      #sec2 #sec2_4 .content dl {
        font-family: "游明朝", YuMincho, "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "メイリオ", Meiryo, "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif; }
        #sec2 #sec2_4 .content dl dt {
          font-size: 28px;
          line-height: 43px;
          letter-spacing: 0.01em; }
        #sec2 #sec2_4 .content dl dd {
          font-size: 28px;
          line-height: 43px;
          letter-spacing: 0.01em; }
          #sec2 #sec2_4 .content dl dd span {
            font-size: 22px; }
      #sec2 #sec2_4 .content .dl_1 {
        position: absolute;
        top: 10px;
        right: 300px; }
      #sec2 #sec2_4 .content .dl_2 {
        position: absolute;
        top: 125px;
        left: 305px; }
      #sec2 #sec2_4 .content .dl_3 {
        position: absolute;
        left: 9px;
        top: 270px; }
      #sec2 #sec2_4 .content .dl_4 {
        position: absolute;
        top: 451px;
        left: 358px; }
      #sec2 #sec2_4 .content .dl_5 {
        position: absolute;
        bottom: 12px;
        left: 563px; }
        #sec2 #sec2_4 .content .dl_5 dd {
          text-align: right; }
  #sec2 #sec2_5 {
    position: relative;
    margin-top: -81px;
    z-index: 2;
    padding-bottom: 55px; }
    #sec2 #sec2_5 h3 {
      margin-left: -100px;
      margin-bottom: -17px; }
    #sec2 #sec2_5 .wrap-li {
      margin-left: -32px;
      margin-right: -32px;
      margin-bottom: 6px; }
    #sec2 #sec2_5 .txt {
      text-align: center; }
  #sec2 #sec2_6 {
    position: relative; }
    #sec2 #sec2_6 .img1 {
      background: url("../img/index/sec2_img3.png") right 0/cover no-repeat;
      height: 697px;
      width: calc(50% + 279px);
      position: absolute;
      left: 0;
      top: 0; }
    #sec2 #sec2_6 h3 {
      position: absolute;
      top: 24px;
      right: 0; }
    #sec2 #sec2_6 .txt {
      height: 358px;
      width: 232px;
      margin-left: 603px;
      padding-top: 104px;
      margin-bottom: 40px; }
    #sec2 #sec2_6 .sub {
      margin-top: 74px;
      margin-bottom: -53px; }
    #sec2 #sec2_6 .wrap-dl {
      margin-left: 550px; }
      #sec2 #sec2_6 .wrap-dl h4 {
        text-align: center;
        width: 450px;
        background-color: #fff;
        color: #000;
        margin-bottom: 10px;
        font-size: 28px;
        line-height: 40px;				
				display: -webkit-flex;
				display: -moz-flex;
				display: -ms-flex;
				display: -o-flex;
				display: flex;
				justify-content: center;
				align-items: center;
        box-sizing: border-box; }
      #sec2 #sec2_6 .wrap-dl dl {
        color: #fff;
        background-color: #af201e;
        width: 340px;
        margin-bottom: 10px;
        padding-left: 50px;
        padding-right: 30px;
        box-sizing: border-box;
        font-size: 28px;
        line-height: 38px;				
        letter-spacing: 0.1em;
        display: table;
        margin-right: 0;
        margin-left: auto; }
        #sec2 #sec2_6 .wrap-dl dl dt {
          width: 170px;
          display: table-cell; }
        #sec2 #sec2_6 .wrap-dl dl dd {
          display: table-cell; }
          #sec2 #sec2_6 .wrap-dl dl dd span {
            font-size: 22px; }

#sec3 {
  background: url("../img/index/sec3_deco.png") center 0 no-repeat; }
  #sec3 #sec3_1 {
    padding-top: 53px; }
    #sec3 #sec3_1 h2 {
      margin-right: -84px;
      margin-bottom: -13px; }
    #sec3 #sec3_1 .left {
      width: 500px;
      margin-right: 50px; }
      #sec3 #sec3_1 .left .txt {
        text-align: center; }
      #sec3 #sec3_1 .left .sub {
        text-align: right;
        margin-top: 25px;
        margin-bottom: 25px; }
      #sec3 #sec3_1 .left .menu h3 {
        font-size: 28px;
        line-height: 43px;
        letter-spacing: 0.1em;
        text-align: center;
        margin-bottom: 22px; }
      #sec3 #sec3_1 .left .menu dl.tt {
        margin-bottom: 18px; }
        #sec3 #sec3_1 .left .menu dl.tt dt span {
          padding-left: 30px;
          display: inline-block;
          width: 500px;
          box-sizing: border-box; }
        #sec3 #sec3_1 .left .menu dl.tt dd {
          display: -webkit-flex;
          display: -moz-flex;
          display: -ms-flex;
          display: -o-flex;
          display: flex;
          justify-content: flex-end; }
          #sec3 #sec3_1 .left .menu dl.tt dd span {
            background-color: #000; }
      #sec3 #sec3_1 .left .menu dl.dl_3 {
        position: relative; }
        #sec3 #sec3_1 .left .menu dl.dl_3 span.span_2 {
          display: inline;
					
}
        #sec3 #sec3_1 .left .menu dl.dl_3 dd {
          position: absolute;
          right: 0;
          bottom: 0; }
      #sec3 #sec3_1 .left .menu .price {
        text-align: center;
        width: 227px;
        font-size: 28px;
        line-height: 37px;
        letter-spacing: 0.1em;
        background-color: #af201e;
        margin-right: 0;
        margin-left: auto;
        margin-top: 22px; }
        #sec3 #sec3_1 .left .menu .price span {
          font-size: 22px; }
    #sec3 #sec3_1 .row {
      position: relative;
     }
    #sec3 #sec3_1 .right {
      position: absolute;
      left: 552px;
      top: 13px; 
right: -112px;}
      #sec3 #sec3_1 .right .img1 {
        margin-bottom: 15px; }
  #sec3 #food {
    padding-top: 112px; }
    #sec3 #food h2 {
      width: 496px;
      margin: 0 auto 50px; }
    #sec3 #food .sub {
      margin-bottom: 19px;
      text-align: center; }

#sec4 {
  padding-top: 83px;
  padding-bottom: 40px;
  position: relative; }
  #sec4:before {
    content: '';
    border-bottom: 1px solid #fff;
    width: 1100px;
    position: absolute;
    left: 50%;
    transform: translateX(-50%);
    bottom: 0; }
#sec4:after {
    content: '';
    border-bottom: 1px solid #fff;
    width: 1100px;
    position: absolute;
    left: 50%;
    transform: translateX(-50%);
    top: 33px; }
  #sec4 h2 {
    width: 582px;
    margin: 0 auto 45px; }
  #sec4 .sub {
    margin-bottom: 26px;
    text-align: center; }
  #sec4 .tel {
    width: 777px;
    margin: 0 auto;
    position: relative; }
    #sec4 .tel span {
      position: absolute;
      left: 50%;
      transform: translateX(-50%);
      bottom: 33px;
      width: 100%;
      text-align: center;
      color: #000; }

#sec5 {
  padding-top: 45px;
  padding-bottom: 71px;
  position: relative; }
  #sec5:before {
    content: '';
    border-bottom: 1px solid #fff;
    width: 1100px;
    position: absolute;
    left: 50%;
    transform: translateX(-50%);
    bottom: 0; }
  #sec5 h2 {
    width: 524px;
    margin: 0 auto 45px; }
  #sec5 .sub {
    margin-bottom: 23px;
    text-align: center; }

#sec6 {
  background: url("../img/index/sec6_deco.png") right bottom no-repeat;
  padding-top: 52px;
  padding-bottom: 108px; }
  #sec6 .col-menu {
    width: 480px; }
  #sec6 .row1 {
    justify-content: space-between; }
  #sec6 h2 {
    width: 741px;
    margin: 0 auto 51px; }
  #sec6 .sub1 {
    margin-bottom: 9px;
    text-align: center;
    font-size: 19px;
    line-height: 30px; }
  #sec6 .sub2 {
    margin-bottom: 41px;
    text-align: center;
    font-size: 19px;
    line-height: 30px; }

#sec7 #sec7_1 {
  background: url("../img/index/sec6_bg1.png") center bottom/cover no-repeat;
  padding-top: 167px;
  padding-bottom: 167px; }
  #sec7 #sec7_1 h2 {
    width: 472px;
    margin: 0 auto; }
#sec7 #sec7_2 {
  padding-top: 50px;
  padding-bottom: 72px;
	background: url("../img/index/sec7_bg.png") center 0 no-repeat;
}
  #sec7 #sec7_2 .left {
    width: 500px; }
    #sec7 #sec7_2 .left .img1 {
      margin-bottom: 19px; }
    #sec7 #sec7_2 .left .img2 {
      margin-left: -53px; }
  #sec7 #sec7_2 .right {
    width: 500px; }
    #sec7 #sec7_2 .right .img3 {
      margin-left: -40px;
      margin-bottom: 30px;
      margin-right: -130px; }
    #sec7 #sec7_2 .right .txt {
      margin-bottom: 27px;
      margin-left: 10px; }
    #sec7 #sec7_2 .right h3 {
      text-align: center;
      font-size: 28px;
      line-height: 43px;
      letter-spacing: 0.1em;
      margin-bottom: 15px; }
    #sec7 #sec7_2 .right ul {
      padding-left: 10px;
      padding-right: 10px; }
      #sec7 #sec7_2 .right ul li {
        width: 100%;
        background-color: #fff;
        font-size: 20px;
        line-height: 38px;
        letter-spacing: 0.01em;
        color: #000;
        margin-bottom: 6px;
        padding-left: 24px;
        box-sizing: border-box; }
#sec7 #sec7_3 {
  padding-bottom: 72px;
	position: relative;
}
#sec7 #sec7_3:before{
	content: '';
    border-bottom: 1px solid #fff;
    width: 1100px;
    position: absolute;
    left: 50%;
    transform: translateX(-50%);
    top: 0;
}
  #sec7 #sec7_3 h2 {
    width: 256px;
    margin: 0 auto 26px; }
  #sec7 #sec7_3 .txt {
    margin-bottom: 24px;
    text-align: center; }
  #sec7 #sec7_3 .tel {
    width: 777px;
    margin: 0 auto; }
    #sec7 #sec7_3 .tel span {
      position: absolute;
      left: 50%;
      transform: translateX(-50%);
      bottom: 17px;
      width: 100%;
      text-align: center;
      color: #000; }

#sec8 {
  background-color: #000;
  padding-top: 80px;
  padding-bottom: 80px; }
  #sec8 .left {
    width: 500px;
    height: 400px;
    box-sizing: border-box;
    margin-left: -100px;
    margin-right: 52px;
    padding-top: 93px;
    border: 1px solid #fff; }
    #sec8 .left h2 {
      width: 160px;
      margin: 0 auto 16px; }
    #sec8 .left .btn-cus {
      width: 220px;
      height: 63px;
      margin: 0 auto 52px; }
    #sec8 .left ul {
      justify-content: center; }
      #sec8 .left ul li {
        margin-right: 20px; }
        #sec8 .left ul li:last-child {
          margin-right: 0; }

#feed {
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flex;
  display: -o-flex;
  display: flex;
  padding-top: 53px;
  justify-content: space-between; }
  #feed .row {
    width: 250px; }
    #feed .row:first-child {
      margin-right: 48px; }
    #feed .row .rss_img {
      margin-bottom: 23px; }
      #feed .row .rss_img:hover {
        opacity: 0.8; }
    #feed .row dd {
      line-height: 29px; }

#sec9 {
  padding-bottom: 50px; }
  #sec9 .row1 {
    margin-bottom: 34px; }
    #sec9 .row1 .left {
      width: 439px;
      margin-right: 50px;
      margin-left: -100px; }
    #sec9 .row1 .right {
      padding-top: 110px; }
      #sec9 .row1 .right dl {
        display: table;
        border-bottom: 1px solid #fff;
        width: 611px;
        line-height: 20px;
        padding-top: 10px;
        padding-bottom: 9px; }
        #sec9 .row1 .right dl dt {
          width: 165px;
          display: table-cell;
          text-align: right; }
        #sec9 .row1 .right dl dd {
          padding-left: 30px;
          display: table-cell; }
          #sec9 .row1 .right dl dd .tel {
            font-size: 19px; }
  #sec9 .btn-cus {
    width: 311px;
    height: 64px; }
  #sec9 ul.wrap-btn {
    justify-content: center; }
    #sec9 ul.wrap-btn li:first-child {
      margin-right: 30px; }
    #sec9 ul.wrap-btn li:nth-child(2) {
      margin-right: 72px; }
  #sec9 .link {
    margin-left: 158px;
    margin-bottom: 23px; }
    #sec9 .link a {
      text-decoration: underline;
      /*font-size: 20px;*/ }
      #sec9 .link a:hover {
        text-decoration: none; }
  #sec9 .map {
    width: 90%;
    margin: 0 5%;
    line-height: 0; }


#news_box {
	background-color: rgba( 255, 255, 255, 1 );
    width: 860px;
    margin: 50px auto 0;
    line-height: 1.8;
    padding-bottom:39px;
}
#news_box .ttl {
	color: #000;
    padding: 39px 50px 10px;
    text-align: center;
    font-size: 25px;
    width: 760px;
    border-bottom: 1px solid #000;
    margin: 0 auto;
}
#news_box .txt {
	color: #000;
	padding: 20px 50px 0;
	text-align: center;
}

@media only screen and (max-width: 480px) {
  #news_box {
	background-color: rgba( 255, 255, 255, 1 );
    width: 98%;
    margin: 30px auto 40px;
    line-height: 1.8;
    padding-bottom:39px;
}
#news_box .ttl {
	color: #000;
    padding: 39px 10px 10px;
    text-align: center;
    font-size: 20px;
    width: 70%;
    border-bottom: 1px solid #000;
    margin: 0 auto;
}
#news_box .txt {
	color: #000;
	padding: 20px 20px 0;
	text-align: center;
}
}
