@charset "UTF-8";
/* ******
KV
****** */
.p-about-kv {
    width: calc(1106 / 1280 * 100vw);
    height: calc(483 / 1280 * 100vw);
    position: relative;
    margin: 0 auto;
}
.p-about-kv__bg {
    width: 100%;
    height: 100%;
    position: absolute;
    top: 0;
    left: 0;
    background-image: url('../img/about/about-kv.webp');
    background-repeat: no-repeat;
    background-size: cover;
    background-position: center;
}
.p-about-kv__contents {
    position: absolute;
    bottom: calc(-146 / 1280 * 100vw);
    left: 50%;
    transform: translateX(-50%);
}
.p-about-kv__title-area {
    background-color: var(--color-primary);
    padding: calc(45 / 1280 * 100vw) calc(20 / 1280 * 100vw) calc(45 / 1280 * 100vw) calc(40 / 1280 * 100vw);
    width: calc(735 / 1280 * 100vw);
    display: flex;
    justify-content: center;
    align-items: center;
}
.p-about-kv__title {
    font-size: calc(30 / 1280 * 100vw);
    color: #fff;
    font-weight: 300;
    line-height: 1.6;
    letter-spacing: 0.05em;
}
.p-about-kv__title-text {
    font-weight: 700;
    color: #fff;
}
/* ******
about
****** */
.p-about__inner {
    width: calc(815 / 1280 * 100vw);
    margin: calc(234 / 1280 * 100vw) auto 0;
}
.p-about__item {
    display: flex;
    flex-direction: column;
    gap: calc(37 / 1280 * 100vw);
    margin-bottom: calc(49 / 1280 * 100vw);
}
.p-about__list {
    display: flex;
    gap: calc(18 / 1280 * 100vw);
}
.p-about__list-title-area {
    background-color: var(--color-primary);
    clip-path: polygon(
        0% 0%,
        calc(100% - 20px) 0%,
        100% 20px,
        100% 100%,
        20px 100%,
        0% calc(100% - 20px)
    );
    width: calc(170 / 1280 * 100vw);
    height: calc(56 / 1280 * 100vw);
}
.p-about__list-title {
    font-size: calc(18 / 1280 * 100vw);
    color: #fff;
    font-weight: 700;
    line-height: 1.6;
    letter-spacing: 0.05em;
    display: flex;
    justify-content: center;
    align-items: center;
    height: 100%;
}
.p-about__list-lead {
    font-size: calc(22 / 1280 * 100vw);
    color: var(--color-primary);
    line-height: 1.6;
    letter-spacing: 0.07em;
    display: flex;
    align-items: center;
    height: 100%;
    border-bottom: 2px solid var(--color-primary);
    font-weight: 700;
}
.p-about__list-text {
    font-size: calc(18 / 1280 * 100vw);
    line-height: 2;
    letter-spacing: 0.1em;
    margin-bottom: 20px;
}
.p-about__list-text02 {
    font-weight: 700;
    color: var(--color-primary);
}
.p-about__list-text03 {
    font-weight: 700;
}
.p-about__inner02 {
    width: 100%;
    padding: 0 calc(87 / 1280 * 100vw);
    position: relative;
}
.p-about__img-area {
    margin-top: calc(5 / 1280 * 100vw);
    display: flex;
    flex-wrap: wrap;
    gap: calc(13 / 1280 * 100vw);
}
.p-about__img-area img {
    /*width: calc(280 / 1280 * 100vw * 0.87);*/
    width: 32%;
    height: calc(209 / 1280 * 100vw );
    object-fit: cover;
}
.p-about__img-catch {
    position: absolute;
    bottom: calc(-97 / 1280 * 100vw);
    left: 50%;
    transform: translateX(-50%);
}
.p-about__img-catch-area {
    background-color: var(--color-primary);
    padding: calc(45 / 1280 * 100vw) calc(20 / 1280 * 100vw) calc(45 / 1280 * 100vw) calc(40 / 1280 * 100vw);
    width: calc(605 / 1280 * 100vw);
    display: flex;
    justify-content: center;
    align-items: center;
}
.p-about__img-catch-text {
    font-size: calc(30 / 1280 * 100vw);
    color: #fff;
    font-weight: 300;
    line-height: 1.6;
    letter-spacing: 0.05em;
}
.p-about__img-catch-text02 {
    font-weight: 700;
    color: #fff;
}
.p-about__inner03 {
    width: calc(829 / 1280 * 100vw);
    margin: calc(234 / 1280 * 100vw) auto 0;
}
.p-about__inner04 {
    width: calc(695 / 1280 * 100vw);
    margin: calc(24 / 1280 * 100vw) auto calc(174 / 1280 * 100vw);
}
.p-about__title-area04 {
    text-align: center;
}
.p-about__title04 {
    font-size: calc(18 / 1280 * 100vw);
    color: var(--color-primary);
    display: inline-block;
    border-bottom: 1px solid var(--color-primary);
    padding-bottom: calc(10 / 1280 * 100vw);
    letter-spacing: 0.1em;
    position: relative;
    margin-bottom: calc(34 / 1280 * 100vw);
    font-weight: 700;
}
.p-about__title04::after {
    content: '';
    position: absolute;
    top: calc(-10 / 1280 * 100vw);
    right: calc(-72 / 1280 * 100vw);
    width: calc(62 / 1280 * 100vw);
    height: calc(37 / 1280 * 100vw);
    background-image: url('../img/about/about-img07.webp');
    background-repeat: no-repeat;
    background-size: cover;
    background-position: center;
}
.p-about__lead-area04 {
    margin-bottom: calc(34 / 1280 * 100vw);
}
.p-about__lead04 {
    line-height: 1.6;
    letter-spacing: 0.07em;
}
.p-about__text-item {
    display: flex;
    flex-direction: column;
    gap: calc(18 / 1280 * 100vw);
}
.p-about__text {
    font-size: calc(18 / 1280 * 100vw);
    font-weight: 700;
    line-height: 1.6;
    letter-spacing: 0.1em;
    margin-bottom: calc(10 / 1280 * 100vw);
}
.p-about__text02 {
    font-size: calc(16 / 1280 * 100vw);
    line-height: 1.6;
    letter-spacing: 0.1em;
    padding-left: calc(10 / 1280 * 100vw);
}
@media screen and (max-width: 767px) {
    .p-about-kv__container {
        padding: 0 calc(40 / 390 * 100vw);
    }
    .p-about-kv {
        width: 100%;
        height: calc(271 / 390 * 100vw);
    }
    .p-about-kv__bg {
        background-image: url('../img/about/about-kv-sp.webp');
    }
    .p-about-kv__contents {
        bottom: calc(-242 / 390 * 100vw);
    }
    .p-about-kv__title-area {
        padding: calc(22 / 390 * 100vw);
        width: calc(312 / 390 * 100vw);
    }
    .p-about-kv__title {
        font-size: calc(24 / 390 * 100vw);
    }
    .p-about__inner {
        width: 100%;
        margin: calc(330 / 390 * 100vw) auto 0;
        padding: 0 calc(40 / 390 * 100vw);
    }
    .p-about__item {
        gap: calc(23 / 390 * 100vw);
        margin-bottom: calc(53 / 390 * 100vw);
    }
    .p-about__list {
        flex-direction: column;
        justify-content: center;
        gap: calc(15 / 390 * 100vw);
    }
    .p-about__list-title-area {
        width: calc(176 / 390 * 100vw);
        height: calc(56 / 390 * 100vw);
        margin: 0 auto;
    }
    .p-about__list-title {
        font-size: calc(18 / 390 * 100vw);
    }
    .p-about__list-lead {
        font-size: calc(22 / 390 * 100vw);
    }
    .p-about__list-text {
        font-size: calc(18 / 390 * 100vw);
        margin-bottom: 30px;
    }
    .p-about__inner02  {
        padding: 0 calc(40 / 390 * 100vw);
    }
    .p-about__img-area {
        margin-top: calc(5 / 390 * 100vw);
        gap: calc(4 / 390 * 100vw);
    }
    .p-about__img-area img {
        width: calc(100 / 390 * 100vw * 0.97);
        height: calc(148 / 390 * 100vw * 0.97);
    }
    .p-about__img-catch {
        bottom: calc(-243 / 390 * 100vw);
    }
    .p-about__img-catch-area {
        padding: calc(22 / 390 * 100vw);
        width: calc(312 / 390 * 100vw);
    }
    .p-about__img-catch-text {
        font-size: calc(24 / 390 * 100vw);
    }
    .p-about__inner03 {
        width: 100%;
        margin: calc(323 / 390 * 100vw) auto 0;
        padding: 0 calc(40 / 390 * 100vw);
    }
    .p-about__list-text03 {
        padding-left: 1em;
        text-indent: -1em;
        display: block;
    }
    .p-about__inner04 {
        width: 100%;
        margin: calc(24 / 390 * 100vw) auto calc(84 / 390 * 100vw);
        padding: 0 calc(40 / 390 * 100vw);
    }
    .p-about__title04 {
        font-size: calc(18 / 390 * 100vw);
        margin-bottom: calc(24 / 390 * 100vw);
        padding-bottom: calc(10 / 390 * 100vw);
    }
    .p-about__title04::after {
        top: calc(-10 / 390 * 100vw);
        right: calc(-72 / 390 * 100vw);
        width: calc(62 / 390 * 100vw);
        height: calc(37 / 390 * 100vw);
    }
    .p-about__lead-area04 {
        margin-bottom: calc(34 / 1280 * 100vw);
    }
    .p-about__text-item {
        gap: calc(18 / 390 * 100vw);
    }
    .p-about__text {
        font-size: calc(18 / 390 * 100vw);
        margin-bottom: calc(10 / 390 * 100vw);
        padding-left: 1em;
        text-indent: -1em;
        display: block;
    }
    .p-about__text02 {
        font-size: calc(16 / 390 * 100vw);
        padding-left: calc(10 / 390 * 100vw);
    }
}
@media screen and (min-width: 1281px)  {
    .p-about-kv {
        width: 1106px;
        height: 483px;
    }
    .p-about-kv__contents {
        bottom: -146px;
    }
    .p-about-kv__title-area {
        padding: 45px 20px 45px 40px;
        width: 735px;
    }
    .p-about-kv__title {
        font-size: 30px;
    }
    .p-about__inner {
        width: 815px;
        margin: 234px auto 0;
    }
    .p-about__item {
        gap: 37px;
        margin-bottom: 49px;
    }
    .p-about__list {
        gap: 18px;
    }
    .p-about__list-title-area {
        clip-path: polygon(
            0% 0%,
            calc(100% - 20px) 0%,
            100% 20px,
            100% 100%,
            20px 100%,
            0% calc(100% - 20px)
        );
        width: 170px;
        height: 56px;
    }
    .p-about__list-title {
        font-size: 18px;
    }
    .p-about__list-lead {
        font-size: 22px;
    }
    .p-about__list-text {
        font-size: 18px;
        margin-bottom: 20px;
    }
    .p-about__inner02 {
        /*width: 1106px;*/
        width: calc(1000 / 1280 * 100vw);
        margin: auto;
    }
    .p-about__img-area {
        margin-top: 5px;
        gap: 13px;
    }
    .p-about__img-catch {
        bottom: -97px;
    }
    .p-about__img-catch-area {
        padding: 45px 20px 45px 40px;
        width: 605px;
    }
    .p-about__img-catch-text {
        font-size: 30px;
    }
    .p-about__inner03 {
        width: 829px;
        margin: 234px auto 0;
    }
    .p-about__inner04 {
        width: 695px;
        margin: 24px auto 174px;
    }
    .p-about__title04 {
        font-size: 18px;
        padding-bottom: 10px;
        margin-bottom: 34px;
    }
    .p-about__title04::after {
        top: -10px;
        right: -72px;
        width: 62px;
        height: 37px;
    }
    .p-about__lead-area04 {
        margin-bottom: 34px;
    }
    .p-about__text-item {
        gap: 18px;
    }
    .p-about__text {
        font-size: 18px;
        margin-bottom: 10px;
    }
    .p-about__text02 {
        font-size: 16px;
        padding-left: 10px;
    }
}