/**/
@import url(https://fonts.googleapis.com/css?family=Noto+Sans+JP:300,400|Roboto:300,400&subset=japanese); body {
    color: #313131;
    background: #f4f4f4;
    font-family: Noto Sans JP, system-ui, -apple-system, Hiragino Sans, Yu Gothic UI, Segoe UI, Meiryo, sans-serif;
    line-height: 1.625;
    font-weight: 300;
    letter-spacing: 0.048em;
}

body, html {
    font-size: 16px;
    padding: 0;
    margin: 0;
}

html {
    box-sizing: border-box;
    overflow-y: scroll;
    -webkit-text-size-adjust: 100%;
}

header {
    background: #222B57;
    height: 122px;
    position: relative;
    z-index: 50;
}

header .header-logo {
    position: absolute;
    top: 50px;
    left: 65px;
    width: 163px;
}

body .container {
    background-color: #F0EEE9;
    padding-top: 120px;
}

body img {
    width: 100%;
}

header .navi-list {
    margin: 0;
    padding: 0;
    list-style: none;
    display: flex;
    color: white;
    position: absolute;
    top: 48px;
    right: 119px;
}

header .navi-list li {
    width: 115px;
}

header .button-search {
    width: 20px;
    height: 20px;
    position: absolute;
    top: 52px;
    right: 68px;
    background-image: url(../img/icon_search.png);
    background-size: 20px 20px;
}

section .fadein {
    opacity: 0;
    transform: translate(0px, 80px);
}

section .active {
    opacity: 1;
    transform: translate(0px, 0px);
    transition: opacity 0.6s linear, transform 0.6s cubic-bezier(0.09, 0.71, 0.35, 0.99);
}

.container section {
    position: relative;
}

.container section.bg-section {
    height: calc(100vw * 0.5125);
    background-size: contain;
}

.container section #top-movie {
    position: relative;
    top: 0;
    left: 0;
    padding-top: 45.625%;
    --breakpoint: pc;
}

.container section#top {
    height: auto;
    background-color: #000000;
    position: relative;
    z-index: 35;
}

.container section#top video {
    width: 100%;
    height: 100%;
    position: absolute;
    top: 0;
    left: 0;
}

.container section#top iframe {
    width: 100%;
    height: 100%;
    opacity: 0;
}

.container section#top iframe.youtube-fade {
    opacity: 1.0;
    transition: opacity 0.3s linear;
}

.container section#top .top-title {
    position: absolute;
    top: 40.5%;
    left: 7.6%;
    width: 46.2%;
    z-index: 35;
}

.container section#top .top-main-image {
    position: absolute;
    top: 17.7%;
    right: 7.6%;
    width: 33%;
}

.container section#weare {
    /* background-color: #F0EEE9; */
    margin-top: calc(100vw * -0.055);
    background-image: url("/wp/wp-content/themes/thinkings009/assets/img/top/section_weAreThinkings.png");
}

.container section#weare canvas {
    z-index: 15;
    position: absolute;
    top: 0;
    left: 0;
}

.container section#weare {
    z-index: 36;
}

.container .section-container {
    padding: 0 12.7%;
    display: flex;
    /* align-items: center; */
    justify-content: center;
    /* margin-top: 5.5%; */
}

.container #weare .section-container {
    padding-left: 0;
}

.container .weare-contianer {
    height: 100%;
    position: relative;
    overflow: hidden;
    z-index: 25;
    display: flex;
    align-items: center;
    justify-content: center;
}

.container section#companyprofile {
    background-image: url("/wp/wp-content/themes/thinkings009/assets/img/top/section_ourService.png");
    height: calc(100vw * 0.475625);
}

.container section#companyprofile .profile-right-block {
    overflow: hidden;
    position: relative;
    width: 100%;
    text-align: right;
    padding: 18% 0 0% 0;
}

.container section#companyprofile .profile-right-block .message {
    text-align: right;
    color: white;
    font-weight: bold;
    font-size: 16px;
    padding: 2% 0px 2.9% 0px;
    line-height: 1.9;
}

