@charset "UTF-8";

@media screen and (min-width: 768px) {
    .is-pc {
        display: block;
    }
    .is-sp {
        display: none !important;
    }
}

@media screen and (max-width: 767px) {
    .is-pc {
        display: none !important;
    }
    .is-sp {
        display: block;
    }
}

/*========================================================================

  image

========================================================================*/

/*  image zoom
========================================================================*/

.zoom-overlay-open .zoom-overlay {
    opacity: 0.8 !important;
}
.point_image_zoom {
    width: 237px;
    margin-top: 30px;
    position: relative;
}
.point_image_zoom:before {
    content: "";
    position: absolute;
    width: 35px;
    height: 35px;
    background: url("/kodate/start/tailor-made-planning/assets/img/ic_zoom.png") no-repeat;
    right: 10px;
    top: 10px;
    pointer-events: none;
}
.point_image_zoom.left:before {
    left: 10px;
}

/*========================================================================

  text

========================================================================*/

.point_text.small {
    font-size: 14px;
    text-align: left;
    margin-top: 10px;
}

/*========================================================================

  mainVisual

========================================================================*/

/*  mainVisual
========================================================================*/

.mainVisual {
    width: 100%;
    position: relative;
}
.mainVisual h1 {
    position: absolute;
    width: calc(100% - 40px);
    top: 37%;
    left: 50%;
    transform: translateY(-50%) translateX(-50%);
    color: #fff;
    text-shadow: 0 0 10px rgba(0, 0, 0, 0.2);
    text-align: center;
    font-size: 80px;
    font-weight: bold;
}
.mainVisual h1 span {
    display: block;
    font-size: 36px;
    margin-bottom: 25px;
}

.mainVisual_title {
    width: 660px;
    display: block;
    margin: 0 auto;
}

.mainVisual img {
    width: 100%;
    height: 100vh;
    object-fit: cover;
}
.mainVisual_title img {
    width: 100%;
    height: auto;
}

@media screen and (max-width: 767px) {
    .mainVisual {
        width: 100%;
        height: 100vh;
        position: relative;
        overflow: hidden;
    }
    .mainVisual h1 {
        top: 32%;
        font-size: 36px;
    }
    .mainVisual h1 span {
        font-size: 15px;
        margin-bottom: 15px;
    }
    .mainVisual img {
        width: 100%;
        height: 100vh;
        object-fit: cover;
    }
    .mainVisual_title {
        width: calc(100% - 100px);
        display: block;
        margin: 0 auto;
    }
    .mainVisual_title img {
        width: 100%;
        height: auto;
    }
}

/*  scroll
========================================================================*/

.scroll {
    position: absolute;
    left: 50%;
    transform: translateX(-50%);
    bottom: 30px;
}
.scroll p {
    color: #eee;
    letter-spacing: 0.2em;
    font-size: 16px;
    font-weight: bold;
}
.scroll p:after {
    content: "";
    position: absolute;
    width: 2px;
    height: 12px;
    background: #eee;
    bottom: -21px;
    left: 50%;
    transform: translateX(-50%);
    animation: pathmove 1.4s ease-in-out infinite;
}

@media screen and (max-width: 767px) {
    .scroll p {
        letter-spacing: 0.15em;
        font-size: 12px;
        font-weight: normal;
    }
    .scroll p:after {
        width: 1px;
        bottom: -17px;
    }
}

/*========================================================================

  anchor

========================================================================*/

/*  section-anchor
========================================================================*/

.section-anchor {
    padding: 80px 0;
    border-bottom: 1px solid #d8d8d8;
}
.section-anchor .inner {
    width: calc(100% - 40px);
    max-width: 837px;
    margin: 0 auto;
    padding: 60px 80px;
    background: #f4f4f4;
    display: flex;
}
.section-anchor .title {
    display: flex;
    align-items: center;
    padding-right: 60px;
    font-size: 18px;
    font-weight: bold;
}
.section-anchor .title p {
    border-bottom: 2px solid #242424;
    line-height: 1;
    padding: 0px 2px 10px;
}
.section-anchor .title span {
    vertical-align: bottom;
    width: 17px;
    display: inline-block;
}

@media screen and (max-width: 767px) {
    .section-anchor {
        border-bottom: none;
        padding: 0;
    }
    .section-anchor .inner {
        width: 100%;
        background: #f4f4f4;
        flex-direction: column;
        padding: 50px 20px;
    }
    .section-anchor .title {
        font-size: 12px;
        padding-right: 0;
        margin: 0 auto;
        font-weight: bold;
        line-height: 1.4;
        letter-spacing: 0.1em;
    }
    .section-anchor .title p {
        font-family: "Hiragino Kaku Gothic ProN";
        border-bottom: 1px solid #242424;
        letter-spacing: 0.145em;
        padding-bottom: 6px;
    }
    .section-anchor .title span {
        font-size: 20px;
        display: inline;
        margin-right: 1px;
    }
    .section-anchor span[data-num]:after {
        content: attr(data-num);
    }
    .section-anchor img {
        display: none;
    }
}

/*  list
========================================================================*/

.section-anchor ol {
    counter-reset: num;
}
.section-anchor ol li {
    position: relative;
    padding-left: 30px;
    padding: 0.5em 0.5em 0.5em 40px;
    font-size: 18px;
    font-weight: bold;
}
.section-anchor ol li:before {
    content: "";
    position: absolute;
    border: 2px solid #242424;
    left: 0;
    width: 20px;
    height: 20px;
    top: 50%;
    transform: translateY(-50%);
}
.section-anchor ol li:nth-child(1):before {
    background: url(/kodate/start/familysuite/assets/img/num_1.png) no-repeat center;
    background-size: 50%;
}
.section-anchor ol li:nth-child(2):before {
    background: url(/kodate/start/familysuite/assets/img/num_2.png) no-repeat center;
    background-size: 50%;
}
.section-anchor ol li:nth-child(3):before {
    background: url(/kodate/start/familysuite/assets/img/num_3.png) no-repeat center;
    background-size: 50%;
}
.section-anchor ol li:nth-child(4):before {
    background: url(/kodate/start/familysuite/assets/img/num_4.png) no-repeat center;
    background-size: 50%;
}
.section-anchor ol li:after {
    content: "";
    position: absolute;
    top: 45%;
    width: 6px;
    height: 6px;
    border-right: 2px solid #242424;
    border-bottom: 2px solid #242424;
    transform: translateY(-50%) rotate(45deg);
}

@media screen and (max-width: 767px) {
    .section-anchor ol {
        margin-top: 20px;
    }
    .section-anchor ol li {
        border: 1px solid #242424;
        border-radius: 5px;
        margin-top: 10px;
        padding: 0 0 0 40px;
        font-size: 15px;
        font-weight: bold;
    }
    .section-anchor ol li:after {
        right: 20px;
    }
    .section-anchor ol li:before {
        border: 0px;
        left: 8px;
        top: 50%;
        transform: translateY(-50%);
        width: 24px;
    }
    .section-anchor ol li a {
        padding: 10px 40px 10px 12px;
        display: block;
    }
    .section-anchor ol li a:before {
        content: "";
        position: absolute;
        border-left: 1px solid #242424;
        height: 100%;
        width: 1px;
        top: 0;
        left: 40px;
    }
}

/*========================================================================

  title

========================================================================*/

/*  section-point2
========================================================================*/

.point_title_num2 {
    font-size: 18px;
    text-align: center;
    padding-top: 80px;
}
.point_title_num2 p {
    font-size: 18px;
    border-bottom: 2px solid #242424;
    display: inline-block;
    line-height: 1;
    padding: 0px 2px 10px 2px;
}
.point_title_num2 span {
    margin-left: 3px;
    display: inline-block;
    vertical-align: bottom;
    width: 18px;
}

@media screen and (max-width: 767px) {
    .point_title_num2 p {
        border-bottom: 1px solid #242424;
        font-size: 12px;
        font-weight: bold;
        font-family: "Hiragino Kaku Gothic ProN";
        letter-spacing: 0.1em;
        padding: 0 0 6px 0;
    }
    .point_title_num2 span {
        font-size: 20px;
        display: unset;
        margin-left: 0;
    }
    .point_title_num2 span[data-num]:after {
        content: attr(data-num);
    }
    .point_title_num2 img {
        display: none;
    }
}

/*========================================================================

  section-point

========================================================================*/

/*  section-point
========================================================================*/

.section-point .inner {
    position: relative;
    max-width: 1160px;
    margin: 0 auto;
    padding: 80px 0 0;
}
.section-point.small .inner {
    padding: 50px 0 55px;
}
.point_title_num {
    font-size: 18px;
    font-weight: bold;
    text-align: center;
}
.point_title_num p {
    border-bottom: 2px solid #242424;
    display: inline-block;
    line-height: 1;
    padding: 0px 2px 10px 2px;
}
.point_title_num span {
    margin-left: 3px;
    display: inline-block;
    vertical-align: bottom;
    width: 18px;
}
.point_h2 {
    font-size: 40px;
    font-weight: bold;
    text-align: center;
    margin-top: 45px;
    line-height: 1.8;
    letter-spacing: 4px;
}
.point_image {
    margin-top: 50px;
}
.point_image {
    width: 100%;
}
.point_image img {
    width: 100%;
}

@media screen and (max-width: 767px) {
    .section-point {
        border-top: 1px solid #d8d8d8;

        padding-top: 0;
    }
    .section-point .inner {
        width: 100%;
        max-width: 1160px;
        margin: 0 auto;
        padding: 55px 0 30px;
    }
    .section-point .inner.pb0 {
        padding: 55px 0 0px;
    }
    .point_title_num p {
        border-bottom: 1px solid #242424;
        font-size: 12px;
        font-weight: bold;
        font-family: "Hiragino Kaku Gothic ProN";
        letter-spacing: 0.1em;
        padding: 0 0 6px 0;
    }
    .point_title_num span {
        font-size: 20px;
        display: unset;
        margin-left: 0;
    }
    .point_title_num span[data-num]:after {
        content: attr(data-num);
    }
    .point_title_num img {
        display: none;
    }
    .point_h2 {
        width: calc(100% - 40px);
        margin: 35px auto 0;
        font-size: 18px;
        font-weight: bolder;
        line-height: 1.6;
        letter-spacing: 0;
    }
    .point_image {
        margin-top: 30px;
    }
}

/*  section-image
========================================================================*/

.section-image img {
    width: 100%;
}

@media screen and (max-width: 767px) {
    .section-image {
        position: relative;
    }
    .section-image .slick-dots {
        top: 0;
        bottom: 0;
        left: 0;
        right: 0;
    }
    .section-image .slick-dots li {
        width: 30px;
        height: 30px;
        position: absolute;
    }
    .section-image .slick-dots li:nth-child(1) {
        top: 19%;
        left: 44%;
        background: url(/kodate/start/familysuite/assets/img/no1.png) no-repeat center;
        background-size: 100%;
        opacity: 0.6;
    }
    .section-image .slick-dots li:nth-child(2) {
        top: 32%;
        left: 66%;
        background: url(/kodate/start/familysuite/assets/img/no2.png) no-repeat center;
        background-size: 100%;
        opacity: 0.6;
    }
    .section-image .slick-dots li:nth-child(3) {
        top: 51%;
        left: 8%;
        background: url(/kodate/start/familysuite/assets/img/no3.png) no-repeat center;
        background-size: 100%;
        opacity: 0.6;
    }
    .section-image .slick-dots li:nth-child(4) {
        top: 83%;
        left: 62%;
        background: url(/kodate/start/familysuite/assets/img/no4.png) no-repeat center;
        background-size: 100%;
        opacity: 0.3;
    }
    .section-image .slick-dots li.slick-active {
        opacity: 1;
    }
    .section-image .slick-dots li button {
        display: none;
    }
}

