/* page-head */
.page-head {
    margin: 0 0 35px;
    text-align: center;
}

.page-head h2 {
    font-size: 38px;
    font-weight: 700;
}

.page-head p {
    color: #00A6DC;
    font-size: 14px;
    font-weight: 700;
    margin-top: 10px;
    letter-spacing: 4px;
}

@media screen and (max-width: 968px) {}

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

    .page-head h2 {
        font-size: 24px;
    }

}

/* companycont */
.companycont {
    padding: 0 0 130px;
}

.companycont-inner {
    margin: 0 auto;
    width: 92%;
    max-width: 920px;
}

.companycont-cards {
    display: flex;
    flex-direction: column;
    gap: 100px;
}

.companycont-card {
    background: #fff;
    border-radius: 20px;
    filter: drop-shadow(0 4px 4px rgb(242 245 249 / 100%));
    overflow: hidden;
}

.companycont-card__head {
    background: linear-gradient(51deg, rgba(96, 200, 255, 1) 41%, rgba(28, 115, 211, 1) 100%);
    padding: 20px 0;
    text-align: center;
}

.companycont-card__head h3 {
    color: #fff;
    font-size: 16px;
    font-weight: 700;
}

.companycont-card__head p {
    color: #fff;
    font-family: var(--ft-inter);
    font-size: 50px;
    font-weight: 500;
    letter-spacing: 2px;
}

.companycont-card__head p span {
    color: #fff;
    font-family: var(--ft-inter);
    font-size: 65px;
    font-weight: 500;
}

.companycont-card__body {
    padding: 50px 75px;
    text-align: center;
}

.companycont-card__body h4 {
    color: #525766;
    font-size: 28px;
    font-weight: 700;
    margin: 0 0 15px;
}

.companycont-card__body p {
    color: #525766;
    font-size: 16px;
    font-weight: 400;
    line-height: 36px;
}

.companycont-list {
    display: flex;
    justify-content: space-between;
    align-items: stretch;
    flex-wrap: wrap;
    gap: 20px;
    row-gap: 65px;
    margin: 65px 0 0;
}

.companycont-list__item {
    background: #F2F5F9;
    border-radius: 10px;
    filter: drop-shadow(0 4px 8.5px rgb(0 166 220 / 20%));
    padding: 50px 25px 30px;
    position: relative;
    width: calc((100% / 3) - calc(40px / 3));
}

.companycont-list__image {
    margin: auto;
    position: absolute;
    left: 0;
    right: 0;
    top: -25px;
    width: 74px;
}

.companycont-list__text .ttl {
    color: #00A6DC;
    font-size: 20px;
    font-weight: 700;
    margin: 0 0 10px;
}

.companycont-list__text .txt {
    font-size: 16px;
    font-weight: 400;
    line-height: 1.8em;
}

@media screen and (max-width: 968px) {
    .companycont {
        padding: 0 0 60px;
    }

    .companycont {
        padding: 0 0 60px;
    }

    .companycont-cards {
        gap: 60px;
    }

    .companycont-list {
        gap: 20px;
        row-gap: 45px;
    }

    .companycont-list__item {
        padding: 60px 35px 35px;
        width: 100%;
    }

    .companycont-card__body {
        padding: 30px 34px 60px;
    }

    .companycont-list__text .ttl {
        margin: 0 0 15px;
    }

    .companycont-card__body p {
        font-size: 18px;
        line-height: 32px;
    }
}

@media screen and (max-width: 768px) {
    .companycont-card__body p {
        font-size: 14.5px;
        line-height: 26px;
    }

    .companycont-card__body h4 {
        font-size: 18px;
    }

    .companycont-list__text .txt {
        font-size: 14.5px;
    }
}

/* blockname */
.message {
    background: #fff;
    padding: 0 0 111px;
    position: relative;
    z-index: 1;
}

.message-head {
    background: linear-gradient(51deg, rgba(96, 200, 255, 1) 41%, rgba(28, 115, 211, 1) 100%);
    padding: 100px 0 100px;
}

.message-head h2,
.message-head p {
    color: #fff;
}

.message-body {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    flex-wrap: wrap;
    margin: calc((36px + 98px) * -1) auto 0;
    width: 92%;
    max-width: 770px;
}

.message-image {
    background: url(../images/blur.png) no-repeat;
    background-position: center bottom;
    background-size: 90%;
    line-height: 0;
    padding: 0;
    width: 484px;
}

.message-text {
    display: flex;
    flex-direction: column;
    gap: 20px;
    padding: 140px 0 0;
    width: 100%;
}

.message-text p {
    font-size: 16px;
    font-weight: 400;
    line-height: 28px;
}

.message-text .r {
    text-align: right;
}