.container section#companyprofile .profile-right-block .h2-title {
    width: 46%;
    position: relative;
    display: inline-block;
    left: 2%;
    margin-top: -4%;
}

.container section#recruitment {
}

.container #recruitment .section-container {
    padding: 0 7.7%;
    padding-top: 8.3%;
    padding-bottom: 6%;
}

.container section#recruitment .recruitment-left-block {
    width: 47%;
    padding-left: 6.5%;
    margin-top: 0%;
}

.container section#recruitment .recruitment-left-block .h2-title {
    width: 66%;
    padding-bottom: 13%;
}

.container section#recruitment .recruitment-left-block .message {
    font-size: 16px;
    font-weight: bold;
    padding-bottom: 6.7%;
}

.container section#recruitment .recruitment-left-block .button-basic {
    float: left;
}

.container section#recruitment .recruitment-right-block {
    width: 53%;
    margin-top: -1.1%;
}

.container section#whats {
    background-image: url("/wp/wp-content/themes/thinkings009/assets/img/top/section_whatsthinings.png");
    height: calc(100vw * 0.500625);
}

.container #whats .section-container {
    padding: 0 4%;
}

.container section#whats .whats-left-block {
    width: 80%;
    padding-top: 13.5%;
    padding-bottom: 25%;
    text-align: right;
}

.container section#whats .whats-left-block .h2-title {
    width: 54%;
    padding-bottom: 2%;
    display: inline-block;
    margin-right: -3%;
}

.container section#whats .whats-left-block .message {
    color: white;
    font-size: 16px;
    font-weight: bold;
    text-align: right;
    padding-bottom: 32px;
}

.container .button-basic {
    font-size: 18px;
    color: #222B57;
    font-weight: bold;
    display: inline;
    padding: 13px 38px;
    border-radius: 30px;
    float: right;
    margin-top: 10px;
    border: 2px solid white;
    transition: background-color 0.3s linear, border 0.3s linear , color 0.3s linear;
}

.container .button-white {
    background-color: #ffffff;
    color: #222B57;
    border: 2px solid #ffffff;
}

.container .button-blue {
    background-color: #222B57;
    color: #ffffff;
    border: 2px solid #222B57;
}

section#weare .wearea-image {
    width: 49%;
    margin-top: 9%;
}

section#weare .wearea-right-block {
    position: relative;
    width: 61%;
    margin-top: -7.8%;
    text-align: right;
    acve }

section#weare .wearea-right-block .h2-title {
    width: 67%;
    text-align: right;
    display: inline-block;
}

section#weare .wearea-right-block p {
    text-align: right;
    font-size: max(calc(1.1vw, 16px));
    font-size: 16px;
    padding-top: 7%;
    line-height: 1.7;
    color: white;
    padding-bottom: 6%;
    font-weight: bold;
}

section#weare .wearea-right-block .button-basic {
}

section#ourservice {
    position: relative;
    z-index: 38;
}

section#ourservice .section-container {
    padding-top: 6.2%;
    padding-bottom: 5.5%;
}

section#ourservice .ourservice-left-block {
    width: 48%;
}

section#ourservice .h2-title {
    width: 56%;
    /* margin-top: 6%; */
    padding-bottom: 12%;
}

section#ourservice .h2-title img {
}

section#ourservice .service-message-left-block {
    overflow: hidden;
    width: 100%;
}

section#ourservice .service-message-left-block .message {
    font-size: 16px;
    width: 100%;
    margin: 0;
    font-weight: bold;
    line-height: 2;
    padding-bottom: 5.3%;
}

section#ourservice .service-right-block {
    width: 52%;
    position: relative;
    margin-top: -8%;
}

section#ourservice .service-right-block img {
    width: 100%;
    position: relative;
    margin-left: 6%;
}

section#ourservice .button-service {
    float: left;
    margin: 7% 0% 5% 0%;
}

section#ourservice .button-basic {
    float: left;
}

section#product {
    z-index: 70;
    display: flex;
    flex-flow: column;
    align-items: center;
    justify-content: center;
}

section#product .h2-title {
    width: 50%;
    padding: 1% 25%;
}