/*  section-point2
========================================================================*/

.section-point2 {
    border-bottom: 1px solid #d8d8d8;
    max-width: 1960px;
    margin: 0 auto;
}
.section-point2 .inner {
    /* width: calc(100% - 40px); */
    width: 100%;
    max-width: 1960px;
    margin: 0 auto;
    padding: 80px 0 150px;
}
@media screen and (max-width: 767px) {
    .section-point2 {
        border-top: 1px solid #d8d8d8;
        border-bottom: none;
        max-width: max-content;
        margin: 0 auto 0;
    }
    .section-point2 .inner {
        width: 100%;
        max-width: 100%;
        padding: 60px 0 75px;
    }
    .section-point2 .inner.pb0 {
        padding: 55px 0 0px;
    }
}

/*  section-point3
========================================================================*/

.section-point3 {
    border-top: 1px solid #d8d8d8;
}
.section-point3 .inner {
    width: calc(100% - 40px);
    max-width: 1960px;
    margin: 0 auto;
    padding: 80px 0 30px;
}
.section-point3.pb40 .inner {
    padding: 80px 0 40px;
}

@media screen and (max-width: 767px) {
    .section-point3 .inner {
        width: 100%;
        padding: 60px 0 20px;
    }
    .section-point3.pb40 .inner {
        padding: 60px 0 0;
    }
}

/*========================================================================

  slider

========================================================================*/

/*  point_slider
========================================================================*/

.point_slider {
    border-bottom: 1px solid #d8d8d8;
}
@media screen and (min-width: 768px) {
    .point_slider {
        margin-top: 50px;
    }
}

@media screen and (max-width: 767px) {
    .point_slider {
        border-bottom: none;
    }
}
.point_slider .inner {
    width: calc(100% - 40px);
    width: 100%;
    max-width: 1960px;
    margin: 60px auto 70px;
}
.point_slider .slider {
    opacity: 0;
    margin: 0 -16px;
}
.point_slider .slider.slick-initialized {
    opacity: 1;
}
.point_slider .slider.slick-dotted.slick-slider {
    margin-bottom: 0;
    padding-bottom: 0;
}
.point_slider .slick-list {
    overflow: visible;
}
.point_slider .slick-slide {
    overflow: hidden;
    margin: 0 16px;
}
.point_slider .item a[target="_blank"]:after {
    content: "";
    position: absolute;
    right: 10px;
    bottom: 10px;
    width: 15px;
    height: 15px;
    background: url(../img/f_icon-blank-w.png) center / contain;
}
.point_slider .item p {
    font-size: 14px;
    font-weight: bold;
    margin-top: 10px;
}

@media screen and (max-width: 767px) {
    .point_slider .slick-prev,
    .point_slider .slick-next {
        z-index: 1;
        width: 32px;
        height: 32px;
    }
    .point_slider .slick-prev {
        background: url("/kodate/start/familysuite/assets/img/arrow-prev.png") no-repeat !important;
        left: 25px;
    }
    .point_slider .slick-next {
        background: url("/kodate/start/familysuite/assets/img/arrow-next.png") no-repeat !important;
        right: 25px;
    }
    .point_slider .slick-prev:before,
    .point_slider .slick-next:before {
        display: none;
    }
    .point_slider .item img {
        text-align: center;
        margin: 0 auto;
    }
    .point_slider .slick-slide {
        margin: 0 2px;
    }
    .point_slider .item {
        position: relative;
        overflow: visible;
    }
    .point_slider .item p {
        position: absolute;
        width: 100vw;
        bottom: -40px;
        left: 50%;
        transform: translateX(-50%);
        font-weight: bold;
        text-align: center;
        opacity: 1;
        transition: all 0.3s 0s ease;
    }
    .point_slider .item:not(.slick-active) p {
        opacity: 0;
    }
    .point_slider .item:not(.slick-active) img {
        opacity: 0.2;
    }
}

/*  point_slider2
========================================================================*/

.title_hukidasi {
    border: 1px solid #242424;
    padding: 8px 20px;
    position: relative;
    font-size: 18px;
    font-weight: bold;
    left: 50%;
    transform: translateX(-50%);
    display: inline-block;
    letter-spacing: 0.6px;
    margin-top: 15px;
}
.title_hukidasi:before {
    content: "";
    position: absolute;
    display: block;
    border-right: 1px solid #242424;
    border-bottom: 1px solid #242424;
    width: 15px;
    height: 15px;
    bottom: -9px;
    left: 50%;
    background-color: #fff;
    transform: translateX(-50%) rotate(45deg);
}
.point_slider2 .inner {
    width: calc(100% - 40px);
    max-width: 1160px;
    margin: 0 auto;
    position: relative;
}
.point_slider2 .slider {
    display: flex;
    justify-content: space-between;
    margin-top: 55px;
}
.point_slider2 .item {
    width: calc(25% - 30px);
}
.point_slider2 .title {
    font-size: 18px;
    font-weight: bold;
    margin-top: 10px;
}
.point_slider2 .text {
    font-size: 14px;
    margin-top: 5px;
}

@media screen and (max-width: 767px) {
    .title_hukidasi {
        left: 30px;
        transform: none;
        font-size: 12px;
        font-weight: bold;
        padding: 5px 8px;
        margin-top: 0;
    }
    .title_hukidasi:before {
        content: "";
        position: absolute;
        border-right: 1px solid #242424;
        border-bottom: 1px solid #242424;
        width: 10px;
        height: 10px;
        bottom: -6px;
        left: 10%;
        background-color: #fff;
        transform: rotate(45deg);
    }
    .point_slider2 .inner {
        width: 100%;
    }
    .point_slider2 .slider {
        margin-top: 30px;
    }
    .point_slider2 .slick-slide {
        margin: 0 5px;
    }
    .point_slider2 .slick-list {
        margin: 0 -5px;
    }
    .point_slider2 .item img {
        width: 100%;
    }
    .point_slider2 .slick-prev,
    .point_slider2 .slick-next {
        z-index: 1;
        width: 32px;
        height: 32px;
        top: 41vw;
    }
    .point_slider2 .slick-prev {
        background: url("/kodate/start/familysuite/assets/img/arrow-prev.png") no-repeat !important;
        left: 13px;
    }
    .point_slider2 .slick-next {
        background: url("/kodate/start/familysuite/assets/img/arrow-next.png") no-repeat !important;
        right: 13px;
    }
    .point_slider2 .slick-prev:before,
    .point_slider2 .slick-next:before {
        display: none;
    }
    .point_slider2 .slick-dots {
        bottom: auto;
    }
    .point_slider2 .slick-disabled {
        opacity: 0 !important;
        transition: all 0.3s 0s ease;
    }
    .point_slider2 .slick-dots li {
        width: 5px;
        height: 5px;
        margin: 0 6px;
    }
    .point_slider2 .slick-dots li.slick-active button {
        background: #242424;
    }
    .point_slider2 .slick-dots li button {
        width: 100%;
        height: 100%;
        padding: 0;
        background: #d8d8d8;
        border-radius: 50%;
    }
    .point_slider2 .slick-dots li button:before {
        display: none;
    }
    .point_slider2 .textbox {
        padding: 50px 10px 0;
    }
    .point_slider2 .title {
        font-size: 15px;
        font-weight: bold;
        margin-top: 0px;
    }
    .point_slider2 .text {
        font-size: 15px;
        margin-top: 5px;
    }
}

/*  point_slider3
========================================================================*/

.point_slider3 .inner {
    width: 100%;
    max-width: 1160px;
    margin: 55px auto 75px;
}

.point_slider3 .item p {
    font-size: 14px;
    margin-top: 15px;
}

@media screen and (min-width: 768px) {
    .point_slider3 .slider {
        display: flex;
        flex-wrap: wrap;
        justify-content: space-between;
        flex-direction: column;
        height: 878px;
        align-content: space-between;
    }
    .point_slider3 .item {
        width: calc(50% - 20px);
    }
}

@media screen and (max-width: 767px) {
    .point_slider3 .inner {
        margin: 30px auto 60px;
    }
    .point_slider3 .slider {
        margin: 0 -5px;
    }
    .point_slider3 .slick-slide {
        margin: 0 5px;
    }
    .point_slider3 .image {
        position: relative;
    }
    .point_slider3 .image:before {
        content: "";
        display: block;
        padding-top: 71.642%;
        background: #eee;
    }
    .point_slider3 .slick-track {
        display: flex;
    }
    .point_slider3 .item:nth-child(n + 3) {
        margin-top: 0;
    }
    .point_slider3 .item img {
        position: absolute;
        top: 0;
        left: 0;
        width: 100%;
        height: 100%;
        object-fit: cover;
        font-family: "object-fit: cover;";
    }
    .point_slider3 .item p {
        font-size: 15px;
        margin: 45px 10px 0px;
    }
    .point_slider3 .slick-arrow {
        z-index: 1;
        width: 32px;
        height: 32px;
        top: 32vw;
    }
    .point_slider3 .slick-prev {
        background: url("/kodate/start/familysuite/assets/img/arrow-prev.png") no-repeat !important;
        left: 13px;
    }
    .point_slider3 .slick-next {
        background: url("/kodate/start/familysuite/assets/img/arrow-next.png") no-repeat !important;
        right: 13px;
    }
    .point_slider3 .slick-prev:before,
    .point_slider3 .slick-next:before {
        display: none;
    }
    .point_slider3 .slick-dots {
        bottom: auto;
    }
    .point_slider3 .slick-dots li {
        width: 5px;
        height: 5px;
        margin: 0 6px;
    }
    .point_slider3 .slick-dots li.slick-active button {
        background: #242424;
    }
    .point_slider3 .slick-dots li button {
        width: 100%;
        height: 100%;
        padding: 0;
        background: #d8d8d8;
        border-radius: 50%;
    }
    .point_slider3 .slick-dots li button:before {
        display: none;
    }
}

/*  point_slider4
========================================================================*/

.point_slider4 {
    width: 100%;
    max-width: 1160px;
    margin: 0 auto;
    padding: 10px 0 10px;
}
.point_slider4.pb80 {
    padding: 10px 0 80px;
}

.point_slider4 .item p {
    font-size: 14px;
    margin-top: 15px;
}

@media screen and (min-width: 768px) {
    .point_slider4 .slider {
        display: flex;
        flex-wrap: wrap;
        justify-content: space-between;
    }
    .point_slider4.col-3 .item {
        width: calc(100% / 3 - 26px);
    }
    .point_slider4.col-3.nospace .item {
        width: calc(100% / 3);
    }
    .point_slider4.col-3 .item:nth-child(n + 4) {
        margin-top: 20px;
    }
}

