@charset "UTF-8";
/* CSS Document */

* { margin: 0; padding: 0; box-sizing: border-box;}
body { font-family: "Yu Gothic", "YuGothic", "Hiragino Kaku Gothic ProN", Meiryo, sans-serif; line-height: 1.6;}
html { scroll-behavior: smooth;}
section { margin: auto;}
a { text-decoration: none; color: #000;}
button { all: unset; cursor: pointer; line-height: 0;}
ul, li { list-style: none; margin: 0; padding: 0;}
#strength, #plan, #trainer, #review .inner, footer .inner { padding-inline: clamp(16px, 7.33vw, 120px); max-width: 1640px; margin: 0 auto;}



@media only screen and (min-width: 1024px) and (max-width: 1366px) and (orientation: landscape) {
  /* iPad Pro横向き用のスタイル */
#strength, #plan, #trainer, #review .inner, footer .inner {max-width: 1100px;}
}
@media only screen and (min-device-width: 768px) and (max-device-width: 1024px) and (orientation:portrait) {
 /* iPad Pro縦向き用のスタイル */
#strength, #plan, #trainer, #review .inner, footer .inner {max-width: 750px;}
}



.en { font-family: 'Inter', sans-serif;}
.section-heading .en { display: inline-block; font-size: 1rem; font-weight: 600; margin-bottom: 0.4rem; position: relative; padding-left: 1.2em;}
.section-heading .en::before { content: ''; width: 0.7em; height: 0.7em; background: linear-gradient(85deg, #8d80a7, #b5a6b3); border-radius: 50%; position: absolute; left: 0; top: 0.42em;}
.section-heading h2 { font-size: clamp(2.5rem, 4.22vw, 3.8rem); font-weight: 600;}

@media (min-width: 768px) {
    .pcOnly { display: block;}
    .spOnly { display: none;}
    .tabletOnly { display: none;}
}

@media (max-width: 767px) {
    .pcOnly { display: none;}
    .spOnly { display: block;}
    .tabletOnly { display: none;}
    .section-heading .en { font-size: 0.8rem;}
    .section-heading h2 { font-size: 1.9rem; font-weight: 600;}
}

@media (max-width: 850px) and (min-width: 768px) {
    .tabletOnly { display: block;}
}




/*メインビジュアル*/
#mv .container { display: flex; min-height: 100vh; margin-bottom: clamp(80px, 9.03vw, 130px);}
#mv .left-area { flex-grow: 0; flex-shrink: 0; flex-basis: 44.444%; padding: 0 clamp(24px, 2.72vw, 68px); background-color: #fff; position: relative; display: flex; flex-direction: column; justify-content: center; text-align: center;}
#mv .left-area .logo { position: absolute; top: clamp(16px, 2.08vw, 30px); left: clamp(16px, 2.08vw, 30px);}
#mv .left-area .logo img { height: clamp(16px, 1.74vw, 25px); width: auto;}
#mv .left-area h2 { font-size: clamp(20px, 2.5vw, 36px); margin-bottom: clamp(0, 1.39vw, 20px);}
#mv .left-area h1 { font-size: clamp(28px, 3.33vw, 48px); border-bottom: solid 2px #000; letter-spacing: 0.02em; width: fit-content; margin: 0 auto clamp(24px, 4.03vw, 58px);}
#mv .cta-button { background: linear-gradient(90deg, #8d80a7, #b5a6b3); color: #fff; border-radius: 999px; padding: clamp(12px, 1.5vw, 20px) clamp(20px, 8.33vw, 100px); font-size: clamp(16px, 1.67vw, 24px); margin: 0 auto clamp(24px, 3.47vw, 50px); width: fit-content; text-align: center; letter-spacing: 0.07em; display: flex; align-items: center;}
#mv .cta-button .arrow { font-size: clamp(16px, 2.67vw, 32px); line-height: 0; display: inline-block; margin-left: 0.5em; transform: translateX(0); opacity: 1; transition: none;}
#mv .cta-button:hover .arrow { animation: arrowExitEnter 0.8s forwards;}
@keyframes arrowExitEnter {
  0% { transform: translateX(0); opacity: 1;}
  20% { transform: translateX(10px); opacity: 0;}
  40% { transform: translateX(-30px); opacity: 0;}
  100% { transform: translateX(0); opacity: 1;}
}



#mv .icon-group { display: flex; justify-content: center; /*gap: clamp(8px, 0.83vw, 12px);*/}
#mv .icon-group img { width: 100%; max-width: clamp(80px, 12vw, 160px); height: auto;}
#mv .image-wrapper { position: relative; display: inline-block; margin-right: clamp(8px, 0.83vw, 12px);}
#mv .image-wrapper:last-child { margin-right: 0;}
#mv .image-wrapper img { display: block; width: 100%; height: auto;}
#mv .image-wrapper .overlay { position: absolute; top: clamp(-28px, -4vw, -36px); right: clamp(-18px, -4vw, -30px); width: clamp(100px, 20vw, 150px); height: auto;}
#mv .icon-note { font-size: clamp(10px, 0.83vw, 12px); color: #8c9a9e; text-align: right; line-height: 1.5; margin-top: clamp(8px, 0.83vw, 12px);}
#mv .scroll-down { font-size: clamp(12px, 1.11vw, 16px); font-weight: 600; position: absolute; bottom: clamp(16px, 2.08vw, 30px); left: 50%; transform: translateX(-50%); animation: fadeMove 1.6s infinite;}
#mv .scroll-down .arrow { display: inline-block; margin-left: 6px;}
@keyframes fadeMove {
    0% { transform: translate(-50%, 0); opacity: 1;}
    100% { transform: translate(-50%, 8px); opacity: 0.4;}
}

#mv .visual-area { flex-grow: 0; flex-shrink: 0; flex-basis: 55.556%; height: 100vh; overflow: hidden; position: relative;}
#mv .marquee { height: 100%; overflow: hidden;}
#mv .marquee-inner { display: flex; flex-direction: column; animation: scrollUp 30s linear infinite;}
#mv .marquee-inner img { /*height: 100vh;*/ width: 100%; object-fit: cover;}
@keyframes scrollUp {
  0% { transform: translateY(0%);}
  100% { transform: translateY(-50%);}
}

@media (max-width: 767px) {
    #mv .container { flex-direction: column;}
    #mv .left-area { padding: 50px 0;}
    #mv .left-area h2 { margin-bottom: 0.2em;}
    #mv .icon-group img { max-width: 100px;}
    #mv .icon-note { text-align: center;}
    #mv .visual-area { height: 60vh;}
    #mv .marquee { height: 60vh; overflow: hidden;}
    #mv .marquee-inner img { height: 60vh;}
}





/*目次*/
#contents { max-width: 1200px; /*gap: clamp(5px, 10.4vw, 150px);*/ margin-bottom: clamp(80px, 11.81vw, 170px);}
#contents .image-container img { border-radius: 10px; width: clamp(180px, 25vw, 300px); margin-right: clamp(5px, 10.4vw, 150px);}
#contents .toc-container { max-width: 630px; width: 100%;}
#contents .toc-container .section-heading.is-reverse { display: flex; justify-content: flex-end; align-items: baseline; margin-bottom: clamp(12px, 2vw, 20px);}
#contents .toc-container .section-heading.is-reverse h2 { padding-right: 20px;}
#contents .toc-container .toc-item a { display: flex; justify-content: space-between; align-items: center; padding: clamp(1rem, 2.5vw, 1.4rem) 0; width: 100%; transition: color 0.3s ease;}
#contents .toc-container .toc-item a:hover { color: #8d80a7;}
#contents .toc-container .toc-item { border-bottom: 1px solid #eee; font-size: clamp(14px, 1.89vw, 20px); font-weight: bold; letter-spacing: 0.05em;}
#contents .toc-container .toc-item .num { padding-right: clamp(12px, 2.78vw, 40px);}
#contents .toc-container .toc-item .arrow { display: inline-block; transition: transform 0.3s ease; font-size: clamp(20px, 1.94vw, 28px);}
#contents .toc-container .toc-item a:hover .arrow { transform: translateY(4px);}

@media (min-width: 768px) {
	#contents { padding-right: 60px; padding-left: 60px; display: flex; justify-content: space-between;}
    #contents .toc-container { margin-top: clamp(40px, 4.17vw, 60px);}
}

@media (max-width: 767px) {
	#contents { width: 82%; display: flex; flex-direction: column-reverse;}
    #contents .image-container { margin: 0 auto;}
	#contents .toc-container .section-heading.is-reverse { justify-content: flex-start;}
}





/*強み*/
#strength { margin-bottom: clamp(80px, 10.42vw, 150px);}
#strength .section-heading { margin-bottom: clamp(24px, 4.86vw, 70px);}
#strength .strength-block .txt-block { flex: 1; position: relative;}
#strength .strength-block .image-block { flex: 1;}
#strength .strength-block .image-block img { width: 100%; height: auto; border-radius: 10px;}
#strength .strength-block .txt-block .num { font-size: clamp(32px, 9.72vw, 140px); color: rgba(0,0,0,0.04); font-weight: normal; position: absolute; top: clamp(-80px, -6.71vw, -110px);}
#strength .strength-block .txt-block .ttl { font-size: clamp(22px, 2.78vw, 40px); font-weight: 600; margin: 0.7em 0; letter-spacing: 0.06em;}
#strength .strength-block .txt-block .desc { font-size: clamp(14px, 1.11vw, 16px); line-height: 2.2; color: #333;}
#strength .strength-block .txt-block .emphasis { color: #cf3668;}

@media (min-width: 768px) {
    #strength .strength-block { display: flex; align-items: center; margin-bottom: 20px; gap: 20px;}
}

@media (max-width: 767px) {
    #strength .section-heading { margin-bottom: 64px;}
    #strength .strength-block { margin-bottom: 90px;}
    #strength .strength-block .txt-block .num { font-size: 90px; top: -80px;}
    #strength .strength-block .txt-block .desc { margin-bottom: 1.5em;}
}





/*プログラム*/
#program { background: #f7f6f4; border-radius: 10px; margin-bottom: clamp(80px, 10.42vw, 150px);}
#program .inner { margin: 0 auto; max-width: 1640px; padding: clamp(60px, 9.03vw, 130px) clamp(16px, 6.94vw, 120px);}
#program .section-heading { margin-bottom: clamp(30px, 3.47vw, 50px);}
#program .program-list { display: grid; grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); gap: clamp(40px, 4vw, 40px);}
#program .program-card { display: flex; flex-direction: column; align-items: center; /*gap: clamp(0.75rem, 2vw, 2.5rem);*/ letter-spacing: 0.07em; text-align: center;}
#program .program-card .image { position: relative; width: 100%; border-radius: 16px; overflow: hidden; aspect-ratio: 3 / 4; margin-bottom: clamp(0.75rem, 2vw, 2.5rem);}
#program .program-card .image::before { content: ""; position: absolute; inset: 0; background-color: rgba(0, 0, 0, 0.35); z-index: 1;}
#program .program-card img { width: 100%; height: 100%; object-fit: cover;}
#program .program-card .label { position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%); color: #fff; z-index: 1;}
#program .program-card .label h3 { font-size: clamp(1.2rem, 2.5vw, 1.8rem); margin: 0;}
#program .program-card .label .en { font-size: clamp(0.8rem, 1.2vw, 1rem); margin: 4px 0 0;}
#program .program-card .desc { font-size: clamp(0.9rem, 1.4vw, 1.125rem); line-height: 1.8; color: #333;}

@media (min-width: 768px) {
	#program { margin-right: 20px; margin-left: 20px;}
}

@media (max-width: 767px) {
    #program { margin-left: 4%; margin-right: 4%;}
    #program .program-list { grid-template-columns: 1fr;}
    #program .program-card .image { max-height: 240px;}
    #program .program-card img { object-position: top;}
}

@media only screen and (min-width: 1024px) and (max-width: 1366px) and (orientation: landscape) {
  /* iPad Pro横向き用のスタイル */
#location { max-width: 1100px;}
}
@media only screen and (min-device-width: 768px) and (max-device-width: 1024px) and (orientation:portrait) {
 /* iPad Pro縦向き用のスタイル */
#location { max-width: 750px;}
}





/*料金プラン*/
#plan { margin-bottom: clamp(80px, 10.42vw, 150px);}
#plan .section-heading { margin-bottom: clamp(20px, 3.47vw, 50px);}
#plan .price-table { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(24px, 4.86vw, 70px) clamp(16px, 3vw, 40px); margin: 0 auto clamp(24px, 4.86vw, 70px);}
#plan .plan-head { font-weight: bold; font-size: clamp(16px, 2vw, 18px); margin-bottom: clamp(12px, 2vw, 24px); line-height: 1.3; border-radius: 10px; color: #fff; padding: clamp(16px, 2.43vw, 30px) clamp(16px, 2.43vw, 32px) clamp(8px, 1.5vw, 20px);}
#plan .plan-head span { font-weight: bold; font-size: clamp(24px, 3.5vw, 44px); letter-spacing: 0.06em;}
#plan .price-section .other-box ul { flex-shrink: 0;}
#plan .price-list li { padding: clamp(12px, 1.11vw, 16px) clamp(16px, 1.81vw, 26px);}
#plan .price-section li { padding: clamp(12px, 2.46vw, 23px) clamp(16px, 1.81vw, 26px);}
#plan .price-section li .main { position: relative; padding-left: 1.1em;}
#plan .price-section li .icon::before { content: ''; width: 0.7em; height: 0.7em; background: #8c9a9e; border-radius: 50%; position: absolute; left: 0; top: 0.42em;}

#plan .price-list li, 
#plan .price-section li { border-bottom: 1px solid #eee; letter-spacing: 0.04em; font-weight: bold;}
#plan .price-list li .main ,
#plan .price-section li .main { font-size: clamp(16px, 2vw, 24px);}
#plan .price-list li .sub ,
#plan .price-section li .sub  { font-size: clamp(12px, 1.1vw, 16px);}

#plan .accordion-content li { border-top: 2px dotted #eee; border-bottom: none; padding: 15px 0;}
#plan .accordion-content li:first-child { margin-top: 15px;}
#plan .accordion-content li:last-child { border-bottom: none;}
#plan .accordion-content .note { background-color: #079ca9;}
#plan .accordion-content .note-text { font-weight: 500;}
#plan .main-row { display: flex; justify-content: space-between; align-items: center;}
#plan .accordion-toggle { background: none; border: none; padding: 4px 8px; cursor: pointer; position: relative;}
#plan .accordion-toggle::after { content: "＋"; font-size: 16px;}
#plan .accordion-item.active .accordion-toggle::after { content: "−";}
#plan .accordion-content { max-height: 0; overflow: hidden; transition: max-height 0.3s ease; font-size: 14px; line-height: 1.6;}
#plan .accordion-item.active .accordion-content { max-height: 500px;}
#plan .price-section .other-box .note { background-color: #8c999e;}
#plan .price-section .other-box .note, 
#plan .accordion-content .note { display: inline-block; color: #fff; font-size: clamp(12px, 1vw, 13px); line-height: 1.2; padding: clamp(5px, 1.2vw, 7px); border-radius: 4px; margin: 0.3em 0 0.3em 0.8em;}

#plan .light { background: linear-gradient(to right, #87d42b, #bed75a);}
#plan .basic { background: linear-gradient(to right, #e52a76, #ea82ae);}
#plan .premium { background: linear-gradient(to right, #8d80a7, #b5a6b3);}
#plan .semi_personal { background: linear-gradient(to right, #079ca9, #60d3cc);}
#plan .other { background: linear-gradient(to right, #8c9a9e, #bcc2c4); font-size: clamp(18px, 1.67vw, 24px); padding: clamp(16px, 2.43vw, 30px) clamp(16px, 2.43vw, 32px)}

#plan .terms { flex: 1; font-size: clamp(14px, 1.11vw, 16px);}
#plan .terms p { text-indent: -1em; padding-left: 1em;
}

@media (min-width: 1025px) {
	#plan .price-section .other-box { display: flex; align-items: baseline; gap: 50px;}
    #plan .terms { padding-top: 30px;}
}

@media (max-width: 1024px) {
	#plan .terms { padding-top: 20px;}
}

@media (min-width: 768px) {
    #plan .price-section li { display: flex; align-items: flex-end;}
    #plan .price-list li, #plan .price-section li {}
}

@media (max-width: 767px) {
	#plan .price-table { grid-template-columns: 1fr;}
    #plan .plan-head { font-size: 13px; line-height: 1.2; padding: 18px 18px 14px; margin-bottom: 0; border-radius: 5px;}
    #plan .price-table { gap: 16px; margin-bottom: 16px;}
    #plan .other { padding: 20px 16px;}
}

#plan .price-list { display: block; max-height: none; overflow: visible; transition: none;}

@media (max-width: 767px) {
  #plan .plan-toggle { display: inline-block; float: right; font-size: 16px; padding-top: 5px;}
  #plan .plan-toggle::after { content: "＋";}
  #plan .price-card.active .plan-toggle::after { content: "−";}
  #plan .price-list { max-height: 0; overflow: hidden; transition: max-height 0.4s ease;}
  #plan .price-card.active .price-list { max-height: 1000px;}
  #plan .plan-head.other { position: relative; cursor: pointer;}
  #plan .plan-head.other .plan-toggle { padding-top: 7px;}
  #plan .price-section.active .plan-toggle::after { content: "−";}
  #plan .price-section .other-box { max-height: 0; overflow: hidden; transition: max-height 0.4s ease;}
  #plan .price-section.active .other-box { max-height: 1000px;}
}



/*イメージ*/
.visual-wrapper { position: relative; overflow: hidden; margin-bottom: clamp(80px, 10.42vw, 150px);}
.visual-wrapper .responsive-img { width: 100%; height: auto; display: block; margin: 0;}
.visual-wrapper .scroll-text { position: absolute; bottom: clamp(10px, 1.39vw, 20px); left: 0; width: 100%; overflow: hidden; white-space: nowrap; z-index: 2; pointer-events: none;}
.visual-wrapper .text-track { display: inline-block; white-space: nowrap; animation: scrollLoop 50s linear infinite;}
.visual-wrapper .text-track span { display: inline-block; padding-right: 4rem; font-size: 3vw; letter-spacing: 0.1em; font-weight: bold; color: white;}

@keyframes scrollLoop {
    0% { transform: translateX(0);}
    100% { transform: translateX(-50%);}
}

@media (max-width: 767px) {
  .visual-wrapper .text-track span { font-size: 7vw;}
}






/*トレーナー*/
#trainer { position: relative; margin-bottom: clamp(80px, 10.42vw, 150px);}
#trainer .section-heading { margin-bottom: clamp(20px, 3.47vw, 50px);}
#trainer .trainer-profile { display: flex; /*gap: clamp(10px, 5.47vw, 50px);*/ align-items: stretch; padding: clamp(20px, 5vw, 70px) clamp(20px, 5vw, 70px) clamp(20px, 5vw, 70px) clamp(20px, 5vw, 40px); background: #f7f6f4; border-radius: 16px; flex-wrap: nowrap; position: relative;}
#trainer .trainer-label { writing-mode: vertical-rl; font-size: 14px; color: #999; font-weight: bold; padding-right: clamp(12px, 1.74vw, 25px); margin-right: clamp(10px, 5.47vw, 50px); border-right: 1px solid #ccc; line-height: 1;}
#trainer .trainer-content { display: flex; flex-direction: column; width: 100%;}
#trainer .trainer-inner { display: flex; flex: 1;}
#trainer .trainer-image img { width: 100%; height: auto; border-radius: 12px; display: block;}
#trainer .label { font-size: clamp(14px, 1.2vw, 18px); font-weight: bold; margin-bottom: 0.6em;}
#trainer .name { font-size: clamp(20px, 3vw, 32px); margin: 0; margin-bottom: 0.2em;}
#trainer .name-en { font-size: clamp(12px, 1.2vw, 16px); color: #999; margin-bottom: 2em;}
#trainer .tag { display: inline-block; background: linear-gradient(to right, #8d80a7, #b5a6b3); color: white; font-size: clamp(12px, 1vw, 14px); border-radius: 999px; padding: 0.4em 1.4em; margin-bottom: 1em;}
#trainer .title { font-size: clamp(14px, 1.2vw, 16px); font-weight: bold; margin-bottom: 1.5em;}
#trainer .message h3 { font-size: clamp(18px, 2.4vw, 30px); font-weight: bold; margin: 1.6em 0 0.6em;}
#trainer .message p { font-size: clamp(14px, 1.1vw, 16px); line-height: 1.8; color: #333;}

#trainer .swiper-buttons { position: absolute; top: 60px; right: clamp(80px, 11.8vw, 170px);}
#trainer .swiper-button-prev, #trainer .swiper-button-next { width: clamp(32px, 3.5vw, 40px); height: clamp(50px, 6vw, 70px); background: black; border-radius: 999px; color: white; font-size: clamp(14px, 1.5vw, 18px); display: flex; align-items: center; justify-content: center;}
#trainer .swiper-button-prev:after, 
#trainer .swiper-rtl .swiper-button-next:after { content: '↓'; font-size: 30px; font-family: inherit;}
#trainer .swiper-button-next:after, 
#trainer .swiper-rtl .swiper-button-prev:after { content: '↑'; font-size: 30px; font-family: inherit;}

@media (min-width: 768px) {
    #trainer .trainer-text { flex: 1 1 390px; min-width: 280px;}
    #trainer .trainer-image { flex: 1 1 590px;}
    #trainer .message { min-height: 220px;}
    #trainer .swiper-buttons, #review .swiper-buttons { display: flex;}
    #trainer .trainer-swiper { height: clamp(510px, 57.17vw, 810px);}
}

@media (max-width: 767px) {
    #trainer .trainer-swiper { height: 720px;}
    #trainer .trainer-profile { flex-direction: column; align-items: stretch; border-radius: 10px;}
    #trainer .trainer-image img {border-radius: 8px;}
    #trainer .trainer-label { writing-mode: horizontal-tb; transform: none; border-right: none; padding-right: 0; font-size: 10px; margin-bottom: 1.3em;}
    #trainer .trainer-inner { flex-direction: column-reverse;}
    #trainer .trainer-text { margin-top: 20px;}
    #trainer .name-box { display: flex; align-items: baseline;}
    #trainer .name { padding-right: 10px;}
    #trainer .name-en { margin-bottom: 1em;}
    #trainer .label { margin-bottom: 0.3em;}
    #trainer .message h3 { margin: 0 0 0.6em;}
    #trainer .trainer-swiper { height: clamp(810px, 124.51vw, 840px);}
    #trainer .swiper-buttons { top: 130px;}
    #trainer .swiper-button-prev, #trainer .swiper-button-next { right: 0;}
}


    



/*口コミ*/
#review .section-heading { margin-bottom: clamp(20px, 5.47vw, 50px); position: relative;}
#review { position: relative; background: url('../img/review_bg.jpg') center/cover no-repeat; padding: clamp(80px, 9.03vw, 130px) 0;}
#review .swiper-buttons { position: absolute; top: 82px; right: clamp(40px, 5.56vw, 80px); display: flex; gap: 8px;}
#review .swiper-button-prev,
#review .swiper-button-next { width: clamp(50px, 6vw, 70px); height: clamp(32px, 3.5vw, 40px); background: black; border-radius: clamp(20px, 5vw, 30px); color: white; font-size: clamp(14px, 1.5vw, 18px); display: flex; align-items: center; justify-content: center;}
#review .swiper-wrapper { display: flex;}
#review .review-swiper.no-swiper .swiper-wrapper { padding-top: 20px;}
#review .review-swiper .swiper-wrapper { padding-top: 20px;}
#review .review-card { background: #fff; border-radius: 16px; padding: clamp(24px, 2.08vw, 30px); text-align: center; height: auto !important;}
#review .review-image img { width: 100%; object-fit: cover; border-radius: 999px;}
#review .review-number { font-size: clamp(10px, 1vw, 14px); font-weight: bold; color: #ccc; margin-bottom: 20px; text-align: left;}
#review .review-title { font-size: clamp(16px, 2vw, 22px); font-weight: bold; margin: 0.8em;}
#review .review-body { font-size: clamp(14px, 1.2vw, 16px); color: #777; line-height: 1.8; text-align: left; margin: 0 1em;}
#review .review-age { font-size: clamp(14px, 1.2vw, 16px); margin: 1em 1em 0;}
#review .note { font-size: clamp(12px, 1vw, 14px); color: #aaa; margin: clamp(12px, 2vw, 20px) clamp(16px, 2.08vw, 30px) 0; text-align: right;}
#review .swiper-button-prev:after, 
#review .swiper-rtl .swiper-button-next:after { content: '←'; font-size: 30px; font-family: inherit;}
#review .swiper-button-next:after, 
#review .swiper-rtl .swiper-button-prev:after { content: '→'; font-size: 30px; font-family: inherit;}
#review .deco:before { content: ""; position: absolute; background: url(../img/deco.png) no-repeat left top; width: 39px; height: 31px; left: 7%; top: -15px; background-size: contain;}
#review .swiper-button-prev, .swiper-rtl .swiper-button-next { right: var(--swiper-navigation-sides-offset, 10px); left: auto;}
#review .swiper-button-next, .swiper-rtl .swiper-button-prev { left: var(--swiper-navigation-sides-offset, 10px); right: auto;}
@media (min-width: 1024px) {
    #review .review-swiper { margin: 0 30px;}
}


/*Swiper無効時のレイアウト（PCで3件以下）*/
@media (min-width: 1024px) {
  #review .review-swiper.no-swiper .swiper-wrapper { display: flex; flex-wrap: nowrap; /*gap: 32px;*/ overflow-x: hidden;}
  #review .review-swiper.no-swiper .swiper-slide { width: calc((100% - 64px) / 3); flex-shrink: 0; box-sizing: border-box; margin-right: 32px;}
  #review .swiper-buttons.is-disabled { display: none !important;}
}

  #review .review-swiper.is-swiper.is-narrow { margin: 0 30px;}

@media (max-width: 1023px) and (min-width: 768px) {
}

@media (max-width: 767px) {
    #review .review-card { width: 82%;}
    #review .swiper-buttons { display: none!important;}
    
}





/*店舗情報*/
#location { max-width: 1640px; padding-inline: clamp(16px, 7.33vw, 120px);}
#location .inner { margin-top: clamp(80px, 10.42vw, 150px); margin-bottom: clamp(20px, 4.86vw, 70px);}
#location .left-box { white-space: nowrap;}
#location .location-title { color: #aaa; font-size: 14px; margin-bottom: 10px;}
#location .location-name { font-size: clamp(22px, 2.4vw, 30px); font-weight: bold; margin-bottom: 30px;}
#location .location-info p { font-size: clamp(14px, 1.11vw, 16px); margin-bottom: 0.15em;}
#location .location-images { display: flex; /*gap: 10px;*/ margin-bottom: 30px;}
#location .location-images img { flex: 1 1 47%; min-width: 0; width: 100%; height: auto; object-fit: cover; border-radius: 10px;}
#location .location-images img:first-child { margin-right: 15px;}
#location .map iframe { width: 100%; height: 270px; border: 0; border-radius: 8px;}

@media (min-width: 768px) {
    #location .inner { display: flex; justify-content: space-between; /*gap: 40px;*/}
    #location .left-box { margin-right: 40px;}
}

@media (max-width: 767px) {
    #location .left-box { padding-bottom: 30px;}
    #location .location-images img { flex: 1 1 100%;}
    #location .map iframe { height: 170px;}
}

@media only screen and (min-width: 1024px) and (max-width: 1366px) and (orientation: landscape) {
  /* iPad Pro横向き用のスタイル */
#location { max-width: 1100px;}
}
@media only screen and (min-device-width: 768px) and (max-device-width: 1024px) and (orientation:portrait) {
 /* iPad Pro縦向き用のスタイル */
#location { max-width: 750px;}
}




#form { margin-bottom: clamp(60px, 6.944vw, 120px);}

@media (max-width: 1023px) {
    #form { padding-inline: 3vw;}
}




/*フッター*/
footer { background: #f7f6f4; padding-top: clamp(80px, 9.03vw, 130px); padding-bottom: clamp(80px, 9.03vw, 130px);}
footer .link-list { display: flex; flex-wrap: wrap; gap: clamp(12px, 2vw, 20px) clamp(24px, 4vw, 40px); max-width: 710px;}
footer .link-list li { flex: 1 1 calc(50% - clamp(12px, 2vw, 20px)); display: flex; gap: clamp(12px, 2vw, 20px); font-size: clamp(14px, 1.2vw, 18px); font-weight: bold;}
footer .link-list .num { padding-right: 20px;}
footer .footer-bottom { margin: clamp(40px, 8vw, 80px) auto 0; padding-top: clamp(30px, 5vw, 50px); border-top: 1px solid #ccc; display: flex; justify-content: flex-end; gap: clamp(20px, 4vw, 40px); font-size: clamp(12px, 1vw, 14px); }

@media (min-width: 768px) {
}

@media (max-width: 767px) {
    footer .link-list li { flex: 1 1 100%;}
    footer .footer-bottom { flex-direction: column; align-items: flex-start; gap: 10px;}
}

/*form */
.ff_hi {font-family: 'Hind', sans-serif;}
.line_br {display: inline-block; background:#ece5e2;margin: 0 auto;border-radius: 2px;line-height: 1.3;letter-spacing: 0.2em;padding: 0 4%;}

#form {background: #f7f6f4;padding: 95px 0 98px; }
#form .tit {background: #f7f6f4;text-align: center;}
#form .tit span {font-size: 24px;vertical-align: middle;}
#form form {padding:0 20%;margin-top:68px; color: #767676;}
#form .contact_form {padding-bottom:25px; }
#form .blockbox {display: flex;justify-content: space-between;width: 100%;}
#form .blockbox div {width: 47.69%;}
#form label,
#form .itemTxt {display: block;font-size:24px; padding-bottom: 15px;}
#form .itemTxt span {font-size: 20px;}
#form input {font-size: 24px;width: 100%;border-radius: 5px;border: none;padding: 20px 20px;}
::placeholder {color: #d0cdcb; font-size: 24px;}
#form .notes {font-size: 20px;color: #8d8d8d; padding-bottom: 15px;}
#form .contact_form_tel input {margin-bottom: 0;}
#form .telbox01{width:23.43%;}
#form .telbox02,
#form .telbox03 {width:25.78%;margin-left: 12.5%;}
#form .telbox01,
#form .telbox02 {position: relative;}
#form .telbox01::after,
#form .telbox02::after{position:absolute; content:"";width: 25px; height: 1px;top: 50%;right:-35%; background:#767676;display: inline-block;background-size: contain;vertical-align: middle;top:50%;}
#form select#shopname {width: 100%;}
#form select {width: 100%;height: 100%;font-size:24px;padding: 20px;border: none;border-radius: 5px;-webkit-appearance: none;appearance: none;}
#form select::-ms-expand {display: none;}
#form .selectBox {position: relative;}
#form .selectBox::before {border-bottom: 6px solid #767676; border-left: 6px solid transparent; border-right: 6px solid transparent; content: ""; position: absolute;right: 20px; top: 35%; width: 0;}
#form .selectBox::after {border-left: 6px solid transparent; border-right: 6px solid transparent; border-top: 6px solid #767676; content: ""; position: absolute; right: 20px; top: 55%; width: 0;}
#form textarea {width: 100%;height: 300px; border:none;border-radius: 5px;padding: 10px 20px;font-size:30px;}
#form .daybox input::-webkit-date-and-time-value {text-align: left!important;padding-left: 17px;}
input[type="date"] {position: relative;}
input[type="date"]::-webkit-calendar-picker-indicator {position: absolute;top: 0; left: 0;right: 0; bottom: 0;width: auto;height: auto;background: transparent; z-index: 1;}
input[type="date"]::before {border-bottom: 6px solid #767676; border-left: 6px solid transparent; border-right: 6px solid transparent; content: ""; position: absolute;right: 20px; top: 35%; width: 0;}
input[type="date"]::after {border-left: 6px solid transparent; border-right: 6px solid transparent; border-top: 6px solid #767676; content: ""; position: absolute; right: 20px; top: 55%; width: 0;}
#form .cvbtn a {background: linear-gradient(90deg, rgba(208,55,104,1) 0%, rgba(224,107,145,1) 100%);}
form .errorItem { outline: 2px solid #cf3769;outline-offset: -2px; }
form #formErrorMessage { color: #cf3769;font-size: 18px;padding: 0 18px 18px 18px;line-height: 1.8; }

@media screen and (max-width: 749px) {
#form {padding: 57px 0; }
#form .tit span {font-size: 2.8vw}
#form form {margin-top:35px;padding: 0 5%;}
#form .contact_form {padding-bottom:15px; }
#form .blockbox {}
#form .blockbox div {}
#form label,
#form .itemTxt {font-size:4vw; padding-bottom: 7px;}
#form .itemTxt span {font-size: 3.2vw;}
#form input {font-size: 4vw;padding: 12px 20px;}
::placeholder {color: #d0cdcb; font-size: 4vw;}
#form .notes {font-size: 3.2vw;padding-bottom: 7px;}
#form .contact_form_tel input {}
#form .telbox01{}
#form .telbox02,
#form .telbox03 {}
#form .telbox01,
#form .telbox02 {}
#form .telbox01::after,
#form .telbox02::after{width: 12px;}
#form select#shopname {}
#form select {font-size:4vw;padding: 17px;background: #fff;}
#form select::-ms-expand {}
#form .selectBox {}
#form .daybox input {font-size: 4vw; padding: 17px;background: #fff;height: 54px;width: 40vw;}
#form .daytimebox select {height: 54px;}
#form .selectBox::before {border-bottom: 3px solid #767676;border-left: 3px solid transparent; border-right: 3px solid transparent; right: 10px; top: 35%;}
#form .selectBox::after {border-left: 3px solid transparent; border-right: 3px solid transparent; border-top: 3px solid #767676; content: ""; position: absolute; right: 10px; top: 55%;}
input[type="date"]::before {border-bottom: 3px solid #767676; border-left: 3px solid transparent; border-right: 3px solid transparent;}
input[type="date"]::after {border-left:3px solid transparent; border-right: 3px solid transparent; border-top: 3px solid #767676; content: "";}
#form textarea {height: 150px; border:none;padding: 5px 10px;font-size:4vw;}
form #formErrorMessage { color: #cf3769;font-size: 3.2vw;padding: 0vw 0vw 4vw 0vw;line-height: 1.8; }
}

/* cvbtn*/
.cvbtn {margin-top: 90px;}
.cvbtn a {position: relative; display: block; color: #fff; border-radius:7px; background: linear-gradient(90deg, rgba(141,128,167,1) 0%, rgba(181,166,179,1) 100%);font-size: 36px;text-align: center;padding: 4%;text-align: center; }
.cvbtn a p {line-height: 1.4;letter-spacing: .4rem;}
.cvbtn a span {font-size: 24px;display: block;}
.cvbtn .cvball {position: absolute;background: #dadf00;color: #111111; border-radius: 50%;top: -27.6%; left: -4.6%;font-size: 30px;padding: 32px 24px; box-shadow: 6px 10px 5px -3px rgba(0, 0, 0, .1)}
.cvbtn a p:before {content: ""; position: absolute;right: 2.9%; width: 25px; height: 1px;background: #fff;top:47.8%;}

.cvbtn a p:after {content: "";position: absolute;top:43.2%;right: 3.07%;width: 16px;height: 16px;border-top: 1px solid #fff;border-right: 1px solid #fff;-webkit-transform: rotate(45deg); transform: rotate(45deg);}

.cvbtn-b {margin-top: 90px;}
.cvbtn-b a {position: relative; display: block; color: #fff; border-radius:7px; background: linear-gradient(90deg, rgba(141,128,167,1) 0%, rgba(181,166,179,1) 100%);font-size: 36px;text-align: center;padding: 4%;text-align: center; }
.cvbtn-b a p {line-height: 1.4;letter-spacing: .4rem;}
.cvbtn-b a span {font-size: 24px;display: block;}
.cvbtn-b .cvball {position: absolute;background: #dadf00;color: #111111; border-radius: 50%;top: -27.6%; left: -4.6%;font-size: 30px;padding: 32px 24px; box-shadow: 6px 10px 5px -3px rgba(0, 0, 0, .1)}
.cvbtn-b a p:before {content: ""; position: absolute;right: 2.9%; width: 25px; height: 1px;background: #fff;top:47.8%;}

.cvbtn-b a p:after {content: "";position: absolute;top:42.3%;right: 3.07%;width: 16px;height: 16px;border-top: 1px solid #fff;border-right: 1px solid #fff;-webkit-transform: rotate(45deg); transform: rotate(45deg);}

@media screen and (max-width: 749px) {
/* cvbtn*/
.cvbtn {margin-top: 45px;}
.cvbtn a {font-size: 4.8vw;padding: 4%; border-radius:4px;}
.cvbtn a p {letter-spacing: .2rem;}
.cvbtn a span {font-size: 3.2vw; }
.cvbtn .cvball {font-size: 4vw;padding: 16px 10px;}
.cvbtn a p:before {width: 3.846vw;top:49.5%;}
.cvbtn a p:after {width: 2.461vw;height: 2.461vw; top:44%;}
.cvbtn-b {margin-top: 45px;}
.cvbtn-b a {font-size: 4.8vw;padding: 4%; border-radius:4px;}
.cvbtn-b a p {letter-spacing: .2rem;}
.cvbtn-b a span {font-size: 3.2vw; }
.cvbtn-b .cvball {font-size: 4vw;padding: 16px 10px;}
.cvbtn-b a p:before {width: 3.846vw;top:49.5%;}
.cvbtn-b a p:after {width: 2.461vw;height: 2.461vw; top:44%;}
}









