@charset "utf-8";

/* ==========================================
cover
========================================== */

.cover {
    position: relative;
}

.cover:before {
    content: "";
    position: absolute;
    z-index: -1;
    /* top: 6rem; */
    top: -16rem;
    left: 6.9rem;
    max-width: 36.6rem;
    height: 97.55%;
    width: 20%;
    background: url(../../../../uploads/cover-deco01.png) no-repeat center / contain;
}

.cover-frame {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    position: relative;
    max-width: 167rem;
    width: 94%;
    margin: 0 0 0 auto;
}

.cover-frame .swiper {
    margin: 0 0 0 auto;
    max-width: 110rem;
}

.cover-frame .swiper-wrapper:before{
    content: "";
    position: absolute;
    max-width: 35rem;
    width: 30%;
    height: 100.5%;
    top: 0;
    left: -1px;
    background: linear-gradient(90deg,rgba(250, 250, 250, 1) 0%, rgba(250, 250, 250, 0) 100%);
    z-index: 2;
}


.cover-left {
    max-width: 65rem;
    width: 100%;
    position: absolute;
    left: 0;
    z-index: 10;
}

.cover-sub-title {
    margin: 2.7rem 0 0;
}

.cover-text-row {
    display: flex;
    align-items: flex-start;
    justify-content: flex-start;
    gap: 4rem;
    margin: 11.9rem 0 0;
    position: relative;
    z-index: 5;
}

.cover-text-row:before,.cover-text-row:after {
    content: "";
    position: absolute;
    z-index: -1;
}

.cover-text-row:before {
    bottom: -5rem;
    left: -2rem;
    max-width: 10.7rem;
    height: 10.7rem;
    width: 17%;
    background: url(../../../../uploads/cover-deco03.png) no-repeat center / contain;
}

.cover-text-row:after {
    max-width: 15.2rem;
    height: 15.2rem;
    width: 24%;
    top: -8rem;
    right: 0rem;
    background: url(../../../../uploads/cover-deco02.png) no-repeat center / contain;
}


.cover-text-box {
    max-width: 25rem;
    width: 48%;
    font-size: clamp(1.5rem, 1.032rem + 0.973vw, 2.2rem);
    text-align: center;
    padding: 4.6rem 2.5rem;
    background: url(../../../../uploads/cover-text-bg.jpg) no-repeat center / cover;
}

.cover-text-box p span {
	font-size: 112.5%; /* 1.6rem × 1.125 = 1.8rem */
	font-weight: 700;
}


/* ==========================================
はじめての方へ
========================================== */

.top01 {
    padding: 18rem 0 0;
}

.top01-contents01-row {
    max-width: 125.8rem;
    width: 100%;
    margin: 0 auto;
    display: flex;
    align-items: flex-start;
    justify-content: center;
    gap: 15rem;
}

.top01-img01 {
    max-width: 50rem;
}

.top01-contents01-text-block {
    margin: 3rem 0 0;
    line-height: 1.85;
}

.top01-text-box01:nth-child(n+2) {
    margin: 4rem 0 0;
}

.top01-text-deco-box01 {
    position: relative;
    display: inline-block;
    padding: 0 0 1.7rem;
}

.top01-text-deco-box01:after {
    content: "";
    position: absolute;
    z-index: -1;
    bottom: 0;
    left: 0;
    height: 9px;
    width: 100%;
    /* background: url(../../../../uploads/text-deco01-blue.png) no-repeat 0 center / cover; */
    /* background: url(../../../../uploads/text-deco02-blue.png) repeat-x 0 center / auto 6px; */
    background-image: url(../../../../uploads/text-deco02-blue.png);
    background-repeat: repeat-x;
    background-position: 0 center;
    background-size: auto 100%;
}

.top01-btn01 {
    margin: 6rem 0 0;
}

.top01-contents02 {
    max-width: 158.7rem;
    width: 100%;
    margin: 10rem auto 0;
}

.top01-contents02-row {
    display: flex;
    align-items: flex-start;
    justify-content: center;
    gap: 4rem;
}

.top01-text-area02 {
    max-width: 57rem;
}

.top01-contents02-text-block {
    max-width: 57rem;
    width: 100%;
    margin: 3rem 0 0;
    line-height: 1.85;
}

.top01-img-block02 {
    max-width: 61rem;
}

.top01-img02 {
    width: 84.26%;
    max-width: 51.4rem;
}

.top01-img03 {
    max-width: 35.3rem;
    width: 57.87%;
    margin: -5rem 0 0 auto;
}


.top01-contents02-text-block .text-box-margin {
    margin: 1rem 0 0;
}

.top01-text-deco-box01.sp-text {
    display: none;
}

/* ==========================================
ヘアメニュー・エステメニュー
========================================== */

.top02 {
    padding: 13.2rem 0 12rem;
}

.top02-contents {
    max-width: 826px;
    width: 75%;
    margin: 0 auto;
    position: relative;
}

.top02-main {
    max-width: 752px;
    width: 95%;
    margin: 0 auto;
    padding: 5.4rem 2rem;
    text-align: center;
    background: url(../../../../uploads/text-bg01.jpg) no-repeat center / cover;
}