@media screen and (max-width: 767px) {
    .point_slider4 .slick-dotted.slick-slider {
        margin-bottom: 0;
    }
    .point_slider4 {
        padding: 15px 0 15px;
    }
    .point_slider4.pb80 {
        padding: 15px 0 40px;
    }
    .point_slider4.pb60_sp {
        padding: 30px 0 60px;
    }
    .point_slider4 .slider {
        margin: 0 -5px;
    }
    .point_imagebox .point_slider4 .slider {
        margin: 0 -20px;
    }
    .point_slider4 .slick-slide {
        margin: 0 5px;
    }
    .point_slider4 .image {
        position: relative;
    }
    .point_slider4 .image:before {
        content: "";
        display: block;
        padding-top: 73.847%;
        background: #eee;
    }
    .point_slider4 .slick-track {
        display: flex;
    }
    .point_slider4 .item:nth-child(n + 3) {
        margin-top: 0;
    }
    .point_slider4 .item img {
        position: absolute;
        top: 0;
        left: 0;
        width: 100%;
        height: 100%;
        object-fit: cover;
        font-family: "object-fit: cover;";
    }
    .point_slider4 .item p {
        font-size: 15px;
        margin: 45px 10px 0px;
    }
    .point_slider4 .slick-arrow {
        z-index: 1;
        width: 32px;
        height: 32px;
        top: 32vw;
    }
    .point_slider4 .slick-prev {
        background: url("/kodate/start/familysuite/assets/img/arrow-prev.png") no-repeat !important;
        left: 13px;
    }
    .point_slider4 .slick-next {
        background: url("/kodate/start/familysuite/assets/img/arrow-next.png") no-repeat !important;
        right: 13px;
    }
    .point_slider4 .slick-prev:before,
    .point_slider4 .slick-next:before {
        display: none;
    }
    .point_slider4 .slick-dots {
        bottom: auto;
    }
    .point_slider4 .slick-dots li {
        width: 5px;
        height: 5px;
        margin: 0 6px;
    }
    .point_slider4 .slick-dots li.slick-active button {
        background: #242424;
    }
    .point_slider4 .slick-dots li button {
        width: 100%;
        height: 100%;
        padding: 0;
        background: #d8d8d8;
        border-radius: 50%;
    }
    .point_slider4 .slick-dots li button:before {
        display: none;
    }
    .point_slider4 .slick-disabled {
        opacity: 0 !important;
        transition: all 0.3s 0s ease;
    }
}

/*  point_slider5
========================================================================*/

.point_slider5 {
    width: 100%;
    max-width: 1160px;
    margin: 0 auto;
    padding: 10px 0 10px;
}
.point_slider5.pb80 {
    padding: 10px 0 80px;
}

.point_slider5 .item p {
    font-size: 14px;
    margin-top: 15px;
}

@media screen and (min-width: 768px) {
    .point_slider5 .slider {
        display: flex;
        flex-wrap: wrap;
        justify-content: space-between;
    }
    .point_slider5.col-3 .item {
        width: calc(100% / 3 - 20px);
    }
    .point_slider5.col-3.nospace .item {
        width: calc(100% / 3);
    }
    .point_slider5.col-3 .item:nth-child(n + 4) {
        margin-top: 30px;
    }
}

@media screen and (max-width: 767px) {
    .point_slider5 .slick-dotted.slick-slider {
        margin-bottom: 0;
    }
    .point_slider5 {
        padding: 15px 0 15px;
    }
    .point_slider5.pb80 {
        padding: 15px 0 40px;
    }
    .point_slider5 .slider {
        margin: 0 -5px;
    }
    .point_imagebox .point_slider5 .slider {
        margin: 0 -20px;
    }
    .point_slider5 .slick-slide {
        margin: 0 5px;
    }
    .point_slider5 .image {
        position: relative;
    }
    .point_slider5 .image:before {
        content: "";
        display: block;
        padding-top: 71.688%;
        background: #eee;
    }
    .point_slider5 .slick-track {
        display: flex;
    }
    .point_slider5 .item:nth-child(n + 3) {
        margin-top: 0;
    }
    .point_slider5 .item img {
        position: absolute;
        top: 0;
        left: 0;
        width: 100%;
        height: 100%;
        object-fit: cover;
        font-family: "object-fit: cover;";
    }
    .point_slider5 .item p {
        font-size: 15px;
        margin: 45px 10px 0px;
    }
    .point_slider5 .slick-arrow {
        z-index: 1;
        width: 32px;
        height: 32px;
        top: 32vw;
    }
    .point_slider5 .slick-prev {
        background: url("/kodate/start/familysuite/assets/img/arrow-prev.png") no-repeat !important;
        left: 13px;
    }
    .point_slider5 .slick-next {
        background: url("/kodate/start/familysuite/assets/img/arrow-next.png") no-repeat !important;
        right: 13px;
    }
    .point_slider5 .slick-prev:before,
    .point_slider5 .slick-next:before {
        display: none;
    }
    .point_slider5 .slick-dots {
        bottom: auto;
    }
    .point_slider5 .slick-dots li {
        width: 5px;
        height: 5px;
        margin: 0 6px;
    }
    .point_slider5 .slick-dots li.slick-active button {
        background: #242424;
    }
    .point_slider5 .slick-dots li button {
        width: 100%;
        height: 100%;
        padding: 0;
        background: #d8d8d8;
        border-radius: 50%;
    }
    .point_slider5 .slick-dots li button:before {
        display: none;
    }
    .point_slider5 .slick-disabled {
        opacity: 0 !important;
        transition: all 0.3s 0s ease;
    }
}

/*========================================================================

  point_imagebox

========================================================================*/

/*  point_imagebox
========================================================================*/

.point_imagebox {
    display: flex;
    justify-content: space-between;
    margin: 0 auto;
    padding: 30px 0 30px;
    width: 100%;
    max-width: 1160px;
}
.point_imagebox.pb80 {
    padding: 30px 0 80px;
}
.point_imagebox .textbox .text {
    font-size: 14px;
    margin-top: 20px;
    line-height: 1.8;
}

@media screen and (min-width: 768px) {
    .point_imagebox .imagebox {
        width: 64.6556%;
    }
    .point_imagebox .textbox {
        width: calc(36.897% - 60px);
    }
    .point_imagebox.pc-reverse {
        flex-direction: row-reverse;
    }
    .point_imagebox .textbox .image {
        margin-top: 20px;
    }
}

@media screen and (max-width: 767px) {
    .point_imagebox {
        padding: 15px 0 15px;
    }
    .point_imagebox.pb80 {
        padding: 15px 0 40px;
    }
    .point_imagebox .textbox {
        width: calc(100% - 40px);
        margin: 0 auto;
    }
    .point_imagebox .textbox .text {
        font-size: 15px;
        margin-top: 30px;
        padding: 0 10px;
        line-height: 1.7;
    }
}

/*  point_title
========================================================================*/

.point_title {
    font-size: 20px;
}

@media screen and (max-width: 767px) {
    .point_title {
        font-size: 15px;
    }
}

/*  point_text
========================================================================*/

.point_text {
    text-align: center;
    margin-top: 35px;
    font-size: 18px;
    font-weight: bold;
    line-height: 2;
    letter-spacing: 0.7px;
}
.point_caption {
    font-size: 14px;
    text-align: left;
    margin-top: 10px;
}

@media screen and (max-width: 767px) {
    .point_text {
        width: calc(100% - 60px);
        margin: 15px auto 0;
        /* text-align: left; */
        font-size: 15px;
        line-height: 1.6;
        font-weight: unset;
        letter-spacing: 0;
    }
    .point_caption {
        font-size: 15px;
        margin: 50px 30px 0;
    }
}

/*  greybox sp_only
========================================================================*/

.greybox_title {
    font-size: 20px;
    font-weight: bold;
}
.greybox_text {
    font-size: 14px;
    margin-top: 20px;
    font-weight: bold;
}

@media screen and (max-width: 767px) {
    .greybox {
        background: #f4f4f4;
        padding: 15px;
        text-align: center;
    }
    .greybox_title {
        font-size: 15px;
        font-weight: bold;
    }
    .greybox_text {
        font-size: 12px;
        font-weight: unset;
        margin-top: 3px;
    }
}

/*========================================================================

/*  point_img01_slider
========================================================================*/

/*  point_img01_slider (PC: max-width 1920px, height 1040px fixed / SP: browser width)
========================================================================*/

/* wrapperの基本設定 */
.point_img01_slider_wrap {
    width: 100%;
    max-width: 1920px;
    margin: 0 auto;
    position: relative;
}

/* .point_slider から継承されるslick系スタイルを上書き */
.point_img01_slider_wrap .slick-list {
    overflow: hidden !important;
}
.point_img01_slider_wrap .slick-slide {
    margin: 0 !important;
    overflow: hidden;
}

/* PC: 高さ1040px固定 */
@media screen and (min-width: 768px) {
    .point_img01_slider_wrap {
        height: 1040px;
        overflow: hidden;
    }
    .point_img01_slider {
        height: 1040px;
    }
    .point_img01_slider .slick-list,
    .point_img01_slider .slick-track {
        height: 1040px;
    }
    .point_img01_slider_item,
    .point_img01_slider .slick-slide {
        height: 1040px;
    }
    .point_img01_slider_item img {
        width: 100%;
        height: 1040px;
        object-fit: cover;
        display: block;
    }
}

/* SP: 幅なりゆき */
@media screen and (max-width: 767px) {
    .point_img01_slider_item img {
        width: 100%;
        height: auto;
        display: block;
    }
}

/* ドット: slick-theme の bottom:-25px を上書き, z-index はslideの1000より上 */
.point_img01_slider .slick-dots {
    bottom: 20px;
    z-index: 1001;
}
@media screen and (max-width: 767px) {
    .point_img01_slider .slick-dots {
        bottom: 5px;
    }
}

.point_img01_slider .slick-dots li {
    width: 10px;
    height: 10px;
    /* margin: 0 6px; */
    padding: 0;
}

.point_img01_slider .slick-dots li button {
    width: 10px;
    height: 10px;
    padding: 0;
    background: rgba(255, 255, 255, 0.6);
    border-radius: 50%;
    border: none;
    font-size: 0;
    line-height: 0;
    cursor: pointer;
    display: block;
    transition: background 0.3s ease;
}

.point_img01_slider .slick-dots li button:before {
    display: none;
}

.point_img01_slider .slick-dots li.slick-active button {
    background: #fff;
}

/* 矢印非表示 */
.point_img01_slider_wrap .slick-prev,
.point_img01_slider_wrap .slick-next {
    display: none !important;
}

/*========================================================================

  point1_accordion

========================================================================*/

.point1_accordion_item-body {
    display: none;
    width: 1160px;
    margin: 0 auto;
}

/*========================================================================

  plan-intro_scroll

========================================================================*/

.plan-intro_scroll-wrap {
    display: flex !important;
    align-items: flex-end;
    overflow-x: auto !important;
    scroll-behavior: smooth;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none; /* Firefox */
    -ms-overflow-style: none; /* IE/Edge */
}
.plan-intro_scroll-wrap::-webkit-scrollbar {
    display: none; /* Chrome, Safari */
}

/* PC時のスクロールボックス設定 */
@media screen and (min-width: 768px) {
    .plan-intro_scroll-wrap {
        margin: 0 0px;
        padding: 0 0px;
    }
    .plan-intro_scroll-box {
        flex-shrink: 0;
        padding-right: 40px;
        /* width: 32%;
    min-width: 300px;
    margin-right: 24px; */
    }
    .plan-intro_scroll-box:last-child {
        margin-right: 0;
    }
    .plan-intro_scroll-image img {
        width: 100%;
        height: auto;
        object-fit: cover;
    }
    .plan-intro_scroll-text {
        font-size: 16px;
        margin-top: 15px;
        line-height: 1.4;
        letter-spacing: 0;
        /* margin-bottom: 15px; */
    }
}

