@import url('https://fonts.googleapis.com/css2?family=Inter:ital,opsz,wght@0,14..32,100..900;1,14..32,100..900&display=swap');

#wrapper{
    /* padding: 140px 0 0;
    background: linear-gradient(180deg, #2E3D55 0%, #021D35 15%, #448ACA 42%, #C2E9FB 62%, #CCE198 99%);
    mix-blend-mode: normal; */
}
/* .page-wrapper{
    max-width: 1200px;
    width: 90%;
    margin: 0 auto;
} */

.layout-wrapper {
    position: relative;
    overflow-x: clip;
    background-repeat: no-repeat;
    background-size: cover;
    background: linear-gradient(180deg, #2E3D55 -0.09%, #021D35 14.81%, #448ACA 41.91%, #C2E9FB 61.91%, #CCE198 98.91%);
}
.page-company {
    position: relative;
    padding-top: min( calc(115/1280*100vw), 8.41rem);
}
.page-company__earth {
    position: absolute;
    width: min( calc(644/1280*100vw), 47.1rem);
    top: min( calc(180/1280*100vw), 11.25rem);
    left: 0;
}
.page-company__bg {
    position: absolute;
    top: 0;
    left: 0;
    width: min( calc(1280/1280*100vw), 93.6rem);
    height: min( calc(2628/1280*100vw), 192.1725rem);
    background-image: url(../images/bg-lower.webp);
    width: 100%;
    background-size: cover;
    background-position: top center;
    background-repeat: no-repeat;
    z-index: -99;
}
.page-company__sun {
    position: absolute;
    top: 0;
    right: 0;
    width: min( calc(344/1280*100vw), 25.155rem);
    z-index: 1;
}
.page-company__sun .circle {
    position: absolute;
    top: 0;
    right: 0;
}
.page-company__sun .sun {
    position: absolute;
    top: 0;
    right: 0;
}

.page-title{
    background: linear-gradient(90deg,rgba(204, 226, 155, 1) 0%, rgba(195, 234, 248, 1) 50%, rgba(76, 144, 205, 1) 100%);
    border-radius: 85px 85px 0 0;
    padding: 114px 0 90px;
    text-align: center;
}
.page-title h2{
    font-family: 'Inter', sans-serif;
    font-style: normal;
    font-weight: 700;
    font-size: 5.333rem;
    line-height: 1;
    letter-spacing: 0.034em;
    color: #FFFFFF;
    text-shadow: 0px 16px 32px #8FC1E8;
}
.page-title h3{
    font-family: 'Inter';
    font-style: normal;
    font-weight: 700;
    font-size: 2.66666rem;
    line-height: 1.21875;
    text-align: center;
    color: #333333;
}


/* .contents{
    border-radius: 0 0 85px 85px;
    background: #fff;
    padding: 0;
}
.contents section{
    padding: 6% 4%;
}
.contents section h3{
    display: block;
    position: relative;
    font-family: 'Inter', sans-serif;
    font-weight: 700;
    font-size: 2.6666rem;
    line-height: 1.21875;
    color: #333333;
    padding: 0 0 20px;
}
.contents section h3:after,
.contents section h3:before{
    content: "";
    display: block;
    position: absolute;
    left: 0;
    bottom: 0;
    height: 3px;
}
.contents section h3:before{
    background: #eee;
    right: 0;
    z-index: 1;
}
.contents section h3:after{
    background: linear-gradient(90deg, rgba(254, 194, 72, 1) 0%,rgba(196, 249, 118, 1) 100%);
    z-index: 2;
    width: 70px;
}
.contents section.history,
.contents section.mission{
    border-radius: 85px;
    background: #FFFDEB;
} */

:is(.message__inner, .mission__inner, .vision__inner, .value__inner, .profile__inner, .history__inner) {
    padding: 0 min( calc(50/1280*100vw), 3.65625rem);
    margin-inline: auto;
}
/* ============================================
Message Section
============================================ */
.message {
    background-color: var(--color-white);
    padding: min( calc(60/1280*100vw), 4.3875rem) 0;
}
.message__content {
    display: flex;
    gap: min( calc(36/1280*100vw), 2.6325rem);
    align-items: flex-start;
    margin-top: min( calc(36/1280*100vw), 2.6325rem);
}
.message__photo {
    flex: 0 1 min( calc(345/1280*100vw), 25.228125rem);
}
.message__photo img {
    border-radius: 50%;
    object-fit: cover;
    aspect-ratio: 1/1;
}
.message__body {
    flex: 1;
}
.message__name {
    display: flex;
    align-items: baseline;
    gap: min( calc(16/1280*100vw), 1.17rem);
    font-weight: 700;
}
.message__name-label {
    font-size: min( calc(20/1280*100vw), 1.4625rem);
}
.message__name-value {
    font-size: min( calc(32/1280*100vw), 2.34rem);
}
.message__text {
    margin-top: min( calc(24/1280*100vw), 1.755rem);
    font-size: min( calc(20/1280*100vw), 1.4625rem);
    line-height: 1.7;
}
/* ============================================
Mission Section
============================================ */
.mission {
    background-color: #FFF;
}
.mission__bg {
    padding: min( calc(60/1280*100vw), 4.3875rem) 0;
    border-radius: min( calc(40/1280*100vw), 2.925rem) min( calc(40/1280*100vw), 2.925rem) 0 0;
    background-color: #FFFDEB;
}
.mission__content {
    display: flex;
    gap: min( calc(169/1280*100vw), 12.358125rem);
    margin-top: min( calc(50/1280*100vw), 3.65625rem);
    margin-right: min( calc(30/1280*100vw), 2.19375rem);
}
.mission__body {
    flex: 1;
}
.mission__title {
    font-size: min( calc(32/1280*100vw), 2.34rem);
    font-weight: bold;
}
.mission__text-wrap {
    margin-top: min( calc(40/1280*100vw), 2.925rem);
}
.mission__text {
    font-size: min( calc(20/1280*100vw), 1.4625rem);
    line-height: 1.7;
}
.mission__text + .mission__text {
    margin-top: min( calc(16/1280*100vw), 1.17rem);
}
.mission__icon {
    flex: 0 1 min( calc(414/1280*100vw), 30.27375rem);
}
.mission__icon img {
    object-fit: cover;
    aspect-ratio: 414/269;
}
/* ============================================
Vision Section
============================================ */
.vision {
    background-color: #FFFDEB;
    padding: min( calc(60/1280*100vw), 4.3875rem) 0;
}
.vision__content {
    display: flex;
    gap: min( calc(58/1280*100vw), 4.24125rem);
    margin-top: min( calc(22/1280*100vw), 1.60875rem);
    margin-left: min( calc(18/1280*100vw), 1.31625rem);
}
.vision__body {
    flex: 1;
    margin-top: min( calc(34/1280*100vw), 2.48625rem);
}
.vision__title {
    font-size: min( calc(32/1280*100vw), 2.34rem);
    font-weight: bold;
}
.vision__text-wrap {
    margin-top: min( calc(40/1280*100vw), 2.925rem);
}
.vision__text {
    font-size: min( calc(20/1280*100vw), 1.4625rem);
    line-height: 1.7;
}
.vision__text + .vision__text {
    margin-top: min( calc(16/1280*100vw), 1.17rem);
}
.vision__diagram {
    flex: 0 1 min( calc(495/1280*100vw), 36.196875rem);
}
.vision__diagram img {
    object-fit: cover;
    aspect-ratio: 495/462;
}
/* ============================================
Value Section
============================================ */
.value {
    background-color: #fff;
}
.value__bg {
    padding: min( calc(60/1280*100vw), 4.3875rem) 0;
    border-radius: 0 0 min( calc(40/1280*100vw), 2.925rem) min( calc(40/1280*100vw), 2.925rem);
    background-color: #FFFDEB;
}
.value__items {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    grid-column-gap: min( calc(38/1280*100vw), 2.77875rem);
    margin-top: min( calc(38/1280*100vw), 2.77875rem);
}
.value__item {
    display: grid;
    grid-template-rows: subgrid;
    grid-row: span 3;
}
.value__item-header {
    position: relative;
}
.value__item-number {
    font-size: min( calc(48/1280*100vw), 3.51rem);
    background: linear-gradient(180deg, #FEC248 0%, #F5F97F 50%, #C4F976 100%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}
.value__item-label {
    position: absolute;
    bottom: 0;
    left: 0;
    padding-left: min( calc(24/1280*100vw), 1.755rem);
    font-size: min( calc(20/1280*100vw), 1.4625rem);
}
.value__item-body {
    background: var(--color-white);
    border-radius: min( calc(32/1280*100vw), 2.34rem);
    padding: min( calc(32/1280*100vw), 2.34rem) min( calc(24/1280*100vw), 1.755rem);
    display: grid;
    grid-template-rows: subgrid;
    grid-row: span 2;
    margin-top: min( calc(7/1280*100vw), .511875rem);
    background-image: url(../images/company_04.webp);
    background-repeat: no-repeat;
    background-size: cover;
}
.value__item-title {
    font-size: min( calc(32/1280*100vw), 2.34rem);
    font-weight: 700;
    border-bottom: 2px solid #EEE;
    padding-bottom: min( calc(16/1280*100vw), 1.17rem);
}
.value__item-text {
    font-size: min( calc(20/1280*100vw), 1.4625rem);
    line-height: 1.8;
    margin-top: min( calc(28/1280*100vw), 2.0475rem);
}
/* ============================================
Profile Section
============================================ */
.profile {
    background-color: var(--color-white);
    padding: min( calc(60/1280*100vw), 4.3875rem) 0;
}
.profile__content {
    display: flex;
    gap: min( calc(62/1280*100vw), 4.53375rem);
    margin-top: min( calc(50/1280*100vw), 3.65625rem);
}
.profile__body {
    flex: 1;
}
.profile__title {
    font-size: min( calc(32/1280*100vw), 2.34rem);
    font-weight: bold;
}
.profile__text-wrap {
    margin-top: min( calc(40/1280*100vw), 2.925rem);
}
.profile__text {
    font-size: min( calc(20/1280*100vw), 1.4625rem);
    line-height: 1.7;
}
.profile__text + .profile__text {
    margin-top: min( calc(32/1280*100vw), 2.34rem);
}
.profile__map {
    flex: 0 1 min( calc(532/1280*100vw), 38.9025rem);
    margin-top: min( calc(70/1280*100vw), 5.11875rem);
}
.profile__map iframe {
    border-radius: min( calc(40/1280*100vw), 2.925rem);
    object-fit: cover;
    aspect-ratio: 532/369;
}
/* ============================================
History Section
============================================ */
.history {
    background-color: var(--color-white);
    padding: 0;
    border-radius: 0 0 min(calc(40 / 1280 * 100vw), 2.925rem) min(calc(40 / 1280 * 100vw), 2.925rem);
}
.history__inner {
    padding: min( calc(60/1280*100vw), 4.3875rem) min( calc(50/1280*100vw), 3.65625rem);
    background-color: #FFFDEB;
    border-radius: min( calc(40/1280*100vw), 2.925rem);
}
.history__title {
    font-size: min( calc(32/1280*100vw), 2.34rem);
    margin-top: min( calc(40/1280*100vw), 2.925rem);
    font-weight: bold;
}
.history__timeline {
    margin-top: min( calc(40/1280*100vw), 2.925rem);
}
.history__item {
    position: relative;
    display: flex;
    align-items: flex-start;
    margin-right: min( calc(239/1280*100vw), 17.476875rem);
    padding-bottom: min( calc(50/1280*100vw), 3.65625rem);
}
.history__year {
    position: relative;
    flex: 0 1 min( calc(208/1280*100vw), 15.21rem);
    font-size: min( calc(56/1280*100vw), 4.095rem);
    margin-right: min( calc(40/1280*100vw), 2.925rem);
    line-height: 1;
}
.history__item::before {
    content: '';
    position: absolute;
    left: min( calc(193.5/1280*100vw), 14.1496875rem);
    top: min( calc(30/1280*100vw), 2.19375rem);
    width: 0;
    height: 100%;
    background: transparent;
    border-right: min( calc(5/1280*100vw), .365625rem) solid #BBBBBB;
}
.history__item:last-child::before {
    border-right: min( calc(5/1280*100vw), .365625rem) dashed #BBBBBB;
}
.history__year::after {
    content: '';
    position: absolute;
    right: 0;
    top: 60%;
    transform: translateY(-50%);
    width: min( calc(24/1280*100vw), 1.755rem);
    height: min( calc(24/1280*100vw), 1.755rem);
    background: var(--color-accent);
    border-radius: 50%;
}
.history__description {
    flex: 1;
    font-size: min( calc(20/1280*100vw), 1.4625rem);
    margin-top: min( calc(18/1280*100vw), 1.31625rem);
}
@media screen and (max-width: 767px) {
    :is(.message, .profile, .history) {
        background-color: var(--color-white);
        padding: 40px 0;
    }
    :is(.message__inner, .mission__inner, .vision__inner, .value__inner, .profile__inner, .history__inner) {
        padding: 0 15px;
        margin-inline: auto;
    }
    .page-company {
        padding-top: 70px;
    }
    .page-company__sun {
        display: none;
    }
    .page-company__earth {
        width: 100%;
        top: 100px;
    }
    .message {
        background-color: var(--color-white);
        padding: 40px 0;
    }
    .message__content {
        flex-direction: column;
        gap: 16px;
        margin-top: 28px;
    }
    .message__photo {
        width: 55%;
        margin-inline: auto;
    }
    .message__name {
        gap: 16px;
    }
    .message__name-label {
        font-size: 16px;
    }
    .message__name-value {
        font-size: 24px;
    }
    .message__text {
        margin-top: 8px;
        font-size: 14px;
        line-height: 1.5;
    }
    .mission__bg {
        padding: 40px 0;
        border-radius: 20px 20px 0 0;
    }
    .mission__content {
        flex-direction: column;
        display: flex;
        gap: 16px;
        margin-top: 16px;
        margin-right: 0;
    }
    .mission__body {
        flex: initial;
    }
    .mission__title {
        font-size: 20px;
    }
    .mission__text-wrap {
        margin-top: 16px;
    }
    .mission__text {
        font-size: 14px;
        line-height: 1.5;
    }
    .mission__text + .mission__text {
        margin-top: 8px;
    }
    .mission__icon {
        flex: initial;
        width: 68%;
        margin-inline: auto;
    }
    .vision {
        padding: 40px 0;
    }
    .vision__content {
        flex-direction: column;
        display: flex;
        gap: 0;
        margin-top: 16px;
        margin-left: 0;
    }
    .vision__body {
        flex: initial;
        display: contents;
        margin-top: 0;
    }
    .vision__title {
        order: 1;
        font-size: 20px;
    }
    .vision__text-wrap {
        order: 3;
        margin-top: 0;
    }
    .vision__text {
        font-size: 14px;
        line-height: 1.5;
    }
    .vision__text + .vision__text {
        margin-top: 16px;
    }
    .vision__diagram {
        order: 2;
        flex: initial;
        width: 100%;
    }
    .value__bg {
        padding: 0 0 40px;
        border-radius: 0 0 20px 20px;
    }
    .value__items {
        display: grid;
        grid-template-columns: repeat(1, 1fr);
        grid-template-rows: repeat(3, auto);
        grid-column-gap: 0;
        grid-row-gap: 0;
        margin-top: 16px;
        grid-row-gap: 24px;
    }
    .value__item {
        grid-row-gap: 0;
    }
    .value__item-number {
        font-size: 32px;
        line-height: 1.4;
    }
    .value__item-label {
        padding-left: 16px;
        font-size: 14px;
    }
    .value__item-body {
        padding: 24px 20px;
        margin-top: 4px;
        background-image: url(../images/company_04_sp.webp);
        border-radius: 20px;
        background-size: 100% 100%;
    }
    .value__item-title {
        font-size: 18px;
        padding-bottom: 16px;
    }
    .value__item-text {
        font-size: 14px;
        line-height: 1.4;
        margin-top: 16px;
    }
    .profile {
        background-color: var(--color-white);
        padding: 40px 0;
    }
    .profile__content {
        flex-direction: column;
        display: flex;
        gap: 16px;
        margin-top: 16px;
    }
    .profile__body {
        flex: initial;
    }
    .profile__title {
        font-size: 20px
    }
    .profile__text-wrap {
        margin-top: 16px;
    }
    .profile__text {
        font-size: 14px;
        line-height: 1.4;
    }
    .profile__text + .profile__text {
        margin-top: 16px;
    }
    .profile__map {
        flex: initial;
        margin-top: 0;
        width: 100%;
    }
    .profile__map iframe {
        border-radius: 20px;
        aspect-ratio: 310/215;
    }
    .history {
        background-color: var(--color-white);
        padding: 0;
        border-radius: 0 0 min(calc(40 / 1280 * 100vw), 2.925rem) min(calc(40 / 1280 * 100vw), 2.925rem);
    }
    .history__inner {
        padding: 40px 16px;
        background-color: #FFFDEB;
        border-radius: 20px;
    }
    .history__title {
        font-size: 20px;
        margin-top: 16px;
    }
    .history__timeline {
        margin-top: 16px;
    }
    .history__item {
        position: relative;
        display: flex;
        align-items: flex-start;
        margin-right: 0;
        padding-bottom: 20px;
    }
    .history__year {
        position: relative;
        flex: 0 1 80px;
        font-size: 28px;
        margin-right: 12px;
    }
    .history__item::before {
        content: '';
        position: absolute;
        left: 73px;
        top: 15px;
        border-right: 2.5px solid #BBBBBB;
    }
    .history__item:last-child::before {
        border-right: 2.5px dashed #BBBBBB;
    }
    .history__year::after {
        top: 50%;
        width: 12px;
        height: 12px;
    }
    .history__description {
        font-size: 14px;
        margin-top: 0;
    }
}