.top02-main .br-768-block {
    line-height: 2.2;
}

/* .text-dot {
    position: relative;
    display: inline-block;
    padding-bottom: 0.8em;
}

.text-dot::after {
    content: "・";
    position: absolute;
    bottom: -.5rem;
    left: 50%;
    transform: translateX(-50%);
    font-size: 140%;
    color: var(--tertiary);
    line-height: 1;
} */

.text-dot {
    font-size: 100%;
    padding-top: 0.75em;
    background-position: top left -1px;
    background-repeat: repeat-x;
    background-size: 1.05em 1em;
    background-image: radial-gradient(#8FD0E1 25%, transparent 26%);
}

.top02-illust01 {
    position: absolute;
    top: -1rem;
    left: 0;
    z-index: 1;
}

.top02-illust02 {
    position: absolute;
    bottom: -1rem;
    right: 0;
    z-index: 1;
}

.top02-btn-row {
    max-width: 67rem;
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 7rem;
    margin: 11rem auto 0;
}

.top02-btn-row .com-btn01 {
    width: 48%;
}

.top02-deco01 {
    position: absolute;
    width: 18.95%;
    top: 11%;
    right: 2%;
    z-index: -1;
}

/* ==========================================
ループ
========================================== */

.top03-loop-wrapper {
    position: relative;
    z-index: 1;
}

/* ==========================================
髪や肌が変わってきたと感じたら…
========================================== */

.top04 {
    margin: -6rem 0 0;
    filter: drop-shadow(0 3px 6px rgb(0 0 0 / 5%));
}

.top04-clip {
    position: absolute;
    inset: 0;
    background: linear-gradient(60deg,rgba(68, 180, 209, 0.52) 0%, rgba(143, 208, 225, 0.51) 60%, rgba(143, 225, 222, 0.5) 100%);
    clip-path: polygon(0 0, 100% 0, 100% 85%, 50% 100%, 0 85%);
    z-index: 0;
}

.top04-contents {
    max-width: 90.3rem;
    width: 98%;
    margin: 0 auto;
    padding: 16rem 0 0;
    position: relative;
    z-index: 1;
}

.top04-title-box {
    display: flex;
    align-items: center;
    justify-content: center;
}

.top04-pc {
    width: 100%;
}

.top04-main {
    position: relative;
    width: 100%;
    padding: 16.5rem 0 7.3rem;
    margin: 3.6rem auto 0;
}

.top04-card-block {
    position: absolute;
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
}

.top04-card-in {
    position: relative;
    z-index: 5;
}

.top04-card {
    border-radius: 1rem;
    padding: 2rem .3rem 1.4rem;
    max-width: 22.5rem;
    width: 100%;
    height: 10.8rem;
    text-align: center;
    font-size: 1.5rem;
    font-weight: 700;
    line-height: 1.8;
    display: flex;
    align-items: center;
    justify-content: center;
    position: absolute;
    z-index: 5;
}

.top04-card:before{
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    border: 1px solid #C5C5C5;
    width: 100%;
    height: 100%;
    border-radius: 1rem;
    z-index: 5;
}

.top04-card:after{
    content: "";
    position: absolute;
    top: .8rem;
    left: .8rem;
    background: var(--white);
    width: 100%;
    height: 100%;
    border-radius: 1rem;
    z-index: -1;
}

.card-01 {
  top: 0;
  left: 50%;
  transform: translateX(-50%); /* イラストの真上に合わせる */
}

/* 左側 */
.card-02 {top: 18%;left: 7%;}   /* 白髪 */
.card-04 { top: 50%; left: 2%; }   /* ハリ */

/* 右側 */
.card-03 {top: 18%;right: 7%;}  /* シミ */
.card-05 { top: 50%; right: 2%; }  /* たるみ */

.top04-illust {
  position: relative;
  max-width: 16rem;
  margin: 0 auto;
}

.top04-illust img {
  width: 100%;
}

.top04-02 {
    margin: 7.13rem 0 0;
}

.top04-02-text-block {
    text-align: center;
}

.top04-text-deco-box01.top01-text-deco-box01 {
    position: relative;
    display: inline-block;
    padding: 0 0 2rem;
}

.top04-text-deco-box01:after {
    /* content: ""; */
    /* position: absolute; */
    z-index: 0;
    /* bottom: 0; */
    /* left: 0; */
    /* height: 18%; */
    /* width: 100%; */
    /* background: url(../../../../uploads/text-deco02-blue.png) no-repeat center / contain; */
}

.top04-deco {
    max-width: 9.1rem;
    width: 9%;
    position: absolute;
    right: 0;
    bottom: 1rem;
    z-index: 1;
}

.top04-illust02 {
    display: none;
}

/* ==========================================
当店のおすすめメニュー
========================================== */

.top-shadow {
    box-shadow: 0 4px 6px -2px rgb(0 0 0 / 6%);
}

.top05 {
    padding: 14.7rem 0 13.4rem;
}

.top05-title-block {
    text-align: center;
}

.top05 .deco-ribbon-title-box {
    max-width: 61rem;
    margin: 3rem auto 0;
}

.top05-main {
    margin: 10.8rem auto 0;
}

.top05-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    max-width: 157rem;
    width: 95%;
    margin: 13.6rem 0 0 auto;
    gap: 10rem;
    position: relative;
}