/* SP時のスクロールボックス設定 */
@media screen and (max-width: 767px) {
    .plan-intro_scroll-wrap {
        margin: 0 -20px;
        /* 左端の文字が切れる問題を防ぐため左右にパディングを追加 */
        padding: 10px 20px;
    }
    /* SPでスクロールボックス間に固定の間隔を確保 */
    .plan-intro_scroll-box {
        flex-shrink: 0;
        width: 80%;
        margin-right: 35px;
    }
    .plan-intro_scroll-box:last-child {
        margin-right: 0;
    }
    .plan-intro_scroll-image {
        width: 267px !important;
        margin-right: 20px;
    }
    .plan-intro_scroll-image img {
        width: 100%;
        height: auto;
    }
    .plan-intro_scroll-text {
        font-size: 10px;
        margin-top: 10px;
    }
}

.intro_scroll-box-4 .plan-intro_scroll-text {
    margin-top: 0;
    margin-bottom: 15px;
}
@media screen and (max-width: 767px) {
    .intro_scroll-box-4 .plan-intro_scroll-text {
        margin-top: 10px;
        margin-bottom: 0;
    }
    /* intro_scroll-box-3 のテキスト先頭が左端で切れる問題を回避 */
    .intro_scroll-box-3 .plan-intro_scroll-text {
        padding-left: 0px;
    }
}
/* PC: scroll-box-5の画像を上揃えに */
@media screen and (min-width: 768px) {
    .intro_scroll-box-5 {
        align-self: flex-start;
    }
}

/* PC: scroll-box-5の画像を上揃えに */
@media screen and (min-width: 768px) {
    .intro_scroll-box-9 {
        align-self: flex-start;
        margin-right: 0;
        padding-right: 0;
    }
}

/* SP: scroll-box-4を上揃えにして、他のboxと上の空きを合わせる */
@media screen and (max-width: 767px) {
    .intro_scroll-box-4 {
        align-self: flex-start;
    }
}

.plan-intro_scroll-heading {
    font-size: 20px;
    margin-top: 90px;
    letter-spacing: 0.06%;
    margin-bottom: 42px;
    font-weight: bold;
    line-height: 2;
}
@media screen and (max-width: 767px) {
    .plan-intro_scroll-imagebox {
        display: block;
        width: 272px;
        min-width: 272px;
        max-width: 272px;
        box-sizing: content-box;
        height: 310px;
        margin-right: 40px; /* 40px spacing to next imagebox */
        padding-left: 0;
        padding-right: 0;
        position: relative;
    }
    .plan-intro_scroll-heading {
        font-size: 16px;
        margin-top: 90px;
        letter-spacing: 0.06%;
        margin-bottom: 15px;
        margin-left: auto;
        margin-right: auto;
        line-height: 1.8;
        font-weight: bold;
        width: calc(100% - 60px);
    }
}

.plan-intro_scroll-image {
    /* margin-right: 40px; */
    display: block;
}

.plan-intro_scroll-imagebox {
    display: block;
    width: 272px;
    min-width: 272px;
    max-width: 272px;
    box-sizing: content-box;
    height: 310px;
    margin-right: 40px; /* 40px gap to next imagebox */
    padding-left: 0;
    padding-right: 0;
    position: relative;
    flex-shrink: 0;
    flex-grow: 0;
    flex-basis: 272px;
}
@media screen and (max-width: 767px) {
    .plan-intro_scroll-imagebox {
        display: none !important;
        margin-right: 20px;
    }
    .plan-intro_scroll-image {
        width: 267px !important;
        margin-right: 0;
    }
    .intro_scroll-box-8 {
        margin-right: 0 !important;
    }
}

.plan-intro_scroll-imagebox .plan-intro_scroll-image {
    padding-right: 0;
}
.plan-intro_scroll-image-1 {
    width: 302px;
}

.plan-intro_scroll-image-2 {
    width: 177px;
}

.plan-intro_scroll-image-3 {
    width: 480px;
}

.plan-intro_scroll-image-4 {
    width: 480px;
}

.plan-intro_scroll-image-5 {
    width: 352px;
}

.plan-intro_scroll-image-6 {
    width: 138px;
    margin-right: 0;
}

.plan-intro_scroll-image-7 {
    width: 221px;
    margin-right: 0;
}

.plan-intro_scroll-image-8 {
    width: 480px;
}
.plan-intro_scroll-image-9 {
    width: 212px;
    margin-right: 0;
}

.intro_scroll-box-6 {
    position: absolute;
    top: -88px;
    right: 0;
    margin: 0 !important;
    padding-right: 0 !important;
}
.intro_scroll-box-7 {
    position: absolute;
    bottom: 0;
    left: 0;
    margin: 0 !important;
    padding-right: 0 !important;
}

@media screen and (max-width: 767px) {
    .plan-intro_scroll-image-9 {
        padding-right: 0;
        margin-right: 0;
    }
}
/*========================================================================

  point2_body (標準横スクロール)

========================================================================*/

.point2_body {
    display: flex !important;
    flex-wrap: nowrap !important; /* 折り返しを防止して横並びを維持 */
    overflow-x: auto !important;
    scroll-behavior: smooth;
    -webkit-overflow-scrolling: touch;
    margin-top: 78px;
    width: 1160px;
    padding-left: 0;
}

/* PC時のスクロールボックス設定 */
@media screen and (min-width: 768px) {
    .point2_body {
        width: 100%;
    }
    .point2_item {
        flex-shrink: 0;
        width: 460px;
        margin-right: 40px;
    }
    .point2_item:last-child {
        margin-right: 0;
    }
}

/* SP時のスクロールボックス設定 */
@media screen and (max-width: 767px) {
    .point2_body {
        margin-left: 0px;
        margin-right: -20px;
        padding: 10px 0px;
        margin-top: 20px;
    }
    .point2_item {
        flex-shrink: 0;
        width: 280px;
        margin-right: 20px;
    }
    .point2_item:last-child {
        margin-right: 0;
    }
}

/*========================================================================

  point2_example-list (Slickスライダー)

========================================================================*/

.point2_example-list {
    opacity: 0;
    margin: 40px -12px 0;
}

.point2_example-list.slick-initialized {
    opacity: 1;
    width: 1040px;
    margin-left: auto;
    margin-right: auto;
}

.point2_example-list .slick-slide {
    margin: 0 12px;
}

@media screen and (max-width: 767px) {
    .point2_example-list {
        opacity: 0;
        margin: 40px 0 0;
    }

    .point2_example-list.slick-initialized {
        opacity: 1;
        width: calc(100% - 60px);
        margin-left: auto;
        margin-right: auto;
        margin-top: 0;
    }

    .point2_example-list .slick-slide {
        margin: 0 12px;
    }
}
.point2_example-list_text {
    font-size: 14px;
    margin-top: 20px;
}
@media screen and (max-width: 767px) {
    .point2_example-list_text {
        font-size: 14px;
        margin-top: 20px;
    }
}
/* コントローラー全体のコンテナ */
.point2_example-ctrl {
    display: flex;
    align-items: center;
    justify-content: center;
    margin-top: 27px;
    padding-bottom: 60px;
    gap: 16px;
}

@media screen and (max-width: 767px) {
    .point2_example-ctrl {
        display: flex;

        padding-bottom: 40px;
    }
}

/* 矢印ボタン共通設定 */
.point2_example-ctrl .slick-prev,
.point2_example-ctrl .slick-next {
    position: static !important;
    top: auto !important;
    transform: none !important;
    display: flex !important;
    align-items: center;
    justify-content: center;
    width: 32px;
    height: 32px;
    background-color: #767676 !important;
    border-radius: 50%;
    border: none;
    cursor: pointer;
    outline: none;
    transition: opacity 0.2s ease;
    padding: 0;
    margin: 0;
    font-size: 0;
    line-height: 0;
    color: transparent;
}

.point2_example-ctrl .slick-prev:hover,
.point2_example-ctrl .slick-next:hover {
    opacity: 0.8;
}

.point2_example-ctrl .slick-prev.slick-disabled,
.point2_example-ctrl .slick-next.slick-disabled {
    opacity: 0.35;
    cursor: not-allowed;
}

/* slickデフォルト疑似要素のテキスト非表示 */
.point2_example-ctrl .slick-prev:before,
.point2_example-ctrl .slick-next:before {
    display: none !important;
}

/* 左矢印アイコンの設定 */
.point2_example-ctrl .slick-prev {
    order: 1;
}
.point2_example-ctrl .slick-prev::after {
    content: "";
    display: block;
    width: 7px;
    height: 7px;
    border-left: 2px solid #fff;
    border-bottom: 2px solid #fff;
    transform: rotate(45deg);
    margin-left: 2px;
}

/* 右矢印アイコンの設定 */
.point2_example-ctrl .slick-next {
    order: 3;
}
.point2_example-ctrl .slick-next::after {
    content: "";
    display: block;
    width: 7px;
    height: 7px;
    border-right: 2px solid #fff;
    border-top: 2px solid #fff;
    transform: rotate(45deg);
    margin-right: 2px;
}

/* ページネーション（ドット）設定 */
.point2_example-ctrl .slick-dots {
    order: 2;
    display: flex !important;
    align-items: center;
    justify-content: center;
    position: static !important;
    bottom: auto !important;
    margin: 0;
    padding: 0;
    list-style: none;
    width: auto;
    height: auto;
}
@media screen and (max-width: 767px) {
    .point2_example-ctrl .slick-dots {
        margin-top: 0;
    }
}
.point2_example-ctrl .slick-dots li {
    width: 10px !important;
    height: 10px !important;
    margin: 0 4px !important;
    padding: 0;
    display: flex !important;
    align-items: center;
    justify-content: center;
    position: static !important;
}

.point2_example-ctrl .slick-dots li button {
    width: 10px !important;
    height: 10px !important;
    padding: 0 !important;
    background-color: #d8d8d8;
    border: none;
    border-radius: 50%;
    cursor: pointer;
    display: block;
    outline: none;
    transition: background-color 0.2s ease;
    font-size: 0;
    line-height: 0;
    color: transparent;
}

.point2_example-ctrl .slick-dots li.slick-active button {
    background-color: #242424;
}

.point2_example-ctrl .slick-dots li button:before {
    display: none !important;
}

/* レスポンシブ用の調整 */
@media screen and (max-width: 767px) {
    .point2_example-list {
        margin: 30px -5px 0;
    }
    .point2_example-list .slick-slide {
        margin: 0 0px;
    }
}

/*========================================================================

text

========================================================================*/

.primary_lead {
    font-size: 24px;
    font-weight: bold;
    line-height: 2.1;
    letter-spacing: 0.06em;
    text-align: center;
    padding-top: 100px;
}
@media screen and (max-width: 767px) {
    .primary_lead {
        font-size: 15px;
        font-weight: normal;
        line-height: 2.1;
        letter-spacing: 0.06em;
        text-align: center;
        padding-top: 50px;
        margin-bottom: 70px;
    }
}
.secondary_lead {
    font-size: 36px;
    line-height: 1.6;
    letter-spacing: 0.08em;
    text-align: center;
    margin-top: 90px;
    font-weight: bold;
}

@media screen and (max-width: 767px) {
    .secondary_lead {
        font-size: 18px;
        margin-top: 50px;
        text-align: center;

        margin-bottom: 0px;
        font-weight: bold;
    }
}

