@charset "utf-8";


figure {
    position: relative;
}

/* main */

.main {
    background-image: url(../img/mv-pc.jpg);
    background-repeat: no-repeat;
    background-size: cover;
    padding: 6% 0 2% 0;
    position: relative;
}

.main_ttl {
    max-width: 800px;
    width: 60%;
    margin: 0 auto;
}

.main_lead {
    max-width: 600px;
    width: 40%;
    margin: 0 auto;
}

/*point area
-------------------------------------------------------------------*/

.point_area {
    padding: 100px 0;
    background: #eff5f8;
}

.point_wrap ul {
    width: 90%;
    margin-left: auto;
}

.point-block.flex {
    justify-content: space-between;
}

.point-block {
    position: relative;
    background: #fff;
    padding: 40px;
    box-shadow: 0px 0px 10px rgba(0,0,0,0.3);
}


.point-block:not(:last-child) {
    margin-bottom: 80px;
}

.point-block .item-text,
.point-block .item-img {
    position: relative;
    width: 45%;
}

.point-block .point-num {
    display: flex;
    align-items: center;
    gap: 10px;
    color: #00788e;
    margin-bottom: 20px;
}

.point-num::before {
    position: absolute;
    display: block;
    color: #fff;
    font-size: 14px;
    padding-left: .5em;
    width: 180px;
    height: 30px;
        line-height: 30px;
    background: url("../img/deco_time_bg.png") no-repeat center / cover;
    top: 0%;
    left: -130px;
    transform: translate(0, 15px);
}

.point01 .point-num::before {
    content: "AM:7:00〜";
}

.point02 .point-num::before,
.point03 .point-num::before  {
    content: "AM:8:00〜";
}

.point04 .point-num::before {
    content: "AM:8:30〜";
}

.point05 .point-num::before {
    content: "AM:11:00〜";
}

.point06 .point-num::before,
.point07 .point-num::before {
    content: "PM:6:00〜";
}

.point08 .point-num::before {
    content: "PM:7:00〜";
}



.point09 .point-num::before {
    content: "PM:8:00〜";
}

.point10 .point-num::before {
    content: "PM:9:00〜";
}

.point-num::after {
    position: absolute;
    display: block;
    content: "";
    width: 10px;
    height: 300px;
    background: url("../img/deco_arrow.png") no-repeat center / contain;
    top: 0%;
    left: -80px;
    transform: translate(0, 21px);
}

.point-block .point-num img {
    width: auto !important;
    height: 60px;
    display: inline;
    object-fit: contain;
}

.point-block .item-text h3 {
    position: relative;
    color: #00788e;
    font-size: 26px;
    margin-bottom: 20px;
    padding: 10px 0;
    line-height: 2.4rem;
    letter-spacing: 0.04em;
}

.point-block .item-text h3::before {
    position: absolute;
    content: "";
    display: block;
    background: url("../img/deco_h_bg.png") no-repeat center / cover;
    top: 0;
    left: -40px;
    height: 100%;
    width: 200%;
}

.point-block .item-text p {
    font-size: 17.5px;
    line-height: 2rem;
    letter-spacing: 0.05em;
}

/*point個別*/

.point09 .item-img .sub-img {
    position: absolute;
    width: 50%;
    bottom: -20%;
    left: -20%;
}

.point02 .item-img .sub-img {
    position: absolute;
    width: 30%;
    bottom: -8%;
    left: -8%;
}

.u-smaller {
    font-size: 70%;
}

.point04 .item-img .sub-img {
    position: absolute;
    width: 55%;
    bottom: -20%;
    left: -20%;
}

.point06 .item-img .sub-img {
    position: absolute;
    width: 35%;
    top: -5%;
    right: 5%;
}

.point07 .item-text .sub-img {
    position: absolute;
    z-index: 2;
    width: 16%;
    top: -3%;
    left: 70%;
}

.point07 .item-text .sub-img-txt {
    position: absolute;
    width: 55%;
    top: -19%;
    left: 70%;
}

.point08 .item-text .sub-img  {
    position: absolute;
    z-index: 2;
    width: 35%;
    top: 3%;
    left: 80%;
}