.top05-row:first-of-type {
    margin: 0 0 0 auto;
}

.top05-row:nth-of-type(2n) {
    margin: 13.6rem auto 0 0;
}

.top05-row:nth-of-type(2n) {
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-direction: row-reverse;
}

.top05-text-area {
    max-width: 57rem;
    width: 37%;
}

.top05-title-row {
    display: flex;
    align-items: center;
    gap: 2.5rem;
}

.top05-num-box {
    width: 7.6rem;
}

.top05-num-box-in {
    width: 100%;
    padding-top: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    border: 1px solid var(--primary);
    border-radius: 100vmax;
}

.top05-num-box-in p {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    font-size: 2.5rem;
    font-weight: 500;
    z-index: 1;
}

.top05-text-box {
    margin: 4rem 0 0;
    line-height: 1.94;
}

.top05-img-box {
    max-width: 90rem;
    width: 58%;

}

.top05-btn01 {
    margin: 6rem 0 0;
}

/* ==========================================
お客様からのあたたかいお声
========================================== */

.top06 {
    padding: 11.1rem 0 18rem;
}

.top06-title-box {
    text-align: center;
    padding: 0 0 2rem;
    border-bottom: 1px solid #C5C5C5;
}

.top06-text-box {
    margin: 4rem auto 0;
    text-align: center;
}


.swiper-frame {
    max-width: 107rem;
    width: 100%;
    margin: 6rem auto 0;
}

.slider-nav {
    display: flex;
    justify-content: space-between;
    position: relative;
    top: -2rem;
    z-index: 9;
}

.swiper-button-next, .swiper-button-prev {
    width: 12px!important;
}

.swiper-button-prev, .swiper-rtl .swiper-button-next {
    left: 0!important;
}

.swiper-button-next, .swiper-rtl .swiper-button-prev {
    right: 0!important;
}

/* デフォルトのアイコンを非表示 */
.swiper-button-next:after,
.swiper-button-prev:after {
    display: none;
}

/* 共通 */
.swiper-button-prev::before,
.swiper-button-next::before {
    content: "";
    display: block;
    width: 12px;
    height: 20px;
    background: #8FD0E1;
    transition: background 0.3s;
}

/* 左向き三角形 */
.swiper-button-prev::before {
    clip-path: polygon(100% 0%, 0% 50%, 100% 100%);
}
.swiper-button-prev:hover::before {
    background: #8FD0E1;
}

/* 右向き三角形 */
.swiper-button-next::before {
    clip-path: polygon(0% 0%, 100% 50%, 0% 100%);
}
.swiper-button-next:hover::before {
    background: #8FD0E1;
}

.swiper-button-next.swiper-button-disabled .swiper-button-next::before, .swiper-button-prev.swiper-button-disabled .swiper-button-prev::before {
    background: #C5C5C5;
}

.top06-card {
    max-width: 50rem;
    width: 100%;
    height: 100%;
    padding: 1rem;
    box-shadow: 0 3px 6px rgb(0 0 0 / 16%);
}

.top06-card-in {
    border-radius: .8rem;
    padding: 2rem;
}

.top06-card-title-row {
    display: flex;
    align-items: center;
    gap: 2rem;
}

.top06-card-title-row figure {
    max-width: 9.3rem;
    width: 26%;
}

.top06-card-title-row p {
    flex: 1;
}

.top06-card-text-box01 {
    margin: 2rem 0 0;
}

.js-limit-text {
  display: -webkit-box;
  -webkit-line-clamp: 4;
  -webkit-box-orient: vertical;
  overflow: hidden;
  line-height: 1.8; /* 数値で必ず指定 */
}

.js-limit-text.is-check {
  display: block !important;
  -webkit-line-clamp: unset !important;
  overflow: visible !important;
}

.top06-card-text-box02 {
    text-align: right;
    margin: 2rem 0 0;
}

.modal {
  display: none;
  position: fixed;
  inset: 0;
  background: rgb(0 0 0 / 50%);
  place-items: center;
  z-index: 100;
}

.modal:target {
  display: grid;
}

.modal-inner {
  background: #fff;
  padding: 2rem;
  border-radius: 8px;
  max-width: 600px;
  width: 90%;
}

/* 続きを読むボタン */
.js-modal-btn {
  display: block;
  max-width: 10rem;
  width: 100%;
  margin: .8rem 0 0 auto;
  padding: .8rem;
  font-size: 1.4rem;
  background: var(--primary);
  color: var(--white);
  border-radius: 100vmax;
  text-decoration: none;
  text-align: center;
  cursor: pointer;
  transition: .3s;
}

.js-modal-btn:hover {
    opacity: 0.6;
    transition: .3s;
}