@media screen and (max-width: 968px) {
    .message {
        padding: 0 0 60px;
    }

    .message-head {
        padding: 60px 0 60px;
    }

    .message-image {
        padding: 0 0 5%;
        width: 100%;
    }

    .message-text {
        width: 100%;
        padding-top: 8rem;
    }
}

@media screen and (max-width: 768px) {
    .message-text p {
        font-size: 14.5px;
    }
}

/* history */
.history {
    background: #F7F8FA;
    padding: 90px 0 100px;
    position: relative;
    z-index: 1;
}

.history-inner {
    margin: 0 auto;
    width: 92%;
    max-width: 920px;
}

.history-head {
    text-align: left;
}

.history-list {
    display: flex;
    flex-direction: column;
    gap: 25px;
}

.history-line {
    display: flex;
    justify-content: space-between;
    align-items: center;
    position: relative;
}

.history-line::before {
    border-top: 1px dashed #C7CEE0;
    content: "";
    display: block;
    height: 1px;
    width: 115px;
}

.history-line::after {
    background: #00A6DC;
    border-radius: 50%;
    content: "";
    display: block;
    height: 16px;
    margin: auto;
    position: absolute;
    left: 0;
    top: 0;
    bottom: 0;
    width: 16px;
}

.history-list__item {
    background: #F2F5F9;
    display: flex;
    justify-content: flex-start;
    align-items: stretch;
    margin: 0 0 0 auto;
    padding: 20px 15px;
    position: relative;
    width: calc(100% - 115px);
}

.history-list__item::before {
    border-left: 1px solid #C7CEE0;
    content: "";
    height: calc(100% + 25px);
    position: absolute;
    left: -108px;
    top: 0;
    width: 1px;
}

.history-line:first-child .history-list__item::before {
    height: 100%;
    top: 50%;
}

.history-line:last-child .history-list__item::before {
    bottom: 50%;
    top: inherit;
}

.history-list__item dt {
    color: #00A6DC;
    font-size: 18px;
    font-weight: 700;
    line-height: 1.8em;
    padding-right: 20px;
    text-align: right;
    width: 100px;
}

.history-list__item dd {
    width: calc(100% - 120px);
}

.history-list__item dd p {
    color: #525766;
    font-size: 16px;
    font-weight: 400;
    line-height: 1.8em;
}

.history-list__item dd p strong {
    color: #525766;
    font-size: 18px;
    font-weight: 700;
}

@media screen and (max-width: 968px) {
    .history {
        padding: 50px 0 60px;
    }

    .history-list__item dd p {
        font-size: 14.5px;
    }

    .history-list__item dd p strong {
        font-size: 14.5px;
    }
}

@media screen and (max-width: 768px) {
    .history-list {
        gap: 20px;
    }

    .history-line::before {
        display: none;
    }

    .history-line::after {
        height: 16px;
        top: 30px;
        bottom: inherit;
        left: -2px;
        width: 16px;
    }

    .history-list__item {
        flex-direction: column;
        padding: 20px;
        width: calc(100% - 27px);
    }

    .history-list__item dt {
        padding: 0;
        text-align: left;
    }

    .history-list__item dd {
        width: 100%;
    }

    .history-list__item::before {
        left: -22px;
    }

    .history-line:first-child .history-list__item::before {
        height: 100%;
        top: 18%;
    }

    .history-line:last-child .history-list__item::before {
        bottom: inherit;
        top: 0;
        height: 22%;
    }
}

/* awards */
.awards {
    background: url(../images/awards-bg.png) no-repeat;
    background-position: center bottom;
    background-size: contain;
    background-color: #fff;
    padding: 95px 0 80px;
    position: relative;
    z-index: 1;
}

.awards-inner {
    margin: 0 auto;
    width: 92%;
    max-width: 920px;
}

.awards-cards {
    display: flex;
    flex-direction: column;
    gap: 45px;
}

.awards-card {
    background: #fff;
    border-radius: 20px;
    box-shadow: 0 4px 20px rgb(0 166 220 / 14%);
    overflow: hidden;
}

.awards-card__head {
    background: #F2F5F9;
    padding: 15px 0;
    text-align: center;
}

.awards-card__head h3 {
    font-size: 26px;
    font-weight: 700;
}

.awards-card__body {
    display: flex;
    flex-direction: column;
    gap: 35px;
    padding: 60px 0;
}

.awards-items {
    display: grid;
    grid-template-columns: repeat(5, 1fr);
    gap: 20px;
    margin: 0 auto;
    width: 95%;
    max-width: 940px;
}

.awards-items.big {
    grid-template-columns: repeat(4, 1fr);
}

.awards-item__logo {
    margin: 10px auto 0;
}

.awards-item__logo[data-shop="コンタクトレンズのレンズワン"] {
    width: 100%;
    max-width: 128px;
}

.awards-item__logo[data-shop="コンタクトクリーン館"] {
    width: 100%;
    max-width: 185px;
}

