@charset "utf-8";

/*-- header -----------------------------------------------------------------*/

.hOnlineLink {
    transition: all .5s;
}

.hOnlineLink:hover {
    transform: scale(0.9);
    transition: all .5s;
}

.header {
    max-width: 1920px;
    width: 100%;
    margin: 0 auto 0 auto;
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
}

.headerPc {
    padding: 15px;
    position: relative;
}

.headerBox01 {
    display: flex;
    align-items: center;
    justify-content: space-between;
    width: calc(100% - 120px);
    margin-left: auto;
}

.hLogoPc {
    max-width: 80px;
    width: 100%;
    margin: auto;
    display: block;
    position: absolute;
    left: 0;
    top: 10px;
}

.hContainerBox {
    width: 100%;
    margin: 0 0 0 auto;
    display: flex;
    align-items: center;
    justify-content: flex-end;
}

.hPcNavBox {
    max-width: 921px;
    width: 100%;
    margin: 0 40px 0 auto;
    display: none;
    align-items: center;
    justify-content: space-between;
}
/* 20251223 */
.hPcNavBox.hPcNavBox-02 {
    max-width: 930px;
}

.hSnsLink01 {
    max-width: 30px;
    width: 100%;
    display: block;
    transition: all .5s;
}

.hSnsLink01:hover {
    transform: scale(0.9);
    transition: all .5s;
}

.hPcNavLink {
    font-family: var(--fontA);
    font-size: 18px;
    font-weight: 500;
    color: #fff;
    letter-spacing: 0.05em;
    transition: all .5s;
}

.hPcNavLink:hover {
    color: #FBD682;
    transition: all .5s;
}

.hContBtn {
    max-width: 55px;
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    border-radius: 50%;
    background: #F34F42;
    color: #fff;
    transition: all .5s;
    height: 55px;
    font-size: 14px;
    font-weight: bold;
    letter-spacing: 0.05em;
    padding: 5px;
    margin: 0 0 0 20px;
}

.hContBtn>p {
    display: none;
}

.hContBtn:hover {
    background: #7B4039;
    color: #fff;
    transition: all .5s;
}

/*--------------PCハンバーガーナビ----------------------------*/

.hHamBox {
    max-width: 55px;
    width: 100%;
    height: 55px;
    padding: 5px;
    color: #fff;
    margin-left: 15px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: pointer;
}

.spNavBtnBarItem {
	width: 100%;
	height: 1px;
	background: #FFF;
	border-radius: 3px;
	position: absolute;
	left: 0;
	transition: ease .5s;
}

.hHamBox .spNavBtnBar {
    max-width: 30px;
    height: 18px;
}

.hHamBox .spNavBtnBar .spNavBtnBarItem:nth-of-type(1) {
    top: 0;
}

.hHamBox .spNavBtnBar .spNavBtnBarItem:nth-of-type(2) {
    top: 50%;
}

.hHamBox .spNavBtnBar .spNavBtnBarItem:nth-of-type(3) {
    bottom: 0;
}

.open.hHamBox .spNavBtnBar .spNavBtnBarItem:nth-of-type(1) {
    transform: translateY(8px) rotate(-45deg);
}

.open .spNavBtnBarItem:nth-of-type(2) {
	opacity: 0;
}

.open.hHamBox .spNavBtnBar .spNavBtnBarItem:nth-of-type(3) {
    transform: translateY(-9px) rotate(45deg);
}

.hHamBox {
    background-color: #F34F42;
}

.spNavBtnBar {
	max-width: 36px;
	height: 26px;
	width: 100%;
	position: relative;
}

.spMenu {
    margin: auto;
    padding: 0;
    max-width: 1920px;
    width: 100%;
    position: fixed;
    right: -100%;
    background: rgb(0 0 0 / 25%);
    z-index: 100;
    transition: ease .5s;
    top: 0;
    display: block;
}

.spMenu.open {
	right: 0;
}