/* モーダル背景 */
.modal {
  display: none;
  position: fixed;
  inset: 0;
  background: rgb(0 0 0 / 50%);
  place-items: center;
  z-index: 100;
}

.modal:target {
  display: grid;
}

/* モーダル本体 */
.modal-inner {
  background: #fff;
  padding: 2rem;
  border-radius: 8px;
  max-width: 600px;
  width: 90%;
  max-height: 80vh;
  overflow-y: auto;
}

.voice-modal-overlay {
    display: none;
    position: fixed;
    inset: 0;
    background: rgb(0 0 0 / 50%);
    place-items: center;
    z-index: 9999;
}

.voice-modal-overlay.is-open {
    display: grid;
}

.voice-modal-inner {
    background: #fff;
    padding: 2rem;
    border-radius: 8px;
    max-width: 600px;
    width: 90%;
    max-height: 80vh;
    overflow-y: auto;
}

.voice-modal-close {
    display: block;
    max-width: 10rem;
    width: 100%;
    margin: 2rem auto 0;
    padding: .8rem;
    font-size: 1.4rem;
    background: var(--primary);
    color: var(--white);
    border-radius: 100vmax;
    text-decoration: none;
    text-align: center;
    cursor: pointer;
    transition: .3s;
}

.voice-modal-close:hover {
    opacity: 0.6;
    transition: .3s;
}

/* 1. Swiperの各スライド自体をFlexboxにして、高さを引き伸ばす準備をする */
.top06 .swiper-slide {
    display: flex !important;
    flex-direction: column !important;
    height: auto !important; /* JSによる固定高さをクリア */
    align-items: center; /* 追加 */
}

/* 2. 外側のカード（グラデーション背景）を縦いっぱいに広げる */
.top06-card {
    display: flex !important;
    flex-direction: column !important;
    flex-grow: 1 !important;   /* 親（slide）の高さまで自動で引き伸ばす */
    height: auto !important;   /* JSのインラインスタイルを強制上書き */
}

/* 3. 内側のカード（白背景）も同様に、外側のカードの底まで広げる */
.top06-card-in {
    display: flex !important;
    flex-direction: column !important;
    flex-grow: 1 !important;   /* 親（card）の底まで自動で引き伸ばす */
    height: auto !important;   /* JSのインラインスタイルを強制上書き */
}

/* 4. [任意] ボタン（続きを読む）を常にカードの最下部に固定したい場合 */
.top06-card-in {
    justify-content: space-between; /* 中身の要素を上下に綺麗に分散配置 */
}
/* または、テキストボックスを広げてボタンを下に押し出す場合 */
.top06-card-text-box01 {
    flex-grow: 1;
}

/* ==========================================
top07
========================================== */

.top07 {
    padding: 0 0 14.1rem 0;
}

.top07-contents {
    max-width: 146.5rem;
    width: 100%;
    margin: 0 auto;
}

.top07-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
}

.top07-right {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 1rem;
    max-width: 78rem;
    width: 50%;
    padding: 2.5rem 12.2rem 3.9rem 8.2rem;
    background: url(../../../../uploads/circle-deco-double01.png) no-repeat center / contain;
}

.top07-left {
    max-width: 78rem;
    width: 48.7%;
    padding: 0 0 0 11.1%;
}

.top07-en-title {
    opacity: .39;
}

.top07-title {
    margin: -5.5rem 0 0;
    font-weight: 600;
}

.top07-sub-title-box, .top07-text-box {
    margin: 4rem 0 0;
}

.top07-text-box {
    line-height: 2;
}

.top07-left .top07-right {
    display: none;
}

/* ==========================================
top08
========================================== */

.top08 {
    padding: 0 0 3rem;
}

.top08-main {
    max-width: 186rem;
    width: 100%;
    margin: 0 auto;
    position: relative;
}

.top08-bg-sp {
    display: none;
}

.top08-bg {
    position: relative;
    width: 100%;
    min-height: 69.8rem;
}

.top08-bg img {
    justify-content: center;
    align-items: center;
    position: absolute;
    display: flex;
    top: 0;
    right: 0;
    left: 0;
    bottom: 0;
    height: 100% !important;
    max-width: 100%;
    width: 100%;
    margin: auto;
    object-fit: cover;
    transition: all .5s;
}

.top08-bg:before {
    content: "";
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0,0,0,.59);
    z-index: 1;
}

.top08-text-area {
    position: absolute;
    width: 100%;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-direction: column;
    z-index: 5;
}

.top08-title-box {
    position: relative;
    max-width: 50rem;
    width: 100%;
    margin: 0 auto;
    text-align: center;
}

.top08-title-box:before,.top08-title-box:after {
    content: "";
    position: absolute;
    top: 50%;
    max-width: 5.7rem;
    width: 20%;
    height: 7rem;
    background: url(../../../../uploads/title-deco01-white.svg) no-repeat center / contain;
    transform: translateY(-50%);
    z-index: 1;
}

.top08-title-box:before {
    left: 0;
}

.top08-title-box:after {
    right: 0;
}

.top08-sub-title-box {
    text-align: center;
}

