@charset "utf-8";
/*
  CSS のみのドロップダウンメニュー
  Copyright Rectus Inc, 2019
  https://www.rectus.co.jp/
  Released under the MIT license
 */

nav{
  position: relative;
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
	    height: 110px;
}
.menu-left{
  margin: 24px 0 0 0;
  z-index: 10;
}

.menu{
  display: flex;
}
a.sns-item{
  width: 30px;
  height: 30px;
  display: inline-block;
}
.sns-item img{
  width: 30px;
  height: 30px;
  border-radius: 50%;
  background-color: #000;
}

ul.menu{
  margin: 40px 0 0 0;
}

li.sns-menu{
  margin: 0 0 0 30px;
}

@media screen and (max-width: 767px) {
nav{
		display: none;
	}
}




/* ----- header ----- */
.header{

}
.header__inner{
  width: calc(100% - 48px);
  height: 100px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin: 0 auto;
}
.header__logo{
  width: 120px;
}
.header__logo img{
  width: 100%;
}
.header__desc{
  font-size: 11px;
}
.header__desc span{
  color: #FFCE00;
}
@media screen and (max-width: 839px) {
  .header__desc{
    display: none;
  }
}
@media screen and (max-width: 767px) {
  .header__inner{
    height: 60px;
    justify-content: center;
  }
}


.search-btn{
  position: fixed;
  right:0 ;
  width: 86px;
  height:140px;
  border-radius: 12px 0 0 12px;
  display: flex;
  justify-content: center;
  align-items: center;
  display: inline-block;
}
.search01, .search02{
  z-index: 120;
}
.search03{
  z-index: 119;
}
.search01{
  top: 200px;
  background-color: #FFCE00;
  border-top: 1px solid #fff;
  border-bottom: 1px solid #fff;
  border-left: 1px solid #fff;
}
.search02{
  top: 352px;
  background-color: #000;
  border-top: 1px solid #fff;
  border-bottom: 1px solid #fff;
  border-left: 1px solid #fff;
}

@media screen and (max-width: 767px) {
  .search-btn-sp {
    width: 33.333%;
    height: 70px;
    border-radius: 0;
    border-top: 1px solid #FFCE00;
  }
  .search01 {
    top:initial;
    bottom: 0;
    right:0;
    background-color: #FFCE00;
  }
  .search02 {
    top: initial;
    bottom: 0;
    right: 33.333%;
    background-color: #fff;
    border-top: 1px solid #FFCE00;
  }
  .search03 {
    top: initial;
    bottom: 0;
    left: 0;
    background-color: #fff;
    border-top: 1px solid #FFCE00;
    border-right: 1px solid #FFCE00;
  }
  .search02 a, .search03 a{
    width: 100%;
    height: 100%;
  }
  img.button02-img{
    display: none;
  }

}


/*モーダル本体の指定 + モーダル外側の背景の指定*/
.modal-container{
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  text-align: center;
  background: rgba(0,0,0,50%);
  padding: 40px 20px;
  overflow: auto;
  opacity: 0;
  visibility: hidden;
  transition: .3s;
  box-sizing: border-box;
  z-index: 100;
}
/*モーダル本体の擬似要素の指定*/
.modal-container:before{
  content: "";
  display: inline-block;
  vertical-align: middle;
  height: 100%;
}
/*モーダル本体に「active」クラス付与した時のスタイル*/
.modal-container.active{
  opacity: 1;
  visibility: visible;
  z-index: 130;
}
/*モーダル枠の指定*/
.modal-body{
  position: relative;
  display: inline-block;
  vertical-align: middle;
  max-width: 660px;
}
/*モーダルを閉じるボタンの指定*/
.modal-close{
  position: absolute;
  display: flex;
  align-items: center;
  justify-content: center;
  top: 6px;
  right: 6px;
  cursor: pointer;
  z-index: 131;
}
/*モーダル内のコンテンツの指定*/
.modal-content{
  width: 660px;
  background: #fff;
  text-align: left;
  z-index: 100;
  border-radius: 7px;
}
.modal-upper{
  padding: 40px 80px 24px 80px;
  background-color: #EDEDED;
  border-radius: 10px 10px 0 0;
}
.modal-lower{
  padding: 24px 80px 40px 80px;
  background-color: #fff;
   border-radius: 0 0 10px 10px;
}
.m-search{
  width: 100%;
  height: 44px;
  border-radius: 4px;
  border: 0;
}
form.m-search-form {
   width: 100%;
  position: relative;
}
img.m-search-icon {
  position: absolute;
  right: 10px;
  top: 14px;

}
.m-cat-menu{
  display: flex;
  flex-wrap: wrap;
  gap:10px;
  border-radius: 2px;
}
.m-cat-menu span{
  width: 100%;
  height: 40px;
  background-color: #fff;
  display: inline-flex;
  align-items: center;
  padding: 0 8px;
  font-feature-settings: "palt";
  font-size: 14px;
line-height: 1.2;
  color: #000;
  gap: 6px;
  border-radius: 3px;
  white-space: nowrap;
}
#modal form.search-form {
  width: 100%;
}
#modal .search-input {
  width: 100%;
  height: 40px;
  background-color: #FFF;
}
#modal img.search-icon {
  top: 12px;
}
.m-info-text{
font-size: 15px!important;
font-family: "Nunito Sans", sans-serif;
font-weight: 400;
  justify-content: center;
}
#type-box label{
  background-color: #fff;
  border-radius: 4px;
  width: 160px;
}