/*========================================================================

.plan-intro

========================================================================*/

.plan-intro {
    margin-top: 100px;
    padding-bottom: 60px;
}

@media screen and (max-width: 767px) {
    .plan-intro {
        margin-top: 60px;
        /* padding-bottom: 60px; */
    }
}

.plan-intro_box {
    width: 100%;
    max-width: 1160px;
    margin: 0 auto;
    padding: 0 0;
    display: flex;
}

.plan-intro_box-item {
    width: 386px;
}

.plan-intro_box-item:nth-of-type(1) {
    background-color: #f8f8f8;
}
.plan-intro_box-item:nth-of-type(2) {
    background-color: #f4f4f2;
}
.plan-intro_box-item:nth-of-type(3) {
    background-color: #eeefea;
}

.plan-intro_box-item-head {
    height: 80px;
    position: relative;
}

.plan-intro_box-item:nth-of-type(1) .plan-intro_box-item-head {
    padding-top: 44px;
}

.plan-intro_box-item:nth-of-type(2) .plan-intro_box-item-head {
    padding-top: 20px;
}
.plan-intro_box-item:nth-of-type(3) .plan-intro_box-item-head {
    padding-top: 20px;
}

@media screen and (max-width: 767px) {
    .plan-intro_box-item:nth-of-type(1) .plan-intro_box-item-head {
        padding-top: 38px;
    }
    .plan-intro_box-item:nth-of-type(2) .plan-intro_box-item-head {
        padding-top: 16px;
    }
    .plan-intro_box-item:nth-of-type(3) .plan-intro_box-item-head {
        padding-top: 16px;
    }
}

.plan-intro_box-item-head-subttl {
    font-size: 12px;
    text-align: center;
    line-height: 1;
    padding-bottom: 10px;
}

.plan-intro_box-item-head-ttl {
    font-size: 20px;
    font-weight: bold;
    text-align: center;
    line-height: 1;
    padding: 0 0 0 0;
    display: block;
}

@media screen and (max-width: 767px) {
    .plan-intro_box-item-head-ttl {
        font-size: 16px;
        font-weight: bold;
        text-align: center;

        padding: 0 0 0 0;
        display: block;
    }
}

.plan-intro_box-item-house {
    margin: 40px auto 16px;
    width: 218px;
}

@media screen and (max-width: 767px) {
    .plan-intro_box-item-house {
        margin: 22px auto 25px;
    }
}

.plan-intro_box-item:nth-of-type(1) .plan-intro_box-item-house {
    width: 210px;
}

@media screen and (max-width: 767px) {
    .plan-intro_box-item:nth-of-type(1) .plan-intro_box-item-house {
        width: 150px;
    }
    .plan-intro_box-item:nth-of-type(2) .plan-intro_box-item-house {
        width: 156px;
    }
    .plan-intro_box-item:nth-of-type(3) .plan-intro_box-item-house {
        width: 170px;
    }
}

.plan-intro_box-item-text {
    font-size: 16px;
    line-height: 1.8;

    padding: 0 0 13px;
    text-align: center;
}
@media screen and (max-width: 767px) {
    .plan-intro_box-item-text {
        font-size: 14px;
        line-height: 1.8;

        padding: 0 0 20px;
        text-align: center;
    }
}
/* 矢印 > の設定 */
.plan-intro_box-item:not(:last-child) .plan-intro_box-item-house {
    position: relative;
}
.plan-intro_box-item:not(:last-child) .plan-intro_box-item-house::after {
    content: "";
    position: absolute;
    right: -92px; /* 隣のアイテムとの中間点 */
    top: 100%;
    transform: translateY(-50%) rotate(45deg);
    width: 14px;
    height: 14px;
    border-top: 1.5px solid #000;
    border-right: 1.5px solid #000;
}

/* 2番目アイテムの矢印を個別に設定 */
.plan-intro_box-item:nth-of-type(2) .plan-intro_box-item-house::after {
    /* 必要に応じてここで個別スタイルを上書きします */
    /* 例: right: -80px; */
    right: -88px;
}

@media screen and (max-width: 767px) {
    .plan-intro_box-item:nth-of-type(2) .plan-intro_box-item-house::after {
        /* スマホレイアウト用の個別設定 */
        /* 例: right: -64px; */
        right: -66px;
    }
}

/* 3つ目のアイテムのバッジ設定 */
.plan-intro_box-item-badge {
    display: flex;
    align-items: center;
    justify-content: flex-start;
    /* background-color: #fff; */
    border: 1px solid #bfc0bd;
    padding: 14px 20px;
    margin: 0px auto 30px;
    font-size: 16px;
    font-weight: normal;
    color: #000;
    letter-spacing: 0.05em;
    text-align: center;
    white-space: nowrap;
    width: 278px;
    position: relative;
}
.plan-intro_box-item-badge-text {
    text-align: center;
    display: block;
    margin: 0 auto;
    position: relative;
}

.plan-intro_box-item-badge .plus {
    font-size: 24px;
    font-weight: 400;
    left: -12px;
    line-height: 1;
    flex-shrink: 0;
    position: absolute;
    background-color: #eeefea;
    padding: 5px 0;
}

/* 注記テキストの設定 */
.plan-intro_description {
    max-width: 1160px;
    margin: 15px auto 0;
    text-align: right;
    font-size: 12px;
    color: #333;
    line-height: 1.5;
}

/* SimpleBar 外側ラッパー設定 */
.plan-intro_box-outer,
.plan-intro_scroll-wrap-outer,
.point2_body-outer {
    width: 100%;
    max-width: 1160px;
    margin: 0 auto;
    padding-bottom: 91px; /* スクロールバーが表示される余白 */
}

@media screen and (max-width: 767px) {
    .plan-intro_box-outer,
    .plan-intro_scroll-wrap-outer,
    .point2_body-outer {
        width: calc(100% - 60px);
        max-width: 100%;
        margin: 0 auto;
        padding-bottom: 35px; /* スクロールバーが表示される余白 */
    }
}

.plan-intro_scroll-wrap-outer {
    max-width: 100%;
}
.point2_body-outer {
    /* max-width: 100%; */
    padding-bottom: 60px;
}
@media screen and (max-width: 767px) {
    .point2_body-outer {
        /* max-width: 100%; */
        padding-bottom: 33px;
    }
}
/* PC表示時はplan-intro_boxはスクロールしないため余白を消す */
@media screen and (min-width: 768px) {
    .plan-intro_box-outer {
        padding-bottom: 0;
    }
}

/* SimpleBar適用時のインナー要素のスクロール設定をリセット */
.plan-intro_box-outer .plan-intro_box,
.plan-intro_scroll-wrap-outer .plan-intro_scroll-wrap,
.point2_body-outer .point2_body {
    overflow-x: visible !important;
    overflow-y: visible !important;
}

/* SimpleBar 自体の横スクロールバーデザイン調整（添付画像再現） */
.simplebar-track.simplebar-horizontal {
    height: 6px !important;
    background-color: #e5e5e5 !important; /* 薄いグレーのレール */
    border-radius: 3px !important;
    bottom: 0px !important;
}
.simplebar-scrollbar::before {
    background-color: #333333 !important; /* 濃いグレーのつまみ */
    border-radius: 3px !important;
    left: 0 !important;
    right: 0 !important;
    opacity: 1 !important; /* 常に表示 */
    top: 0 !important;
    bottom: 0 !important;
    transition: none !important;
}
.simplebar-scrollbar {
    opacity: 1 !important;
    visibility: visible !important;
}
.simplebar-track.simplebar-horizontal .simplebar-scrollbar {
    opacity: 1 !important;
    visibility: visible !important;
    height: 6px !important;
}
.simplebar-scrollbar.simplebar-visible::before {
    opacity: 1 !important;
}

/* スマホ表示時の設定 */
@media screen and (max-width: 767px) {
    .plan-intro_box {
        display: flex !important;
        flex-direction: row !important;
        flex-wrap: nowrap !important;
        padding: 0;
        width: max-content !important;
        max-width: none !important;
    }
    .plan-intro_box-item {
        width: 260px !important;
        flex-shrink: 0;
        margin-right: 0px;
        margin-bottom: 0 !important;
    }
    .plan-intro_box-item:last-child {
        margin-right: 0;
        padding-bottom: 20px;
    }
    /* スマホでも矢印を縮小して表示 */

    .plan-intro_box-item:not(:last-child) .plan-intro_box-item-house::after {
        display: block !important;
        right: -58px !important;
        width: 14px;
        top: 120%;
        height: 14px;
        border-top: 1.2px solid #000;
        border-right: 1.2px solid #000;
    }
    /* スマホ用のバッジマージン調整 */
    .plan-intro_box-item-badge {
        margin: 0 auto;
        width: 225px;
        font-size: 14px;
        padding: 7px 20px;
    }
    .plan-intro_description {
        padding: 0;
        text-align: right;
        margin-top: 15px;
        white-space: normal;
        width: max-content;
        white-space: nowrap;
        position: relative;
    }
}

.plan-intro_scroll-body {
    width: 1160px;
    margin: 0 auto;
}

@media screen and (max-width: 767px) {
    .plan-intro_scroll-body {
        width: 100%;
    }
}

/*========================================================================

.point1

========================================================================*/

.point1_block {
    margin-top: 150px;
    width: 100%;
    margin: 0 auto;
}

.point1_block_inner {
    /* width: 1160px; */
    margin: 0 auto;
}

.point1_accordion {
    padding-top: 50px;

    margin: 0 auto;
    /* border-bottom: 1px solid #d8d8d8; */
}

@media screen and (min-width: 768px) {
    .point1_accordion {
        width: 1160px;
        margin-bottom: 170px;
    }
}

@media screen and (max-width: 767px) {
    .point1_accordion {
        padding-top: 40px;
        width: calc(100% - 60px);
        margin: 0 auto 80px;
    }
}

.point1_accordion_item-head {
    display: flex;
    justify-content: space-between;
    width: 1160px;
    margin: 0 auto;
}

.point1_accordion_item-textarea {
    width: 500px;
    position: relative;
}

.plan-1 .point1_accordion_item-textarea::after {
    content: "";
    width: 118px;
    height: 120px;
    position: absolute;
    top: 0;
    right: 0;
    background: url("/library/kodate/start/familysuite/assets/img/point_plan01_illust01.png") no-repeat;
    background-size: contain;
}

@media screen and (max-width: 767px) {
    .plan-1 .point1_accordion_item-textarea::after {
        content: "";
        width: 72px;
        height: 73px;
    }
}

.plan-2 .point1_accordion_item-textarea::after {
    content: "";
    width: 104px;
    height: 138px;
    position: absolute;
    top: 0;
    right: 0;
    background: url("/library/kodate/start/familysuite/assets/img/point_plan02_illust01.png") no-repeat;
    background-size: contain;
}

@media screen and (max-width: 767px) {
    .plan-2 .point1_accordion_item-textarea::after {
        content: "";
        width: 73px;
        height: 97px;
        right: 17px;
    }
}

.plan-3 .point1_accordion_item-textarea::after {
    content: "";
    width: 120px;
    height: 111px;
    position: absolute;
    top: 0;
    right: 0;
    background: url("/library/kodate/start/familysuite/assets/img/point_plan03_illust01.png") no-repeat;
    background-size: contain;
}

@media screen and (max-width: 767px) {
    .plan-3 .point1_accordion_item-textarea::after {
        content: "";
        width: 82px;
        height: 76px;
        right: 17px;
    }
}

.point1_accordion_item-image {
    width: 580px;
}

.point1_accordion_item {
    padding-top: 60px;
    padding-bottom: 60px;
    border-top: 1px solid #d8d8d8;
}
@media screen and (max-width: 767px) {
    .point1_accordion_item {
        padding-top: 60px;
    }
}
.point1_accordion_item-plan {
    font-size: 16px;
    font-weight: bold;
    letter-spacing: 0.02em;
    border-bottom: 2px solid #242424;
    display: inline-block;
    line-height: 1;
    padding: 0px 2px 10px 2px;
    margin-bottom: 25px;
}
@media screen and (max-width: 767px) {
    .point1_accordion_item-plan {
        font-size: 14px;
        padding-bottom: 5px;
        font-weight: bold;
    }
}

.point1_accordion_item-plan-heading {
    margin-bottom: 11px;
    text-align: center;
    font-size: 14px;
    font-weight: bold;
}

.thirdly-heading {
    font-size: 26px;
    line-height: 1.7;
    font-weight: bold;
    letter-spacing: 0.06em;
    margin-bottom: 20px;
}

@media screen and (max-width: 767px) {
    .thirdly-heading {
        font-size: 18px;
        line-height: 1.5;
        font-weight: bold;

        margin-bottom: 10px;
    }
}

.point1_accordion_text {
    font-size: 18px;
    line-height: 2;
    letter-spacing: 0.04em;
    text-align: left;
    margin-top: 0px;
}
@media screen and (max-width: 767px) {
    .point1_accordion_text {
        font-size: 15px;
        line-height: 1.7;
    }
}
.point1_accordion_data {
    font-size: 14px;
    line-height: 1.6;
    letter-spacing: 0.06em;
    text-align: left;
    margin-top: 20px;
}

.point1_accordion_btn {
    font-size: 15px;
    width: 215px;
    letter-spacing: 0.08em;
    text-align: center;
    margin-top: 39px;
    border-radius: 30px;
    line-height: 60px;
    border: 1px solid #000;
    font-weight: bold;
}

.point1_accordion_data {
    display: none;
    margin-top: 40px;
    border: 1px solid #d8d8d8;
    padding: 20px 30px;
    font-size: 18px;
    line-height: 1.7;
    letter-spacing: 0.04em;
}

@media screen and (max-width: 767px) {
    .point1_accordion_data {
        padding: 20px 20px;
        font-size: 15px;
    }
}

.point1_accordion_item-plan-base {
    margin-top: 60px;
    margin-bottom: 80px;
    width: 1160px;
    background-color: #f8f8f8;
    padding-bottom: 50px;
}

.plan-2 .point1_accordion_item-plan-base {
    margin-bottom: 20px;
    padding-bottom: 49px;
}

.plan-3 .point1_accordion_item-plan-base {
    margin-bottom: 20px;
    padding-bottom: 49px;
}

@media screen and (max-width: 767px) {
    .plan-3 .point1_accordion_item-plan-base {
        margin-bottom: 20px;
        padding-bottom: 0px;
    }
    .plan-2 .point1_accordion_item-plan-base {
        margin-bottom: 20px;
        padding-bottom: 20px;
    }

    .plan-3 .point1_accordion_item-plan-base {
        margin-bottom: 20px;
        padding-bottom: 20px;
    }
}

.point1_accordion_item-plan-image {
    width: 1048px;
    padding-top: 25px;
    padding-bottom: 65px;
    /* margin-bottom: 40px; */
    margin-left: 50px;
}

.plan-2 .point1_accordion_item-plan-image {
    width: 1068px;
    padding-top: 25px;
    padding-bottom: 40px;

    margin-left: 62px;
}
.plan-3 .point1_accordion_item-plan-image {
    width: 1095px;
    padding-top: 30px;
    padding-bottom: 40px;

    margin-left: 35px;
}

.point1_accordion_item-plan-detail {
    width: 1046px;
    margin: 0 auto;
    border-top: 1px solid #d8d8d8;
    display: flex;
    justify-content: space-between;
    padding-top: 35px;
}

@media screen and (max-width: 767px) {
    .point1_accordion_item-plan-detail {
        border-top: none;
    }
}
.point1_accordion_item-plan-detail-col-number {
    width: 32px;
    height: 32px;
    border-radius: 50%;
    background-color: #000;
    color: #fff;
    font-size: 16px;
    font-weight: bold;
    line-height: 32px;
    text-align: center;
    flex-shrink: 0;
}

@media screen and (max-width: 767px) {
    .point1_accordion_item-plan-detail-col-number {
        width: 32px;
        height: 32px;
        border-radius: 50%;
        background-color: #000;
        color: #fff;
        font-size: 16px;
        font-weight: bold;
        line-height: 32px;
        text-align: center;
        flex-shrink: 0;
    }
}
.point1_accordion_item-plan-detail-col {
    width: 320px;
}
.point1_accordion_item-plan-detail-col-textarea {
    display: flex;
    align-items: center;
    margin-bottom: 13px;
    height: 48px;
}

.point1_accordion_item-plan-detail-col-text {
    font-size: 14px;
    line-height: 1.6;
}

@media screen and (max-width: 767px) {
    .point1_accordion_item-plan-detail-col-text {
        letter-spacing: -0.02em;
    }
}
.point1_accordion_item-plan-detail-col-title {
    font-size: 16px;
    font-weight: bold;
    letter-spacing: 0.02em;

    display: inline-block;
    line-height: 1.5;
    padding-left: 15px;
}
@media screen and (max-width: 767px) {
    .point1_accordion_item-plan-detail-col-title {
        font-size: 15px;
    }
}

.plan-detail-col-text {
    font-size: 14px;
    line-height: 1.5;
    letter-spacing: 0.02em;
    text-align: left;
    margin-top: 0px;
}

.point1_accordion_item-movie {
    width: 500px;
    /* max-width: 100%; */
    margin: 70px auto 10px;
    position: relative;
    display: block;
}
.point1_accordion_item-movie-inner {
    position: relative;
    /* width: 500px;
    max-width: 100%; */

    overflow: visible;
    /* margin: 0 auto; */
}
.point1_accordion_item-movie-inner iframe {
    position: absolute;
    top: 0;
    left: 0;
    width: 100% !important;
    height: 100% !important;
    border: 0;
    display: block;
}

.point1_accordion_item-movie-text {
    font-size: 18px;
    font-weight: bold;
    text-align: center;
    margin-top: 20px;

    position: relative;
}

@media screen and (max-width: 767px) {
    .point1_accordion_item-movie-text {
        margin-top: 15px;
    }
}

/*========================================================================

.point2

========================================================================*/

.point2_image {
    width: 500px;
}
.point2_textarea {
    width: 580px;
    display: flex;
    align-items: center;
}

.point2_box {
    margin-top: 150px;
    width: 1160px;
    margin: 60px auto 0;
    display: flex;
    justify-content: space-between;
}

@media screen and (max-width: 767px) {
    .point2_image {
        width: 100%;
    }
    .point2_textarea {
        width: calc(100% - 60px);
        display: block;
        align-items: center;
        margin: 40px auto 0;
    }

    .point2_box {
        width: 100%;
        margin-top: 38px;
        display: block;
    }
}

.point2_text {
    font-size: 26px;
    font-weight: bold;
    line-height: 1.8;
    letter-spacing: 0.06em;
}
@media screen and (max-width: 767px) {
    .point2_text {
        font-size: 18px;
        font-weight: bold;
        line-height: 1.8;
        letter-spacing: 0.1em;
        text-align: center;
    }
}
.point2_item-time {
    font-size: 16px;
    font-weight: bold;
    line-height: 1;
    letter-spacing: 0em;
    text-align: center;
    width: 73px;
    height: 73px;
    border-radius: 50%;
    position: relative;
    border: 1px solid #000;
    line-height: 73px;
    margin-bottom: 15px;
}

.point2_item-time::after {
    content: "";
    position: absolute;
    top: 50%;
    margin-left: 30px;
    /* transform: translate(-50%, -50%) rotate(45deg); */
    width: 390px;
    height: 1px;

    background-color: #000;
}

@media screen and (max-width: 767px) {
    .point2_item-time::after {
        content: "";
        position: absolute;
        top: 50%;
        margin-left: 20px;
        /* transform: translate(-50%, -50%) rotate(45deg); */
        width: 215px;
        height: 1px;

        background-color: #000;
    }
}

@media screen and (max-width: 767px) {
    .point2_item-time {
        font-size: 12px;
        font-weight: bold;

        width: 50px;
        height: 50px;

        line-height: 50px;
        margin-bottom: 15px;
    }
}

.simplebar-content {
    padding-left: 0 !important;
    width: 1160px;
}
.point2_item-image {
    margin-bottom: 30px;
}
@media screen and (max-width: 767px) {
    .point2_item-image {
        width: 280px;
        margin-bottom: 20px;
    }
}
.point2_item_heading {
    font-weight: bold;
    line-height: 1.4;
    font-size: 18px;
    letter-spacing: 0.02em;
    margin-bottom: 10px;
}
@media screen and (max-width: 767px) {
    .point2_item_heading {
        font-size: 15px;

        margin-bottom: 15px;
    }
}
.point2_item-text {
    font-size: 14px;
    line-height: 1.5;
    letter-spacing: 0.02em;
    text-align: left;
}

.point2_example {
    margin-top: 120px;
}

@media screen and (max-width: 767px) {
    .point2_example {
        margin: 0 auto;
        width: calc(100% - 60px);
    }
}

.point2_example-base {
    padding-top: 60px;
    background-color: #f8f8f8;
    width: 1160px;
    margin: 0 auto;
}

@media screen and (max-width: 767px) {
    .point2_example-base {
        padding-top: 40px;

        width: 100%;
        margin: 60px auto 0;
    }
}

.point2_example-heading {
    font-size: 26px;
    font-weight: bold;
    line-height: 1;
    letter-spacing: 0em;
    margin-bottom: 30px;
    text-align: center;
}

@media screen and (max-width: 767px) {
    .point2_example-heading {
        font-size: 16px;

        margin-bottom: 17px;
        text-align: center;
    }
}

/*========================================================================

.point3

========================================================================*/

.point3_body {
    width: 1160px;
    margin: 0 auto;
}
@media screen and (max-width: 767px) {
    .point3_body {
        /* width: calc(100% - 60px); */
        width: 100%;
        margin: 0 auto;
    }
}
.point3_heading {
    border: 1px solid #000;
    line-height: 1;
    padding: 20px 40px;
    font-size: 24px;
    text-align: center;
    width: fit-content;
    margin: 95px auto 25px;
    font-weight: bold;
}
@media screen and (max-width: 767px) {
    .point3_heading {
        line-height: 1;
        padding: 10px 30px;
        font-size: 18px;

        margin: 45px auto 15px;
    }
}
.point3_text {
    font-size: 24px;
    line-height: 1.6;
    letter-spacing: 0.02em;
    text-align: center;
    margin: 0 auto 50px;
    font-weight: bold;
}
@media screen and (max-width: 767px) {
    .point3_text {
        font-size: 16px;
        line-height: 1.6;
        letter-spacing: 0.02em;
        text-align: center;
        margin: 0 auto 25px;
        font-weight: bold;
    }
}
.point3_description {
    font-size: 12px;
    line-height: 1.5;
    letter-spacing: 0em;
    text-align: center;
    margin: 15px auto 0px;
    text-align: left;
}

