@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-works {
    position: relative;
    padding-top: min( calc(115/1280*100vw), 8.41rem);
}
.page-works__earth {
    position: absolute;
    width: min( calc(644/1280*100vw), 47.1rem);
    top: min( calc(180/1280*100vw), 11.25rem);
    left: 0;
}
.page-works__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-works__sun {
    position: absolute;
    top: 0;
    right: 0;
    width: min( calc(344/1280*100vw), 25.155rem);
    z-index: 1;
}
.page-works__sun .circle {
    position: absolute;
    top: 0;
    right: 0;
}
.page-works__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;
}



/* ============================================
Works Solve Section
============================================ */
.works-solve {
    margin-top: min( calc(50/1280*100vw), 3.65625rem);
}
.works-solve__inner {
    background-color: #FFFDEB;
    border-radius: min( calc(20/1280*100vw), 1.4625rem);
    padding: min( calc(40/1280*100vw), 2.925rem) min( calc(50/1280*100vw), 3.65625rem);
}
.works-solve__heading {
    font-size: min( calc(24/1280*100vw), 1.755rem);
    font-weight: bold;
}
.works-solve__content {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: min( calc(40/1280*100vw), 2.925rem);
    margin-top: min( calc(24/1280*100vw), 1.755rem);
}
.works-solve__icon {
    flex: 0 0 min( calc(120/1280*100vw), 8.775rem);
}
.works-solve__list {
    background-color: var(--color-white);
    border-radius: min( calc(12/1280*100vw), .8775rem);
    padding: min( calc(20/1280*100vw), 1.4625rem) min( calc(30/1280*100vw), 2.19375rem);
}
.works-solve__item {
    font-size: min( calc(18/1280*100vw), 1.31625rem);
    line-height: 1.8;
    position: relative;
    padding-left: 1.2em;
}
.works-solve__item::before {
    content: "・";
    position: absolute;
    left: 0;
}

/* ============================================
Works Language Section
============================================ */
.works-lang {
    margin-top: min( calc(60/1280*100vw), 4.3875rem);
}
.works-lang__inner {
    padding: 0 min( calc(50/1280*100vw), 3.65625rem);
}
.works-lang__grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: min( calc(30/1280*100vw), 2.19375rem);
    margin-top: min( calc(30/1280*100vw), 2.19375rem);
}
.works-lang__category {
    background-color: #FFFDEB;
    border-radius: min( calc(16/1280*100vw), 1.17rem);
    padding: min( calc(24/1280*100vw), 1.755rem);
}
.works-lang__category-title {
    font-size: min( calc(18/1280*100vw), 1.31625rem);
    font-weight: bold;
    text-align: center;
    padding: min( calc(8/1280*100vw), .585rem) 0;
    border-radius: min( calc(20/1280*100vw), 1.4625rem);
    color: var(--color-white);
}
.works-lang__category-title--frontend {
    background: linear-gradient(90deg, #4A90D9, #67B8DE);
}
.works-lang__category-title--backend {
    background: linear-gradient(90deg, #E8734A, #F5A623);
}
.works-lang__category-title--server {
    background: linear-gradient(90deg, #7BC67E, #A8D86B);
}
.works-lang__category-title--other {
    background: linear-gradient(90deg, #C084D9, #E8A4C8);
}
.works-lang__items {
    display: flex;
    flex-wrap: wrap;
    gap: min( calc(16/1280*100vw), 1.17rem);
    margin-top: min( calc(16/1280*100vw), 1.17rem);
    justify-content: center;
}
.works-lang__item {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: min( calc(6/1280*100vw), .43875rem);
    width: min( calc(80/1280*100vw), 5.85rem);
}
.works-lang__item img {
    width: min( calc(60/1280*100vw), 4.3875rem);
    height: min( calc(60/1280*100vw), 4.3875rem);
    object-fit: contain;
}
.works-lang__item span {
    font-size: min( calc(12/1280*100vw), .8775rem);
    text-align: center;
    line-height: 1.3;
}

/* ============================================
Works Achievement Section
============================================ */
.works-achievement {
    margin-top: min( calc(60/1280*100vw), 4.3875rem);
}
.works-achievement__inner {
    padding: 0 min( calc(50/1280*100vw), 3.65625rem);
}
.works-achievement__grid {
    display: grid;
    grid-template-columns: repeat(5, 1fr);
    gap: min( calc(20/1280*100vw), 1.4625rem);
    margin-top: min( calc(30/1280*100vw), 2.19375rem);
}
.works-achievement__item {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: min( calc(10/1280*100vw), .73125rem);
    background-color: #FFFDEB;
    border-radius: min( calc(12/1280*100vw), .8775rem);
    padding: min( calc(20/1280*100vw), 1.4625rem) min( calc(10/1280*100vw), .73125rem);
}
.works-achievement__icon {
    width: min( calc(80/1280*100vw), 5.85rem);
    height: min( calc(80/1280*100vw), 5.85rem);
}
.works-achievement__icon img {
    object-fit: contain;
}
.works-achievement__label {
    font-size: min( calc(14/1280*100vw), 1.02375rem);
    font-weight: bold;
    text-align: center;
    line-height: 1.4;
}

/* ============================================
Works Cases Section
============================================ */
.works-cases {
    margin-top: min( calc(60/1280*100vw), 4.3875rem);
    padding-bottom: min( calc(80/1280*100vw), 5.85rem);
}
.works-cases__inner {
    padding: 0 min( calc(50/1280*100vw), 3.65625rem);
}
.works-cases__list {
    display: flex;
    flex-direction: column;
    gap: min( calc(30/1280*100vw), 2.19375rem);
}
.works-cases__card {
    background-color: var(--color-white);
    border: 1px solid #EEEEEE;
    border-radius: min( calc(16/1280*100vw), 1.17rem);
    padding: min( calc(30/1280*100vw), 2.19375rem) min( calc(40/1280*100vw), 2.925rem);
}
.works-cases__card-category {
    display: flex;
    align-items: center;
    gap: min( calc(8/1280*100vw), .585rem);
    font-size: min( calc(14/1280*100vw), 1.02375rem);
    color: #888;
}
.works-cases__card-icon {
    display: flex;
    align-items: center;
}
.works-cases__card-icon img {
    width: min( calc(24/1280*100vw), 1.755rem);
    height: min( calc(24/1280*100vw), 1.755rem);
    object-fit: contain;
}
.works-cases__card-title {
    font-size: min( calc(24/1280*100vw), 1.755rem);
    font-weight: bold;
    margin-top: min( calc(12/1280*100vw), .8775rem);
}
.works-cases__card-text {
    font-size: min( calc(16/1280*100vw), 1.17rem);
    line-height: 1.7;
    margin-top: min( calc(12/1280*100vw), .8775rem);
    color: #666;
}
.works-cases__card-tags {
    display: flex;
    flex-wrap: wrap;
    gap: min( calc(8/1280*100vw), .585rem);
    margin-top: min( calc(16/1280*100vw), 1.17rem);
}
.works-cases__card-tag {
    font-size: min( calc(14/1280*100vw), 1.02375rem);
    padding: min( calc(4/1280*100vw), .2925rem) min( calc(16/1280*100vw), 1.17rem);
    border: 1px solid #DDDDDD;
    border-radius: min( calc(4/1280*100vw), .2925rem);
    color: #666;
}