.spMenuArea {
	width: 100%;
	height: 100%;
}

.spMenuConte {
    padding: 140px 15px 40px;
    width: 100%;
    max-width: 100%;
    height: 100%;
    overflow-y: scroll;
    -ms-overflow-style: none;
    display: flex;
    align-items: flex-start;
    margin: 0 0 0 auto;
    background: #fff;
}

.hSpNavBox {
    max-width: 375px;
    width: 100%;
    margin: 0 auto 0 auto;
}

.spMenuConte::-webkit-scrollbar {
	display:none;
}

.spMenuLink {
	padding: 7px 5px;
	text-align: center;
	display: block;
	font-weight: bold;
	color: #485053;
	border-bottom: 1px solid #485053;
}

.spMenuLink:hover {
	color: #FFF;
	background: #485053;
}

.hSpNavBox {
    max-width: 320px;
    width: 100%;
    margin: 0 auto 0 auto;
}

.spNavList01 {
    display: block;
    color: #7B4039;
    font-size: 16px;
    font-weight: 500;
    letter-spacing: 0.05em;
    padding: 15px 0;
    text-align: left;
    border-bottom: 1px solid #ccc;
}

.spNavList01:hover {
    color: #FF6E48;
}


.hHamTelBox {
    margin: 40px 0 0;
}

.hHamTelBtn {
    max-width: 383px;
    width: 100%;
    color: #7B4039;
    background-color: #FBD682;
    border: 2px solid #FBD682;
    border-radius: 20px;
    height: 68px;
    display: flex;
    justify-content: center;
    align-items: center;
    padding: 5px 5px 5px 5px;
    margin: 10px 0 0;
}

.hHamTelIcon {
    max-width: 30px;
    width: 100%;
    margin: 0 20px 0 0;
}

.hHamTelText01 {
    font-size: 18px;
    font-weight: 500;
    letter-spacing: 0.05em;
}

.hHamTelText02 {
    font-size: 9px;
    font-weight: 500;
    letter-spacing: 0.05em;
}

.hHamTelSet {
    text-align: center;
}

/*--is-animation--*/

.header.clone.is-animation {
    top: 0;
    transition: all .5s;
    visibility: visible;
    opacity: 1;
}

.header.clone {
    position: fixed;
    top: -100px;
    transition: all .5s;
    visibility: hidden;
    opacity: 0;
    background: #FBD682;
}

.header.clone .hLogoPc {
    max-width: 80px;
}

.header.clone .headerBox01 {
    width: calc(100% - 120px);
}

.header.clone .hPcNavLink {
    color: #7B4039;
}

.header.clone .hPcNavLink:hover {
    color: #F34F42;
}

/*---------------------------------------------------------------------------*/

/*-- footer -----------------------------------------------------------------*/

.fContBox02 {
    display: grid;
    grid-template-columns: repeat(1, 1fr);
    gap: 15px;
}

.fEcBtn01 {
    border: 2px solid #FBD682;
    background: #FBD682;
    font-family: var(--fontA);
    max-width: 278px;
    width: 100%;
    height: 63px;
    padding: 5px;
    color: #7B4039;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    font-weight: 500;
    letter-spacing: 0.05em;
    font-size: 18px;
    border-radius: 20px;
    transition: all .5s;
    margin: 20px auto 0;
}

.fEcBtn01:hover {
    background: #fff;
    color: #7B4039;
    transition: all .5s;
}

.fSnsBox {
    gap: 15px;
}

.fSnsLink01:hover {
    transition: all .5s;
}

.fSnsLink01:hover {
    transition: all .5s;
    transform: scale(0.9);
}

.fNavWr02 {
    gap: 15px;
}

.fTownTextBox {
    font-size: 14px !important;
}

.fNavLink {
    font-size: 16px !important;
}

/*---------------------------------------------------------------------------*/


/* ★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★ */
/* ★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★ */

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

/* ★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★ */
/* ★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★ */

/* ☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆ */

} /* min-width: 375px ここまで */

/* ☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆ */

/* ★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★ */
/* ★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★ */

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

/* ★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★ */
/* ★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★ */

  



/* ☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆ */

} /* min-width: 414px ここまで */

/* ☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆ */

/* ★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★ */
/* ★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★ */

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

/* ★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★ */
/* ★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★ */
  

  
/* ☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆ */

} /* min-width: 544px ここまで */

/* ☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆ */

/* ★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★ */
/* ★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★ */

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

/* ★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★ */
/* ★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★ */

.fEcBtn01 {
    height: 83px;
    gap: 20px;
    font-size: 20px;
}

.hLogoPc {
    max-width: 100px;
}

.headerBox01 {
    width: calc(100% - 120px);
}

.hPcNavLink {
    font-size: 13px;
}

.hPcNavBox {
    max-width: 680px;
    margin: 0 20px 0 auto;
}
/* 20251223 */
.hPcNavBox.hPcNavBox-02 {
    max-width: 695px;
}

.hSnsLink01 {
    max-width: 30px;
}

.hPcHamBox01 .spNavBtnBar .spNavBtnBarItem {
    background: #fff;
}
  
.spMenuConte {
    align-items: flex-start;
}
  
.spMenuConte {
    max-width: 460px;
}
  
.spMenu {
  	top: 0;
}

.hSpNavBox {
    max-width: 320px;
    width: 100%;
    margin: 0 auto 0 auto;
}
  
/* ☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆ */

} /* min-width: 768px ここまで */

/* ☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆ */

/* ★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★ */
/* ★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★ */

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

/* ★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★ */
/* ★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★ */
  


/* ☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆ */

} /* min-width: 992px ここまで */

/* ☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆ */


/* ★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★ */
/* ★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★ */

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

/* ★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★ */
/* ★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★ */

.fEcBtn01 {
    margin: 20px auto 0 0;
}

.hPcNavBox {
    display: flex;
}

.hContBtn>p {
    display: block;
}

.hContBtn {
    max-width: 160px;
    border-radius: 29px;
    margin: 0 0 0 20px;
}

.hLogoPc {
    max-width: 130px;
}

.headerBox01 {
    width: calc(100% - 130px);
}

.hHamBox {
    display: none;
}

.header.clone .hLogoPc {
    max-width: 130px;
}

.header.clone .headerBox01 {
    width: calc(100% - 130px);
}

.headerPc {
    padding: 20px;
}
  
.spMenu {
    display: none;
}
	
/* ☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆ */

} /* min-width: 1024px ここまで */

/* ☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆ */


/* ★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★ */
/* ★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★ */

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

/* ★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★ */
/* ★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★ */

.fContBox02 {
    grid-template-columns: repeat(3, 1fr);
    gap: 35px;
}

.hPcNavLink {
    font-size: 14px;
}
  
.fTownTextBox {
    font-size: 16px !important;
}

.fNavLink {
    font-size: 14px !important;
}

.hContBtn {
    max-width: 180px;
    border-radius: 29px;
    margin: 0 0 0 20px;
    height: 68px;
    gap: 20px;
}

/* ☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆ */

} /* min-width: 1200px ここまで */

/* ☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆ */


/* ★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★ */
/* ★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★ */

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

/* ★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★ */
/* ★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★ */

.hLogoPc {
    max-width: 230px;\
}

.headerBox01 {
    width: calc(100% - 250px);
}

.hPcNavLink {
    font-size: 18px;
}

.hPcNavBox {
    max-width: 921px;
    margin: 0 40px 0 auto;
}

.hPcNavBox.hPcNavBox-02 {
    max-width: 930px;
}

.hSnsLink01 {
    max-width: 50px;
}

.hContBtn {
    max-width: 218px;
    gap: 20px;
    border-radius: 29px;
    height: 68px;
    margin: 0 0 0 25px;
    font-size: 18px;
}

.fNavLink {
    font-size: 18px !important;
}
    
/* ☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆ */

} /* min-width: 1600px ここまで */

/* ☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆ */