@charset "UTF-8";

#top {
    width: 100%;
    height: auto;
    background-image: url("/images/bg.jpg");
    background-repeat: repeat;
    background-size: cover;
}

/* 共通項目 */
/* br */
br.pc-only {
    display: none;
}
br.sp-only {
    display: block;
}


/* section-title */
.section-title {
    text-align: center;
}
.section-title h2 {
    font-family: 'Noto Serif JP', serif;
    font-size: 30px;
    font-size: clamp(30px, 1.693rem + 0.91vw, 38px);
    line-height: 1.3em;
    text-align: center;
}
.section-title small {
    font-family: "work-sans", sans-serif;
    font-weight: 400;
    font-style: normal;
    font-size: 16px;
    font-size: clamp(16px, 0.856rem + 0.62vw, 20px);
    line-height: 1em;
    text-align: center;
}
.section-title hr {
    width: 1px;
    height: 50px;
    margin-top: 16px;
    border: none;
}
/* article */
.article {
    padding-bottom: 23px;
    border-radius: 8px;
    color: #2c2c2c;
    background-color: #ffffff;
    text-decoration: none;
    overflow: hidden;
    text-align: left;
}
.article > div {
    width: 100%;
    height: auto;
    margin-bottom: 16px;
    overflow: hidden;
}
.article img {
    width: 100%;
    height: auto;
    aspect-ratio: 1.52 / 1;
    object-fit: cover;
    object-position: 50% 50%;
}
.article p {
    margin: auto auto 4px 3.2vw;
    font-family: "noto-sans-cjk-jp", sans-serif;
    font-weight: 500;
    font-style: normal;
    font-size: 10px;
    font-size: clamp(10px, 0.481rem + 0.62vw, 14px);
    line-height: 1.5em;
}
.article h3 {
    margin-left: 3.2vw;
    font-family: 'Noto Serif JP', serif;
    font-size: 14px;
    font-size: clamp(14px, 0.586rem + 1.23vw, 22px);
    line-height: 1em;
    letter-spacing: 0.1em;
}

.add-title{
    font-size: 24px;
    font-family: 'Noto Serif JP', serif;
    font-size: 30px;
    font-size: clamp(30px, 1.693rem + 0.91vw, 38px);
    line-height: 1.3em;
    text-align: center;
    padding-top: 20px;;
}

/* parking-btn */
.parking-btn {
    display: block;
    padding: 2.29vw 1.14vw;
    position: fixed;
    bottom: 30px;
    right: 0;
    font-family: 'Noto Serif JP', serif;
    font-size: 24px;
    font-size: clamp(16px, 0.427rem + 0.89vw, 24px);
    line-height: 1.2em;
    writing-mode: vertical-rl;
    color: #ffffff;
    background-color: #29233e;
    border-radius: 5px 0 0 5px;
    text-decoration: none;
    z-index: 999;
}

/* kv */
#top .kv video {
    width: 100%;
    height: auto;
}

/* description */
#top .description {
    background-image: url("/images/top-bg-kamon1.png"),
        url("/images/top-bg-kamon2.png");
    background-size: 30.9vw;
    background-position: 110% 8%, -8% calc(100% + 30px);
    background-repeat: no-repeat;
}

#top .add-title{
    text-align: left;
    margin: auto;
    width: 87.2vw;
    padding-top: 30px;
}

#top .description p {
    width: 87.2vw;
    margin: auto;
    padding: 10px 0 115px;
    font-family: 'Noto Serif JP', serif;
    font-size: 14px;
    font-size: clamp(14px, 0.658rem + 0.92vw, 20px);
    line-height: 2.28em;
    letter-spacing: 0.02em;
    text-align: left;
    color: #000000;
}

/* information */
.information {
    padding: 76px 0 81px;
    background-image: url("../images/top-info-bg--sp.png");
    background-repeat: no-repeat;
    background-size: cover;
    text-align: center;
}

.information__title {
    margin-bottom: 20px;
}
.information__title h2 {
    color: #bcac8b;
}

.information__title small {
    color: #ffffff;
}

.information__title hr {
    background-color: #ffffff;
}

.information__articles {
    width: 87.2vw;
    height: auto;
    margin: auto auto 85px;
    display: grid;
    grid-template-columns: 1fr;
    gap: 20px;
}

.information .more-btn {
    font-family: 'Noto Serif JP', serif;
    font-size: 16px;
    font-size: clamp(16px, 0.856rem + 0.62vw, 20px);
    letter-spacing: 0.1em;
    color: #ffffff;
    text-decoration: none;
}

/* about */
#top .about {
    padding: 100px 0;
    background-image: url("/images/top-bg-kamon3.png"),
        url("/images/top-bg-kamon4.png");
    background-size: 30.9vw;
    background-position: 108% 1%, -6% calc(100% + 40px);
    background-repeat: no-repeat;
}

.about__title {
    margin-bottom: 20px;
}
.about__title h2 {
    color: #5a5179;
}
.about__title small {
    color: #000000;
}
#top .about__title hr {
    background-color: #796b4c;
}

#top .about__content {
    width: 87.2vw;
    height: auto;
    margin: auto;
}

#top .about__content .img-wrapper {
    width: 100%;
    height: auto;
    margin: auto auto 64px;
}

#top .about__img1 {
    width: 58.13vw;
    height: auto;
    margin: auto auto 4vw;
}

#top .about__content .img-wrapper > div {
    display: flex;
    align-items: flex-start;
}
#top .about__content .img-wrapper > div > div {
    width: 100%;
    margin: auto 4vw auto auto;
}

#top .about__img2 {
    width: 100%;
    height: auto;
    margin: auto 0 4vw auto;
}

#top .about__img3 {
    width: 100%;
    height: auto;
}

#top .about__img4 {
    width: 34.66vw;
    height: auto;
}

#top .about__content .text-wrapper {
    text-align: left;
}

#top .about__content .text-wrapper p {
    font-family: 'Noto Serif JP', serif;
    font-size: 14px;
    font-size: clamp(14px, 0.658rem + 0.92vw, 20px);
    letter-spacing: 0.01em;
    line-height: 2.28em;
    text-align: left;
    color: #000000;
    margin-bottom: 30px;
}

#top .about__content .detail-btn {
    width: 33.06vw;
    height: auto;
    display: block;
    font-family: 'Noto Serif JP', serif;
    font-size: 14px;
    font-size: clamp(12px, 0.461rem + 1.23vw, 20px);
    line-height: 37px;
    letter-spacing: 0.1em;
    text-align: center;
    background-color: #000000;
    color: #ffffff;
    border: 1px solid #000000;
    text-decoration: none;
}

/* about-karatsu */
.about-karatsu {
    padding: 80px 0;
    background-image: url("../images/top-aboutkaratsu-bg--sp.png");
    background-repeat: no-repeat;
    background-size: cover;
    text-align: center;
}

.about-karatsu__content {
    width: 87.2vw;
    height: auto;
    margin: auto;
}

.about-karatsu__title {
    margin: auto auto 20px;
    font-family: 'Noto Serif JP', serif;
    font-size: 25px;
    font-size: clamp(30px, 1.693rem + 0.91vw, 38px);
    line-height: 1.3em;
    color: #bcac8b;
    text-align:  center;
}

.about-karatsu__articles {
    margin: auto auto 80px;
    display: grid;
    grid-template-columns: 1fr;
    gap: 20px;
}

.about-karatsu__content .more-btn {
    font-family: 'Noto Serif JP', serif;
    font-size: clamp(16px, 0.856rem + 0.62vw, 20px);
    letter-spacing: 0.1em;
    color: #ffffff;
    text-decoration: none;
}

/* explore */
.explore {
    padding: 100px 0 78px;
    background-image: url("/images/top-bg-kamon5.png"),
        url("/images/top-bg-kamon6.png");
    background-size: 30.9vw;
    background-position: 103% -3%, -5% calc(100% + 40px);
    background-repeat: no-repeat;
}
.explore__title {
    margin-bottom: 20px;
}
.explore__title h2 {
    color: #5a5179;
}
.explore__title small {
    color: #000000;
}
.explore__title hr {
    background-color: #796b4c;
}
.explore__links {
    width: 100%;
    height: auto;
    margin: auto;
}
.explore__link {
    position: relative;
    display: block;
}
.explore__link > div {
    width: calc(100% - 20px);
    height: calc(100% - 20px);
    position: absolute;
    top: 10px;
    left: 10px;
    border: 1px solid #ffffff;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
}
.explore__link h4 {
    /* margin-bottom: 20px; */
    font-family: "work-sans", sans-serif;
    font-weight: 400;
    font-style: normal;
    font-size: 30px;
    font-size: clamp(30px, 1.442rem + 1.85vw, 42px);
    line-height: 1.2em;
    color: #ffffff;
}
.explore__link p {
    font-family: "noto-sans-cjk-jp", sans-serif;
    font-weight: 500;
    font-style: normal;
    font-size: 14px;
    font-size: clamp(14px, 0.731rem + 0.62vw, 18px);
    color: #ffffff;
}