.top08-text-box {
    margin: 4rem auto 0;
    text-align: center;
    line-height: 1.96;
}

.top08-btn {
    width: 100%;
    margin: 5rem auto 0;
}

.top08-illust01 {
    position: absolute;
    top: 0;
    right: 0;
    z-index: 2;
    max-width: 37.7rem;
    width: 21%;
}

.top08-illust02 {
    position: absolute;
    bottom: 0;
    left: 0;
    z-index: 5;
    max-width: 26.5rem;
    width: 15%;
}

/* ★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★ */
/* ★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★ */

@media screen and (width <=1550px) {

    /* ==========================================
	cover
	========================================== */

    .cover-frame .swiper:before {
        width: 42%;
    }

    .cover-frame .swiper {
        width: 66%;
    }

    .cover-text-row {
        margin: 6rem 0 0;
    }

    .cover-sub-title {
        margin: 2rem 0 0;
    }

    /* ==========================================
	top01
	========================================== */

    .top01-contents01 {
        width: 88%;
        margin: 0 auto;
    }

    .top01-contents01-row {
        gap: 5rem;
    }

    .top01-img01 {
        width: 38%;
    }

    .top01-text-area01 {
        width: 56%;
    }

	/* ==========================================
	top02
	========================================== */



	/* ==========================================
	top05
	========================================== */

    .top05-row {
        width: 90%;
        gap: 4rem;
    }

    .top05-text-area {
        width: 46%;
    }

    .top05-img-box {
        width: 52%;
    }

}

/* ☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆ */
/* ☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆ */

/* ★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★ */
/* ★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★ */

@media screen and (width <= 1250px) {

    .cover-text-row:after {
        top: -5rem;
        right: 7rem;
    }


	/* ==========================================
	top01
	========================================== */

    .top01-contents01-row {
        gap: 4rem;
    }

    .top01-img01 {
        width: 36%;
    }

    .top01-text-area01 {
        width: 62%;
    }

    .top01-contents02-row {
        gap: 3rem;
        width: 90%;
        margin: 0 auto;
    }

    .top01-img03 {
        margin: -2rem 0 0 auto;
    }

    .top02-contents {
        width: 90%;
    }

	/* ==========================================
	top05
	========================================== */

    .top05-row {
        width: 93%;
        gap: 3.5rem;
    }

    .top05-text-area {
        max-width: 66rem;
        width: 52%;
    }

    .top05-img-box {
        width: 46%;
    }

    .top05-title-row .title33 {
        font-size: 25px;
    }

    .top05-num-box {
        width: 6.5rem;
    }

    .top05-text-box.text23 {
        font-size: 20px;
    }

}

/* ☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆ */
/* ☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆ */

/* ★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★ */
/* ★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★ */

@media screen and (width <=1024px) {

    /* ==========================================
	cover
	========================================== */

    .cover:before {
        top: -6rem;
        left: 1rem;
    }

    .cover-frame .swiper:before {
        width: 55%;
    }

    .cover-text-row {
        margin: 4rem 0 0;
        width: 63%;
        gap: 2rem;
    }

    .cover-text-box {
        padding: 2rem 1rem;
    }

    .cover-title.title50 {
        font-size: 30px;
    }

    .cover-sub-title.title25 {
        font-size: 1.75rem;
    }

    /* ==========================================
	top01
	========================================== */

    .top01-contents01 {
        width: 94%;
    }

    .top01-img01 {
        width: 32%;
    }

    .top01-text-area01 {
        width: 67.5%;
    }

    .top01-text-area02 {
        width: 45%;
    }

    .top01-img-block02 {
        width: 45%;
    }

	/* ==========================================
	top02
	========================================== */


	/* ==========================================
	top03
	========================================== */

	/* ==========================================
	top05
	========================================== */

    .top05-row {
        width: 93%;
        gap: 3rem;
    }

    .top05-img-box {
        width: 38%;
    }

    .top05-text-area {
        width: 60%;
    }
    
    .top05-title-row {
        gap: 2rem;
    }

    .top05-num-box {
        width: 6rem;
    }

    .top05-text-box {
        margin: 3rem 0 0;
    }

    .top05-btn01 {
        margin: 4rem 0 0;
    }

}

/* ☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆ */
/* ☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆ */


/* ★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★ */
/* ★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★ */