section#product .product-list {
    display: flex;
    flex-wrap: wrap;
    /* 折返し可 */
    justify-content: space-between;
    padding-top: 13.6%;
    padding-bottom: 15%;
}

section#product .product-list li {
    flex-basis: 48.8%;
    border-radius: 24px;
    margin-bottom: 2.2%;
    overflow: hidden;
}

section#product .product-list li a {
    display: flex;
    padding: 4.5%;
    height: 100%;
    background-color: white;
    transition: background-color 0.3s linear;
}

section#product .product-list li .list-thum {
    width: 39%;
}

section#product .product-list li .list-right-block {
    flex: 1;
    padding-left: 5%;
    line-height: 1.4;
}

section#product .product-list li .list-thum img {
    border: 1px solid #e9e9e9;
    box-sizing: border-box;
}

section#product .product-list li p {
    padding: 0% 0% 3% 0%;
    margin: 0;
    font-weight: bold;
    font-size: 18px;
}

section#product .product-list li p.product-body {
    font-size: 14px;
    line-height: 1.9;
    font-weight: normal;
}

section#news {
    z-index: 80;
}

section#news .section-container {
    display: flex;
    flex-flow: column;
    align-items: center;
    justify-content: center;
    margin: 0 auto;
    max-width: 1152px;
    padding: 0 5%;
}

section#news .h2-title {
    width: 16%;
    padding-top: 16%;
    padding-bottom: 7.6%;
}

section#news .news-list {
    list-style: none;
    margin: 0;
    width: 100%;
    padding-bottom: 19px;
}

section#news .news-list > li a {
    border-bottom: 1px solid black;
    display: flex;
    padding: 22px 0;
    transition: background-color 0.3s linear;
}

section#news .news-list > li:first-child a {
    border-top: 1px solid black;
}

section#news .news-list li .news-list-date {
    display: flex;
    justify-content: left;
    align-items: center;
    width: 153px;
    font-size: 18px;
}

section#news .news-list li .new-list-content {
    display: flex;
    justify-content: center;
    flex-flow: column;
    flex: 1;
}

section#news .news-list li .news-list-thum {
    width: 204px;
}

section#news .news-list li .new-list-content p {
    padding: 0;
    font-size: 16px;
    font-weight: bold;
    margin: 0;
    padding-bottom: 13px;
}

section#news .news-list li .new-list-content .tag-list {
    list-style: none;
    padding: 0;
    display: block;
}

section#news .news-list li .new-list-content .tag-list li {
    background-color: gray;
    color: white;
    font-size: 10px;
    padding: 4px 13px;
    margin: 0px 3px 0px 0px;
    border-radius: 4px;
    display: inline-block;
}

section#news .button-more {
    float: none;
    margin: 40px 0;
    display: inline-block;
    width: 190px;
    text-align: center;
}

body {
}

@media (min-width: 1600px) {
    .container section#weare {
    }
}

@media (max-width: 959px) {
    body .container {
        padding-top: 64px;
    }

    .container section #top-movie {
        position: relative;
        top: 0;
        left: 0;
        padding-top: 106.4432989690722%;
    }
}