/* instagram */
.instagram {
    padding: 80px 0;
    background-image: url("../images/top-instagram-bg--sp.png");
    background-repeat: no-repeat;
    background-size: cover;
    text-align: center;
}
.instagram__title {
    margin-bottom: 20px;
}
.instagram__title h2 {
    font-family: "work-sans", sans-serif;
    font-weight: 400;
    font-style: normal;
    color: #bcac8b;
}
.instagram__title small {
    font-family: 'Noto Serif JP', serif;
    color: #ffffff;
}
.instagram__title hr {
    background-color: #ffffff;
}
.instagram__content {
    width: 87.2vw;
    height: auto;
    margin: auto auto 80px;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 4vw;
}
.ads {
    width: 87.2vw;
    height: auto;
    margin: auto;
    display: grid;
    grid-template-columns: 1fr;
    row-gap: 10px;
}

/**********************************************************
* min-width: 600px
/**********************************************************/
@media screen and (min-width: 600px) {

}

/**********************************************************
* min-width: 1025px
/**********************************************************/
@media screen and (min-width: 1025px) {

    #top {
    }

    /* 共通項目 */
    /* br */
    br.pc-only {
        display: block;
    }
    br.sp-only {
        display: none;
    }


    /* section-title */
    .section-title {
    }

    .section-title h2 {
        font-size: 50px;
        font-size: clamp(40px, 1.784rem + 1.12vw, 50px);
        line-height: 1.3em;
    }

    .section-title small {
        font-size: 20px;
        font-size: clamp(18px, 0.982rem + 0.22vw, 20px);
        line-height: 1em;
    }

    .section-title hr {
    }

    /* article */
    .article {
        padding-bottom: 33px;
    }
    .article:hover img {
        transform: scale(1.1);
        filter: brightness(0.7);
    }
    .article > div {
        margin-bottom: 27px;
    }
    .article img {
        aspect-ratio: 1.53 / 1;
        object-position: 50% 50%;
        transition: transform 0.3s, filter 0.3s;
    }
    .article p {
        margin: auto auto 4px 20px;
        font-size: 17px;
        font-size: clamp(14px, 0.66rem + 0.34vw, 17px);
        line-height: 1.47em;
    }
    .article h3 {
        margin-left: 20px;
        font-size: 24px;
        font-size: clamp(20px, 0.964rem + 0.45vw, 24px);
    }

    /* parking-btn */
    .parking-btn {
        display: block;
        padding: 2.29vw 1.14vw;
        position: fixed;
        bottom: 30px;
        right: 0;
        font-family: 'Noto Serif JP', serif;
        font-size: 24px;
        font-size: clamp(16px, 0.427rem + 0.89vw, 24px);
        line-height: 1.2em;
        writing-mode: vertical-rl;
        color: #ffffff;
        background-color: #29233e;
        border-radius: 5px 0 0 5px;
        text-decoration: none;
    }

    /* kv */
    #top .kv video {
    }

    /* description */
    #top .description {
        background-size: 14.58vw;
        background-position: 105% 35%, -5% calc(100% + 70px);
    }

    #top .add-title{
        text-align: center;
        padding-top: 80px;
    }

    #top .description p {
        padding: 50px 0 205px;
        font-size: 24px;
        font-size: clamp(16px, 0.427rem + 0.89vw, 24px);
        letter-spacing: 0.1em;
        line-height: 3.54em;
        text-align: center;
    }

    /* information */
    .information {
        padding: 80px 0;
        background-image: url("../images/top-info-bg.png");
        background-repeat: no-repeat;
        background-size: cover;
        text-align: center;
    }
    .information__title {
        margin-bottom: 59px;
    }
    .information__title h2 {
    }
    .information__title small {
    }
    #top .information__title hr {
    }

    #top .information__articles {
        width: 82.08vw;
        margin: auto auto 90px;
        grid-template-columns: 1fr 1fr 1fr;
        gap: 2.29vw;
    }
    #top .information .more-btn {
        font-size: 24px;
        font-size: clamp(16px, 0.427rem + 0.89vw, 24px);
        position: relative;
    }
    #top .information .more-btn::after {
        position: absolute;
        bottom: -10px;
        left: 50%;
        content: "";
        width: 0;
        height: 1px;
        background-color: #ffffff;
        transition: 0.3s;
        transform: translateX(-50%);
    }
    #top .information .more-btn:hover::after {
        width: 100%;
    }

    /* about */
    #top .about {
        padding: 160px 0;
        background-size: 14.58vw;
        background-position: 103% 20%, -5% calc(100% + 70px);
    }

    .about__title {
        margin-bottom: 59px;
    }
    .about__title h2 {
    }
    .about__title small {
    }
    #top .about__title hr {
    }

    #top .about__content {
        width: 100%;
        margin: auto;
        display: grid;
        grid-template-columns: 1fr 1fr;
    }

    #top .about__content .img-wrapper {
        width: 100%;
        margin: 0 auto;
        padding: 0 3.9vw 0 6.66vw;
    }

    #top .about__img1 {
        width: 28.17vw;
        margin: auto auto 36px;
    }

    #top .about__content .img-wrapper > div {
    }

    #top .about__content .img-wrapper > div > div {
        margin: 0 2.08vw auto auto;
    }

    #top .about__img2 {
        margin: auto 0 36px auto;
    }

    #top .about__img3 {
    }

    #top .about__img4 {
        width: 16.82vw;
    }

    #top .about__content .text-wrapper {
        width: 100%;
        padding-right: 5.26vw;
    }

    #top .about__content .text-wrapper p {
        margin: -1em auto 57px 0;
        font-size: 24px;
        font-size: clamp(14px, 0.159rem + 1.12vw, 24px);
        letter-spacing: 0.1em;
        line-height: 3.54em;
    }

    #top .about__content .detail-btn {
        width: 200px;
        height: auto;
        display: block;
        font-size: 24px;
        font-size: clamp(18px, 0.696rem + 0.67vw, 24px);
        line-height: 50px;
        letter-spacing: 0.1em;
        transition: 0.3s;
    }
    #top .about__content .detail-btn:hover {
        background-color: #ffffff;
        color: #000000;
        border: 1px solid #000000;
    }

    /* about-karatsu */
    .about-karatsu {
        background-image: url("../images/top-aboutkaratsu-bg.png");
        background-repeat: no-repeat;
        background-size: cover;
        text-align: center;
    }

    .about-karatsu__content {
        width: 82.08vw;
    }

    .about-karatsu__title {
        margin: auto auto 40px;
        font-size: 50px;
        font-size: clamp(40px, 1.784rem + 1.12vw, 50px);
        line-height: 1.3em;
        display: grid;
        grid-template-columns: auto 1fr;
        align-items: center;
        gap: 2.18vw;
    }

    .about-karatsu__title::after {
        content: "";
        width: 100%;
        height: 1px;
        background-color: #ffffff;
    }

    .about-karatsu__articles {
        margin: auto auto 90px;
        grid-template-columns: 1fr 1fr 1fr;
        gap: 2.29vw;
    }

    .about-karatsu__content .more-btn {
        font-size: 24px;
        font-size: clamp(16px, 0.427rem + 0.89vw, 24px);
        letter-spacing: 0.1em;
        position: relative;
    }
    .about-karatsu__content .more-btn::after {
        position: absolute;
        bottom: -10px;
        left: 50%;
        content: "";
        width: 0;
        height: 1px;
        background-color: #ffffff;
        transition: 0.3s;
        transform: translateX(-50%);
    }
    .about-karatsu__content .more-btn:hover::after {
        width: 100%;
    }

    /* explore */
    .explore {
        padding: 160px 0;
        background-size: 14.58vw;
        background-position: 103% -3%, -5% calc(100% + 30px);
    }

    .explore__title {
        margin-bottom: 18px;
    }

    .explore__title h2 {
    }
    .explore__title small {
    }
    .explore__title hr {
    }

    .explore__links {
        width: 82.08vw;
        display: grid;
        grid-template-columns: 1fr 1fr;
    }
    .explore__link {
        position: relative;
        overflow: hidden;
    }
    .explore__link:hover > img {
        transform: scale(1.1);
        filter: brightness(0.7);
    }
    .explore__link > img {
        transition: transform 0.3s, filter 0.3s;
    }
    .explore__link > div {
        width: calc(100% - 30px);
        height: calc(100% - 30px);
        top: 15px;
        left: 15px;
    }
    .explore__link h4 {
        margin-bottom: 20px;
        font-size: 50px;
        font-size: clamp(38px, 1.516rem + 1.34vw, 50px);
        line-height: 1em;
    }
    .explore__link p {
        font-size: 20px;
        font-size: clamp(16px, 0.714rem + 0.45vw, 20px);
        line-height: 1em;
    }
    .explore__link:nth-child(5) h4,
    .explore__link:nth-child(6) h4 {
        margin-bottom: 1px;
    }

    /* instagram */
    .instagram {
        padding: 100px 0 160px;
        background-image: url("../images/top-instagram-bg.png");
        background-repeat: no-repeat;
        background-size: cover;
        text-align: center;
    }
    .instagram__title {
    }
    .instagram__title h2 {
    }
    .instagram__title small {
    }
    .instagram__title hr {
    }
    .instagram__content {
        width: 82.08vw;
        margin: auto auto 142px;
        grid-template-columns: 1fr 1fr 1fr 1fr;
        column-gap: 30px;
        row-gap: 1.45em;
    }
    .instagram__content a {
        overflow: hidden;
    }
    .instagram__content a:hover img {
        transform: scale(1.1);
        filter: brightness(0.7);
    }
    .instagram__content a img {
        transition: transform 0.3s, filter 0.3s;
    }
    .ads {
        width: 82.08vw;
        grid-template-columns: 1fr 1fr 1fr;
        column-gap: 1.04em;
        row-gap: 25px;
    }
}