@media screen and (width <=820px) {

    .cover-title.title50 {
        font-size: clamp(2rem, -0.004rem + 4.17vw, 5rem);
    }

    .cover-sub-title.title25 {
        font-size: clamp(1.6rem, 0.999rem + 1.251vw, 2.5rem);
    }

    /* ==========================================
	top01
	========================================== */

    .top01 {
        padding: 10rem 0 0;
    }

    .top01-contents01-row {
        gap: 3rem;
    }

    .top01-img01.pc {
        display: block !important;
    }

    .top01-img01.sp {
        display: none !important;
    }

    .top01-img-block02.pc  {
        display: block !important;
    }

    .top01-img-block02.sp {
        display: none !important;
    }

    .top01-text-box01:nth-child(n+2) {
        margin: 2rem 0 0;
    }

    .top01-btn01 {
        margin: 4rem auto 0;
    }

    .top01-text-deco-box01.sp-text {
        display: inline-block;
    }

    .top01-text-deco-box01.pc-text {
        display: none;
    }

    .text-deco {
        display: inline-block;
        padding-bottom: 6px;
        background: url(../../../../uploads/text-deco01-blue.png) repeat-x bottom left / auto 6px;
    }

    .top01-text-deco-box01.sp-text:after {
        content: none;
    }

    .top01-img-block02 {
        width: 40%;
    }

    .top01-text-area02 {
        width: 50%;
    }

    /* ==========================================
	top05
    ========================================== */
    
    .top04-text-deco-box01:after {
        /* background: url(../../../../uploads/text-deco01-blue.png) no-repeat center / contain; */
    }

    /* ==========================================
	top05
	========================================== */

    .top05 {
        padding: 8rem 0 8rem;
    }

    .top05-row:nth-of-type(2n) {
        margin: 8rem auto 0;
    }

    .top05-row:first-of-type {
        margin: 0 auto;
    }

    .top05-text-area {
        width: 100%;
        margin: 0 auto;
    }

    .top05-img-box01 {
        margin: 3rem auto 0;
    }

    .top05-btn01 {
        margin: 4rem auto 0;
    }

    /* ==========================================
    top06
    ========================================== */

    .top06 {
        padding: 8rem 0 12rem;
    }

    .top06-card-title-row figure {
        width: 22%;
    }

    /* ==========================================
	top07
	========================================== */

    .top07 {
        padding: 0 0 10rem 0;
    }

    .top07-left {
        padding: 0 0 0 6.1%;
    }

    .top07-right {
        padding: 2.5rem 7.2rem 3.9rem 5.2rem;
    }

}

/* ☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆ */
/* ☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆ */

/* ★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★ */
/* ★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★ */