.point08 .item-img .sub-img-txt {
    position: absolute;
    width: 55%;
    bottom: -20%;
    left: -25%;
}


.point10 .item-img .sub-img {
    position: absolute;
    width: 55%;
    top: -25%;
    right: -5%;
}

/*kyushu area
-------------------------------------------------------------------*/

.kyushu_area {
    padding: 100px 0 0 0;
}

.kyushu_area h3 {
    width: 20%;
    min-width: 300px;
    margin: 0 auto 90px auto;
}

.build-img-block {
    display: grid;
    grid-template-columns: 30% 40% 30%;
    grid-template-rows: 45% 45%;
    gap: 3px;
    margin-bottom: 0px;
}

.build-img-block figure {
    overflow: hidden;
}

.build-img-block figure:nth-child(1) {
    grid-column: 1 / 2;
    grid-row: 1 / 2;
}

.build-img-block figure:nth-child(2) {
    grid-column: 1 / 2;
    grid-row: 2 / 3;
}
.build-img-block figure:nth-child(3) {
    grid-column: 2 / 3;
    grid-row: 1 / 3;
}
.build-img-block figure:nth-child(4) {
    grid-column: 3 / 4;
    grid-row: 1 / 2;
}
.build-img-block figure:nth-child(5) {
    grid-column: 3 / 4;
    grid-row: 2 / 3;
}

.build-img-block figcaption {
    position: absolute;
    width: 100%;
    bottom: 0;
    left: 0;
    background: rgba(0,0,0,0.8);
    padding: 10px 0;
    font-size: 12px;
    color: #fff;
    text-align: center;
}

.kyusyu-area-list {
    padding: 40px;
    background: #f7f7f7;
}


.kyushu_area .kyusyu-area-list h3 {
    width: auto;
    margin: 0 0 40px 0;
    text-align: center;
    font-size: 24px;
    padding: 10px;
    border-top: 1px solid #000;
    border-bottom: 1px solid #000;
}

.kyusyu-area-list ul.grid {
    display: grid;
    gap: 30px 0px;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    font-size: 14px;
}

sup {
    font-size: 8px;
}

.notes_Wrap {
    padding-top: 10px;
}

/*tab----------------------------------------------------------
-------------------------------------------------------------*/


@media only screen and (max-width: 1020px) {

.point-block.flex {
    flex-wrap: wrap;
}

.point-block .item-text,
.point-block .item-img {
    position: relative;
    width: 100%;
}

.point-block .item-text {
    margin-bottom: 20px;
}

.point-num::after {
    width: 15px;
    height: 500px;
    top: -16%;
}
.point02 .point-num::after {
    top: -14%;
}

.point-num::before {
    width: 155px;
    left: -115px;
    transform: translate(0, 15px);
}

.point-block .item-text h3::before {
    width: 120%;
}

.point09 .item-img .sub-img {
    bottom: -20%;
    left: -14%;
}

.point02 .item-img .sub-img {
    bottom: -4%;
    left: -3%;
}

.point04 .item-img .sub-img {
    bottom: -20%;
    left: -12%;
}

.point07 .item-text .sub-img {
    width: 10%;
    top: -10%;
    left: 73%;
}

.point07 .item-text .sub-img-txt {
    width: 30%;
    top: -26%;
    left: 73%;
}

.point08 .item-text .sub-img  {
    width: 20%;
    top: 3%;
    left: 75%;
}

.point08 .item-img .sub-img-txt {
    bottom: -22%;
    left: -15%;
}

.point10 .item-img .sub-img {
    top: -22%;
    right: -5%;
}

.kyushu_area h3 {
    width: 30%;
    min-width: 240px;
    margin: 0 auto 90px auto;
}


.kyusyu-area-list ul.grid {
    gap: 20px 0px;
    font-size: 12px;
    grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
}

}

@media only screen and (max-width: 780px) {


.point07 .item-text .sub-img {
    width: 10%;
    top: 10%;
    left: 73%;
}

.point07 .item-text .sub-img-txt {
    width: 30%;
    top: -2%;
    left: 73%;
}

.point02 .item-text .sub-img  {
    width: 20%;
    top: 20%;
    left: 75%;
}


}