@media (max-width: 959px) {
    .container section #top-movie {
        position: relative;
        top: 0;
        left: 0;
        padding-top: 45.625%;
        --breakpoint: pc;
    }

    .container .button-basic {
        font-size: 16px;
        padding: 12px 36px;
        border-radius: 30px;
        float: initial;
        display: inline-block;
    }

    section#weare .wearea-image {
        top: auto;
        width: 100%;
        height: 25%;
        position: relative;
        margin: 0;
        float: left;
        text-align: left;
    }

    section#weare .wearea-image img {
        width: 50%;
    }

    section#weare .wearea-right-block {
        position: relative;
        width: 100%;
        margin: auto;
        text-align: right;
        height: 75%;
        padding-right: 8.4%;
        padding-top: 15.8%;
    }

    section#weare .wearea-right-block .h2-title {
        width: 62.6%;
    }

    section#weare .wearea-right-block p {
        text-align: right;
        font-size: 2.1vw;
        margin: 6.1% 0 3.2% 0;
        line-height: 4.2vw;
        color: white;
        padding: 0;
    }

    .container .weare-contianer {
        position: relative;
        display: flex;
        align-items: center;
        flex-flow: column;
        height: 100%;
        margin: 0;
        padding: 0;
        flex-direction: column-reverse;
    }

    .container section#weare {
        /* background-color: #F0EEE9; */
        margin-top: calc(100vw * -0.0575);
        background-image: url("/wp/wp-content/themes/thinkings009/assets/img/top/tab/section_weAreThinkings.png");
        background-size: cover;
        z-index: 36;
    }

    .container section#weare.bg-section {
        height: calc(100vw * 1.03125);
    }

    section#ourservice {
        position: relative;
        z-index: 38;
        margin-top: -40px;
    }

    .container section#ourservice .section-container {
        padding: 0 5%;
        display: flex;
        align-items: center;
        justify-content: center;
        flex-flow: column;
        flex-direction: column-reverse;
    }

    section#ourservice .ourservice-left-block {
        width: 50%;
    }

    section#ourservice .h2-title {
        width: 54%;
        margin-top: 18%;
        padding-bottom: 8%;
    }

    section#ourservice .h2-title img {
    }

    section#ourservice .service-message-left-block {
        overflow: hidden;
        width: 100%;
    }

    section#ourservice .service-message-left-block .message {
        font-size: 18px;
        width: 100%;
        margin: 0;
        font-weight: bold;
        line-height: 1.8;
        padding-bottom: 6%;
    }

    section#ourservice .service-right-block {
        width: 50%;
        position: relative;
    }

    section#ourservice .service-right-block img {
        width: 101%;
        position: relative;
        margin-top: 10%;
        margin-left: 5%;
    }

    section#ourservice .button-service {
        float: left;
        margin: 7% 0% 5% 0%;
    }

    section#ourservice .button-basic {
        float: left;
    }

    section#ourservice {
        position: relative;
        z-index: 38;
        margin-top: -40px;
    }

    section#ourservice .ourservice-left-block {
        width: 100%;
        text-align: center;
    }

    section#ourservice .h2-title {
        width: 40%;
        padding: 0;
        text-align: center;
        margin: 6.2% auto 5.8% auto;
    }

    section#ourservice .h2-title img {
    }

    section#ourservice .service-message-left-block {
        overflow: hidden;
        width: 100%;
        padding-bottom: 11%;
    }

    section#ourservice .service-message-left-block .message {
        font-size: 16px;
        width: 100%;
        margin: 0;
        font-weight: bold;
        line-height: 2;
        padding-bottom: 5.3%;
    }

    section#ourservice .service-right-block {
        width: 76%;
        position: relative;
        padding-top: 13.8%;
    }

    section#ourservice .service-right-block img {
        width: 100%;
        position: relative;
        padding: 0;
        margin: 0;
    }

    section#ourservice .button-service {
        float: left;
        margin: 7% 0% 5% 0%;
    }

    section#ourservice .button-basic {
        float: initial;
        margin: 0 auto;
        display: inline-block;
    }

    .container section#companyprofile .section-container {
        padding: 0 0%;
        display: flex;
        align-items: center;
        justify-content: center;
        flex-direction: column-reverse;
        height: 100%;
    }

    .container section#companyprofile {
        background-image: url("/wp/wp-content/themes/thinkings009/assets/img/top/tab/section_ourService.png");
        background-size: cover;
        height: calc(100vw * 0.7578125);
    }

    .container section#companyprofile .profile-right-block {
        overflow: hidden;
        position: relative;
        width: 100%;
        text-align: center;
        padding: 0;
        display: flex;
        align-items: center;
        justify-content: center;
        flex-flow: column;
        margin-top: -9%;
    }

    .container section#companyprofile .profile-right-block .message {
        text-align: center;
        color: white;
        font-weight: bold;
        font-size: 16px;
        padding: 2% 0px 3% 0px;
        line-height: 2;
    }

    .container section#companyprofile .profile-right-block .h2-title {
        width: 62%;
        position: relative;
        display: inline-block;
        left: auto;
        margin-top: 5%;
    }

    .container #recruitment .section-container {
        display: flex;
        align-items: center;
        justify-content: center;
        flex-direction: column-reverse;
        height: 100%;
        padding: 0;
    }

    .container section#recruitment .recruitment-left-block {
        width: 100%;
        padding: 0 5% 12% 5%;
        margin: 0;
        text-align: center;
    }

    .container section#recruitment .recruitment-left-block .h2-title {
        width: 45%;
        margin: 0;
        display: inline-block;
        padding: 9% 0 7% 0;
    }

    .container section#recruitment .recruitment-left-block .message {
        font-size: 16px;
        font-weight: bold;
        padding: 0 0 5% 0;
        display: inline-block;
        width: 100%;
    }

    .container section#recruitment .recruitment-left-block .button-basic {
        float: initial;
        display: inline-block;
    }

    .container section#recruitment .recruitment-right-block {
        width: 90%;
        padding-top: 13%;
    }

    .container section#whats {
        background-image: url("/wp/wp-content/themes/thinkings009/assets/img/top/tab/section_whatsthinings.png");
        background-size: cover;
        height: calc(100vw * 0.7578125);
    }

    .container #whats .section-container {
        padding: 0;
        display: flex;
        align-items: center;
        justify-content: center;
        flex-direction: column-reverse;
        height: 100%;
    }

    .container section#whats .whats-left-block {
        width: 100%;
        padding: 0;
        text-align: center;
        margin-top: -9%;
    }

    .container section#whats .whats-left-block .h2-title {
        width: 70%;
        padding: 0 0 1.9% 0;
        display: inline-block;
        margin: 0;
    }

    .container section#whats .whats-left-block .message {
        color: white;
        font-size: 16px;
        font-weight: bold;
        text-align: center;
        padding: 0 5% 4% 5%;
    }

    section#news .h2-title {
        width: 19%;
        padding-top: 11.5%;
        padding-bottom: 8.4%;
    }

    section#news .news-list {
        list-style: none;
        margin: 0;
        width: 100%;
        padding-bottom: 19px;
    }

    section#news .news-list > li a {
        border-bottom: 1px solid black;
        display: flex;
        padding: 71px 0 22px 0;
        transition: background-color 0.3s linear;
        align-items: center;
        justify-content: center;
        position: relative;
    }

    section#news .news-list > li:first-child a {
        border-top: 1px solid black;
    }

    section#news .news-list li .news-list-date {
        display: inline-block;
        width: auto;
        font-size: 18px;
        position: absolute;
        top: 26px;
        left: 0;
    }

    section#news .news-list li .new-list-content {
        display: flex;
        justify-content: center;
        flex-flow: column;
        flex: 1;
        padding-right: 182px;
    }

    section#news .news-list li .news-list-thum {
        width: 164px;
        position: absolute;
        top: 50%;
        margin-top: -43px;
        right: 0;
    }

    section#news .news-list li .new-list-content p {
        padding: 0;
        font-size: 16px;
        font-weight: bold;
        margin: 0;
        padding-bottom: 13px;
    }

    section#news .news-list li .new-list-content .tag-list {
        list-style: none;
        padding: 0;
        display: block;
    }

    section#news .news-list li .new-list-content .tag-list li {
        background-color: gray;
        color: white;
        font-size: 10px;
        padding: 4px 13px;
        border-radius: 4px;
    }

    section#product {
        z-index: 70;
        display: flex;
        flex-flow: column;
        align-items: center;
        justify-content: center;
    }

    .container section#product .section-container {
        padding: 0 5.4%;
        display: flex;
        align-items: center;
        justify-content: center;
    }

    section#product .h2-title {
        width: 50%;
        padding: 1% 25%;
    }

    section#product .product-list {
        display: flex;
        flex-wrap: wrap;
        /* 折返し可 */
        justify-content: space-between;
        padding-top: 18.3%;
        padding-bottom: 21%;
    }

    section#product .product-list li {
        flex-basis: auto;
        border-radius: 17px;
        margin-bottom: 2.7%;
        overflow: hidden;
    }

    section#product .product-list li a {
        display: flex;
        padding: 3.1%;
        height: 100%;
        background-color: white;
        transition: background-color 0.3s linear;
    }

    section#product .product-list li a:hover {
        background-color: #e9e9e9;
        transition: background-color 0.1s linear;
    }

    section#product .product-list li .list-thum {
        width: 33%;
    }

    section#product .product-list li .list-right-block {
        flex: 1;
        padding-left: 4%;
        line-height: 1.1;
    }

    section#product .product-list li .list-thum img {
        border: 1px solid #e9e9e9;
        box-sizing: border-box;
    }

    section#product .product-list li p {
        padding: 0% 0% 3% 0%;
        margin: 0;
        font-weight: bold;
        font-size: 18px;
        line-height: 1.3;
    }

    section#product .product-list li p.product-body {
        font-size: 14px;
        line-height: 1.9;
        font-weight: normal;
    }
}