@media screen and (max-width: 767px) {
    .point3_description {
        margin: 20px auto 0px;
        width: calc(100% - 60px);
    }
}

/*========================================================================

.point3

========================================================================*/

.point4_icon {
    position: absolute;
    right: 279px;
    top: 94px;
    width: 140px;
}
@media screen and (max-width: 767px) {
    .point4_icon {
        position: absolute;
        right: 16px;
        top: 30px;
        width: 110px;
    }
}
.point4_caption {
    text-align: center;
    font-size: 12px;
    line-height: 1.6;
    margin-top: 28px;
    margin-bottom: 50px;
}
@media screen and (max-width: 767px) {
    .point4_caption {
        text-align: left;
        font-size: 10px;
        width: calc(100% - 60px);
        margin: 35px auto;
    }
}

.point4_box {
    width: 1160px;
    margin: 0 auto 80px;
    display: flex;
    justify-content: space-between;
}
@media screen and (max-width: 767px) {
    .point4_box {
        width: 100%;
        margin: 0 auto 55px;
        display: block;
    }
}
.point4_image {
    width: 580px;
}
@media screen and (max-width: 767px) {
    .point4_image {
        width: 100%;
    }
}
.point4_textarea {
    width: 500px;
    display: flex;
    justify-content: left;

    flex-direction: column;
    text-align: left;
}
@media screen and (max-width: 767px) {
    .point4_textarea {
        width: calc(100% - 60px);
        display: block;
        margin: 0 auto;
    }
}
.point4_text {
    font-size: 18px;
    line-height: 2;
}
@media screen and (max-width: 767px) {
    .point4_text {
        font-size: 15px;
        line-height: 2;
    }
}
.point4_title {
    font-size: 26px;
    letter-spacing: 0.06em;
    font-weight: bold;
    margin-bottom: 35px;
    margin-top: 90px;
}
@media screen and (max-width: 767px) {
    .point4_title {
        text-align: center;
        font-size: 18px;
        letter-spacing: 0.06em;
        font-weight: bold;
        margin-bottom: 17px;
        margin-top: 35px;
        text-align: center;
    }
}
.point4_base {
    position: relative;
    display: block;
    margin-top: 80px;
    /* padding: 45px 90px; */
    background-color: #f5f5f5;
    /* width: 1160px; */
    width: 847px;
    margin: 0 auto;
    border-radius: 5px;
}
@media screen and (max-width: 767px) {
    .point4_base {
        position: relative;
        display: block;

        padding: 40px 20px;
        /* padding: 45px 90px; */
        background-color: #f5f5f5;
        /* width: 1160px; */
        width: calc(100% - 40px);
        margin: 0 auto;
    }
}
.point4_base-box {
    display: flex;
    justify-content: space-between;
    padding: 40px 100px;
    width: 847px;
}
@media screen and (max-width: 767px) {
    .point4_base-box {
        display: block;
        width: 100%;
        padding: 0;
    }
}
.point4_base-image {
    width: 289px;
}
@media screen and (max-width: 767px) {
    .point4_base-image {
        width: 100%;
    }
}
.point4_base-textarea {
    width: 320px;

    display: flex;
    justify-content: left;

    flex-direction: column;
    text-align: left;
}
@media screen and (max-width: 767px) {
    .point4_base-textarea {
        width: 100%;
        display: block;
    }
}
.point4_base-title {
    font-size: 26px;
    letter-spacing: 0.06em;
    font-weight: bold;
    margin-bottom: 35px;
    margin-top: 90px;
}

.point4_base-box {
    display: flex;
    justify-content: space-between;
}
@media screen and (max-width: 767px) {
    .point4_base-box {
        display: block;
    }
}
.point4_base-subtext {
    font-size: 14px;
    line-height: 1.5;
    margin-bottom: 5px;
    margin-top: 20px;
}

@media screen and (max-width: 767px) {
    .point4_base-subtext {
        font-size: 12px;
        line-height: 1.5;
        margin-bottom: 5px;
        margin-top: 25px;
    }
}
.point4_base-text {
    font-size: 20px;
    font-weight: bold;
    width: fit-content;
    display: block;
    margin-bottom: 25px;
}
@media screen and (max-width: 767px) {
    .point4_base-text {
        font-size: 16px;
        font-weight: bold;
        width: fit-content;
        display: block;
        margin-bottom: 11px;
    }
}
.point4_base-link {
    width: fit-content;
    display: inline-block;
    padding-bottom: 5px;
    border-bottom: 1px solid #000;
    transition: 0.2s all;
}

@media screen and (max-width: 767px) {
    .point4_base-link {
        font-size: 14px;
    }
}

.point4_base-link:hover {
    opacity: 0.6;
}
.point4_base-link::after {
    content: "";
    background: url(/library/kodate/start/familysuite/assets/img/window.png) no-repeat right center transparent;
    display: inline-block;
    position: relative;
    width: 11px;
    height: 11px;
    background-size: 11px 11px;
    padding-left: 15px;
}

/*========================================================================

.banner-area

========================================================================*/

.banner-area {
    border-top: 1px solid #d8d8d8;

    width: 100%;
    margin: 0 auto;
    margin-top: 150px;
    margin-bottom: 150px;
    padding-top: 150px;
}
@media screen and (max-width: 767px) {
    .banner-area {
        width: 100%;
        margin: 0 auto;
        margin-top: 50px;
        margin-bottom: 80px;
        padding-top: 80px;
    }
}

.banner-box {
    width: 1160px;
    display: flex;
    justify-content: space-between;
    padding: 0 0 0;
    margin: 0 auto;
}

@media screen and (max-width: 767px) {
    .banner-box {
        width: calc(100% - 60px);
        display: block;
        padding: 0 0 0;
        margin: 0 auto;
    }
}
.banner-link {
    display: block;
    width: 565px;
    transition: all 0.2s ease;
}

@media screen and (max-width: 767px) {
    .banner-link {
        width: 100%;
        margin-bottom: 20px;
    }
}
.banner-link:hover {
    opacity: 0.6;
}

@media screen and (max-width: 767px) {
    .point1_accordion_item-head {
        width: 100%;
        align-items: start !important;
        flex-direction: column;
        padding: 0 0 !important;
    }
    .point1_accordion_item-textarea {
        width: 100%;
        margin-bottom: 0 !important;
    }
    .point1_accordion_item-image {
        width: 100%;
        margin-top: 35px;
    }
    .point1_accordion_item-body {
        width: 100%;
    }
    .point1_accordion_item-plan-base {
        width: 100%;
        margin-top: 0px;
        margin-bottom: 0px;
        padding-bottom: 0px;
        padding: 20px 20px;
    }
    .point1_accordion_item-plan-base {
        margin-top: 40px;
    }
    .point1_accordion_item-plan-image,
    .plan-2 .point1_accordion_item-plan-image,
    .plan-3 .point1_accordion_item-plan-image {
        width: 100%;
        margin-left: 0;
        padding: 20px 15px;
    }
    .point1_accordion_item-plan-image img {
        width: 100%;
        height: auto;
    }
    .point1_accordion_item-plan-detail {
        width: 100%;
        flex-direction: column;
        padding-top: 20px;
    }
    .point1_accordion_item-plan-detail-col {
        width: 100%;
        margin-bottom: 25px;
    }
    .point1_accordion_item-plan-detail-col-textarea {
        height: auto;
    }
    .point1_accordion_item-plan-detail-col:last-child {
        margin-bottom: 0;
    }
    .point1_accordion_item-movie {
        /* width: 100%;
        max-width: 500px; */
        margin: 40px auto;
        /* width: calc(100% - 40px); */
        width: 100%;
    }
    .point1_accordion_item-movie-inner {
        /* スマホでは幅が可変なのでpadding-topで16:9を維持 */
        width: 100% !important;
        /* height: 0 !important; */
        /* padding-top: 56.25% !important; */
    }
    .point1_accordion_item-movie-inner iframe {
        width: 100% !important;
        height: 100% !important;
    }
    .point1_accordion_btn {
        margin-left: 0;
        margin-right: 0;
        display: block;
        width: 15px;
        line-height: 46px;
        width: 160px;
    }
    .simplebar-content {
        width: auto !important;
    }

    /* slick slider 用のスタイル */
    .point1_accordion_item-plan-base-list {
        opacity: 0;
        margin: 20px 0 0;
    }
    .point1_accordion_item-plan-base-list.slick-initialized {
        opacity: 1;
    }
    .point1_accordion_item-plan-base-listitem {
        outline: none;
        width: 100%;
    }
    .point1_accordion_item-plan-base-listitem .point1_accordion_item-plan-image {
        padding: 0 !important;
        width: 100%;
        margin-left: 0;
    }
    .point1_accordion_item-plan-base-listitem .point1_accordion_item-plan-detail {
        padding-top: 20px !important;
    }

    /* .point1_accordion-ctrl の設定 */
    .point1_accordion-ctrl {
        display: flex;
        align-items: center;
        justify-content: center;
        margin-top: 30px;
        padding-bottom: 20px;
        gap: 16px;
    }

    .point1_accordion-ctrl .slick-prev,
    .point1_accordion-ctrl .slick-next {
        position: static !important;
        top: auto !important;
        transform: none !important;
        display: flex !important;
        align-items: center;
        justify-content: center;
        width: 32px;
        height: 32px;
        background-color: #767676 !important;
        border-radius: 50%;
        border: none;
        cursor: pointer;
        outline: none;
        transition: opacity 0.2s ease;
        padding: 0;
        margin: 0;
        font-size: 0;
        line-height: 0;
        color: transparent;
    }

    .point1_accordion-ctrl .slick-prev:hover,
    .point1_accordion-ctrl .slick-next:hover {
        opacity: 0.8;
    }

    .point1_accordion-ctrl .slick-prev.slick-disabled,
    .point1_accordion-ctrl .slick-next.slick-disabled {
        opacity: 0.35;
        cursor: not-allowed;
    }

    .point1_accordion-ctrl .slick-prev:before,
    .point1_accordion-ctrl .slick-next:before {
        display: none !important;
    }

    .point1_accordion-ctrl .slick-prev {
        order: 1;
    }
    .point1_accordion-ctrl .slick-prev::after {
        content: "";
        display: block;
        width: 7px;
        height: 7px;
        border-left: 2px solid #fff;
        border-bottom: 2px solid #fff;
        transform: rotate(45deg);
        margin-left: 2px;
    }

    .point1_accordion-ctrl .slick-next {
        order: 3;
    }
    .point1_accordion-ctrl .slick-next::after {
        content: "";
        display: block;
        width: 7px;
        height: 7px;
        border-right: 2px solid #fff;
        border-top: 2px solid #fff;
        transform: rotate(45deg);
        margin-right: 2px;
    }

    .point1_accordion-ctrl .slick-dots {
        order: 2;
        display: flex !important;
        align-items: center;
        justify-content: center;
        position: static !important;
        bottom: auto !important;
        margin: 0;
        padding: 0;
        list-style: none;
        width: auto;
        height: auto;
    }

    .point1_accordion-ctrl .slick-dots li {
        width: 10px !important;
        height: 10px !important;
        margin: 0 5px !important;
        padding: 0;
        display: flex !important;
        align-items: center;
        justify-content: center;
        position: static !important;
    }

    .point1_accordion-ctrl .slick-dots li button {
        width: 10px !important;
        height: 10px !important;
        padding: 0 !important;
        background-color: #d8d8d8;
        border: none;
        border-radius: 50%;
        cursor: pointer;
        display: block;
        outline: none;
        transition: background-color 0.2s ease;
        font-size: 0;
        line-height: 0;
        color: transparent;
    }

    .point1_accordion-ctrl .slick-dots li.slick-active button {
        background-color: #242424;
    }

    .point1_accordion-ctrl .slick-dots li button:before {
        display: none !important;
    }
}

/* 中間幅・タブレットサイズ（768px〜1160px）での崩れを防ぐためのレスポンシブ調整 */
@media screen and (max-width: 1160px) {
    .primary_lead {
        padding-top: 60px;
    }
    .point1_accordion_item-head {
        width: 100%;
        padding: 0 30px;
        flex-direction: column;
        align-items: center;
        box-sizing: border-box;
    }
    .point1_accordion_item-textarea {
        width: 100%;
        max-width: 500px;
        margin-bottom: 30px;
    }
    .point1_accordion_item-image {
        width: 100%;
        max-width: 580px;
    }
    .point1_accordion_item-body {
        width: 100%;
        /* padding: 0 30px; */
        box-sizing: border-box;
    }
    .point1_accordion_item-plan-base {
        width: 100%;
        max-width: 100%;
        box-sizing: border-box;
        padding-left: 20px;
        padding-right: 20px;
    }
    /* .plan-1 .point1_accordion_item-plan-base {
        padding-left: 20px;
        padding-right: 20px;
    } */
    .point1_accordion_item-plan-image,
    .plan-2 .point1_accordion_item-plan-image,
    .plan-3 .point1_accordion_item-plan-image {
        width: 100%;
        max-width: 100%;
        margin-left: 0;
        padding-bottom: 40px;
    }
    .point1_accordion_item-plan-image img {
        width: 100%;
        height: auto;
    }
    .point1_accordion_item-plan-detail {
        width: 100%;
        flex-wrap: wrap;
        justify-content: center;
        gap: 30px 20px;
    }
    .point1_accordion_item-plan-detail-col {
        /* width: 45%;
        min-width: 280px; */
    }
}

.slick-dots li button {
    width: 10px !important;
    height: 10px !important;
    /* margin: 0 15px !important; */
}

.point2_example-ctrl {
    gap: 30px;
    align-items: center !important;
}
.point2_example-ctrl .slick-dots {
    margin-top: 0 !important;
    align-self: center;
}
.point2_example-ctrl .slick-dots li {
    width: 10px !important;
    height: 10px !important;
    margin: 0 5px !important;
    display: flex;
    align-items: center;
    justify-content: center;
}

.slick-dotted.slick-slider {
    margin-bottom: 0px !important;
}
.point_img01_slider .slick-dots li {
    margin: 0 10px !important;
}

@media screen and (max-width: 767px) {
    .point_img01_slider .slick-dots li {
        margin: 0 5px !important;
    }
}

.point_img01_slider .slick-dots li button {
    background-color: #fff;
}
.point_img01_slider .slick-dots li.slick-active button {
    background-color: #3b3b41 !important;
}

@media screen and (min-width: 768px) {
    .mt120_pc {
        margin-top: 120px;
    }
}
@media screen and (max-width: 767px) {
    .mt45_sp {
        margin-top: 45px;
    }
}

@media screen and (max-width: 767px) {
    .mb12_sp {
        margin-bottom: 12px;
    }
}
@media screen and (max-width: 767px) {
    .pb12_sp {
        padding-bottom: 12px;
    }
}
@media screen and (max-width: 767px) {
    .pt17_sp {
        padding-top: 17px !important;
    }
}
@media screen and (min-width: 768px) {
    .pt90_pc {
        padding-top: 90px;
    }
}
@media screen and (max-width: 767px) {
    .ls-008_sp {
        letter-spacing: -0.08em;
    }
}

@media screen and (max-width: 767px) {
    .mt60_sp {
        margin-top: 60px;
    }
}

/* slickデフォルト矢印文字（四角い豆腐マーク等）の完全な非表示化 */
.slick-prev:before,
.slick-next:before,
.slick-prev.slick-disabled:before,
.slick-next.slick-disabled:before {
    display: none !important;
    content: "" !important;
}

/* スマホ表示時のロールオーバー（ホバー不透明度変化）の無効化と無効化ボタンのリセット */
@media screen and (max-width: 767px) {
    .point2_example-ctrl .slick-prev:hover,
    .point2_example-ctrl .slick-next:hover,
    .point1_accordion-ctrl .slick-prev:hover,
    .point1_accordion-ctrl .slick-next:hover {
        opacity: 1 !important;
    }

    .slick-prev:disabled,
    .slick-next:disabled,
    .slick-prev.slick-disabled,
    .slick-next.slick-disabled {
        outline: none !important;
        box-shadow: none !important;
        color: transparent !important;
        text-indent: -9999px !important;
    }
}

/* ========================================================================
   スマホ表示時の各プラン（plan-1, plan-2, plan-3）の
   スライド「枚数（1枚目〜3枚目）」ごとの詳細エリア (.point1_accordion_item-plan-detail)
   の padding-top 個別設定
   ======================================================================== */
@media screen and (max-width: 767px) {
    /* --------------------------------------------------
       【PLAN 1】各スライドの余白設定
       -------------------------------------------------- */
    /* plan-1: 1枚目のスライド */
    .plan-1 .point1_accordion_item-plan-base-listitem:nth-child(1) .point1_accordion_item-plan-detail {
        padding-top: 21px !important;
    }
    /* plan-1: 2枚目のスライド */
    .plan-1 .point1_accordion_item-plan-base-listitem:nth-child(2) .point1_accordion_item-plan-detail {
        padding-top: 26px !important;
    }
    /* plan-1: 3枚目のスライド */
    .plan-1 .point1_accordion_item-plan-base-listitem:nth-child(3) .point1_accordion_item-plan-detail {
        padding-top: 31px !important;
    }

    /* --------------------------------------------------
       【PLAN 2】各スライドの余白設定
       -------------------------------------------------- */
    /* plan-2: 1枚目のスライド */
    .plan-2 .point1_accordion_item-plan-base-listitem:nth-child(1) .point1_accordion_item-plan-detail {
        padding-top: 27px !important;
    }
    /* plan-2: 2枚目のスライド */
    .plan-2 .point1_accordion_item-plan-base-listitem:nth-child(2) .point1_accordion_item-plan-detail {
        padding-top: 32px !important;
    }
    /* plan-2: 3枚目のスライド */
    .plan-2 .point1_accordion_item-plan-base-listitem:nth-child(3) .point1_accordion_item-plan-detail {
        padding-top: 83px !important;
    }

    /* --------------------------------------------------
       【PLAN 3】各スライドの余白設定
       -------------------------------------------------- */
    /* plan-3: 1枚目のスライド */
    .plan-3 .point1_accordion_item-plan-base-listitem:nth-child(1) .point1_accordion_item-plan-detail {
        padding-top: 18px !important;
    }
    /* plan-3: 2枚目のスライド */
    .plan-3 .point1_accordion_item-plan-base-listitem:nth-child(2) .point1_accordion_item-plan-detail {
        padding-top: 18px !important;
    }
    /* plan-3: 3枚目のスライド */
    .plan-3 .point1_accordion_item-plan-base-listitem:nth-child(3) .point1_accordion_item-plan-detail {
        padding-top: 20px !important;
    }
}

.sup {
    font-size: 60% !important;
    vertical-align: top !important;
    position: relative !important;
    top: 0.1em !important;
}

/* ========================================================================
   動画モーダル (Simple Video Modal)
   ======================================================================== */
.video-modal {
    display: none;
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: 10000;
}
.video-modal-bg {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(0, 0, 0, 0.6);
    opacity: 0;
    transition: opacity 0.3s ease;
}
.video-modal-content {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%) scale(1);
    width: 90%;
    max-width: 960px;
    opacity: 0;
    transition:
        transform 0.3s ease,
        opacity 0.3s ease;
}
.video-modal-iframe-wrapper {
    position: relative;
    width: 100%;
    /* padding-top: 56.25%; */
    background: #000;
}

@media screen and (max-width: 767px) {
    .video-modal-iframe-wrapper {
        position: relative;
        width: 100%;
        /* padding-top: 56.25%; */
        background: #000;
        aspect-ratio: 16 / 9;
    }
    .video-modal-iframe-wrapper video {
        position: absolute;
        top: 0;
        left: 0;
        width: 100%;
        height: 100%;
        border: none;
    }
}

.video-modal-iframe-wrapper iframe {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    border: none;
}
.video-modal-close {
    position: absolute;
    top: -45px;
    right: 0;
    background: none;
    border: none;
    color: #fff;
    font-size: 44px;
    line-height: 1;
    cursor: pointer;
    padding: 0;
    outline: none;
    transition: color 0.2s ease;
}
.video-modal-close:hover {
    /* color: #ccc; */
}

/* モーダル表示時のアクティブクラス */
.video-modal.is-active {
    display: block;
}
.video-modal.is-active .video-modal-bg {
    opacity: 1;
}
.video-modal.is-active .video-modal-content {
    transform: translate(-50%, -50%) scale(1);
    opacity: 1;
}

/* サムネイルのホバー表現とポインタ */
.point1_accordion_item-movie-thumbnail {
    cursor: pointer;
    position: relative;
    display: block;
    overflow: visible;
}
.point1_accordion_item-movie-thumbnail img {
    display: block;
    width: 100%;
    height: auto;
    transition: transform 0.3s ease;
}
.point1_accordion_item-movie-thumbnail:hover img {
    opacity: 0.7;
}
/* 再生アイコンをオーバーレイ */
.point1_accordion_item-movie-thumbnail::after {
    /* content: "";
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 70px;
    height: 70px;
    background: rgba(0, 0, 0, 0.6) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='white'%3E%3Cpath d='M8 5v14l11-7z'/%3E%3C/svg%3E") no-repeat center;
    background-size: 32px;
    border-radius: 50%;
    transition: background-color 0.3s, transform 0.3s ease;
    pointer-events: none;
    box-shadow: 0 0 15px rgba(0,0,0,0.3); */
}
/* .point1_accordion_item-movie-thumbnail:hover::after {
    background-color: rgba(200, 0, 0, 0.9);
    transform: translate(-50%, -50%) scale(1.1);
} */
@media screen and (max-width: 767px) {
    .point1_accordion_item-movie-thumbnail::after {
        width: 50px;
        height: 50px;
        background-size: 24px;
    }
    .video-modal-close {
        top: -40px;
        font-size: 36px;
    }
}

@media screen and (min-width: 768px) {
    .bt_pc {
        border-top: 1px solid #d8d8d8;
    }
}

.bb {
    border-bottom: 1px solid #d8d8d8;
}

/* ========================================================================
   SimpleBar Grab-to-scroll (dragscroll 連携)
   ======================================================================== */
.simplebar-content-wrapper.dragscroll {
    cursor: grab !important;
}
.simplebar-content-wrapper.dragscroll:active {
    cursor: grabbing !important;
}
.simplebar-content-wrapper.dragscroll * {
    user-select: none !important;
    -webkit-user-select: none !important;
}
.simplebar-content-wrapper.dragscroll img {
    -webkit-user-drag: none;
    user-drag: none;
}