/*sp----------------------------------------------------------
-------------------------------------------------------------*/


@media only screen and (max-width: 640px) {

.main {
    padding: 25% 0 15% 0;
}

.main_ttl {
    max-width: 350px;
    width: 80%;
}

.main_lead {
    max-width: 330px;
    width: 75%;
}

.point_wrap ul {
    width: 100%;
    margin-left: auto;
}

.point_area {
    padding: 60px 0;
}

.point-block {
    padding: 20px 20px 20px 20px;
}

.point-block:not(:last-child) {
    margin-bottom: 40px;
}

.point-block .point-num {
    justify-content: flex-end;
    margin-top: 5%;
    margin-right: 5%;
}

.point-num::before {
    width: 200px;
    top: -15px;
    left: -20px;
}

.point-num::after {
    width: 10px;
    height: 80px;
    background: url("../img/deco_arrow_sp.png") no-repeat center / contain;
    top: -1px;
    left: -15px;
}

.point02 .point-num::after {
    top: -1px;
}

.point-block .item-text h3::before {
    left: -20px;
    width: 120%;
}

.point-block .item-text h3 {
    font-size: 20px;
    line-height: 1.8rem;
}

.point-block .item-text p {
    font-size: 14px;
    line-height: 1.5rem;
    letter-spacing: 0.1em;
}

.point09 .item-img .sub-img {
    width: 65%;
    bottom: -24%;
    left: -17%;
}

.point02 .item-img .sub-img {
    width: 40%;
    bottom: -4%;
    left: -3%;
}

.u-smaller {
    font-size: 80%;
}

.point04 .item-img .sub-img {
    width: 65%;
    bottom: -24%;
    left: -14%;
}



.point07 .item-text .sub-img {
    width: 8%;
    top: 35%;
    left: 44%;
}

.point07 .item-text .sub-img-txt {
    width: 40%;
    top: 0%;
    left: 40%
}


.point08 .item-text .sub-img  {
    width: 25%;
    top: 18%;
    left: 45%;
}

.point10 .item-img .sub-img {
    width: 65%;
    top: -25%;
    right: -10%;
}

/*kyushu area
-------------------------------------------------------------------*/

.kyushu_area {
    padding: 50px 0 0 0;
}


.kyushu_area h3 {
    width: 40%;
    min-width: 200px;
    margin: 0 auto 40px auto;
}

.build-img-block {
    display: grid;
    grid-template-columns: 50% 50% ;
    grid-template-rows: auto .94fr .94fr;
    gap: 3px;
    margin-bottom: 40px;
}

.build-img-block figure {
    overflow: hidden;
}

.build-img-block figure:nth-child(1) {
    grid-column: 1 / 2;
    grid-row: 2 / 3;
}

.build-img-block figure:nth-child(2) {
    grid-column: 2 / 3;
    grid-row: 2 / 3;
}
.build-img-block figure:nth-child(3) {
    grid-column: 1 / 3;
    grid-row: 1 / 2;
}
.build-img-block figure:nth-child(4) {
    grid-column: 1 / 2;
    grid-row: 3 / 4;
}
.build-img-block figure:nth-child(5) {
    grid-column: 2 / 3;
    grid-row: 3 / 4;
}

.kyusyu-area-list {
    padding: 20px;
}

.kyushu_area .kyusyu-area-list h3 {
    font-size: 16px;
}

}

/*調整*/


@media only screen and (max-width: 440px) {

    .point07 .item-text .sub-img {
        width: 8%;
        top: 45%;
        left: 62%;
    }

    .point07 .item-text .sub-img-txt {
        width: 43%;
        top: 22%;
        left: 59%
    }

    .point08 .item-text .sub-img  {
        width: 28%;
        top: 35%;
        left: 55%;
    }

}

@media only screen and (max-width: 360px) {

    .point07 .item-text .sub-img {
        width: 10%;
        top: 42%;
        left: 65%;
    }

    .point07 .item-text .sub-img-txt {
        width: 43%;
        top: 30%;
        left: 63%
    }

    .point08 .item-text .sub-img  {
        width: 25%;
        top: 42%;
        left: 72%;
    }


}