#type-box label input:checked + span {
  color: #FFCE00;
  background: #000;
}

#type-box label.m-info-btn{
  width: 500px;
  justify-content: center;
  display: inline-flex;
}
img.m-title01{
 width: 103px;
}
img.m-cat-icon{
  width: 24px;
  height: 24px;
}

.modal-title{
  font-size: 18px;
  font-weight: 500;
}
.title-keyword{
  margin: 30px 0 0 0;
}
.modal-box{
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
row-gap: 10px;
  max-height: 100px;
  border-top: 1px solid #ccc;
  border-bottom: 1px solid #ccc;
  padding: 10px 0;
  overflow-y: scroll;
  .scrollbar-width: 24px;
  .scrollbar-height: 24px;
  margin: 4px 0 0 0;
}



img.arrow05{
 position: absolute;
 top:10px;
 left:12px;
}
#modal-search-form label input {
  display: none; 
}

#category-search-form label input {
  display: none; 
}
#modal-lower label input {
  display: none; 
}

#area-box label span, #keyword-box label span {
  color: #000; 
  font-size: 13px;
  border-radius: 20px; 
  padding:4px 8px; 

}
#area-box label span{
  border: 1px solid #000;
  background-color: #fff;
}
#keyword-box label span{
  background-color: #FFCE00;
  border: 1px solid #FFCE00;
}

#area-box label input:checked + span {
  color: #fff; /* 文字色を白に */
  background: #000; /* 背景色を薄い赤に */
  border: 1px solid #000; /* 淵の線を薄い赤に */
}

#keyword-box label input:checked + span {
  color: #fff; /* 文字色を白に */
  background: #000; /* 背景色を薄い赤に */
  border: 1px solid #000; /* 淵の線を薄い赤に */
}

.modal-box::-webkit-scrollbar {
width: 24px;
}
.modal-box::-webkit-scrollbar-track {
background: #ccc;
border-radius: 13px;
}
.modal-box::-webkit-scrollbar-thumb {
background: #fff;
width: 24px;
border-radius: 13px;
border: 3px solid #ccc;
}
.button01-s-wrap{
 display: none;
}
.submit01-wrap{
  text-align: center;
  margin: 40px 0 0 0;
}
.submit01-wrap span{
  position: relative;
  height: 42px;
  display: inline-block;
}
.submit01{
  font-size: 15px;
  font-weight: 500;
  width: 210px;
  height: 42px;
  text-align: center;
  border: 1px solid #000;
  border-radius: 21px;
  cursor:pointer;
  background-color:#fff;
  color: #000;
}
.btn01 {
  display: inline-block;
  position: relative;
  width: 210px;
  height: 42px;
  border-radius: 21px;
  overflow: hidden;
  text-decoration: none;
  transition: background-color 0.6s ease;
}


.btn01 svg {
  position: absolute;
  top: 9px;
  left: 9px;
  width: 23.52px;
  height: 23.52px;
  transition: transform 0.6s ease;
  pointer-events: none;
}
.submit01:hover {
  color: #000;
}

.submit01:hover {
  background-color: #FFCE00;
}

.btn01:hover svg {
  transform: translateX(170px);
}
.cls-1 {
  transition: fill 0.6s ease;
  fill: #fff;
}
.btn01:hover .cls-1 {
  fill: #FFCE00; /* 矢印ホバー時の色 */
}
.cls-2 {
  fill: #FFCE00; /* 初期状態の色 */
}
.btn01:hover .cls-2 {
  fill: #000; /* ホバー時の色 */
}
.btn-text-wrap{
    position: absolute;
    top:50%;
    left:50%;
    transform: translateX(-50%)translateY(-50%);
}
.btn-text01{
  position: absolute;
  line-height: 1;
  text-align: center;
  font-size: 14px;
  color: #000;
  top:50%;
  left:50%;
  transform: translateX(-50%)translateY(-50%);
  pointer-events: none;
}
.btn-text02{
  position: absolute;
  line-height: 1;
  text-align: center;
  font-size: 14px;
  color: #000;
  opacity: 0;
  top:calc(50% - 20px);
  left:50%;
  transform: translateX(-50%)translateY(-50%);
  pointer-events: none;
}