@media screen and (width <=768px) {

    /* ==========================================
	cover
	========================================== */

    .cover-frame {
        flex-direction: column;
        width: 100%;
    }

    .cover:before,.cover-text-row:before,.cover-text-row:after {
        content: none;
    }


    .cover-frame .swiper {
        width: 100%;
        margin: 21% auto 0;
    }

    .cover-frame .swiper:before{
        content: "";
        position: absolute;
        max-width: inherit;
        width: 100%;
        height: 30%;
        background: linear-gradient(180deg, rgba(250, 250, 250, 1) 0%, rgba(250, 250, 250, .8) 50%, rgba(250, 250, 250, .0) 100%);
        z-index: 2;
    }

    .cover-left {
        position: absolute;
        top: 0;
        right: 0;
        margin: auto;
    }

    .cover-frame, .cover-left {
        height: auto;
        min-height: calc(100svh - 20rem);
    }

    .cover-text-box {
        font-size: clamp(1.5rem, 1.023rem + 2.036vw, 2rem);
    }

    .cover-title-block {
        text-align: center;
        /* height: 77rem; */
        height: 100%;
    }

    .cover-title-box {
        padding: 12rem 4rem;
        position: absolute;
        width: 100%;
        top: -5%;
        left: 0;
        right: 0;
        margin: auto;
        z-index: 2;
    }

    .cover-title-box:before {
        content: "";
        position: absolute;
        z-index: -1;
        top: 0;
        left: 0;
        right: 0;
        bottom: 0;
        margin: auto;
        max-width: 58rem;
        height: auto;
        width: 100%;
        background: url(../../../../uploads/cover-deco01.png) no-repeat center / contain;
    }

    .cover-sub-title {
        font-weight: 600;
    }

    .cover-text-row {
        justify-content: center;
        margin: 0;
        width: 100%;
        gap: 2rem;
        position: absolute;
        bottom: 0;
        z-index: 2;
    }

    /* ==========================================
    top01
    ========================================== */

    .top01 {
        padding: 8rem 0 0;
    }

    .top01-contents01 {
        width: 100%;
    }

    .top01-contents02 {
        margin: 7rem auto 0;
    }

    .top01-text-area01 {
        width: 100%;
        max-width: 57rem;
    }

    .top01-text-area02 {
        width: 100%;
    }

    .top01-img01 {
        width: 72.5%;
        margin: 5rem auto 0;
    }

    .top01-img01.pc {
        display: none !important;
    }

    .top01-img01.sp {
        display: block !important;
    }

    .top01-contents02-row {    
        flex-direction: column;
        max-width: 57rem;
        width: 100%;
    }

    .top01-img-block02.pc  {
        width: 100%;
        margin: 5rem 0 0;
    }

    /* .top01-img-block02.sp {
        display: block !important;
    }

    .top01-img-block02 {
        width: 100%;
        margin: 5rem 0 0;
    } */

    .top01-img-block02 .top02-deco01 {
        display: block;
    }

    
    .top01-contents01-text-block {
        display: flex;
        flex-direction: column;
    }

    .top01-img01.sp {
        order: 1;
    }

    .top01-text-deco-box01 {
        padding: 0 0 1.25rem;
    }


    /* ==========================================
    top02
    ========================================== */

    .top02 {
        padding: 8rem 0 7rem;
    }

    .top02-btn-row {
        margin: 5rem auto 0;
    }

    .top02-deco01 {
        display: none;
        width: 30%;
        top: -3rem;
        right: 0;
    }

    /* ==========================================
    top03
    ========================================== */


    /* ==========================================
    top04
    ========================================== */

    .top04-clip {
        clip-path: polygon(0 0, 100% 0, 100% 90%, 50% 100%, 0 90%);
        background: linear-gradient(230deg,rgba(143, 225, 222, .5) 0%, rgba(143, 208, 225, .5) 45%, rgba(68, 180, 209, .5) 100%);
    }

    .top04-text-deco-box01.title33 {
        font-size: 2rem;
    }

    .top04-title-box .title30 {
        font-size: 2.5rem;
    }

    .top04-title-box .deco-bg-white-title-box {
        padding: 2.7rem 3rem 2.9rem 4rem;
    }

    .top04-title-box .deco-bg-white-title-box:after {
        right: 2rem;
    }

    .top04-deco {
        display: none;
    }

    .top04-main {
        padding: 0 0 7.3rem;
    }

    .top04-illust {
        width: 28%;
    }

    .top04-card-block {
        position: relative;
        max-width: 53.7rem;
        width: 100%;
        height: 35rem;
        margin: 0 auto;
    }

    .card-02 {
        top: 50%;
        transform: translateY(-50%);
    }

    .card-03 {
        top: 50%;
        transform: translateY(-50%);
    }

    .card-04 {
        top: auto;
        bottom: 0;
    }

    .card-05 {
        top: auto;
        bottom: 0;
    }

    .top04-illust02 {
        display: block;
        position: absolute;
        right: 0;
        bottom: 12rem;
        z-index: 1;
    }

	/* ==========================================
	top05
	========================================== */

    .top05-title-block {
        padding: 0 2rem;
    }

    .top05-row {
        width: 100%;
    }

    .top05-row:after {
        content: "";
        position: absolute;
        top: -4rem;
        left: 0;
        right: 0;
        width: 90%;
        height: 1px;
        margin: 0 auto;
        background: #ccc;
        z-index: 2;
    }

    .top05-row:first-child::after {
        content: none;
    }

    .top05-text-area {
        width: 100%;
        max-width: 80rem;
    }

    .top05-title-row, .top05-text-block {
        padding:  0 2.2rem;
    }

    .top05-img-box01 {
        margin: 2rem auto 0;
    }

    .top05-text-box {
        line-height: 1.78;
    }

    


    /* ==========================================
    top07
    ========================================== */

    .top07 .padding-x {
        padding: 0;
    }

    .top07-row {
        flex-direction: column;
    }

    .top07-left {
        padding: 0;
        width: 100%;
    }

    .top07-right {
        display: none;
    }

    .top07-right {
        /* max-width: 45rem; */
    }

    .top07-left .top07-right {
        display: grid;
        margin: 3rem auto 0;
        width: 100%;
        padding: 2.5rem 10rem 3.9rem 10rem;
    }

    .top07-title-box, .top07-sub-title-box, .top07-text-box {
        padding: 0 2.5rem;
    }

    .top07-title {
        margin: -4rem 0 0;
    }

	/* ==========================================
	top08
	========================================== */

    .top08-bg {
        min-height: 56.7rem;
    }

    .top08-bg-pc {
        display: none;
    }

    .top08-bg-sp {
        display: block;
    }

    .top08-illust01 {
        width: 38.3%;
    }

    .top08-illust02 {
        width: 30%;
    }

}

/* ☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆ */
/* ☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆ */

/* ★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★ */
/* ★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★ */