.awards-item__logo[data-shop="LensUno"] {
    width: 100%;
    max-width: 119px;
}

@media screen and (max-width: 968px) {
    .awards {
        background-size: 520%;
        padding: 50px 0 60px;
    }

    .awards-items {
        display: grid;
        grid-template-columns: repeat(4, 1fr);
        gap: 20px;
        margin: 0 auto;
        width: 95%;
        max-width: 980px;
    }

    .awards-items.big {
        grid-template-columns: repeat(3, 1fr);
    }

    .awards-cards {
        gap: 40px;
    }
}

@media screen and (max-width: 768px) {
    .awards-items {
        grid-template-columns: repeat(2, 1fr);
    }

    .awards-card:nth-child(2) .awards-items,
    .awards-card:nth-child(3) .awards-items {
        grid-template-columns: 1fr;
        margin: 0 auto;
        width: 55%;
    }

    .awards-items.big {
        grid-template-columns: 1fr;
    }

    .awards-items.big .awards-item {
        margin: 0 auto;
        width: 70%;
    }

    .awards-card__head h3 {
        font-size: 20px;
    }
}

/* profile */
.profile {
    background: #F7F8FA;
    padding: 110px 0 117px;
    position: relative;
    z-index: 1;
}

.profile-inner {
    margin: 0 auto;
    width: 92%;
    max-width: 920px;
}

.profile-list__item {
    border-bottom: 1px solid #C7CEE0;
    display: flex;
    justify-content: space-between;
    align-items: center;
    flex-wrap: wrap;
    margin: 0 0 30px;
    padding: 0 0 30px;
}

.profile-list__item dt {
    font-size: 16px;
    font-weight: 700;
    line-height: 1.8em;
    width: 200px;
}

.profile-list__item dd {
    color: #525766;
    font-size: 16px;
    font-weight: 400;
    line-height: 1.8em;
    width: calc(100% - 200px);

}

@media screen and (max-width: 968px) {
    .profile {
        background: #F7F8FA;
        padding: 50px 0 40px;
        position: relative;
        z-index: 1;
    }

    .profile-list__item dt {
        width: 120px;
    }

    .profile-list__item dd {
        width: calc(100% - 120px);
    }
}

@media screen and (max-width: 768px) {
    .profile-list__item dd {
        width: 100%;
        font-size: 14.5px;
    }
}

/* access */
.access {
    background: #fff;
    padding: 90px 0 200px;
    position: relative;
    z-index: 3;
}

.access-inner {
    margin: 0 auto;
    width: 92%;
    max-width: 920px;
}

.access-map {
    line-height: 0;
    margin: 0 0 15px;
}

.access-map iframe {
    aspect-ratio: 16 / 9;
    height: 100%;
    width: 100%;
}

.access-body p {
    color: #525766;
    font-size: 18px;
    font-weight: 400;
}

@media screen and (max-width: 968px) {
    .access {
        padding: 50px 0 100px;
    }
}

@media screen and (max-width: 768px) {
    .access-map {
        border-radius: 20px;
        margin: 0 0 10px;
        overflow: hidden;
    }

    .access-body p {
        font-size: 14.5px;
    }
}

/* service */
.servicetop,
.servicebottom {
    position: relative;
    z-index: 3;
}

.servicetop {
    padding: 0 0 100px;
}

.servicebottom {
    background: #F2F5F9;
    padding: 100px 0 240px;
}

.servicetop-inner,
.servicebottom-inner {
    margin: 0 auto;
    width: calc(100% - 48px);
    max-width: 920px;
}

.servicetop-head {
    margin: 0 0 50px;
    text-align: center;
}

.servicetop-head p {
    color: #525766;
    font-size: 20px;
    font-weight: 500;
}

.service-cards {
    flex-direction: column;
    width: 100%;
}

.service-card {
    background: none;
    box-shadow: none;
    border-radius: 0;
    display: flex;
    justify-content: space-between;
    align-items: center;
    flex-wrap: wrap;
    overflow: visible;
    width: 100%;
}

.servicebottom .service-card {
    flex-direction: row-reverse;
}

.service-card__text {
    background: #fff;
    border-radius: 50px;
    filter: drop-shadow(0 4px 4px rgb(0 0 0 / 15%));
    padding: 35px 50px 35px;
    width: 53%;
}

.service-card__image {
    border-radius: 60px;
    line-height: 0;
    margin-left: -20%;
    overflow: hidden;
    width: 64%;
}

.servicebottom .service-card__image {
    margin-right: -20%;
    margin-left: 0;
}

.service-card__text h2 {
    display: flex;
    justify-content: flex-start;
    align-items: center;
    gap: 10px;
    font-size: 28px;
    font-weight: 700;
    line-height: 1;
    margin: 0 0 10px;
}

.service-card__text h2::before {
    background: url(../images/service/icon-ec.png) no-repeat;
    background-position: center;
    background-size: contain;
    content: "";
    display: block;
    height: 46px;
    width: 60px;
}