@media screen and (max-width: 767px) {
  
  img.button01-img{
  display: none;
  }
  .button01-s-wrap{
  display: inline-block;
  }
  .btn-name{
      font-size: 13px;
      font-weight: 600;
      margin: 4px 0 0 0;
  }
  .btn-name-w{
      color:#fff;
  }
  .btn-name-y{
      color:#FFCE00;
  }
  .btn-shadow{
      width: 100%;
      height: 70px;
      position: fixed;
      left: 0;
      bottom: 0;
      z-index: 81;
      box-shadow: 0px 0px 36px 7px #c4bfbf;
  mix-blend-mode: multiply;
  }
  .modal-container{
      top: -24px;
      padding: 0;
      height: auto;
      overflow-y: scroll;
  }
  .modal-body {
      width: 100%;
  height: 100vh;
  }
  .modal-content {
      width: 100vw;
      height: 100vh;
      border-radius: 0;
  }
  .modal-upper {
      padding: 40px 24px 13px 24px;
      background-color: #EDEDED;
      border-radius: 10px 10px 0 0;
  }
  .modal-title {
      font-size: 14px;
  }
  .m-cat-menu a{
      width: 100%;
  }
  .m-cat-menu li{
      width: calc(50% - 5px);
  }
  li.m-info-btn{
      width: 100%;
  }
  .modal-lower {
      padding: 18px 24px 40px 24px;
      border-radius: 0;
  }
  .title-keyword {
      margin: 18px 0 0 0;
  }
  .submit01-wrap {
      margin: 32px 0 0 0;
  }
      
  .m-cat-menu {
      gap: 5%;
      row-gap: 10px;
  }
  #type-box label {
      width: 47.5%;
  }
  #type-box label.m-info-btn {
      width: 100%;
  }
}





/* ----- side-area ----- */
.side-area{
  width: 240px;
  height: calc(100vh - 24px);
  margin: 0 0 0 24px;
  position: sticky;
  top: 24px;
}
.search-text{
  font-size: 11px;
  margin: 0 0 2px 0;
}
.search-input{
  width: 240px;
  height: 28px;
  padding: 6px;
  background-color: #F5F5F5;
  border-radius: 4px;
  border: 0;
}

form.search-form{
  width: 240px;
  position: relative;
}
img.search-icon{
 position: absolute;
 right: 10px;
 top: 6px;
}
#side-nav li:first-child{
  border-top: 1px solid #A7A7A7;
}
#side-nav li{
  width: 100%;
  height: 52px;
  border-bottom: 1px solid #A7A7A7;

}
#side-nav li a{
  color: #000;
}
a.side-menu{
  width: 100%;
  display: inline-block;
  position: relative;
  height: 52px;
  display: inline-flex;
  align-items: center;
}
img.cat-icon{
  margin: 0 0 0 2px;
  width: 26px;
  height: 26px;
  display: inline-block;
}


.side-menu span{
  font-size: 14px;
  margin: 0 0 0 10px;
  display: inline-block;
  line-height: 1.2;
  font-weight: 600;
  align-items: center;
  -webkit-font-smoothing: antialiased;
}
#side-nav .arrow01{
  position: absolute;
  top: 22px;
  right: 14px;
}
#side-nav .arrow-2line{
  top: 21px;
}

#side-area img.top-title01{
  width: 100px;
}

#side-area .top-title01{
  margin: 0;
}
#side-area .sns-wrap{
  display: flex;
  flex-wrap: wrap;
  gap: 25px;
  position: fixed;
  bottom: 24px;
  left: 24px;
}
#side-area .sns-wrap.is-scrolled{
  position: absolute;
  left: 0;
}
#side-area .sns-icon{
  width: 34px;
  height: 34px;
  background-color: #E8E8E8;
  border-radius: 50%;
}

.info{
  color: #000;
  display: block;
  font-weight: 400;
}
.info01{
  font-family: "Nunito Sans", sans-serif;
  font-size: 18px;
  line-height: 1.5;
  font-weight: bold;
  margin: 22px 0 0 0;
}
.info01 span{
  font-size: 9px;
  line-height: 1.5;
  font-weight: 400;
  display: block;
}
@media screen and (max-width: 1080px) {
  #side-area{
    display: none;
  }
}
@media screen and (max-width: 767px) {
  #side-nav{
    display: none;
  }

  .keyword-wrap{
    display: none;
  }

  #side-area{
    display: none;
    width: 100%;
    position: fixed;
    top: 0;
    left: 0;
    background-color: #fff;
    margin: 0;
    z-index: 90;
    height: 60px!important;
  }
  #side-area img.top-title01 {
    display: none;
  }
  #side-area .sns-wrap{
    display: none;
  }


  a.side-menu {
    height: 40px;
  }
  img.side-logo{
    width: 111px;
    position: fixed;
    top:12px;
    left: 50%;
    transform: translateX(-50%);
    z-index: 100;
  }
  #side-nav li:first-child {
    border-top: 0;
  }
  img.cat-icon {
    margin: -2px 0 0 8px;
    width: 21px;
    height: 21px;
  }

  .side-menu span {
    font-size: 13px;
    margin: 3px 0 0 6px;
    text-align: left;
  }
}