@media screen and (width <=576px) {

    
    /* ==========================================
    cover
    ========================================== */

    .cover-frame, .cover-left {
        min-height: calc(100svh - 16rem);
    }

    /* .cover-frame .swiper {
        margin: 32% auto 0;
    } */

    .cover-frame .swiper {
        margin: auto auto 0;
    }

    .cover-text-row {
        gap: 1rem;
        margin: 0;
    }

    /* .cover-title-block {
        height: 65rem;
    } */

    
    .cover-title-block {
        height: 100%;
    }

    .cover-title-box {
        padding: 5rem .5rem;
        width: 80%;
        margin: 0 auto;
    }

    .cover-title-box {
        position: absolute;
        top: -3%;
        left: 0;
        right: 0;
    }

    .cover-title-box .title50 {
        font-size: 2.8rem;
    }

    .cover-sub-title {
        font-size: 1.6rem;
    }

    /*.cover-text-row {
         flex-direction: column;
        align-items: center;
    } */

    .cover-text-box {
        width: 77%;
        max-width: 32rem;
        padding: 1rem;
    } 

    /* ==========================================
	top01
	========================================== */

    .top01 {
        padding: 7rem 0 0;
    }

    .top01 .padding-x {
		padding: 0 2.7rem;
	}

    .top01-contents02-row {
        width: 100%;
    }

    .top01-img01 {
        margin: 5rem auto 0;
    }

    .top01-text-box01:nth-child(n+2) {
        margin: 2rem 0 0;
    }


    /* ==========================================
    top02
    ========================================== */

    .top02 {
        padding: 7rem 0;
    }

    .top02-main {
        width: 95%;
        padding: 5.4rem 1.5rem;
    }

    .top02-illust01 {
        width: 21.8%;
    }

    .top02-illust02 {
        width: 34%;
    }

    .top02-btn-row {
        flex-direction: column;
        gap: 2rem;
        margin: 5rem auto 0;
    }

    .top02-btn-row .com-btn01 {
        width: 100%;
    }

    /* ==========================================
    top03
    ========================================== */



    /* ==========================================
    top04
    ========================================== */

    .top04 {
        margin: -3rem 0 0;
    }

    .top04-clip {
        clip-path: polygon(0 0, 100% 0, 100% 95%, 50% 100%, 0 95%);
    }

    .top04-contents {
        padding: 7.8rem 0 0;
    }

    .top04-title-box .deco-bg-white-title-box {
        max-width: 34rem;
        width: 100%;
        display: block;
        padding: 1.3rem 3rem 1.3rem 4rem;
    }

    .top04-text-deco-box01:after {
        /* background-size: inherit; */
        background-position: left center;
    }

    .top04-main {
        padding: 0 0 7.3rem;
        margin: 4.7rem auto 0;
    }

    .top04-card-block {
        max-width: 40rem;
        height: auto;
    }

    .top04-card {
        position: relative;
        max-width: 20.8rem;
        font-size: 1.3rem;
    }

    .card-01 {
        top: auto;
        left: auto;
        transform: none;
        margin: 1.6rem 0 0;
    }

    .card-02 {
        top: auto;
        transform: none;
        left: auto;
    }

    .card-03 {
        top: auto;
        transform: none;
        right: auto;
        margin: 1.6rem 0 0 auto;
    }

    .card-04 {
        top: auto;
        bottom: auto;
        left: auto;
        margin: 1.6rem 0 0 auto;
    }

    .card-05 {
        top: auto;
        bottom: auto;
        right: auto;
        margin: 1.6rem 0 0;
    }

    .top04-illust {
        width: 18%;
        position: absolute;
        top: 1%;
        right: 10rem;
    }

    .top04-illust02 {
        bottom: 5rem;
    }
    
    /* ==========================================
    top05
    ========================================== */

    .top05 {
        padding: 6rem 0 7rem;
    }

    .top05-btn01 {
        margin: 4rem auto 0;
    }

    .top05-main {
        margin: 5rem auto 0;
    }

    .top05-row:nth-of-type(2n) {
        margin: 9rem auto 0 0;
    }

    .top05-title-row {
        gap: 1rem;
    }

    .top05 .title33 {
        font-size: 2.3rem;
    }

    .top05 .text23 {
        font-size: 1.8rem;
    }

    .top05-num-box {
        width: 5.4rem;
    }

    .top05-num-box-in p {
        font-size: 1.8rem;
    }

    .top05-img-box01 figure {
        aspect-ratio: 375 / 200;
    }

    .top05-img-box01 img {
        object-fit: cover;
        width: 100%;
        height: 100% !important;
    }

    .top05 .deco-ribbon-title-box {
        width: 95.3%;
        margin: 1.58rem auto 0;
    }

    /* ==========================================
    top06
    ========================================== */

    .top06 {
        padding: 7rem 0;
    }

    .swiper-frame {
        max-width: 50rem;
    }

    /* ==========================================
    top07
    ========================================== */

    .top07 {
        padding: 0 0 8rem 0;
    }

    .top07 .text23 {
        font-size: 1.8rem;
    }

    .top07-left .top07-right {
        padding: 2.5rem 5rem 3.9rem;
        gap: .8rem;
        /* background: unset; */
    }

    /* ==========================================
    top08
    ========================================== */

    .top08-text-area {
        padding: 0 1.8rem;
    }

    .top08-title-box:before, .top08-title-box:after {
        width: 12%;
    }
    
    .top08-illust02 {
        display: none;
    }

    .top08-text-box {
        margin: 3.4rem auto 0;
    }

}

/* ☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆ */
/* ☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆ */

/* ★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★ */
/* ★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★ */

@media screen and (width <=414px) {

    /* .cover-title-block {
        height: 55rem;
    } */

    .cover-title-box .title50 {
        padding: 0 0 0 5%;
    }

    .cover-sub-title {
        padding: 0 0 0 8%;
    }

    .cover-text-box {
        font-size: 1.7rem;
    }

    .cover-text-box p span {
        font-size: 138%;
    }

    .top04-illust {
        top: 6%;
        right: 6rem;
    }

    .top04-title-box .title30 {
        font-size: 2.2rem;
    }

    .top04-02-text-block .title27 {
        font-size: 1.8rem;
    }

    .top05-title-block .title35 {
        font-size: 2.2rem;
    }

    .top08-text-area .en-title65 {
        font-size: 4.5rem;
    }

}

/* ☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆ */
/* ☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆☆ */