/* =========================================
   ページ上書き・装飾
========================================= */

.l-page {
    padding-bottom: 0;
}

.lower_layer-lineup .fv__title {
    margin-bottom: min(6.6666666667vw, 25px);
}

.lower_layer-lineup .trouble-bg-deco {
    height: min(120vw, 450px);
    margin-top: max(-450px, -120vw);
}

/* =========================================
   FV（SP）
========================================= */

.lineup-fv {
    padding: min(16vw, 60px) 0;
}

.lineup-fv__desc {
    font-size: min(3.7333333333vw, 0.875rem);
    font-weight: 400;
    line-height: 1.8;
    letter-spacing: 0.08em;
}

/* =========================================
   FV（PC）
========================================= */

@media (min-width: 768px) {

    .lineup-fv {
        padding: min(5.5555555556vw, 80px) 0;
    }

    .lineup-fv .section_space {
        padding: 0 min(5.5555555556vw, 80px);
    }

    .lineup-fv__desc {
        font-size: clamp(0.875rem, 1.0416666667vw, 0.9375rem);
    }
}

/* =========================================
   カードリスト（SP）
========================================= */

.section_content--lineup {
    padding-bottom: min(16vw, 60px);
}

.lineup__list {
    list-style: none;
    display: flex;
    flex-direction: column;
    gap: min(13.3333333333vw, 50px);
    position: relative;
    z-index: 2;
    max-width: max-content;
    margin: 0 auto;
}

.lineup__item {
    max-width: 500px;
    display: flex;
    flex-direction: column;
}

.lineup__img {
    width: 100%;
    aspect-ratio: 335 / 226;
    overflow: hidden;
}

.lineup__img img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.lineup__body {
    margin-top: clamp(-30px, -8vw, -15px);
    flex: 1;
    display: flex;
    flex-direction: column;
}

.lineup__heading {
    margin-bottom: min(4vw, 15px);
}

.lineup__title {
    font-size: clamp(1.125rem, 0.428rem + 3.28vw, 2rem);
    font-weight: bold;
    line-height: 1;
    letter-spacing: 0.04em;
    font-family: var(--sub-font);
    margin-bottom: min(2.6666666667vw, 10px);
}

.lineup__sub-title {
    font-size: min(3.2vw, 0.75rem);
    font-weight: bold;
    line-height: 1;
    letter-spacing: 0.08em;
    color: var(--text-gray-color);
}

.lineup__desc {
    font-size: min(3.7333333333vw, 0.875rem);
    font-weight: 400;
    line-height: 1.8;
    letter-spacing: 0.04em;
    margin-bottom: min(4vw, 15px);
}

.lineup__tag {
    font-size: min(3.2vw, 0.75rem);
    font-weight: 500;
    line-height: 1.8;
    letter-spacing: 0.04em;
    color: var(--text-gray-color);
    margin-bottom: 0;
}

.lineup__tag:has(+ .cp-btn) {
    margin-bottom: min(5.3333333333vw, 20px);
}

.lineup__body .cp-btn {
    margin: auto auto 0;
}

/* =========================================
   カードリスト（PC）
========================================= */

@media (min-width: 768px) {

    .section_content--lineup {
        padding-bottom: min(13.17715959vw, 180px);
        padding-inline: 20px;
    }

    .section_content--lineup .section_space {
        max-width: 1280px;
    }

    .lineup__list {
        display: grid;
        grid-template-columns: repeat(2, 1fr);
        gap: min(2.9282576867vw, 40px);
        max-width: 100%;
    }

    .lineup__item {
        max-width: 100%;
    }

    .lineup__img {
        aspect-ratio: 620 / 419;
    }

    .lineup__body {
        margin-top: clamp(-20px, -1.3888888889vw, -10px);
    }

    .lineup__heading {
        margin-bottom: min(1.0980966325vw, 15px);
    }

    .lineup__title {
        font-size: clamp(0.75rem, 0.179rem + 1.19vw, 1.25rem);
        margin-bottom: min(0.7320644217vw, 10px);
    }

    .lineup__sub-title {
        font-size: 0.75rem;
    }

    .lineup__desc {
        font-size: clamp(0.75rem, 0.9722222222vw, 0.875rem);
        margin-bottom: min(1.0980966325vw, 15px);
    }

    .lineup__tag {
        font-size: clamp(0.625rem, 0.8333333333vw, 0.75rem);
    }

    .lineup__tag:has(+ .cp-btn) {
        margin-bottom: min(1.4641288433vw, 20px);
    }

    .lineup__body .cp-btn {
        margin-left: inherit;
    }
}

/* =========================================
   あなたに合った"整う"の選び方（SP）
========================================= */

.section_content--guide {
    background: #fff;
    padding: min(16vw, 60px) 0 min(32vw, 120px);
}

.guide-inner {
    display: flex;
    flex-direction: column;
    gap: min(10.6666666667vw, 40px);
}

.guide__desc {
    font-size: min(3.7333333333vw, 0.875rem);
    font-weight: 400;
    line-height: 2;
    letter-spacing: 0.04em;
    margin-bottom: min(8vw, 30px);
}

.guide__desc:last-of-type {
    margin-bottom: 30px;
}

.guide__btn {
    font-weight: 400;
    letter-spacing: 0.04em;
    margin: 0 auto;
}

.guide__cards {
    list-style: none;
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: min(4vw, 15px);
}

.guide__card {
    background: #F5F5F5;
    border-radius: 10px;
    overflow: hidden;
}

.guide__card__link {
    display: flex;
    flex-direction: column;
    padding: min(5.3333333333vw, 20px) min(2.6666666667vw, 10px) min(2.6666666667vw, 10px);
    text-decoration: none;
    color: inherit;
    height: 100%;
}

.guide__card-img {
    width: min(24vw, 90px);
    margin: 0 auto min(5.3333333333vw, 20px);
}

.guide__card-img img {
    width: 100%;
    height: auto;
    display: block;
}

.guide__card-body {
    flex: 1;
    text-align: center;
}

.guide__card-title {
    font-size: min(3.7333333333vw, 0.875rem);
    font-weight: bold;
    line-height: 1;
    letter-spacing: 0.08em;
    word-break: keep-all;
    margin-bottom: min(2.6666666667vw, 10px);
}

.guide__card-service {
    font-family: var(--sub-font);
    font-size: min(2.6666666667vw, 0.625rem);
    font-weight: 600;
    letter-spacing: 0.04em;
    color: var(--text-gray-color);
    line-height: 1;
}

.guide__card-arrow {
    width: min(2.1333333333vw, 8px);
    height: min(2.1333333333vw, 8px);
    display: block;
    margin-top: min(2.1333333333vw, 8px);
    margin-left: auto;
}

/* =========================================
   あなたに合った"整う"の選び方（PC）
========================================= */

@media (min-width: 768px) {

    .section_content--guide {
        padding: 0 20px min(13.17715959vw, 180px);
    }

    .section_content--guide .section_space {
        max-width: 1280px;
    }

    .section_content--guide .lower-section__title {
        text-align: left;
    }

    .guide-inner {
        flex-direction: row;
        align-items: center;
        gap: min(1.4641288433vw, 20px);
    }

    .guide__lead {
        flex: 1 1 min(46.8521229868vw, 640px);
    }

    .guide__desc {
        font-size: clamp(0.875rem, 1.0980966325vw, 0.9375rem);
        margin-bottom: min(2.196193265vw, 30px);
        letter-spacing: 0;
    }

    .guide__desc:last-of-type {
        margin-bottom: min(2.196193265vw, 30px);
    }

    .guide__btn {
        margin-left: inherit;
    }

    .guide__cards {
        flex: 1 1 min(45.3879941435vw, 620px);
        gap: min(2.196193265vw, 30px);
        min-width: 0;
    }

    .guide__card {
        position: relative;
    }

    .guide__card__link {
        padding: min(1.4641288433vw, 20px) min(1.0980966325vw, 15px);
        transition: background-color 0.3s ease, box-shadow 0.3s ease, transform 0.3s ease;
    }

    .guide__card__link:not(.is-disabled):hover {
        background: var(--yellow-color);
        box-shadow: var(--btn-shadow);
        transform: translateY(-2px);
    }

    .guide__card__link.is-disabled {
        cursor: default;
        pointer-events: none;
    }

    .guide__card-img {
        width: min(8.3333333333vw, 90px);
        margin: 0 auto min(1.3888888889vw, 20px);
        flex-shrink: 0;
    }

    .guide__card-title {
        font-size: clamp(0.875rem, 1.1713030747vw, 1rem);
        margin-bottom: min(0.7320644217vw, 10px);
    }

    .guide__card-service {
        font-size: clamp(0.625rem, 0.878477306vw, 0.75rem);
    }

    .guide__card-arrow {
        position: absolute;
        bottom: 10px;
        right: 10px;
    }
}

/* =========================================
   あなたに合った"整う"の選び方（大画面）
========================================= */

@media (min-width: 1024px) {

    .guide__card__link {
        flex-direction: row;
        align-items: center;
        gap: min(1.0980966325vw, 15px);
    }

    .guide__card-img {
        margin: 0;
    }

    .guide__card-body {
        text-align: left;
    }
}