/* ----- breadcrumbs ----- */
.breadcrumb-wrap{
  width: 1000px;
  margin: 0 auto;
}
.breadcrumbs{
  margin-top: 100px;
  padding: 25px 0;
  width: 100%;
}
.breadcrumbs ol{
  display: flex;
  align-items: center;
  gap: 12px;
  overflow: hidden;
}
.breadcrumbs ol li{
  font-size: 12px;
  line-height: 1;
  font-weight: 500;
  display: flex;
  align-items: center;
  gap: 12px;
  padding-left: 20px;
  position: relative;
}
.breadcrumbs ol li a{
  white-space: nowrap;
  color: #A3A3A3;
}
.breadcrumbs ol li span{
  white-space: nowrap;
  color: #A3A3A3;
  display: flex;
  align-items: center;
  gap: 5px;
}
.breadcrumbs ol li img{
  width: 15px;
  margin-bottom: 3px;
  filter: brightness(0) saturate(100%) invert(66%) sepia(5%) saturate(23%) hue-rotate(319deg) brightness(100%) contrast(83%);
}
.breadcrumbs ol li + li::before{
  content: "";
  width: 6px;
  height: 6px;
  margin: auto;
  border-top: 1px solid #A3A3A3;
  border-right: 1px solid #A3A3A3;
  box-sizing: border-box;
  display: block;
  position: absolute;
  left: 0;
  top: 50%;
  transform: translateY(-50%) rotate(45deg);
}
.breadcrumbs ol li .slash{
  font-size: 0.7em;
  color: transparent;
  width: 1em;
  flex-shrink: 0;
  content: "";
  width: 1px;
  height: 9px;
  background: #A3A3A3;
  display: block;
}
.breadcrumbs ol li:first-of-type{
  padding-left: 0;
}
.breadcrumbs ol li:last-of-type{
  overflow: hidden;
  text-overflow: ellipsis;
  display: unset;
}
.breadcrumbs ol li:last-of-type span{
  display: unset;
}
@media screen and (max-width: 1080px) {
  .breadcrumb-wrap{
    width: 90%;
  }
}
@media screen and (max-width: 767px) {
  .breadcrumbs{
    margin-top: 70px;
    margin-bottom: 20px;
  }
}




/* ----- footer ----- */
footer{
  padding: 60px 0;
  background-color: #FFCE00;
  position: relative;
 z-index: 95;
}

.footer-wrap{
display: flex;
flex-wrap: wrap;
justify-content: space-between;
    position: relative;
}
#footer .sns-wrap{
  margin: 70px 0 0 0;
  display: flex;
  flex-wrap: wrap;
  gap: 16px;
}
#footer .sns-icon{
  width: 26px;
  height: 26px;
  background-color: #000;
  border-radius: 50%;
}

.footer-item01{
  text-align: left;
  position: relative;
}

.copyright{
  margin: 40px 0 0 0;
  font-size: 13px;
  color:#fff;
}
.footer-inner{
display: flex;
flex-wrap: wrap;
}
a.f-menu{
  color: #000;
}
.footer-item02{
  text-align: left;
  width:160px;
  font-size: 13px;
  font-weight: 500;
}
.footer-item03{
  text-align: left;
  width:160px;
  font-size: 13px;
  font-weight: 500;
}
#footer li{
  margin: 0 0 16px 0;
}
.top-of-page{
  position: absolute;
  top: -87px;
  right: 0;
}
img.arrow04{
 border-radius: 50px;
 width: 54px;
 height: 54px;
 border: 1px solid #FFCE00;
 background-color: #fff;
}
a.f-info{
  display: none;
  color: #fff;
}

@media screen and (max-width: 767px) {
footer{
  padding: 60px 0 30px 0 ;
  z-index: 80;
}
.footer-wrap{
flex-direction: column-reverse;
margin: 0 20px;
}
.sns-wrap{
  position: absolute;
  right: 0;
  bottom: 58px;
}
.footer-item01{
  margin: 20px 0 0 0 ;
}
.footer-item02{
  display: none;
}
.top-of-page {
  display: none;
}
a.f-info{
  display: inline-block;
  color: #fff;
}
}