.servicebottom .service-card__text h2::before {
    background-image: url(../images/service/icon-spa.png);
    height: 58px;
    width: 60px;
}

.service-card__text h2 span {
    color: #00A6DC;
    display: block;
    font-size: 16px;
    font-weight: 500;
    line-height: 1;
}

.service-card__text p {
    color: #525766;
    font-size: 16px;
    font-weight: 400;
    line-height: 26px;
}

.service-card__btn {
    height: 50px;
    margin: 30px 0 0;
    width: 100%;
    max-width: 310px;
}

.service-card__btn a {
    background: var(--main-theme-color);
    border-radius: 50px;
    color: #fff;
    display: flex;
    justify-content: center;
    align-items: center;
    font-size: 12.5px;
    font-weight: 700;
    height: 100%;
    width: 100%;
}

.service-card__btn a::after {
    background: url(../images/service/icon-openwindow.svg) no-repeat;
    background-position: center;
    background-size: contain;
    content: "";
    display: block;
    height: 15px;
    margin-left: 15px;
    width: 18px;
}

.service-items {
    display: flex;
    flex-direction: column;
    gap: 85px;
    margin: 85px auto 0;
    width: 100%;
    max-width: 1146px;
}

.service-item {
    display: flex;
    justify-content: space-between;
    align-items: center;
    flex-wrap: wrap;
}

.service-item:nth-child(even) {
    flex-direction: row-reverse;
}

.service-item__image {
    border-radius: 20px;
    line-height: 0;
    overflow: hidden;
    width: 473px;
}

.service-item__text {
    width: calc(100% - (473px + 80px));
}

.service-item__text h3 {
    margin: 0 0 25px;
    padding: 35px 0;
    position: relative;
}

.service-item__text h3::before {
    color: rgb(199 206 224 / 30%);
    font-family: var(--ft-poppin);
    font-size: 122px;
    font-weight: 400;
    height: auto;
    line-height: 1;
    margin: auto;
    position: absolute;
    left: 0;
    top: 0;
    bottom: 0;
    width: 100%;
}

.service-item__text h3[data-title="LaClarte"]::before {
    content: "LaClarte";
}

.service-item__text h3[data-title="LaFORTE"]::before {
    content: "LaFORTE";
}

.service-item__text h3 span {
    font-size: 24px;
    font-weight: 700;
    position: relative;
}

.service-item__text p {
    font-size: 16px;
    font-weight: 400;
    line-height: 1.8em;
    color: #525766;
}

@media screen and (max-width: 968px) {
    .service-item__image {
        width: 373px;
    }

    .service-item__text {
        width: calc(100% - 413px);
    }
}

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

    .servicetop-inner,
    .servicebottom-inner {
        width: 100%;
    }

    .slug-service .parallax-container {
        display: none;
    }

    .servicetop {
        background-color: #fff;
        background-image: none;
        padding: 0 0 60px;
    }

    .servicetop-head p {
        font-size: 16px;
    }

    .servicebottom {
        padding: 60px 0 100px;
    }

    .service-card {
        flex-direction: column-reverse;
    }

    .servicebottom .service-card {
        flex-direction: column-reverse;
    }

    .service-card__text {
        background: none;
        border-radius: 0;
        filter: none;
        padding: 22px 0 0;
        width: calc(100% - 48px);
    }

    .service-card__text p {
        font-size: 14.5px;
        line-height: 26px;
    }

    .service-card__image {
        border-radius: 50px 0 0 50px;
        margin-left: auto;
        position: relative;
        width: calc(100% - 27px);
    }

    .servicebottom .service-card__image {
        border-radius: 0 60px 60px 0;
        margin-right: 0;
        right: 0;
        left: calc(-6% + 5px);
    }

    .service-card__text h2 {
        flex-wrap: wrap;
        margin: 0 0 15px;
        font-size: 24px;
    }

    .service-card__text h2 span {
        display: block;
        width: 100%;
    }

    .service-card__text h2 span br {
        display: none;
    }

    .service-item__text p {
        font-size: 14.5px;
        line-height: 26px;
    }

    .service-card__btn {
        margin: 40px auto 0;
    }

    .service-card__btn a {
        background: var(--main-theme-color);
        border-radius: 50px;
        color: #fff;
        display: flex;
        justify-content: center;
        align-items: center;
        font-size: 14.5px;
        font-weight: 700;
        height: 100%;
        width: 100%;
    }

    .service-card__btn a::after {
        background: url(../images/service/icon-openwindow.svg) no-repeat;
        background-position: center;
        background-size: contain;
        content: "";
        display: block;
        height: 15px;
        margin-left: 15px;
        width: 18px;
    }

    .service-items {
        gap: 45px;
        margin: 45px auto 0;
        width: calc(100% - 48px);
    }

    .service-item__image {
        border-radius: 50px;
        overflow: hidden;
        width: 100%;
    }

    .service-item__text {
        margin: 20px 0 0;
        width: 100%;
    }

    .service-item__text h3 {
        margin: 0 0 20px;
        padding: 35px 0;
    }

    .service-item__text h3::before {
        font-size: 94px;
    }
}

/* recruitcont */
.recruitcont {
    padding: 0 0 200px;
    position: relative;
}

.recruitcont-inner {
    margin: 0 auto;
    width: 92%;
    max-width: 1410px;
}

.recruitcont-head {
    margin: 0 0 40px;
}

.recruitcont h2 {
    font-size: 34px;
    letter-spacing: 4px;
}

.recruitcont-body p {
    font-size: 16px;
    font-weight: 400;
    line-height: 1.8em;
    text-align: center;
    color: #525766;
}

.recruitcont-body picture {
    display: block;
    margin: 65px auto 0;
    width: 100%;
    max-width: 759px;
}

.recruit-circles {
    display: flex;
    justify-content: center;
    align-items: center;
    flex-wrap: wrap;
    margin: 65px auto 0;
    width: 100%;
    max-width: 759px;
}

.recruit-circle {
    aspect-ratio: 1 / 1;
    border-radius: 50%;
    display: flex;
    justify-content: center;
    align-items: center;
    filter: drop-shadow(0 4px 4px rgb(171 233 255 / 100%));
    overflow: hidden;
    padding: 15px 45px;
    position: relative;
    width: 398px;
}

.recruit-circle:nth-child(1) {
    margin-bottom: -115px;
    padding-bottom: 45px;
}

.recruit-circle:nth-child(2) {
    margin-right: -20px;
}

.recruit-circle:nth-child(3) {
    margin-left: -20px;
}

.recruit-circle::before {
    background: linear-gradient(51deg, rgba(96, 200, 255, 1) 41%, rgba(28, 115, 211, 1) 100%);
    content: "";
    display: block;
    height: 100%;
    opacity: .7;
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
}

.recruit-circle__text {
    position: relative;
    z-index: 1;
}

.recruit-circle__text h3 {
    border-bottom: 1px solid #fff;
    color: #fff;
    font-size: 22px;
    font-weight: 700;
    margin: 0 0 10px;
    padding: 0 0 5px;
    text-align: center;
}

.recruit-circle__text p {
    color: #fff;
    font-size: 16px;
    font-weight: 500;
    line-height: 1.8em;
    padding: 0 10px 0 0;
    text-align: left;
}

.recruit-circle:nth-child(1) .recruit-circle__text p {
    padding: 0;
}

.recruit-circle:nth-child(3) .recruit-circle__text p {
    padding: 0 0 0 10px;
}

@media screen and (max-width: 968px) {}

@media screen and (max-width: 868px) {
    .recruitcont {
        padding: 0 0 80px;
    }

    .recruitcont-body picture {
        margin: 30px auto 0;
        max-width: 351px;
    }

    .recruitcont h2 {
        font-size: 24px;
    }

    .recruitcont-body p {
        text-align: left;
        font-size: 14.5px;
        line-height: 1.4rem;
    }

    .recruit-circles {
        flex-direction: column;
    }

    .recruit-circle {
        padding: 15px 25px;
        width: 350px;
    }

    .recruit-circle:nth-child(1) {
        margin-bottom: -60px;
    }

    .recruit-circle:nth-child(2) {
        margin-bottom: -60px;
        margin-right: 0;
    }

    .recruit-circle:nth-child(3) {
        margin-bottom: -60px;
        margin-left: 0;
    }
}

@media screen and (max-width: 368px) {
    .recruit-circle {
        width: 310px;
    }

    .recruit-circle:nth-child(1),
    .recruit-circle:nth-child(2),
    .recruit-circle:nth-child(3) {
        margin-bottom: -50px;
    }

    .recruit-circle__text h3 {
        font-size: 18px;
    }

    .recruit-circle__text p {
        font-size: 14px;
    }
}

/* recruit-image */
.recruit-image {
    padding: 0 0 200px;
    position: relative;
    z-index: 3;
}

.loopslider-images {
    animation: scroll-left 40s linear infinite;
    display: flex;
    gap: 10px;
    width: max-content;
}

.loopslider-image {
    flex-shrink: 0;
    line-height: 0;
    width: 2600px;
}

/* CSSアニメーション */
@keyframes scroll-left {
    from {
        transform: translateX(0);
    }

    to {
        transform: translateX(-50%);
    }
}

@media screen and (max-width: 968px) {
    .recruit-image {
        padding: 0 0 100px;
    }
}

@media screen and (max-width: 768px) {
    .loopslider-images {
        animation: scroll-left 40s linear infinite;
    }

    .loopslider-image {
        width: 1400px;
    }
}

/* blockname */
@media screen and (max-width: 968px) {}

@media screen and (max-width: 768px) {}

/* blockname */
@media screen and (max-width: 968px) {}

@media screen and (max-width: 768px) {}

/* blockname */
@media screen and (max-width: 968px) {}

@media screen and (max-width: 768px) {}

/* blockname */
@media screen and (max-width: 968px) {}

@media screen and (max-width: 768px) {}

/* blockname */
@media screen and (max-width: 968px) {}

@media screen and (max-width: 768px) {}

/* blockname */
@media screen and (max-width: 968px) {}

@media screen and (max-width: 768px) {}

/* blockname */
@media screen and (max-width: 968px) {}

@media screen and (max-width: 768px) {}

/* blockname */
@media screen and (max-width: 968px) {}

@media screen and (max-width: 768px) {}



/* know */
.know {
    padding: 0 0 190px;
    position: relative;
    z-index: 3;
}

.know-inner {
    margin: 0 auto;
    width: calc(100% - 48px);
    max-width: 1128px;
}

.know-head {
    margin: 0 0 45px;
    text-align: center;
}

.know-head h2 {
    font-size: 34px;
    letter-spacing: 4px;
}

.know-head p {
    color: #525766;
    font-size: 16px;
    font-weight: 500;
    letter-spacing: 0px;
    margin: 25px 0 0;
}

.know-cards {
    display: flex;
    justify-content: space-between;
    align-items: stretch;
    flex-wrap: wrap;
    gap: 24px;
}

.know-card {
    --bar-dur: 1200ms;
    /* バー伸長の基本時間 */
    --num-dur: 1200ms;
    /* 数字のカウント時間（デフォルト） */
    background: #fff;
    border-radius: 20px;
    filter: drop-shadow(0 4px 40px rgb(55 154 206 / 36%));
    padding: 35px 35px;
    width: calc((100% - (24px * 2)) / 3);
}

.know-card__flex {
    display: flex;
    justify-content: space-between;
    align-items: stretch;
    flex-wrap: wrap;
    gap: 24px;
    width: calc((((100% - (24px * 2)) / 3) * 2) + 24px);
}

.know-card__flex .know-card {
    padding: 36px 45px;
    width: calc((100% - (24px * 1)) / 2);
}

.know-card__text {
    color: #525766;
    font-size: 12px;
    font-weight: 400;
    line-height: 18.5px;
}

/* 基本スタイル（必要に応じて調整） */
.know-card__head {
    margin: 0 0 10px;
    text-align: center;
}

.know-card__head h3 {
    color: #00A6DC;
    font-size: 24px;
    font-weight: 700;
}

.know-card .average {
    display: flex;
    align-items: baseline;
    justify-content: center;
    margin: 0 0 10px;
}

.know-card .ave-num,
.know-card .graph .graph-item dd>span {
    font-variant-numeric: tabular-nums;
}

.know-card .average .ave-txt {
    color: #00A6DC;
    font-size: 15.5px;
    font-weight: 700;
    margin-right: 5px;
}

.know-card .average .ave-num {
    color: #00A6DC;
    font-family: var(--ft-robo);
    font-size: 78px;
    font-weight: 900;
}

.know-card .average .ave-txt2 {
    color: #00A6DC;
    font-size: 18.45px;
    font-weight: 900;
}

/* グラフ行 */
.know-card .graph {
    display: flex;
    flex-direction: column;
    gap: 14px;
}

.know-card .graph-item {
    display: flex;
    justify-content: flex-start;
    align-items: center;
    gap: 10px;
}

.know-card .graph-item dt {
    color: #00A6DC;
    font-size: 12.4px;
    font-weight: 500;
    white-space: nowrap;
    width: 30px;
}

/* バー本体：初期は0% */
.know-card .graph-item dd {
    display: flex;
    justify-content: flex-start;
    align-items: center;
    position: relative;
    gap: 10px;
    width: calc(100% - 30px);
}

.know-card .graph-item dd .graph-bar {
    height: 17.48px;
    overflow: hidden;
    position: relative;
}

.know-card .graph-item dd .graph-bar::after {
    content: "";
    position: absolute;
    inset: 0;
    width: 0%;
    background: #00A6DC;
    border-radius: 0 50px 50px 0;
    transition: width var(--bar-dur) ease-out;
    will-change: width;
}

.know-card .graph-item dd p,
.know-card .graph-item dd p span {
    color: #00A6DC;
    font-size: 14px;
    font-weight: 500;
}

/* アニメーション開始時にwidthを目標％へ */
.know-card.is-animated .graph-item dd[data-target] .graph-bar::after {
    width: attr(data-target percentage);
}

.mf-ratios {
    display: flex;
    flex-direction: column;
    gap: 12px;
    margin: 20px 0 0;
}

.mf-ratio {
    display: flex;
    justify-content: center;
    align-items: center;
}

.mf-img {
    margin-right: 20px;
    width: 58px;
}

.mf-numwrap {
    display: flex;
    justify-content: flex-start;
    align-items: baseline;
    width: calc(100% - 78px);
    max-width: max-content;
}

.mf-num {
    font-family: var(--ft-robo);
    font-size: 78px;
    font-weight: 900;
    line-height: 1em;
}

.mf-numwrap span {
    font-family: var(--ft-robo);
    font-size: 22.6px;
    font-weight: 900;
}

.mf-ratio:nth-child(1) .mf-num,
.mf-ratio:nth-child(1) .mf-numwrap span {
    color: #008AD2;
}

.mf-ratio:nth-child(2) .mf-num,
.mf-ratio:nth-child(2) .mf-numwrap span {
    color: #204483;
}

.card-notice {
    color: #6d6d6d;
    font-size: 14px;
    font-weight: 400;
    margin: 5px 0 0;
    text-align: right;
}

.jobtype-items {
    display: flex;
    flex-direction: column;
    gap: 15px;
}

.jobtype-item {
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.jobtype-ttl {
    color: #00A6DC;
    font-size: 12px;
    font-weight: 700;
}

.jobtype-numwrap {
    display: flex;
    justify-content: flex-start;
    align-items: baseline;
}

.jobtype-num {
    color: #00A6DC;
    font-family: var(--ft-robo);
    font-size: 49px;
    font-weight: 700;
    line-height: 1em;
}

.jobtype-numwrap span {
    color: #00A6DC;
    font-family: var(--ft-robo);
    font-size: 21px;
    font-weight: 700;
}

.jobtype-item .bar {
    background: #00A6DC;
    display: block;
    height: 1px;
    width: auto;
    flex: 1;
    margin: 0 10px;
}

.holiday-items {
    background: url(../images/holiday.png) no-repeat;
    background-position: right bottom;
    background-size: 80px;
    display: flex;
    justify-content: space-between;
    align-items: stretch;
    flex-wrap: wrap;
    row-gap: 20px;
    margin: 20px 0 0;
}

.holiday-item:nth-child(3) {
    width: calc(100% - 100px);
}

.holiday-item__ttl {
    color: #00A6DC;
    font-size: 12px;
    font-weight: 700;
    margin: 0 0 10px;
}

.holiday-item__ttl span {
    color: #00A6DC;
    font-size: 10px;
    font-weight: 700;
}

.holiday-item__numwrap {
    display: flex;
    justify-content: flex-start;
    align-items: baseline;
}

.holiday-num {
    color: #00A6DC;
    font-family: var(--ft-robo);
    font-size: 49px;
    font-weight: 700;
    line-height: 1;
}

.holiday-item__numwrap span {
    color: #00A6DC;
    font-family: var(--ft-robo);
    font-size: 12.7px;
    font-weight: 700;
}

.holiday-notice {
    color: #525766;
    font-size: 14px;
    font-weight: 400;
    margin: 10px 0 0;
}

.know-card__def {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin: 0 auto;
    padding: 0 10px;
}

.know-def__icon {
    margin-right: 15px;
    width: 70px;
}

.know-def__text {
    width: calc(100% - 95px);
}

.know-def__text p {
    color: #525766;
    font-size: 14px;
    font-weight: 400;
    line-height: 18.5px;
}

@media screen and (max-width: 1400px) {
    .know-cards {
        gap: 30px;
    }

    .know-card {
        filter: drop-shadow(0 4px 40px rgb(55 154 206 / 36%));
        padding: 40px 60px;
        width: calc((100% - (30px * 2)) / 3);
    }

    .know-card__flex {
        gap: 30px;
        width: calc((((100% - (30px * 2)) / 3) * 2) + 30px);
    }

    .know-card__flex .know-card {
        padding: 40px 50px;
        width: calc((100% - (30px * 1)) / 2);
    }

    .know-card__text {
        font-size: 14px;
        line-height: 22px;
    }

    /* 基本スタイル（必要に応じて調整） */
    .know-card__head {
        margin: 0 0 15px;
    }

    .know-card__head h3 {
        font-size: 26px;
    }

    .know-card .average {
        margin: 0 0 5px;
    }

    .know-card .average .ave-txt {
        font-size: 19px;
    }

    .know-card .average .ave-num {
        font-size: 95px;
    }

    .know-card .average .ave-txt2 {
        font-size: 22px;
    }

    /* グラフ行 */
    .know-card .graph {
        gap: 15px;
    }

    .know-card .graph-item {
        gap: 10px;
    }

    .know-card .graph-item dt {
        font-size: 15px;
        width: 34px;
    }

    /* バー本体：初期は0% */
    .know-card .graph-item dd {
        gap: 10px;
        width: calc(100% - 44px);
    }

    .know-card .graph-item dd .graph-bar {
        height: 15px;
    }

    .know-card .graph-item dd p,
    .know-card .graph-item dd p span {
        font-size: 19px;
    }

    /* アニメーション開始時にwidthを目標％へ */
    .know-card.is-animated .graph-item dd[data-target] .graph-bar::after {
        width: attr(data-target percentage);
    }

    .mf-ratios {
        gap: 20px;
        margin: 30px 0 0;
    }

    .mf-img {
        margin-right: 18px;
        width: 63px;
    }

    .mf-numwrap {
        width: calc(100% - 81px);
    }

    .mf-num {
        font-size: 95px;
    }

    .mf-numwrap span {
        font-size: 27px;
    }

    .card-notice {
        font-size: 12px;
    }

    .jobtype-items {
        gap: 15px;
    }

    .jobtype-ttl {
        font-size: 15px;
    }

    .jobtype-num {
        font-size: 60px;
    }

    .jobtype-numwrap span {
        font-size: 26px;
    }

    .holiday-items {
        background-size: 86px;
    }

    .holiday-item:nth-child(3) {
        width: calc(100% - 100px);
    }

    .holiday-item__ttl {
        font-size: 15px;
    }

    .holiday-item__ttl span {
        font-size: 12px;
    }

    .holiday-num {
        font-size: 60px;
    }

    .holiday-item__numwrap span {
        font-size: 15px;
    }

    .holiday-notice {
        font-size: 12px;
    }

    .know-def__icon {
        width: 75px;
    }

    .know-def__text {
        width: calc(100% - 95px);
    }

    .know-def__text p {
        font-size: 15px;
    }
}

@media screen and (max-width: 1268px) {
    .know-cards {
        gap: 20px;
    }

    .know-card {
        padding: 35px 20px;
        width: calc((100% - (20px * 2)) / 3);
    }

    .know-card__flex {
        gap: 20px;
        width: calc((((100% - (20px * 2)) / 3) * 2) + 20px);
    }

    .know-card__flex .know-card {
        padding: 35px 20px;
        width: calc((100% - (20px * 1)) / 2);
    }
}

@media screen and (max-width: 1068px) {
    .know-card {
        padding: 35px 50px;
        width: calc((100% - (20px * 1)) / 2);
    }

    .know-card__flex {
        width: calc((((100% - (20px * 1)) / 2) * 2) + 20px);
    }

    .know-card__flex .know-card {
        padding: 35px 50px;
        width: calc((100% - (20px * 1)) / 2);
    }
}

@media screen and (max-width: 968px) {
    .know {
        padding: 0 0 95px;
    }

    .know-head h2 {
        font-size: 24px;
        letter-spacing: 0px;
    }

    .know-head p {
        font-size: 14.5px;
        text-align: left;
        line-height: 1.4rem;
    }

    .know-card {
        padding: 35px 50px;
        width: 100%;
    }

    .know-card__flex {
        width: 100%;
    }

    .know-card__flex .know-card {
        padding: 35px 50px;
        width: 100%;
    }
}

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

    .know-card,
    .know-card__flex .know-card {
        padding: 35px 25px;
    }

    .know-card__text {
        font-size: 14.5px;
    }

    /* 基本スタイル（必要に応じて調整） */
    .know-card__head h3 {
        font-size: 24px;
    }

    .know-card .average .ave-txt {
        font-size: 17px;
    }

    .know-card .average .ave-num {
        font-size: 90px;
    }

    .know-card .average .ave-txt2 {
        font-size: 20px;
    }

    /* グラフ行 */
    .know-card .graph-item dt {
        font-size: 14px;
        width: 32px;
    }

    /* バー本体：初期は0% */
    .know-card .graph-item dd {
        width: calc(100% - 42px);
    }

    .know-card .graph-item dd p,
    .know-card .graph-item dd p span {
        font-size: 17px;
    }

    .mf-img {
        margin-right: 18px;
        width: 58px;
    }

    .mf-numwrap {
        width: calc(100% - 76px);
    }

    .mf-num {
        font-size: 90px;
    }

    .mf-numwrap span {
        font-size: 23px;
    }

    .jobtype-ttl {
        font-size: 14.5px;
    }

    .jobtype-num {
        font-size: 56px;
    }

    .jobtype-numwrap span {
        font-size: 22px;
    }

    .holiday-items {
        background-size: 75px;
    }

    .holiday-item:nth-child(3) {
        width: calc(100% - 85px);
    }

    .holiday-item__ttl {
        font-size: 14px;
    }

    .holiday-num {
        font-size: 55px;
    }

    .holiday-item__numwrap span {
        font-size: 13px;
    }

    .know-def__icon {
        width: 70px;
    }

    .know-def__text {
        width: calc(100% - 90px);
    }

    .know-def__text p {
        font-size: 14.5px;
    }
}