@media (max-width: 768px) {
    .container section #top-movie {
        position: relative;
        top: 0;
        left: 0;
        padding-top: 106.4432989690722%;
        --breakpoint: sp;
    }
}

@media (max-width: 470px) {
    .container section #top-movie {
        position: relative;
        top: 0;
        left: 0;
        padding-top: 106.4432989690722%;
        --breakpoint: sp;
    }

    .container .button-basic {
        font-size: 14px;
        padding: 12px 36px;
        border-radius: 30px;
        float: initial;
        display: inline-block;
    }

    section#weare .wearea-image {
        top: auto;
        width: 100%;
        height: 20%;
        position: relative;
        margin: 0;
        float: left;
        text-align: left;
    }

    section#weare .wearea-image img {
        width: 68%;
    }

    section#weare .wearea-right-block {
        position: relative;
        width: 100%;
        margin: auto;
        text-align: center;
        height: 80%;
        padding: 22% 0 0 0;
    }

    section#weare .wearea-right-block .h2-title {
        width: 67.6%;
        text-align: center;
    }

    section#weare .wearea-right-block p {
        text-align: center;
        font-size: 14px;
        margin: 10% 0 4.2% 0;
        line-height: 1.7;
        color: white;
        padding: 0;
    }

    .container .weare-contianer {
        position: relative;
        display: flex;
        align-items: center;
        flex-flow: column;
        height: 100%;
        margin: 0;
        padding: 0;
        flex-direction: column-reverse;
    }

    .container section#weare {
        /* background-color: #F0EEE9; */
        margin-top: calc(100vw * -0.0575);
        background-image: url("/wp/wp-content/themes/thinkings009/assets/img/top/sp/section_weAreThinkings.png");
        background-size: cover;
        z-index: 36;
    }

    .container section#weare.bg-section {
        height: calc(100vw * 1.616);
    }

    section#ourservice {
        position: relative;
        z-index: 38;
        margin-top: -40px;
    }

    .container section#ourservice .section-container {
        padding: 0 0.8%;
        display: flex;
        align-items: center;
        justify-content: center;
        flex-flow: column;
        flex-direction: column-reverse;
    }

    section#ourservice .ourservice-left-block {
        width: 50%;
    }

    section#ourservice .h2-title {
        width: 54%;
        margin-top: 18%;
        padding-bottom: 8%;
    }

    section#ourservice .h2-title img {
    }

    section#ourservice .service-message-left-block {
        overflow: hidden;
        width: 100%;
    }

    section#ourservice .service-message-left-block .message {
        font-size: 18px;
        width: 100%;
        margin: 0;
        font-weight: bold;
        line-height: 1.8;
        padding-bottom: 6%;
    }

    section#ourservice .service-right-block {
        width: 50%;
        position: relative;
    }

    section#ourservice .service-right-block img {
        width: 101%;
        position: relative;
        margin-top: 10%;
        margin-left: 5%;
    }

    section#ourservice .button-service {
        float: left;
        margin: 7% 0% 5% 0%;
    }

    section#ourservice .button-basic {
        float: left;
    }

    section#ourservice {
        position: relative;
        z-index: 38;
        margin-top: -40px;
    }

    section#ourservice .ourservice-left-block {
        width: 100%;
        text-align: center;
    }

    section#ourservice .h2-title {
        width: 44%;
        padding: 0;
        text-align: center;
        margin: 8.8% auto 7.8% auto;
    }

    section#ourservice .h2-title img {
    }

    section#ourservice .service-message-left-block {
        overflow: hidden;
        width: 100%;
        padding: 1% 6% 16% 6%;
    }

    section#ourservice .service-message-left-block .message {
        font-size: 14px;
        width: 100%;
        margin: 0;
        font-weight: bold;
        line-height: 1.8;
        padding-bottom: 9%;
    }

    section#ourservice .service-right-block {
        width: 95%;
        position: relative;
        padding-top: 21%;
    }

    section#ourservice .service-right-block img {
        width: 100%;
        position: relative;
        margin: 0;
    }

    section#ourservice .button-service {
        float: left;
        margin: 7% 0% 5% 0%;
    }

    section#ourservice .button-basic {
        float: initial;
        margin: 0 auto;
        display: inline-block;
    }

    .container section#companyprofile .section-container {
        padding: 0 0%;
        display: flex;
        align-items: center;
        justify-content: center;
        flex-direction: column-reverse;
        height: 100%;
    }

    .container section#companyprofile {
        background-image: url("/wp/wp-content/themes/thinkings009/assets/img/top/sp/section_ourService.png");
        background-size: cover;
        height: calc(100vw * 1.069333333333333);
    }

    .container section#companyprofile .profile-right-block {
        overflow: hidden;
        position: relative;
        width: 100%;
        text-align: center;
        padding: 0;
        display: flex;
        align-items: center;
        justify-content: center;
        flex-flow: column;
    }

    .container section#companyprofile .profile-right-block .message {
        text-align: center;
        color: white;
        font-weight: bold;
        font-size: 14px;
        padding: 4% 0px 4% 0px;
        line-height: 1.8;
    }

    .container section#companyprofile .profile-right-block .h2-title {
        width: 74%;
        position: relative;
        display: inline-block;
        left: auto;
        margin-top: 4%;
    }

    .container #recruitment .section-container {
        display: flex;
        align-items: center;
        justify-content: center;
        flex-direction: column-reverse;
        height: 100%;
        padding: 0;
    }

    .container section#recruitment .recruitment-left-block {
        width: 100%;
        padding: 0 0 15% 0;
        margin: 0;
        text-align: center;
    }

    .container section#recruitment .recruitment-left-block .h2-title {
        width: 49%;
        padding: 15% 0 10% 0;
        margin: 0;
        display: inline-block;
    }

    .container section#recruitment .recruitment-left-block .message {
        font-size: 14px;
        font-weight: bold;
        padding: 0 0 6% 0;
        display: inline-block;
    }

    .container section#recruitment .recruitment-left-block .button-basic {
        float: initial;
        display: inline-block;
    }

    .container section#recruitment .recruitment-right-block {
        width: 100%;
        padding-top: 13%;
    }

    .container section#whats {
        background-image: url("/wp/wp-content/themes/thinkings009/assets/img/top/sp/section_whatsthinings.png");
        background-size: cover;
        height: calc(100vw * 1.037333333333333);
    }

    .container #whats .section-container {
        padding: 0;
        display: flex;
        align-items: center;
        justify-content: center;
        flex-direction: column-reverse;
        height: 100%;
    }

    .container section#whats .whats-left-block {
        width: 100%;
        padding: 0;
        text-align: center;
        margin-top: -13%;
    }

    .container section#whats .whats-left-block .h2-title {
        width: 85%;
        padding: 7% 0 3.3% 0;
        display: inline-block;
        margin: 0;
    }

    .container section#whats .whats-left-block .message {
        color: white;
        font-size: 14px;
        font-weight: bold;
        text-align: center;
        padding-bottom: 3%;
        line-height: 2.1;
    }

    section#news .h2-title {
        width: 28%;
        padding-top: 20.5%;
        padding-bottom: 12%;
    }

    section#news .news-list {
        list-style: none;
        margin: 0;
        width: 100%;
        padding-bottom: 0;
    }

    section#news .news-list > li a {
        border-bottom: 1px solid black;
        display: flex;
        padding: 52px 0 22px 0;
        transition: background-color 0.3s linear;
        align-items: flex-start;
        justify-content: center;
        position: relative;
    }

    section#news .news-list > li:first-child a {
        border-top: 1px solid black;
    }

    section#news .news-list > li a:hover {
        background-color: #e7e4dd;
        transition: background-color 0.1s linear;
    }

    section#news .news-list li .news-list-date {
        display: inline-block;
        width: auto;
        font-size: 14px;
        position: absolute;
        top: 21px;
        left: 0;
    }

    section#news .news-list li .new-list-content {
        display: flex;
        justify-content: center;
        flex-flow: column;
        flex: 1;
        padding-right: 117px;
    }

    section#news .news-list li .news-list-thum {
        width: 104px;
        position: absolute;
        top: auto;
        margin-top: 0;
        right: 0;
    }

    section#news .news-list li .new-list-content p {
        padding: 0;
        font-size: 12px;
        font-weight: bold;
        margin: 0;
        padding-bottom: 13px;
    }

    section#news .news-list li .new-list-content .tag-list {
        list-style: none;
        padding: 0;
        display: flex;
    }

    section#news .news-list li .new-list-content .tag-list li {
        background-color: gray;
        color: white;
        font-size: 10px;
        padding: 4px 13px;
        margin: 0px 8px 0px 0px;
        border-radius: 4px;
    }

    section#product {
        z-index: 70;
        display: flex;
        flex-flow: column;
        align-items: center;
        justify-content: center;
    }

    .container section#product .section-container {
        padding: 0 5.9%;
        display: flex;
        align-items: center;
        justify-content: center;
    }

    section#product .h2-title {
        width: 50%;
        padding: 1% 25%;
    }

    section#product .product-list {
        display: flex;
        flex-wrap: wrap;
        /* 折返し可 */
        justify-content: space-between;
        padding-top: 23.3%;
        padding-bottom: 34%;
    }

    section#product .product-list li {
        flex-basis: auto;
        border-radius: 17px;
        margin-bottom: 4.9%;
        overflow: hidden;
    }

    section#product .product-list li a {
        display: flex;
        flex-flow: column;
        padding: 5.2%;
        height: 100%;
        background-color: white;
        transition: background-color 0.3s linear;
    }

    section#product .product-list li a:hover {
        background-color: #e9e9e9;
        transition: background-color 0.1s linear;
    }

    section#product .product-list li .list-thum {
        width: 100%;
    }

    section#product .product-list li .list-right-block {
        flex: 1;
        padding: 7% 0 0 0;
        line-height: 1.1;
    }

    section#product .product-list li .list-thum img {
        border: 1px solid #e9e9e9;
        box-sizing: border-box;
    }

    section#product .product-list li p {
        padding: 0% 0% 3% 0%;
        margin: 0;
        font-weight: bold;
        font-size: 14px;
        line-height: 1.3;
    }

    section#product .product-list li p.product-body {
        font-size: 12px;
        line-height: 1.9;
        font-weight: normal;
        padding: 0;
    }
}

@media (hover: hover) and (pointer: fine) {
    .container .button-basic:hover {
        background-color: #F0F2FF;
        color: #272930;
        border: 2px solid #272930;
        transition: background-color 0.1s linear, border 0.1s linear, color 0.1s linear;
    }

    section#product .product-list li a:hover {
        background-color: #e9e9e9;
        transition: background-color 0.1s linear;
    }

    section#news .news-list > li a:hover {
        background-color: #e7e4dd;
        transition: background-color 0.1s linear;
    }

    section .fadein {
        opacity: 0;
        transform: translate(0px, 50px);
    }

    section .active {
        opacity: 1;
        transform: translate(0px, 0px);
        transition: opacity 0.6s linear, transform 0.6s cubic-bezier(0.09, 0.71, 0.35, 0.99);
    }
}
