@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(630px, 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;}
}








