@charset "utf-8";


/**
 * スマホ用設定
 */
@media ( width < 768px ) {

    #mv1 {
        margin: 60px auto 0;
        padding: 12.0vw 0 0;
        width: 100%;
        height: auto;
        background: #f7f7f7;
    }
    #mv2 {
        margin: 60px auto 0;
        padding: 0;
        width: 100%;
        height: auto;
        aspect-ratio: 2 / 1;
        display: flex;
        flex-direction: column;
        justify-content: center;
    }
    #mv2::before {
        position: absolute;
        content: "";
        top: 0;
        left: 0;
        width: 100%;
        height: 100%;
        background: url(../images/top-section-bg.webp) no-repeat center / cover;
        opacity: 0.3;
        z-index: -1;
    }
    .mv > .mv-box {
        margin: 0 auto;
        padding: 0;
        width: 90%;
    }
    .mv > .mv-box span:nth-of-type(1) {
        display: block;
        color: #3a4689;
        font-size: 3.2vw;
        font-weight: 700;
    }
    .mv > .mv-box span:nth-of-type(2) {
        display: block;
        font-size: 8.0vw;
        font-weight: 700;
        font-family: var(--font-alphabet);
    }
    .mv > .breadcrumbs {
        margin: 4.0vw auto 0;
        padding: 0;
        width: 90%;
        color: #cecece;
        font-size: 2.8vw;
        font-weight: 400;
        line-height: 1.0;
    }
    .mv > .breadcrumbs a {
        color: #cecece;
    }
    #mv2 > .breadcrumbs,
    #mv2 > .breadcrumbs a {
        color: #787878;
    }
    .mv > .breadcrumbs :last-child,
    .mv > .breadcrumbs :last-child a {
        color: var(--fg-color);
    }
    .mv > .mv-bg {
        width: 100%;
        margin: 0;
        padding: 0;
        width: 100%;
        height: auto;
        aspect-ratio: 1440/ 500;
        clip-path: polygon( 0 20%, 100% 0, 100% 80%, 0 100% );
        overflow: hidden;
    }
    .mv > .mv-bg img {
        width: 100%;
        height: 100%;
        object-position: center top;
        object-fit: cover;
    }
    .mv > .mv-flex {
        margin: 0 auto;
        padding: 4.0vw 0;
        width: 90%;
        display: flex;
        flex-direction: column;
        align-items: center;
        justify-content: center;
        gap: 8.0vw 0;
    }
    .mv-flex .movie {
        margin: 0 auto;
        width: 80%;
        height: auto;
        aspect-ratio: 508 / 298;
    }
    .mv-flex .movie iframe {
        width: 100%;
        height: 100%;
    }
    .mv-flex .mv-info {
        width: 100%;
    }
    .mv-flex .mv-info > .head {
        font-size: 4.0vw;
        font-weight: 700;
    }
    .mv-flex .mv-info > p {
        margin: 2.0vw 0 0;
        font-size: 3.2vw;
        font-weight: 500;
    }
    .mv-flex .mv-info > a {
        display: flex;
        align-items: center;
        justify-content: space-between;
        gap: 0 0.5em;

        margin: 3.0vw auto 0;
        padding: 0 1.5em;
        width: 100%;
        max-width: 320px;
        height: auto;
        aspect-ratio: 320 / 62;
        background: #3a4689;

        color: #fff;
        font-size: 3.2vwx
        font-weight: 700;
        line-height: 1.0;
    }
    .mv-flex .mv-info > a::after {
        display: block;
        content: "";
        width: 2.2em;
        height: auto;
        aspect-ratio: 30 / 4;
        background: url(../images/arrow-r-white.svg) no-repeat center / contain;
    }
    .mv > #mv-slider {
        margin: 0 auto;
        padding: 4.0vw 0;
        width: 100%;
        height: 16.0vw;
        background: rgba( 255, 255, 255, 0.4 );
    }
    .mv > #mv-slider .swiper-wrapper {
        transition-timing-function: linear;
    }
    .mv > #mv-slider .swiper-wrapper .swiper-slide {
        flex-shrink: 0;
        width: auto;
        height: 100%;
    }
    .mv > #mv-slider .swiper-wrapper .swiper-slide figure {
        width: auto;
        height: 100%;
    }
    .mv > #mv-slider .swiper-wrapper .swiper-slide figure img {
        width: auto;
        height: 100%;
    }
    .mv-logos {
        margin: 0 auto;
        padding: 2.0vw;
        width: 100%;
        background: #fff;
        display: flex;
        flex-wrap: wrap;
        align-items: flex-start;
        justify-content: center;
        gap: 2.0vw 4.0vw;
    }
    .mv-logos .logo-item {
        width: auto;
        height: 5.0vw;
    }
    .mv-logos .logo-item figure {
        width: auto;
        height: 5.0vw;
    }
    .mv-logos .logo-item figure img {
        width: auto;
        height: 5.0vw;
        object-fit: cover;
    }

    .page-menu {
        margin: 0 auto;
        padding: 4.0vw 5%;
        width: 100%;
        display: grid;
        grid-template-columns: repeat( 3, 1fr );
        gap: 4.0vw 4.0vw;
        background: #f7f7f7;
    }
    .page-menu.col4 {
        grid-template-columns: repeat( 2, 1fr );
    }
    .page-menu .page-menu-item {
        position: relative;
        display: block;
        padding: 0 0 4.0vw;
        width: 100%;
        border-bottom: 1px solid var(--fg-color);
    }
    .page-menu .page-menu-item::after {
        position: absolute;
        content: "";
        bottom: 1.0vw;
        left: calc( 50% - 80.0vw / 1200 );
        width: calc( 16 * 80.0vw / 1200 );
        height: auto;
        aspect-ratio: 1 / 1;
        border-right: 2px solid var(--fg-color);
        border-bottom: 2px solid var(--fg-color);
        rotate: 45deg;
    }
    .page-menu .page-menu-item span:nth-of-type(1) {
        display: block;
        width: 100%;
        color: #a5a5a5;
        font-size: 3.2vw;
        font-weight: 400;
        font-family: var(--font-alphabet);
        text-align: center;
        line-height: 1.2;
    }
    .page-menu .page-menu-item span:nth-of-type(2) {
        display: block;
        width: 100%;
        font-size: 3.2vw;
        font-weight: 700;
        text-align: center;
        line-height: 1.2;
    }

    .common-section {
        margin: 0 auto;
        padding: 8.0vw 5%;
        width: 100%;
        background: #f7f7f7;
    }
    .common-section > h2 {
        position: relative;
        margin: 1.0em auto 0;
        font-size: 8.0vw;
        font-weight: 700;
        font-family: var(--font-alphabet);
        line-height: 1.0;
    }
    .common-section > h2::before {
        position: absolute;
        content: attr(data-subtitle);
        left: 0;
        bottom: calc( 100% + 1.0em );
        display: block;
        color: #3a4689;
        font-size: 3.2vw;
        font-weight: 700;
    }
    .common-section > .service-flex {
        margin: 4.0vw auto 0;
        width: 100%;
        display: flex;
        flex-direction: column;
        align-items: center;
        justify-content: center;
        gap: 8.0vw 0;
    }
    .common-section > .service-flex + .service-flex {
        margin-top: 6.0vw;
    }
    .service-flex .pic {
        margin: 0 auto;
        width: 90%;
        height: auto;
        aspect-ratio: 583 / 380;
        order: 1;
    }
    .service-flex .pic img {
        width: 100%;
        height: 100%;
        object-fit: cover;
    }
    .service-flex .service-info {
        width: 100%;
        order: 2;
    }
    .service-flex .service-info > .head {
        font-size: 4.0vw;
        font-weight: 700;
    }
    .service-flex .service-info > p {
        margin: 2.0vw 0 0;
        font-size: 3.2vw;
        font-weight: 500;
    }
    .service-flex .service-info > a {
        display: flex;
        align-items: center;
        justify-content: space-between;
        gap: 0 0.5em;

        margin: 3.0vw auto 0;
        padding: 0 1.5em;
        width: 100%;
        max-width: 320px;
        height: auto;
        aspect-ratio: 320 / 62;
        background: #3a4689;

        color: #fff;
        font-size: 3.2vwx
        font-weight: 700;
        line-height: 1.0;
    }
    .service-flex .service-info > a::after {
        display: block;
        content: "";
        width: 2.2em;
        height: auto;
        aspect-ratio: 30 / 4;
        background: url(../images/arrow-r-white.svg) no-repeat center / contain;
    }
    .common-section > h3 {
        margin: 1.0em auto 0;
        padding: 0 0 0 1.0em;
        font-size: 4.8vw;
        font-weight: 700;
        font-family: var(--font-alphabet);
        line-height: 1.0;
        border-left: 6px solid #3a4689;
    }
    .common-section > .service-grid {
        margin: 2.0vw auto 0;
        padding: 0;
        width: 100%;
        display: grid;
        grid-template-columns: repeat( 2, 1fr );
        gap: 4.0vw 0.2vw;
        background: #edf2f7;
    }
    .common-section > .service-grid.col2 {
        grid-template-columns: repeat( 2, 1fr );
    }
    .service-grid .service-item {
        width: 100%;
        display: grid;
        grid-template-rows: subgrid;
        grid-row: span 3;
        gap: 10px 0;
    }
    .service-grid .service-item > .pic {
        margin: 0 0 10px;
        width: 100%;
        height: auto;
        aspect-ratio: 405 / 250;
        overflow: hidden;
    }
    .service-grid.col2 .service-item > .pic {
        aspect-ratio: 610 / 290;
    }
    .service-grid .service-item > .pic img {
        width: 100%;
        height: 100%;
        object-fit: cover;
    }
    .service-grid .service-item > .head {
        margin: 0 auto;
        width: 90%;
        font-size: 3.2vw;
        font-weight: 700;
    }
    .service-grid .service-item > p {
        margin: 0 auto;
        width: 90%;
        font-size: 2.8vw;
        font-weight: 400;
    }
    .common-section .feature-pic {
        margin: 4.0vw auto 0;
        width: 100%;
        height: auto;
    }
    .common-section .feature-pic img {
        width: 100%;
        height: auto;
    }
    .common-section .feature-grid {
        margin: 4.0vw auto 0;
        width: 100%;
        display: grid;
        grid-template-columns: repeat( 2, 1fr );
        gap: 3.0vw 2.0vw;
    }
    .feature-grid .feature-item {
        position: relative;
        margin: 0;
        padding: 1.5em 1.0em 1.0em;
        width: 100%;
        font-size: 3.2vw;
        font-weight: 500;
        background: #fff;
        border: 1px solid #bcbcbc;
        box-shadow: 0 0 4px rgba( 0, 0, 0, 0.25 );
    }
    .feature-grid .feature-item::before {
        position: absolute;
        content: "‘‘";
        top: -0.3em;
        left: -0.05em;
        color: #3a4689;
        font-size: 6.0vw;
        font-weight: 700;
        line-height: 1.0;
    }

    #thanks {
        margin: 60px auto 0;
        padding: 12.0vw 0;
        width: 100%;
    }
    #thanks > h1 {
        position: relative;
        margin: 0 0 2.0em;
        padding: 0;
        width: 100%;
        font-size: 6.0vw;
        font-weight: 700;
        text-align: center;
    }
    #thanks > h1::after {
        position: absolute;
        content: "";
        top: calc( 100% + 10px );
        left: calc( 50% - 15px );
        width: 30px;
        height: 6px;
        background: var(--color-theme);
    }
    #thanks > p {
        margin: 1.0em 0 0;
        padding: 0;
        width: 100%;
        font-size: 3.2vw;
        font-weight: 500;
        text-align: center;
    }

    #privacy {
        margin: 0 auto;
        padding: 8.0vw 0;
        width: 90%;
    }
    #privacy > .head {
        margin: 0;
        padding: 0;
        font-size: 3.6vw;
        font-weight: 500;
    }
    #privacy > h2 {
        margin: 2.0em 0 0.8em;
        padding: 0 0 0 1.0em;
        color: #3a4689;
        font-size: 3.6vw;
        font-weight: 700;
        border-left: 4px solid #3a4689;
    }
    #privacy > p {
        margin: 0;
        padding: 0;
        font-size: 3.2vw;
        font-weight: 400;
    }
    #privacy > ul {
        margin: 0 0 0 4.0vw;
        padding: 0;
    }
    #privacy > ul li {
        font-size: 3.2vw;
        font-weight: 400;
    }

    #form {
        margin: 0 auto;
        padding: 12.0vw 0;
        width: 100%;
        background: #f7f7f7;
    }
    #form > .memo {
        margin: 0 auto;
        width: 90%;
        color: #f00;
        font-size: 2.8vw;
        font-weight: 500;
        text-align: right;
    }
    #form > .form-box {
        margin: 1.0vw auto 0;
        padding: 5.0vw 5.0vw 8.0vw;
        width: 90%;
        background: #fff;
    }
    .form-box .label {
        display: block;
        margin: 6.0vw 0 2.0vw;
        width: 100%;
        font-size: max( 18px, 4.0vw );
        font-weight: 700;
    }
    .form-box .label:nth-of-type(1) {
        margin-top: 0;
    }        
    .form-box .label::after {
        content: "*";
        color: #f00;
    }
    .form-box :is(input[type="text"],input[type="email"],input[type="tel"]) {
        display: block;
        margin: 0;
        padding: 1.0em;
        width: 100%;
        font-size: max( 16px, 3.6vw );
        font-weight: 500;
        font-family: inherit;
        background: #f7f7f7;
        border: 0;
    }
    .form-box :is(input[type="text"],input[type="email"],input[type="tel"])::placeholder {
        color: #a1a1a1;
    }
    .form-box .submit {
        margin: 6.0vw 0 0;
        display: flex;
        flex-direction: column;
        align-items: center;
        justify-content: center;
        gap: 4.0vw 0;
    }
    .form-box .submit p {
        margin: 0;
        font-size: 3.2vw;
        font-weight: 400;
    }
    .form-box .submit p a {
        text-decoration: underline;
    }
    .form-box .submit input[type="submit"] {
        margin: 0;
        padding: 0.5em 4.0em;
        color: #fff;
        font-size: 3.2vw;
        font-family: inherit;
        line-height: 1.0;
        background: var(--color-theme);
        border: 0;
    }

    .company-wrap {
        margin: 0 auto;
        padding: 12.0vw 5%;
        width: 100%;
        display: flex;
        align-items: stretch;
        justify-content: space-between;
    }
    .company-wrap .company-sidebar {
        display: none;
        margin: 0;
        padding: 0;
        width: 200px;
    }
    .company-wrap .company-sidebar .company-links {
        position: sticky;
        top: 100px;
        background: #f7f7f7;
    }
    .company-wrap .company-sidebar .company-links a {
        display: block;
        margin: 0.5em 0;
        color: #bababa;
        color: var(--fg-color);
    }
    .company-wrap .company-sidebar .company-links a.active {
        color: var(--fg-color);
    }
    .company-wrap .company-contents {
        margin: 0;
        padding: 0;
        width: calc( 100% - 200px );
        width: 100%;
    }
    .company-wrap .company-contents .company-content + .company-content {
        margin-top: 16.0vw;
    }
    .company-wrap .company-contents h2 {
        margin: 0 0 8.0vw;
    }
    .company-wrap .company-contents h2 span:nth-of-type(1) {
        display: block;
        color: #3a4689;
        font-size: 3.2vw;
        font-weight: 700;
        text-align: center;
    }
    .company-wrap .company-contents h2 span:nth-of-type(2) {
        display: block;
        font-size: 4.8vw;
        font-weight: 700;
        text-align: center;
    }
    .company-wrap .company-message-flex {
        display: flex;
        flex-direction: column;
        align-items: center;
        justify-content: center;
        gap: 6.0vw 0;
    }
    .company-wrap .company-message-flex .company-message-info {
        width: 100%;
    }
    .company-wrap .company-message-flex .company-message-info h3 {
        margin: 0 0 1.0em;
        font-size: 4.8vw;
        font-weight: 500;
        font-family: var(--font-mincho);
        text-align: center;
    }
    .company-wrap .company-message-flex .company-message-info p {
        margin: 0;
        font-size: 3.2vw;
        font-weight: 400;
        text-align: left;
        line-height: calc( 30 / 16 );
    }
    .company-wrap .company-message-flex .company-message-pic {
        width: 100%;
    }
    .company-wrap .company-message-flex .company-message-pic .pic {
        margin: 0 auto;
        width: 80%;
        height: auto;
        aspect-ratio: 344 / 354;
        overflow: hidden;
    }
    .company-wrap .company-message-flex .company-message-pic .pic img {
        width: 100%;
        height: 100%;
        object-fit: cover;
        transform: scale( 1.2, 1.2 ) translate( 2%, -8% );
    }
    .company-wrap .company-message-flex .company-message-pic .caption {
        margin: 0.5em 0 0;
        font-size: 3.6vw;
        font-weight: 500;
        font-family: var(--font-mincho);
        text-align: center;
    }
    .company-wrap .company-common {
        margin: 0 auto;
        width: 100%;
    }
    .company-wrap .company-common .head {
        margin: 0;
        font-size: 3.6vw;
        font-weight: 500;
        font-family: var(--font-mincho);
        text-align: left;
    }
    .company-wrap .company-common .float-pic {
        margin: 0 0 4.0vw 4.0vw;
        width: 40%;
        height: auto;
        float: right;
    }
    .company-wrap .company-common .float-pic img {
        width: 100%;
        height: auto;
    }
    .company-wrap .company-common h3 {
        margin: 2.0em 0 0.5em;
        padding: 0 0 0 0.8em;
        font-size: 3.6vw;
        font-weight: 500;
        text-align: left;
        border-left: 4px solid #3a4689;
        clear: both;
    }
    .company-wrap .company-common p {
        margin: 0;
        padding: 0;
        font-size: 3.2vw;
        font-weight: 400;
        text-align: left;
    }
    .company-wrap .company-common ol {
        margin: 0 0 0 8.0vw;
        padding: 0;
        list-style-type: lower-alpha;
    }
    .company-wrap .company-common ul {
        margin: 0 0 0 8.0vw;
        padding: 0;
    }
    .company-wrap .company-common li {
        margin: 0.2em 0;
        font-size: 3.2vw;
        font-weight: 400;
        text-align: left;
    }
    .company-wrap .company-table {
        margin: 0 auto;
        width: 100%;
        display: grid;
        grid-template-columns: 1fr;
        gap: 0;
    }
    .company-wrap .company-table > dt {
        margin: 0;
        padding: 4.0vw 0 1.0vw;
        width: 100%;
        color: #282828;
        font-size: 4.0vw;
        font-weight: 350;
    }
    .company-wrap .company-table > dd {
        margin: 0;
        padding: 1.0vw 0 4.0vw;
        width: 100%;
        font-size: 3.6vw;
        font-weight: 500;
        border-bottom: 1px solid #cecece;
    }
    .company-wrap .company-table > dd a {
        text-decoration: underline;
    }


    #recruit-mv {
        margin: 60px auto 0;
        width: 100%;
    }
    #recruit-mv > .mv-bg {
        position: relative;
        margin: 0;
        width: 100%;
        height: auto;
        aspect-ratio: 2 / 1;
    }
    #recruit-mv.mv-top > .mv-bg {
        aspect-ratio: 4 / 3;
    }
    #recruit-mv > .mv-bg::after {
        position: absolute;
        content: "";
        top: 0;
        left: 0;
        width: 100%;
        height: 100%;
        background: rgba( 0, 0, 0, 0.3 );
    }
    #recruit-mv.mv-top > .mv-bg::after {
        background: rgba( 0, 0, 0, 0.2 );
    }
    #recruit-mv > .mv-bg img {
        width: 100%;
        height: 100%;
        object-fit: cover;
    }
    #recruit-mv > .mv-box {
        position: absolute;
        top: 50%;
        left: 5%;
        width: 90%;
        translate: 0 -50%;
    }
    #recruit-mv.mv-top > .mv-box {
        position: absolute;
        left: 0;
        width: 100%;
    }
    #recruit-mv > .mv-box h1 {
        color: #fff;
        text-align: left;
        line-height: 1.2;
    }
    #recruit-mv.mv-top > .mv-box h1 {
        text-align: center;
    }
    #recruit-mv > .mv-box h1 span:nth-of-type(1) {
        display: block;
        font-size: 8.0vw;
        font-weight: 700;
        text-shadow:
            0 0 4px #000,
            0 0 4px #000,
            0 0 4px #000,
            0 0 4px #000;
    }
    #recruit-mv > .mv-box h1 span:nth-of-type(2) {
        margin: 2.0em 0 0;
        display: block;
        color: #00ccff;
        font-size: 3.2vw;
        font-family: var(--font-alphabet);
        text-shadow:
            0 0 2px #fff,
            0 0 2px #fff;
    }
    #recruit-mv.mv-top > .mv-box h1 span:nth-of-type(2) {
        margin: 0.8em 0 0;
        color: #fff;
        font-size: 3.6vw;
        text-shadow:
            0 0 4px #000,
            0 0 4px #000;
    }
    #recruit-mv > .mv-box .breadcrumbs {
        margin: 0 0 1.0em;
        display: flex;
        align-items: center;
        justify-content: flex-start;
        gap: 0 2.0vw;
        color: #fff;
        font-size: 3.2vw;
        font-weight: 400;
        line-height: 1.0;
        text-shadow:
            0 0 4px #000,
            0 0 4px #000;
    }
    #recruit-mv > .mv-box .breadcrumbs .breadcrumbs-bar {
        display: inline-block;
        width: 4.0vw;
        height: 2px;
        background: #01e2c2;
    }
    #recruit-mv > .mv-box .breadcrumbs a {
        color: #fff;
    }


    main.recruit-content {
        margin: 60px auto 0;
    }
    main.recruit-apply {
        margin: 60px auto 0;
        background: #e7f9ff;
    }

    .recruit-footer {
        position: relative;
        margin: 0 auto;
        padding: 0;
        width: 100%;
        height: auto;
        aspect-ratio: 2 / 1;
    }
    .recruit-footer .footer-bg {
        position: relative;
        width: 100%;
        height: 100%;
    }
    .recruit-footer .footer-bg::after {
        position: absolute;
        content: "";
        top: 0;
        left: 0;
        width: 100%;
        height: 100%;
        background: rgba( 255, 255, 255, 0.5 );
    }
    .recruit-footer .footer-bg img {
        width: 100%;
        height: 100%;
        object-fit: cover;
    }
    .recruit-footer .footer-btn-intern {
        position: absolute;
        display: flex;
        align-items: center;
        justify-content: center;
        top: 10%;
        left: 20%;
        width: 60%;
        height: auto;
        aspect-ratio: 522 / 103;
        color: transparent;
        background: #fff;
        border: 2px solid transparent;
        border-image: linear-gradient( to right, #0fabff, #00e3c1 ) 1;
    }
    .recruit-footer .footer-btn-intern::before {
        position: absolute;
        content: "インターン";
        top: 50%;
        left: 50%;
        width: max-content;
        font-size: 3.6vw;
        font-weight: 700;
        text-align: center;
        background: linear-gradient( to right, #0fabff, #00e3c1 );
        -webkit-background-clip: text;
        -webkit-text-fill-color: transparent;
        translate: -50% -50%;
    }
    .recruit-footer .footer-btn-fresh {
        position: absolute;
        display: flex;
        align-items: center;
        justify-content: center;
        top: 40%;
        left: 20%;
        width: 60%;
        height: auto;
        aspect-ratio: 522 / 103;
        color: #fff;
        font-size: 3.6vw;
        font-weight: 700;
        text-align: center;
        background: linear-gradient( to right, #0fabff, #00e3c1 );
    }
    .recruit-footer .footer-btn-career {
        position: absolute;
        display: flex;
        align-items: center;
        justify-content: center;
        top: 70%;
        left: 20%;
        width: 60%;
        height: auto;
        aspect-ratio: 522 / 103;
        color: transparent;
        background: #fff;
        border: 2px solid transparent;
        border-image: linear-gradient( to right, #0fabff, #00e3c1 ) 1;
    }
    .recruit-footer .footer-btn-career::before {
        position: absolute;
        content: "キャリアエントリー";
        top: 50%;
        left: 50%;
        width: max-content;
        font-size: 3.6vw;
        font-weight: 700;
        text-align: center;
        background: linear-gradient( to right, #0fabff, #00e3c1 );
        -webkit-background-clip: text;
        -webkit-text-fill-color: transparent;
        translate: -50% -50%;
    }

    #recruit-top-about {
        margin: 0 auto;
        padding: 12.0vw 4.0vw;
        width: 100%;
        background: #f1faff;
        display: flex;
        flex-direction: column;
        align-items: center;
        justify-content: center;
        gap: 4.0vw 0;
    }
    #recruit-top-about .about-info {
        margin: 0;
        padding: 0;
        width: 100%;
    }
    #recruit-top-about .about-info h2 {
        margin: 0;
        width: max-content;
        max-width: 100%;
        font-size: 16.0vw;
        font-weight: 700;
        font-family: var(--font-alphabet);
        line-height: 1.1;
        background: linear-gradient( to right, #0fabff, #00e3c1 );
        -webkit-background-clip: text;
        -webkit-text-fill-color: transparent;
    }
    #recruit-top-about .about-info h3 {
        margin: 1.0em 0 0;
        width: max-content;
        max-width: 100%;
        font-size: 3.6vw;
        font-weight: 700;
        font-family: var(--font-alphabet);
        line-height: 1.1;
        background: linear-gradient( to right, #0fabff, #00e3c1 );
        -webkit-background-clip: text;
        -webkit-text-fill-color: transparent;
    }
    #recruit-top-about .about-info h4 {
        margin: 1.0em 0 0;
        font-size: 4.8vw;
        font-weight: 700;
        line-height: calc( 50 / 36 );
    }
    #recruit-top-about .about-info p {
        margin: 2.0em 0 0;
        width: 100%;
        font-size: 3.6vw;
        font-weight: 500;
        line-height: calc( 30 / 18 );
    }
    #recruit-top-about .about-movie {
        position: relative;
        margin: 0;
        padding: 0;
        width: 100%;
        z-index: 2;
        overflow: hidden;
    }
    #recruit-top-about .about-movie .about-movie-wrap {
        width: 100%;
        height: auto;
        aspect-ratio: 1920 / 1080;
    }
    #recruit-top-about .about-movie iframe {
        position: relative;
        display: block;
        width: 100%;
        height: auto;
        aspect-ratio: 1920 / 1080;
        border: 0;
        z-index: 2;
    }

    #recruit-top-links {
        margin: 0 auto;
        padding: 0 0 12.0vw;
        width: 100%;
        background: #f1faff;
    }
    #recruit-top-links .link-pic {
        margin: 0 auto;
        padding: 0;
        width: 100%;
        height: auto;
        aspect-ratio: 3 / 1;
    }
    #recruit-top-links .link-pic img {
        width: 100%;
        height: 100%;
        object-fit: cover;
    }
    #recruit-top-links .link-flex {
        display: flex;
        align-items: stretch;
        justify-content: center;
        gap: 0 2.0vw;
        translate: 0 -20%;
    }
    #recruit-top-links .link-flex > a {
        display: block;
        padding: 4.0vw 2.0vw;
        width: 30%;
        background: #fff;
    }
    #recruit-top-links .link-flex > a .icon {
        display: block;
        margin: 0 auto;
        width: 40%;
        height: auto;
        aspect-ratio: 1 / 1;
    }
    #recruit-top-links .link-flex > a .icon img {
        width: 100%;
        height: 100%;
        object-fit: contain;
    }
    #recruit-top-links .link-flex > a span {
        position: relative;
        display: block;
        margin: 4.0vw 0 0;
        width: 100%;
        font-size: 3.2vw;
        font-weight: 700;
        text-align: center;
        line-height: 1.5;
    }

    #recruit-top-works {
        margin: 0 auto;
        padding: 0;
        width: 100%;
        display: flex;
        flex-direction: column;
        align-items: center;
        justify-content: center;
    }
    #recruit-top-works .pic {
        margin: 0;
        padding: 0;
        width: 100%;
        height: auto;
        aspect-ratio: 16 / 9;
    }
    #recruit-top-works .pic img {
        width: 100%;
        height: 100%;
        object-fit: cover;
    }
    #recruit-top-works .work-info {
        padding: 8.0vw 4.0vw;
        width: 100%;
    }
    #recruit-top-works .work-info h2 {
        margin: 0;
        width: max-content;
        max-width: 100%;
        font-size: 16.0vw;
        font-weight: 700;
        font-family: var(--font-alphabet);
        line-height: 1.1;
        background: linear-gradient( to right, #0fabff, #00e3c1 );
        -webkit-background-clip: text;
        -webkit-text-fill-color: transparent;
    }
    #recruit-top-works .work-info h3 {
        margin: 1.0em 0 0;
        width: max-content;
        max-width: 100%;
        font-size: 3.6vw;
        font-weight: 700;
        line-height: 1.1;
        background: linear-gradient( to right, #0fabff, #00e3c1 );
        -webkit-background-clip: text;
        -webkit-text-fill-color: transparent;
    }
    #recruit-top-works .work-info h4 {
        margin: 1.0em 0 0;
        font-size: 4.8vw;
        font-weight: 700;
        line-height: calc( 50 / 36 );
    }
    #recruit-top-works .work-info p {
        margin: 2.0em 0 0;
        width: 100%;
        font-size: 3.6vw;
        font-weight: 500;
        line-height: calc( 30 / 18 );
    }
    #recruit-top-works .work-info .common-btn {
        margin: 12.0vw 0 0;
        display: flex;
        align-items: center;
        justify-content: center;
        gap: 0 10px;
        width: 50.0vw;
        height: auto;
        aspect-ratio: 240 / 48;
        color: #fff;
        font-size: 3.2vw;
        font-weight: 500;
        text-align: center;
        background: linear-gradient( to right, #0fabff, #00e3c1 );
    }
    #recruit-top-works .work-info .common-btn span:nth-child(2) {
        position: relative;
        display: inline-block;
        width: 1.6em;
        height: 1.0em;
    }
    #recruit-top-works .work-info .common-btn span:nth-child(2)::before {
        position: absolute;
        content: "";
        top: 0.5em;
        left: 0;
        width: 100%;
        height: 1px;
        background: #fff;
    }
    #recruit-top-works .work-info .common-btn span:nth-child(2)::after {
        position: absolute;
        content: "";
        top: 0.5em;
        right: 0;
        width: 0.6em;
        height: 1px;
        background: #fff;
        transform-origin: right center;
        transform: rotate( 40deg );
    }

    #recruit-top-environment {
        margin: 0 auto;
        padding: 12.0vw 0;
        width: 100%;
        background: linear-gradient( to bottom, #fff, #0fabff );
    }
    #recruit-top-environment > h2 {
        margin: 0;
        padding: 0 4.0vw;
        width: max-content;
        max-width: 100%;
        font-size: 14.0vw;
        font-weight: 700;
        font-family: var(--font-alphabet);
        line-height: 1.1;
        background: linear-gradient( to right, #0fabff, #00e3c1 );
        -webkit-background-clip: text;
        -webkit-text-fill-color: transparent;
    }
    #recruit-top-environment > h3 {
        margin: 0.8em 0 0;
        padding: 0 4.0vw;
        width: max-content;
        max-width: 100%;
        color: #fff;
        font-size: 26px;
        font-weight: 700;
        line-height: 1.1;
        text-shadow:
            0 0 4px #000,
            0 0 4px #000;
    }
    #recruit-top-environment > .environment-wrap {
        position: relative;
        margin: 8.0vw auto 0;
        padding: 0;
        width: 100%;
        height: auto;
    }
    #recruit-top-environment > .environment-wrap .pic {
        margin: 0 auto 0 0;
        padding: 0;
        width: 100%;
        height: auto;
        aspect-ratio: 16 / 9;
    }
    #recruit-top-environment > .environment-wrap .pic img {
        width: 100%;
        height: 100%;
        object-fit: cover;
    }
    #recruit-top-environment > .environment-wrap .environment-box {
        margin: 4.0vw auto 0;
        padding: 4.0vw 10.0vw;
        width: 90%;
        height: auto;
        background: #fff;
    }
    #recruit-top-environment > .environment-wrap .environment-box h4 {
        margin: 0;
        padding: 4.0vw 0 0;
        font-size: 4.0vw;
        font-weight: 700;
        text-align: left;
    }
    #recruit-top-environment > .environment-wrap .environment-box a {
        position: relative;
        display: block;
        margin: 1.0em 0 0;
        padding: 0 8.0vw 4.0vw 0;
        font-size: 3.6vw;
        font-weight: 500;
        line-height: calc( 30 / 18 );
        border-bottom: 1px solid #d6d6d6;
    }
    #recruit-top-environment > .environment-wrap .environment-box a::before {
        position: absolute;
        content: "";
        top: 0.5em;
        right: 0;
        width: 1.6em;
        height: 1px;
        background: var(--fg-color);
    }
    #recruit-top-environment > .environment-wrap .environment-box a::after {
        position: absolute;
        content: "";
        top: 0.5em;
        right: 0;
        width: 0.6em;
        height: 1px;
        background: var(--fg-color);
        transform-origin: right center;
        transform: rotate( 40deg );
    }

    #recruit-top-people {
        margin: 0 auto;
        padding: 12.0vw 4.0vw;
        width: 100%;
        background: linear-gradient( to bottom, #0fabff, #00e3c1 );
        overflow: hidden;
        z-index: 1;
    }
    #recruit-top-people > h2 {
        position: relative;
        margin: 0;
        width: max-content;
        max-width: 100%;
        color: #fff;
        font-size: 16.0vw;
        font-weight: 700;
        font-family: var(--font-alphabet);
        line-height: 1.1;
        z-index: 3;
    }
    #recruit-top-people > h3 {
        position: relative;
        margin: 0.8em 0 0 5.0vw;
        width: max-content;
        max-width: 100%;
        color: #fff;
        font-size: 3.6vw;
        font-weight: 700;
        line-height: 1.1;
        z-index: 3;
    }
    #recruit-top-people > .people-flex {
        position: relative;
        margin: 8.0vw auto 0;
        width: 100%;
        display: flex;
        align-items: flex-start;
        justify-content: space-between;
        gap: 0;
        z-index: 3;
    }
    #recruit-top-people > .people-flex .people-flex-item {
        display: block;
        margin: 0;
        width: 32%;
    }
    #recruit-top-people > .people-flex .people-flex-item:nth-child(2) {
        translate: 0 10%;
    }
    #recruit-top-people > .people-flex .people-flex-item .pic {
        position: relative;
        width: 100%;
        height: auto;
        aspect-ratio: 301 / 333;
    }
    #recruit-top-people > .people-flex .people-flex-item .pic figcaption {
        display: block;
        margin: 0;
        padding: 1.0vw;
        width: 100%;
        height: auto;
        background: #fff;
    }
    #recruit-top-people > .people-flex .people-flex-item .pic figcaption span {
        display: block;
        color: #626262;
        font-size: 2.2vw;
        font-weight: 400;
        line-height: 1.5;
    }
    #recruit-top-people > .people-flex .people-flex-item .pic figcaption span:nth-child(1) {
        margin: 0 0 0.5em;
        color: var(--fg-color);
        font-size: 2.8vw;
        font-weight: 700;
    }
    #recruit-top-people > .people-flex .people-flex-item .pic img {
        width: 100%;
        height: 100%;
        object-fit: cover;
    }
    #recruit-top-people > .people-flex .people-flex-item p {
        margin: 0.5em 0 0;
        font-size: 3.2vw;
        font-weight: 700;
        text-align: left;
        line-height: calc( 25 / 16 );
    }

    .recruit-wrap {
        margin: 0 auto;
        padding: 12.0vw 0;
        width: 100%;
        background: #f1faff;
    }
    .recruit-wrap .recruit-sidebar {
        display: none;
    }
    .recruit-wrap .recruit-contents {
        width: 100%;
    }
    .recruit-wrap .recruit-contents .recruit-team {
        width: 100%;
    }
    .recruit-wrap .recruit-contents .recruit-team + .recruit-team {
        margin-top: 12.0vw;
    }
    .recruit-wrap .recruit-contents h2 {
        margin: 0 auto;
        width: max-content;
        max-width: 90%;
        font-size: 8.0vw;
        font-weight: 700;
        line-height: 1.1;
        background: linear-gradient( to right, #0fabff, #00e3c1 );
        -webkit-background-clip: text;
        -webkit-text-fill-color: transparent;
    }
    .recruit-wrap .recruit-contents h2.normal {
        margin: 0 auto;
        width: 90%;
        max-width: 90%;
        color: #00aeef;
        font-size: 4.8vw;
        background: none;
        -webkit-background-clip: initial;
        -webkit-text-fill-color: initial;
    }
    .recruit-wrap .recruit-contents h2:not(:first-of-type) {
        margin-top: 16.0vw;
    }
    .recruit-wrap .recruit-contents h3 {
        margin: 0.2em auto 0;
        width: max-content;
        max-width: 90%;
        font-size: 4.0vw;
        font-weight: 700;
        line-height: 1.1;
        background: linear-gradient( to right, #0fabff, #00e3c1 );
        -webkit-background-clip: text;
        -webkit-text-fill-color: transparent;
    }
    .recruit-wrap .recruit-contents h4 {
        margin: 1.5em auto;
        width: 90%;
        font-size: 4.8vw;
        font-weight: 700;
        text-align: center;
        line-height: 1.2;
    }
    .recruit-wrap .recruit-contents :is(h3,h4).bar {
        margin: 1.5em auto 0;
        padding: 0.8em 1.0em;
        width: 90%;
        color: #fff;
        font-size: 4.8vw;
        font-weight: 500;
        text-align: left;
        line-height: 1.0;
        background: #00aeef;
    }
    .recruit-wrap .recruit-contents p {
        margin: 1.5em auto 0;
        padding: 0;
        width: 90%;
        font-size: 3.6vw;
        font-weight: 400;
        line-height: 1.8;
    }
    .recruit-wrap .recruit-contents p.list {
        margin: 1.0em auto 0;
        width: 90%;
        color: #00aeef;
        font-size: 4.0vw;
        font-weight: 500;
        line-height: 1.8;
    }
    .recruit-wrap .recruit-contents p.list::before {
        content: "◆ ";
    }
    .recruit-wrap .recruit-contents p.indent {
        margin: 1.0em auto 0;
        text-indent: 1.5em;
        width: 90%;
        font-size: 3.6vw;
        font-weight: 400;
        line-height: 1.8;
    }
    .recruit-wrap .recruit-contents .pic {
        margin: 8.0vw auto 0;
        width: 100%;
        height: auto;
        aspect-ratio: 1015 / 345;
    }
    .recruit-wrap .recruit-contents .pic.business {
        margin: 4.0vw auto 0;
        width: 90%;
        aspect-ratio: 1210 / 964;
    }
    .recruit-wrap .recruit-contents .pic img {
        width: 100%;
        height: 100%;
        object-fit: cover;
    }
    .recruit-wrap .recruit-contents .grid-area {
        margin: 8.0vw auto 0;
        width: 90%;
        display: grid;
        grid-template-columns: 1fr;
        gap: 8.0vw 0;
    }
    .recruit-wrap .recruit-contents :is(h3,h4).bar + .grid-area {
        margin-top: 4.0vw;
    }
    .recruit-wrap .recruit-contents .grid-area .grid-item {
        margin: 0;
        width: 100%;
    }
    .recruit-wrap .recruit-contents .grid-area .grid-item.left-bar {
        padding-left: 4.0vw;
        border-left: 1px solid #00e3c1;
    }
    .recruit-wrap .recruit-contents .grid-area .grid-item .pic {
        width: 100%;
        height: auto;
        aspect-ratio: 398 / 216;
    }
    .recruit-wrap .recruit-contents .grid-area .grid-item .pic img {
        width: 100%;
        height: 100%;
        object-fit: cover;
    }
    .recruit-wrap .recruit-contents .grid-area .grid-item :is(h3,h4) {
        margin: 0.8em 0;
        color: #00aeef;
        font-size: 4.0vw;
        font-weight: 700;
        text-align: left;
        line-height: 1.2;
    }
    .recruit-wrap .recruit-contents .grid-area .grid-item p {
        margin: 1.0em 0;
        font-size: 3.6vw;
        font-weight: 700;
        text-align: left;
        line-height: 1.8;
    }

    #recruit-interview {
        margin: 0 auto;
        padding: 12.0vw 0;
        width: 100%;
        background: #f1faff;
    }
    #recruit-interview .interview-grid {
        margin: 0 auto;
        width: 90%;
        display: grid;
        grid-template-columns: 1fr;
        gap: 8.0vw 0;
    }
    #recruit-interview .interview-grid .interview-grid-item {
        display: block;
        margin: 0;
        width: 100%;
    }
    #recruit-interview .interview-grid .interview-grid-item .pic {
        position: relative;
        margin: 0;
        width: 100%;
        height: auto;
        aspect-ratio: 562 / 246;
    }
    #recruit-interview .interview-grid .interview-grid-item .pic img {
        width: 100%;
        height: 100%;
        object-fit: cover;
    }
    #recruit-interview .interview-grid .interview-grid-item .pic figcaption {
        margin: 0;
        padding: 2.0vw;
        width: 100%;
        height: auto;
        background: #fff;
    }
    #recruit-interview .interview-grid .interview-grid-item .pic figcaption span {
        display: block;
        color: #626262;
        font-size: 3.6vw;
        font-weight: 400;
        line-height: 1.5;
    }
    #recruit-interview .interview-grid .interview-grid-item .pic figcaption span:nth-child(1) {
        margin: 0 0 0.5em;
        color: var(--fg-color);
        font-size: 3.2vw;
        font-weight: 700;
    }
    #recruit-interview .interview-grid .interview-grid-item p {
        margin: 0.5em 0 0;
        font-size: 3.6vw;
        font-weight: 700;
        text-align: left;
        line-height: calc( 25 / 16 );
    }

    #recruit-info-child {
        margin: 0 auto;
        padding: 12.0vw 5%;
        width: 100%;
    }
    #recruit-info-child > h1 {
        margin: 0 0 1.5em;
        font-size: 6.0vw;
        font-weight: 700;
        text-align: left;
    }
    .recruit-apply #recruit-info-child .recruit-info-child-content {
        padding: 4.0vw;
        background: #fff;
    }
    #recruit-info-child .recruit-info-child-content .recruit-info-box {
        display: block;
        margin: 6.0vw auto 0;
        padding: 4.0vw;
        width: 100%;
        display: flex;
        flex-direction: column;
        align-items: center;
        justify-content: center;
        gap: 6.0vw 0;
        border: 1px solid #d6d6d6;
    }
    #recruit-info-child .recruit-info-child-content .recruit-info-box .recruit-info-pic {
        margin: 0 auto;
        padding: 0;
        width: 80%;
        height: auto;
        aspect-ratio: 241 / 124;
    }
    #recruit-info-child .recruit-info-child-content .recruit-info-box .recruit-info-pic img {
        width: 100%;
        height: 100%;
        object-fit: cover;
    }
    #recruit-info-child .recruit-info-child-content .recruit-info-box .recruit-info-txt {
        margin: 0;
        padding: 0;
        width: 100%;
    }
    #recruit-info-child .recruit-info-child-content .recruit-info-box .recruit-info-txt h2 {
        margin: 0;
        font-size: 3.6vw;
        font-weight: 700;
        text-align: left;
    }
    #recruit-info-child .recruit-info-child-content .recruit-info-box .recruit-info-txt p {
        margin: 1.5em 0 0;
        font-size: 3.2vw;
        font-weight: 400;
        text-align: left;
        line-height: 1.8:
    }
    #recruit-info-child .recruit-info-child-content h2 {
        margin: 1.5em 0 0.5em;
        color: #00aeef;
        font-size: 4.8vw;
        font-weight: 500;
        text-align: left;
    }
    #recruit-info-child .recruit-info-child-content h2:first-child {
        margin-top: 0;
    }
    #recruit-info-child .recruit-info-child-content :is(p,div) {
        margin: 1.5em 0 0;
        font-size: 3.2vw;
        font-weight: 400;
        text-align: left;
        line-height: 1.8;
    }
    #recruit-info-child .recruit-info-child-content th {
        margin: 0;
        font-size: 3.6vw;
        font-weight: 700;
        text-align: left;
        line-height: 1.8;
    }
    #recruit-info-child .recruit-info-child-content td {
        margin: 0;
        font-size: 3.2vw;
        font-weight: 400;
        text-align: left;
        line-height: 1.8;
    }
    #recruit-info-child .recruit-info-child-content dl {
        margin: 4.0vw 0 0 4.0vw;
        width: calc( 100% - 4.0vw );
        display: grid;
        grid-template-columns: 1fr;
        gap: 0;
        border-top: 1px solid #d6d6d6;
    }
    #recruit-info-child .recruit-info-child-content dt {
        margin: 0;
        padding: 4.0vw 0 1.0vw;
        font-size: 3.6vw;
        font-weight: 500;
        text-align: left;
        line-height: 1.8;
    }
    #recruit-info-child .recruit-info-child-content dd {
        margin: 0;
        padding: 1.0vw 0 4.0vw;
        font-size: 3.2vw;
        font-weight: 400;
        text-align: left;
        line-height: 1.8;
        border-bottom: 1px solid #d6d6d6;
    }
    #recruit-info-child .recruit-info-child-content .common-btn {
        margin: 8.0vw 0 0 auto;
        display: flex;
        align-items: center;
        justify-content: center;
        gap: 0 2.0vw;
        width: 50%;
        height: auto;
        aspect-ratio: 240 / 48;
        color: #fff;
        font-size: 3.2vw;
        font-weight: 500;
        text-align: center;
        background: linear-gradient( to right, #0fabff, #00e3c1 );
    }
    #recruit-info-child .recruit-info-child-content .common-btn span:nth-child(2) {
        position: relative;
        display: inline-block;
        width: 1.6em;
        height: 1.0em;
    }
    #recruit-info-child .recruit-info-child-content .common-btn span:nth-child(2)::before {
        position: absolute;
        content: "";
        top: 0.5em;
        left: 0;
        width: 100%;
        height: 1px;
        background: #fff;
    }
    #recruit-info-child .recruit-info-child-content .common-btn span:nth-child(2)::after {
        position: absolute;
        content: "";
        top: 0.5em;
        right: 0;
        width: 0.6em;
        height: 1px;
        background: #fff;
        transform-origin: right center;
        transform: rotate( 40deg );
    }

    #recruit-info-child  .recruit-info-child-content .recruit-apply-form {
        margin: 0;
        width: 100%;
        display: grid;
        grid-template-columns: 1fr;
        gap: 4.0vw;
    }
    #recruit-info-child  .recruit-info-child-content .recruit-apply-form > div {
        margin: 0;
        width: 100%;
    }
    #recruit-info-child  .recruit-info-child-content .recruit-apply-form > div.two-cols {
    }
    #recruit-info-child  .recruit-info-child-content .recruit-apply-form > div label {
        font-size: 3.6vw;
        font-weight: 500;
    }
    #recruit-info-child  .recruit-info-child-content .recruit-apply-form > div label::after {
        content: " 必須";
        color: #848484;
        font-size: 2.8vw;
        font-weight: 400;
    }
    #recruit-info-child  .recruit-info-child-content .recruit-apply-form > div :is(input[type="text"],input[type="email"],input[type="date"],select) {
        margin: 0;
        padding: 0.5em;
        width: 100%;
        font-size: 16px;
        font-family: inherit;
        font-weight: 500;
        border: 1px solid #ccc;
        border-radius: 0.5em;
    }
    #recruit-info-child  .recruit-info-child-content input[type="submit"] {
        display: block;
        margin: 4.0em 0 0;
        padding: 0.5em 2.0em;
        width: max-conetnt;
        color: #fff;
        font-size: 18px;
        font-family: inherit;
        font-weight: 500;
        border: 0;
        background: linear-gradient( to right, #0fabff, #00e3c1 );
    }

    #recruit-interview-child {
        margin: 0 auto;
        padding: 12.0vw 0;
        width: 100%;
    }
    #recruit-interview-child .recruit-interview-child-content {
        margin: 0 auto;
        width: 90%;
    }
    #recruit-interview-child .recruit-interview-child-content .recruit-interview-child-flex {
        margin: 0 auto;
        width: 100%;
        display: flex;
        flex-direction: column;
        align-items: center;
        justify-content: center;
        gap: 6.0vw 0;
    }
    #recruit-interview-child .recruit-interview-child-content .recruit-interview-child-flex + .recruit-interview-child-flex {
        margin-top: 12.0vw;
    }
    #recruit-interview-child .recruit-interview-child-content .recruit-interview-child-flex .recruit-interview-child-head-pic {
        margin: 0 auto;
        width: 80%;
        height: auto;
        aspect-ratio: 813 / 447;
        order: 2;
    }
    #recruit-interview-child .recruit-interview-child-content .recruit-interview-child-flex .recruit-interview-child-head-txt {
        margin: 0;
        width: 100%;
        height: auto;
        order: 1;
    }
    #recruit-interview-child .recruit-interview-child-content .recruit-interview-child-flex .recruit-interview-child-pic {
        margin: 0 auto;
        width: 80%;
        height: auto;
        aspect-ratio: 499 / 260;
        order: 2;
    }
    #recruit-interview-child .recruit-interview-child-content .recruit-interview-child-flex .recruit-interview-child-txt {
        margin: 0;
        width: 100%;
        height: auto;
        order: 1;
    }
    #recruit-interview-child .recruit-interview-child-content h1 {
        margin: 0 0 0.5em;
        color: #00ccff;
        font-size: 6.0vw;
        font-weight: 400;
        text-align: left;
    }
    #recruit-interview-child .recruit-interview-child-content h2 {
        margin: 0;
        font-size: 4.0vw;
        font-weight: 700;
        text-align: left;
        line-height: 1.5;
    }
    #recruit-interview-child .recruit-interview-child-content h3 {
        margin: 0 0 1.0em;
        font-size: 4.0vw;
        font-weight: 700;
        text-align: left;
        line-height: 1.5;
    }
    #recruit-interview-child .recruit-interview-child-content p {
        margin: 1.0em 0 0;
        font-size: 3.6vw;
        font-weight: 400;
        text-align: left;
        line-height: 1.8;
    }
    #recruit-interview-child .recruit-interview-child-content hr {
        margin: 4.0vw 0;
        width: 100%;
        height: 1px;
        background: #d6d6d6;
        border: 0;
    }
    #recruit-interview-child .recruit-interview-child-content .interview-attr {
        margin: 0;
        color: #626262;
        font-size: 2.8vw;
        font-weight: 500;
        text-align: left;
    }
    #recruit-interview-child .recruit-interview-child-content .interview-name {
        margin: 0.5em 0 0;
        font-size: 3.6vw;
        font-weight: 700;
        text-align: left;
    }

}


/**
 * PC用設定
 */
@media ( width >= 768px ) {

    #mv1 {
        margin: 78px auto 0;
        padding: 160px 0 0;
        width: 100%;
        height: auto;
        background: #f7f7f7;
    }
    #mv2 {
        margin: 78px auto 0;
        padding: 0;
        width: 100%;
        height: auto;
        aspect-ratio: 1440 / 489;
        display: flex;
        flex-direction: column;
        justify-content: center;
    }
    #mv2::before {
        position: absolute;
        content: "";
        top: 0;
        left: 0;
        width: 100%;
        height: 100%;
        background: url(../images/top-section-bg.webp) no-repeat center / cover;
        opacity: 0.3;
        z-index: -1;
    }
    .mv > .mv-box {
        margin: 0 auto;
        padding: 0;
        width: 90%;
        max-width: 1440px;
        line-height: 1.2;
    }
    .mv > .mv-box span:nth-of-type(1) {
        display: block;
        color: #3a4689;
        font-size: 20px;
        font-weight: 700;
    }
    .mv > .mv-box span:nth-of-type(2) {
        display: block;
        font-size: 96px;
        font-weight: 700;
        font-family: var(--font-alphabet);
    }
    .mv > .breadcrumbs {
        margin: 40px auto 0;
        padding: 0;
        width: 90%;
        max-width: 1440px;
        color: #cecece;
        font-size: 12px;
        font-weight: 400;
        line-height: 1.0;
    }
    .mv > .breadcrumbs a {
        color: #cecece;
    }
    #mv2 > .breadcrumbs,
    #mv2 > .breadcrumbs a {
        color: #787878;
    }
    .mv > .breadcrumbs :last-child,
    .mv > .breadcrumbs :last-child a {
        color: var(--fg-color);
    }
    .mv > .mv-bg {
        width: 100%;
        margin: 0;
        padding: 0;
        width: 100%;
        height: auto;
        aspect-ratio: 1440/ 500;
        clip-path: polygon( 0 20%, 100% 0, 100% 80%, 0 100% );
        overflow: hidden;
    }
    .mv > .mv-bg img {
        width: 100%;
        height: 100%;
        object-position: center top;
        object-fit: cover;
    }
    .mv > .mv-flex {
        margin: 0 auto;
        padding: 40px 0;
        width: 90%;
        max-width: 1200px;
        display: flex;
        align-items: center;
        justify-content: space-between;
    }
    .mv-flex .movie {
        width: 48%;
        height: auto;
        aspect-ratio: 508 / 298;
    }
    .mv-flex .movie iframe {
        width: 100%;
        height: 100%;
    }
    .mv-flex .mv-info {
        width: 48%;
    }
    .mv-flex .mv-info > .head {
        font-size: 32px;
        font-weight: 700;
    }
    .mv-flex .mv-info > p {
        margin: 20px 0 0;
        font-size: 16px;
        font-weight: 500;
    }
    .mv-flex .mv-info > a {
        display: flex;
        align-items: center;
        justify-content: space-between;
        gap: 0 0.5em;

        margin: 30px auto 0 0;
        padding: 0 1.5em;
        width: 100%;
        max-width: 320px;
        height: auto;
        aspect-ratio: 320 / 62;
        background: #3a4689;

        color: #fff;
        font-size: 16px
        font-weight: 700;
        line-height: 1.0;
    }
    .mv-flex .mv-info > a::after {
        display: block;
        content: "";
        width: 2.2em;
        height: auto;
        aspect-ratio: 30 / 4;
        background: url(../images/arrow-r-white.svg) no-repeat center / contain;
    }
    .mv > #mv-slider {
        margin: 0 auto;
        padding: 40px 0;
        width: 100%;
        height: 160px;
    }
    .mv > #mv-slider .swiper-wrapper {
        transition-timing-function: linear;
    }
    .mv > #mv-slider .swiper-wrapper .swiper-slide {
        flex-shrink: 0;
        width: auto;
        height: 100%;
    }
    .mv > #mv-slider .swiper-wrapper .swiper-slide figure {
        width: auto;
        height: 100%;
    }
    .mv > #mv-slider .swiper-wrapper .swiper-slide figure img {
        width: auto;
        height: 100%;
    }
    .mv-logos {
        margin: 0 auto;
        padding: 20px;
        width: 100%;
        background: #fff;
        display: flex;
        flex-wrap: wrap;
        align-items: flex-start;
        justify-content: center;
        gap: 40px 60px;
    }
    .mv-logos .logo-item {
        width: auto;
        height: 40px;
    }
    .mv-logos .logo-item figure {
        width: auto;
        height: 40px;
    }
    .mv-logos .logo-item figure img {
        width: auto;
        height: 40px;
        object-fit: cover;
    }

    .page-menu {
        margin: 0 auto;
        padding: 40px 5%;
        width: 100%;
        display: grid;
        grid-template-columns: repeat( 6, 1fr );
        gap: 0 calc( 20 * min( 80.0vw, 1200px ) / 1200 );
        background: #f7f7f7;
    }
    .page-menu.col4 {
        grid-template-columns: repeat( 4, 1fr );
    }
    .page-menu .page-menu-item {
        position: relative;
        display: block;
        padding: 0 0 calc( 30 * min( 80.0vw, 1200px ) / 1200 );
        width: 100%;
        border-bottom: 1px solid var(--fg-color);
    }
    .page-menu .page-menu-item::after {
        position: absolute;
        content: "";
        bottom: calc( 8 * min( 80.0vw, 1200px ) / 1200 );
        left: calc( 50% - 8 * min( 80.0vw, 1200px ) / 1200 );
        width: calc( 16 * min( 80.0vw, 1200px ) / 1200 );
        height: auto;
        aspect-ratio: 1 / 1;
        border-right: 2px solid var(--fg-color);
        border-bottom: 2px solid var(--fg-color);
        rotate: 45deg;
    }
    .page-menu .page-menu-item span:nth-of-type(1) {
        display: block;
        width: 100%;
        color: #a5a5a5;
        font-size: calc( 20 * min( 80.0vw, 1200px ) / 1200 );
        font-weight: 400;
        font-family: var(--font-alphabet);
        text-align: center;
        line-height: 1.2;
    }
    .page-menu .page-menu-item span:nth-of-type(2) {
        display: block;
        width: 100%;
        font-size: calc( 20 * min( 80.0vw, 1200px ) / 1200 );
        font-weight: 700;
        text-align: center;
        line-height: 1.2;
    }

    .common-section {
        margin: 0 auto;
        padding: 40px 5%;
        width: 100%;
        background: #f7f7f7;
    }
    .common-section > h2 {
        position: relative;
        margin: 1.0em auto 0;
        font-size: 64px;
        font-weight: 700;
        font-family: var(--font-alphabet);
        line-height: 1.0;
    }
    .common-section > h2::before {
        position: absolute;
        content: attr(data-subtitle);
        left: 0;
        bottom: calc( 100% + 1.0em );
        display: block;
        color: #3a4689;
        font-size: 20px;
        font-weight: 700;
    }
    .common-section > .service-flex {
        margin: 40px auto 0;
        width: 100%;
        display: flex;
        align-items: center;
        justify-content: space-between;
    }
    .common-section > .service-flex + .service-flex {
        margin-top: 60px;
    }
    .service-flex .pic {
        width: 48%;
        height: auto;
        aspect-ratio: 583 / 380;
    }
    .service-flex .pic img {
        width: 100%;
        height: 100%;
        object-fit: cover;
    }
    .service-flex .service-info {
        width: 48%;
    }
    .service-flex .service-info > .head {
        font-size: 32px;
        font-weight: 700;
    }
    .service-flex .service-info > p {
        margin: 20px 0 0;
        font-size: 16px;
        font-weight: 500;
    }
    .service-flex .service-info > a {
        display: flex;
        align-items: center;
        justify-content: space-between;
        gap: 0 0.5em;

        margin: 30px auto 0 0;
        padding: 0 1.5em;
        width: 100%;
        max-width: 320px;
        height: auto;
        aspect-ratio: 320 / 62;
        background: #3a4689;

        color: #fff;
        font-size: 16px
        font-weight: 700;
        line-height: 1.0;
    }
    .service-flex .service-info > a::after {
        display: block;
        content: "";
        width: 2.2em;
        height: auto;
        aspect-ratio: 30 / 4;
        background: url(../images/arrow-r-white.svg) no-repeat center / contain;
    }
    .common-section > h3 {
        margin: 1.0em auto 0;
        padding: 0 0 0 1.0em;
        font-size: 48px;
        font-weight: 700;
        font-family: var(--font-alphabet);
        line-height: 1.0;
        border-left: 6px solid #3a4689;
    }
    .common-section > .service-grid {
        margin: 20px auto 0;
        padding: 0;
        width: 100%;
        display: grid;
        grid-template-columns: repeat( 3, 1fr );
        gap: 40px 2px;
        background: #edf2f7;
    }
    .common-section > .service-grid.col2 {
        grid-template-columns: repeat( 2, 1fr );
    }
    .service-grid .service-item {
        width: 100%;
        display: grid;
        grid-template-rows: subgrid;
        grid-row: span 3;
        gap: 10px 0;
    }
    .service-grid .service-item > .pic {
        margin: 0 0 10px;
        width: 100%;
        height: auto;
        aspect-ratio: 405 / 250;
        overflow: hidden;
    }
    .service-grid.col2 .service-item > .pic {
        aspect-ratio: 610 / 290;
    }
    .service-grid .service-item > .pic img {
        width: 100%;
        height: 100%;
        object-fit: cover;
    }
    .service-grid .service-item > .head {
        margin: 0 auto;
        width: 90%;
        font-size: 16px;
        font-weight: 700;
    }
    .service-grid .service-item > p {
        margin: 0 auto;
        width: 90%;
        font-size: 14px;
        font-weight: 400;
    }
    .common-section .feature-pic {
        margin: 0 auto;
        width: 70%;
        height: auto;
    }
    .common-section .feature-pic img {
        width: 100%;
        height: auto;
    }
    .common-section .feature-grid {
        margin: 40px auto 0;
        width: 90%;
        display: grid;
        grid-template-columns: repeat( 3, 1fr );
        gap: 30px 20px;
    }
    .feature-grid .feature-item {
        position: relative;
        margin: 0;
        padding: 1.5em 1.0em 1.0em;
        width: 100%;
        font-size: 16px;
        font-weight: 500;
        background: #fff;
        border: 1px solid #bcbcbc;
        box-shadow: 0 0 4px rgba( 0, 0, 0, 0.25 );
    }
    .feature-grid .feature-item::before {
        position: absolute;
        content: "‘‘";
        top: -0.3em;
        left: -0.05em;
        color: #3a4689;
        font-size: 48px;
        font-weight: 700;
        line-height: 1.0;
    }

    #thanks {
        margin: 78px auto 0;
        padding: 120px 0;
        width: 100%;
    }
    #thanks > h1 {
        position: relative;
        margin: 0 0 2.0em;
        padding: 0;
        width: 100%;
        font-size: 24px;
        font-weight: 700;
        text-align: center;
    }
    #thanks > h1::after {
        position: absolute;
        content: "";
        top: calc( 100% + 10px );
        left: calc( 50% - 15px );
        width: 30px;
        height: 6px;
        background: var(--color-theme);
    }
    #thanks > p {
        margin: 1.0em 0 0;
        padding: 0;
        width: 100%;
        font-size: 16px;
        font-weight: 500;
        text-align: center;
    }

    #privacy {
        margin: 0 auto;
        padding: 60px 0;
        width: 90%;
        max-width: 1140px;
    }
    #privacy > .head {
        margin: 0;
        padding: 0;
        font-size: 18px;
        font-weight: 500;
    }
    #privacy > h2 {
        margin: 2.0em 0 0.8em;
        padding: 0 0 0 1.0em;
        color: #3a4689;
        font-size: 18px;
        font-weight: 700;
        border-left: 4px solid #3a4689;
    }
    #privacy > p {
        margin: 0;
        padding: 0;
        font-size: 16px;
        font-weight: 400;
    }
    #privacy > ul {
        margin: 0 0 0 20px;
        padding: 0;
    }
    #privacy > ul li {
        font-size: 16px;
        font-weight: 400;
    }

    #form {
        margin: 0 auto;
        padding: 80px 0;
        width: 100%;
        background: #f7f7f7;
    }
    #form > .memo {
        margin: 0 auto;
        width: 90%;
        max-width: 960px;
        color: #f00;
        font-size: 12px;
        font-weight: 500;
        text-align: right;
    }
    #form > .form-box {
        margin: 10px auto 0;
        padding: 30px;
        width: 90%;
        max-width: 960px;
        background: #fff;
    }
    .form-box .label {
        display: block;
        margin: 30px 0 10px;
        width: 100%;
        font-size: 18px;
        font-weight: 700;
    }
    .form-box .label:nth-of-type(1) {
        margin-top: 0;
    }        
    .form-box .label::after {
        content: "*";
        color: #f00;
    }
    .form-box :is(input[type="text"],input[type="email"],input[type="tel"]) {
        display: block;
        margin: 0;
        padding: 1.0em;
        width: 100%;
        font-size: 16px;
        font-weight: 500;
        font-family: inherit;
        background: #f7f7f7;
        border: 0;
    }
    .form-box :is(input[type="text"],input[type="email"],input[type="tel"])::placeholder {
        color: #a1a1a1;
    }
    .form-box .submit {
        margin: 40px 0 0;
        display: flex;
        align-items: center;
        justify-content: flex-end;
        gap: 0 40px;
    }
    .form-box .submit p {
        margin: 0;
        font-size: 14px;
        font-weight: 400;
    }
    .form-box .submit p a {
        text-decoration: underline;
    }
    .form-box .submit input[type="submit"] {
        margin: 0;
        padding: 0.5em 4.0em;
        color: #fff;
        font-size: 16px;
        font-family: inherit;
        line-height: 1.0;
        background: var(--color-theme);
        border: 0;
    }

    .company-wrap {
        margin: 0 auto;
        padding: 80px 5%;
        width: 100%;
        display: flex;
        align-items: stretch;
        justify-content: space-between;
    }
    .company-wrap .company-sidebar {
        margin: 0;
        padding: 0;
        width: 200px;
    }
    .company-wrap .company-sidebar .company-links {
        position: sticky;
        top: 100px;
        margin: 0;
        padding: 10px 16px;
        background: #f7f7f7;
    }
    .company-wrap .company-sidebar .company-links a {
        display: block;
        margin: 0.5em 0;
        color: #bababa;
        color: var(--fg-color);
    }
    .company-wrap .company-sidebar .company-links a.active {
        color: var(--fg-color);
    }
    .company-wrap .company-contents {
        margin: 0;
        padding: 0;
        width: calc( 100% - 220px );
    }
    .company-wrap .company-contents .company-content + .company-content {
        margin-top: 120px;
    }
    .company-wrap .company-contents h2 {
        margin: 0 0 60px;
    }
    .company-wrap .company-contents h2 span:nth-of-type(1) {
        display: block;
        color: #3a4689;
        font-size: 16px;
        font-weight: 700;
        text-align: center;
    }
    .company-wrap .company-contents h2 span:nth-of-type(2) {
        display: block;
        font-size: 20px;
        font-weight: 700;
        text-align: center;
    }
    .company-wrap .company-message-flex {
        display: flex;
        align-items: flex-start;
        justify-content: space-between;
    }
    .company-wrap .company-message-flex .company-message-info {
        width: 55%;
    }
    .company-wrap .company-message-flex .company-message-info h3 {
        margin: 0 0 1.0em;
        font-size: 24px;
        font-weight: 500;
        font-family: var(--font-mincho);
        text-align: center;
    }
    .company-wrap .company-message-flex .company-message-info p {
        margin: 0;
        font-size: 16px;
        font-weight: 400;
        text-align: left;
        line-height: calc( 30 / 16 );
    }
    .company-wrap .company-message-flex .company-message-pic {
        width: 40%;
    }
    .company-wrap .company-message-flex .company-message-pic .pic {
        width: 100%;
        height: auto;
        aspect-ratio: 344 / 354;
        overflow: hidden;
    }
    .company-wrap .company-message-flex .company-message-pic .pic img {
        width: 100%;
        height: 100%;
        object-fit: cover;
        transform: scale( 1.2, 1.2 ) translate( 2%, -8% );
    }
    .company-wrap .company-message-flex .company-message-pic .caption {
        margin: 0.5em 0 0;
        font-size: 20px;
        font-weight: 500;
        font-family: var(--font-mincho);
    }
    .company-wrap .company-common {
        margin: 0 auto;
        width: 100%;
    }
    .company-wrap .company-common .head {
        margin: 0;
        font-size: 18px;
        font-weight: 500;
        font-family: var(--font-mincho);
        text-align: left;
    }
    .company-wrap .company-common .float-pic {
        margin: 0 0 20px 20px;
        width: 20%;
        height: auto;
        float: right;
    }
    .company-wrap .company-common .float-pic img {
        width: 100%;
        height: auto;
    }
    .company-wrap .company-common h3 {
        margin: 2.0em 0 0.5em;
        padding: 0 0 0 0.8em;
        font-size: 18px;
        font-weight: 500;
        text-align: left;
        border-left: 4px solid #3a4689;
        clear: both;
    }
    .company-wrap .company-common p {
        margin: 0;
        padding: 0;
        font-size: 16px;
        font-weight: 400;
        text-align: left;
    }
    .company-wrap .company-common ol {
        margin: 0 0 0 40px;
        padding: 0;
        list-style-type: lower-alpha;
    }
    .company-wrap .company-common ul {
        margin: 0 0 0 40px;
        padding: 0;
    }
    .company-wrap .company-common li {
        margin: 0.2em 0;
        font-size: 16px;
        font-weight: 400;
        text-align: left;
    }
    .company-wrap .company-table {
        margin: 0 auto;
        width: 100%;
        display: grid;
        grid-template-columns: 200px 1fr;
        gap: 0;
    }
    .company-wrap .company-table > dt {
        margin: 0;
        padding: 24px 0;
        width: 100%;
        color: #282828;
        font-size: 18px;
        font-weight: 350;
        border-bottom: 1px solid #cecece;
        display: flex;
        align-items: center;
    }
    .company-wrap .company-table > dd {
        margin: 0;
        padding: 24px 0;
        width: 100%;
        font-size: 18px;
        font-weight: 500;
        border-bottom: 1px solid #cecece;
    }
    .company-wrap .company-table > dd a {
        text-decoration: underline;
    }


    #recruit-mv {
        margin: 78px auto 0;
        width: 100%;
    }
    #recruit-mv > .mv-bg {
        position: relative;
        margin: 0;
        width: 100%;
        height: auto;
        aspect-ratio: 1512 / 676;
    }
    #recruit-mv.mv-top > .mv-bg {
        aspect-ratio: 1512 / 788;
    }
    #recruit-mv > .mv-bg::after {
        position: absolute;
        content: "";
        top: 0;
        left: 0;
        width: 100%;
        height: 100%;
        background: rgba( 0, 0, 0, 0.3 );
    }
    #recruit-mv.mv-top > .mv-bg::after {
        background: rgba( 0, 0, 0, 0.2 );
    }
    #recruit-mv > .mv-bg img {
        width: 100%;
        height: 100%;
        object-fit: cover;
    }
    #recruit-mv > .mv-box {
        position: absolute;
        top: 50%;
        left: 10%;
        width: 80%;
        translate: 0 -50%;
    }
    #recruit-mv.mv-top > .mv-box {
        position: absolute;
        left: 0;
        width: 100%;
    }
    #recruit-mv > .mv-box h1 {
        color: #fff;
        text-align: left;
        line-height: 1.2;
    }
    #recruit-mv.mv-top > .mv-box h1 {
        text-align: center;
    }
    #recruit-mv > .mv-box h1 span:nth-of-type(1) {
        display: block;
        font-size: 5.0vw;
        font-weight: 700;
        text-shadow:
            0 0 4px #000,
            0 0 4px #000,
            0 0 4px #000,
            0 0 4px #000;
    }
    #recruit-mv > .mv-box h1 span:nth-of-type(2) {
        margin: 2.0em 0 0;
        display: block;
        color: #00ccff;
        font-size: 2.0vw;
        font-family: var(--font-alphabet);
    }
    #recruit-mv.mv-top > .mv-box h1 span:nth-of-type(2) {
        margin: 0.8em 0 0;
        color: #fff;
        font-size: 3.0vw;
        text-shadow:
            0 0 4px #000,
            0 0 4px #000;
    }
    #recruit-mv > .mv-box .breadcrumbs {
        margin: 0 0 1.0em;
        display: flex;
        align-items: center;
        justify-content: flex-start;
        gap: 0 20px;
        color: #fff;
        font-size: 18px;
        font-weight: 400;
        line-height: 1.0;
        text-shadow:
            0 0 4px #000,
            0 0 4px #000;
    }
    #recruit-mv > .mv-box .breadcrumbs .breadcrumbs-bar {
        display: inline-block;
        width: 40px;
        height: 2px;
        background: #01e2c2;
    }
    #recruit-mv > .mv-box .breadcrumbs a {
        color: #fff;
    }


    main.recruit-content {
        margin: 78px auto 0;
    }
    main.recruit-apply {
        margin: 78px auto 0;
        background: #e7f9ff;
    }

    .recruit-footer {
        position: relative;
        margin: 0 auto;
        padding: 0;
        width: 100%;
        height: auto;
        aspect-ratio: 1512 / 403;
    }
    .recruit-footer .footer-bg {
        position: relative;
        width: 100%;
        height: 100%;
    }
    .recruit-footer .footer-bg::after {
        position: absolute;
        content: "";
        top: 0;
        left: 0;
        width: 100%;
        height: 100%;
        background: rgba( 255, 255, 255, 0.5 );
    }
    .recruit-footer .footer-bg img {
        width: 100%;
        height: 100%;
        object-fit: cover;
    }
    .recruit-footer .footer-btn-intern {
        position: absolute;
        display: flex;
        align-items: center;
        justify-content: center;
        top: 50%;
        left: 5%;
        width: 28%;
        height: auto;
        aspect-ratio: 522 / 103;
        color: transparent;
        background: #fff;
        border: 2px solid transparent;
        border-image: linear-gradient( to right, #0fabff, #00e3c1 ) 1;
        translate: 0 -50%;
    }
    .recruit-footer .footer-btn-intern::before {
        position: absolute;
        content: "インターン";
        top: 50%;
        left: 50%;
        width: max-content;
        font-size: 2.0vw;
        font-weight: 700;
        text-align: center;
        background: linear-gradient( to right, #0fabff, #00e3c1 );
        -webkit-background-clip: text;
        -webkit-text-fill-color: transparent;
        translate: -50% -50%;
    }
    .recruit-footer .footer-btn-fresh {
        position: absolute;
        display: flex;
        align-items: center;
        justify-content: center;
        top: 50%;
        left: 36%;
        width: 28%;
        height: auto;
        aspect-ratio: 522 / 103;
        color: #fff;
        font-size: 2.0vw;
        font-weight: 700;
        text-align: center;
        background: linear-gradient( to right, #0fabff, #00e3c1 );
        translate: 0 -50%;
    }
    .recruit-footer .footer-btn-career {
        position: absolute;
        display: flex;
        align-items: center;
        justify-content: center;
        top: 50%;
        right: 5%;
        width: 28%;
        height: auto;
        aspect-ratio: 522 / 103;
        color: transparent;
        background: #fff;
        border: 2px solid transparent;
        border-image: linear-gradient( to right, #0fabff, #00e3c1 ) 1;
        translate: 0 -50%;
    }
    .recruit-footer .footer-btn-career::before {
        position: absolute;
        content: "キャリアエントリー";
        top: 50%;
        left: 50%;
        width: max-content;
        font-size: 2.0vw;
        font-weight: 700;
        text-align: center;
        background: linear-gradient( to right, #0fabff, #00e3c1 );
        -webkit-background-clip: text;
        -webkit-text-fill-color: transparent;
        translate: -50% -50%;
    }

    #recruit-top-about {
        margin: 0 auto;
        padding: 0;
        width: 100%;
        background: #f1faff;
        display: flex;
        align-items: center;
        justify-content: space-between;
    }
    #recruit-top-about .about-info {
        margin: 0;
        padding: 0 0 0 6%;
        width: 52%;
    }
    #recruit-top-about .about-info h2 {
        margin: 0;
        width: max-content;
        max-width: 100%;
        font-size: 100px;
        font-weight: 700;
        font-family: var(--font-alphabet);
        line-height: 1.1;
        background: linear-gradient( to right, #0fabff, #00e3c1 );
        -webkit-background-clip: text;
        -webkit-text-fill-color: transparent;
    }
    #recruit-top-about .about-info h3 {
        margin: 1.0em 0 0;
        width: max-content;
        max-width: 100%;
        font-size: 26px;
        font-weight: 700;
        font-family: var(--font-alphabet);
        line-height: 1.1;
        background: linear-gradient( to right, #0fabff, #00e3c1 );
        -webkit-background-clip: text;
        -webkit-text-fill-color: transparent;
    }
    #recruit-top-about .about-info h4 {
        margin: 1.0em 0 0;
        font-size: 36px;
        font-weight: 700;
        line-height: calc( 50 / 36 );
    }
    #recruit-top-about .about-info p {
        margin: 2.0em 0 0;
        width: 85%;
        font-size: 18px;
        font-weight: 500;
        line-height: calc( 30 / 18 );
    }
    #recruit-top-about .about-movie {
        position: relative;
        margin: 0;
        padding: 130px 0;
        width: 45%;
        z-index: 2;
        overflow: hidden;
    }
    #recruit-top-about .about-movie::before {
        position: absolute;
        content: "";
        top: 50%;
        left: 10%;
        width: 80%;
        height: auto;
        aspect-ratio: 1 / 1;
        background: linear-gradient( to right, #0fabff, #00e3c1 );
        transform: translate( 10%, -50% ) rotate( 135deg );
        z-index: 1;
    }
    #recruit-top-about .about-movie .about-movie-wrap {
        width: 100%;
        height: auto;
        aspect-ratio: 1920 / 1080;
    }
    #recruit-top-about .about-movie iframe {
        position: relative;
        display: block;
        width: 100%;
        height: auto;
        aspect-ratio: 1920 / 1080;
        border: 0;
        z-index: 2;
    }

    #recruit-top-links {
        margin: 0 auto;
        padding: 0 0 5.0vw;
        width: 100%;
        background: #f1faff;
    }
    #recruit-top-links .link-pic {
        margin: 0 auto;
        padding: 0;
        width: 100%;
        height: auto;
        aspect-ratio: 1512 / 458;
    }
    #recruit-top-links .link-pic img {
        width: 100%;
        height: 100%;
        object-fit: cover;
    }
    #recruit-top-links .link-flex {
        display: flex;
        align-items: center;
        justify-content: center;
        gap: 0 4.0vw;
        translate: 0 -35%;
    }
    #recruit-top-links .link-flex > a {
        display: block;
        padding: 2.0vw;
        width: 28%;
        background: #fff;
    }
    #recruit-top-links .link-flex > a .icon {
        display: block;
        margin: 0 auto;
        width: 82px;
        height: 82px;
    }
    #recruit-top-links .link-flex > a .icon img {
        width: 100%;
        height: 100%;
        object-fit: contain;
    }
    #recruit-top-links .link-flex > a span {
        position: relative;
        display: block;
        margin: 40px 0 0;
        width: 100%;
        font-size: 18px;
        font-weight: 700;
        line-height: 1.0;
    }
    #recruit-top-links .link-flex > a span::before {
        position: absolute;
        content: "";
        top: 0.5em;
        right: 0;
        width: 1.6em;
        height: 1px;
        background: var(--fg-color);
    }
    #recruit-top-links .link-flex > a span::after {
        position: absolute;
        content: "";
        top: 0.5em;
        right: 0;
        width: 0.6em;
        height: 1px;
        background: var(--fg-color);
        transform-origin: right center;
        transform: rotate( 40deg );
    }

    #recruit-top-works {
        margin: 0 auto;
        padding: 0;
        width: 100%;
        display: flex;
        align-items: center;
        justify-content: space-between;
    }
    #recruit-top-works .pic {
        margin: 0;
        padding: 0;
        width: 48%;
        height: auto;
        aspect-ratio: 724 / 793;
    }
    #recruit-top-works .pic img {
        width: 100%;
        height: 100%;
        object-fit: cover;
    }
    #recruit-top-works .work-info {
        width: 48%;
    }
    #recruit-top-works .work-info h2 {
        margin: 0;
        width: max-content;
        max-width: 100%;
        font-size: 100px;
        font-weight: 700;
        font-family: var(--font-alphabet);
        line-height: 1.1;
        background: linear-gradient( to right, #0fabff, #00e3c1 );
        -webkit-background-clip: text;
        -webkit-text-fill-color: transparent;
    }
    #recruit-top-works .work-info h3 {
        margin: 1.0em 0 0;
        width: max-content;
        max-width: 100%;
        font-size: 26px;
        font-weight: 700;
        line-height: 1.1;
        background: linear-gradient( to right, #0fabff, #00e3c1 );
        -webkit-background-clip: text;
        -webkit-text-fill-color: transparent;
    }
    #recruit-top-works .work-info h4 {
        margin: 1.0em 0 0;
        font-size: 36px;
        font-weight: 700;
        line-height: calc( 50 / 36 );
    }
    #recruit-top-works .work-info p {
        margin: 2.0em 0 0;
        width: 85%;
        font-size: 18px;
        font-weight: 500;
        line-height: calc( 30 / 18 );
    }
    #recruit-top-works .work-info .common-btn {
        margin: 80px 0 0;
        display: flex;
        align-items: center;
        justify-content: center;
        gap: 0 10px;
        width: 240px;
        height: auto;
        aspect-ratio: 240 / 48;
        color: #fff;
        font-size: 14px;
        font-weight: 500;
        text-align: center;
        background: linear-gradient( to right, #0fabff, #00e3c1 );
    }
    #recruit-top-works .work-info .common-btn span:nth-child(2) {
        position: relative;
        display: inline-block;
        width: 1.6em;
        height: 1.0em;
    }
    #recruit-top-works .work-info .common-btn span:nth-child(2)::before {
        position: absolute;
        content: "";
        top: 0.5em;
        left: 0;
        width: 100%;
        height: 1px;
        background: #fff;
    }
    #recruit-top-works .work-info .common-btn span:nth-child(2)::after {
        position: absolute;
        content: "";
        top: 0.5em;
        right: 0;
        width: 0.6em;
        height: 1px;
        background: #fff;
        transform-origin: right center;
        transform: rotate( 40deg );
    }

    #recruit-top-environment {
        margin: 0 auto;
        padding: 130px 0;
        width: 100%;
        background: linear-gradient( to bottom, #fff, #0fabff );
    }
    #recruit-top-environment > h2 {
        margin: 0 0 0 5.0vw;
        width: max-content;
        max-width: 100%;
        font-size: 100px;
        font-weight: 700;
        font-family: var(--font-alphabet);
        line-height: 1.1;
        background: linear-gradient( to right, #0fabff, #00e3c1 );
        -webkit-background-clip: text;
        -webkit-text-fill-color: transparent;
    }
    #recruit-top-environment > h3 {
        margin: 0.8em 0 0 5.0vw;
        width: max-content;
        max-width: 100%;
        color: #fff;
        font-size: 26px;
        font-weight: 700;
        line-height: 1.1;
    }
    #recruit-top-environment > .environment-wrap {
        position: relative;
        margin: 80px auto 0;
        padding: 0;
        width: 100%;
        height: auto;
    }
    #recruit-top-environment > .environment-wrap .pic {
        margin: 0 auto 0 0;
        padding: 0;
        width: 46%;
        height: auto;
        aspect-ratio: 693 / 525;
    }
    #recruit-top-environment > .environment-wrap .pic img {
        width: 100%;
        height: 100%;
        object-fit: cover;
    }
    #recruit-top-environment > .environment-wrap .environment-box {
        position: absolute;
        top: 50%;
        right: 5%;
        margin: 0;
        padding: 20px 100px;
        width: 60%;
        height: auto;
        background: #fff;
        translate: 0 -50%;
    }
    #recruit-top-environment > .environment-wrap .environment-box h4 {
        margin: 0;
        padding: 40px 0 0;
        font-size: 26px;
        font-weight: 700;
        text-align: left;
    }
    #recruit-top-environment > .environment-wrap .environment-box a {
        position: relative;
        display: block;
        margin: 1.0em 0 0;
        padding: 0 0 40px;
        font-size: 18px;
        font-weight: 500;
        line-height: calc( 30 / 18 );
        border-bottom: 1px solid #d6d6d6;
    }
    #recruit-top-environment > .environment-wrap .environment-box a::before {
        position: absolute;
        content: "";
        top: 0.5em;
        right: 0;
        width: 1.6em;
        height: 1px;
        background: var(--fg-color);
    }
    #recruit-top-environment > .environment-wrap .environment-box a::after {
        position: absolute;
        content: "";
        top: 0.5em;
        right: 0;
        width: 0.6em;
        height: 1px;
        background: var(--fg-color);
        transform-origin: right center;
        transform: rotate( 40deg );
    }

    #recruit-top-people {
        margin: 0 auto;
        padding: 130px 0;
        width: 100%;
        background: linear-gradient( to bottom, #0fabff, #00e3c1 );
        overflow: hidden;
        z-index: 1;
    }
    #recruit-top-people::before {
        position: absolute;
        content: "";
        top: 0;
        right: 0;
        width: 36%;
        height: auto;
        aspect-ratio: 1 / 1;
        background: #fff;
        rotate: -45deg;
        z-index: 2;
    }
    #recruit-top-people > h2 {
        position: relative;
        margin: 0 0 0 5.0vw;
        width: max-content;
        max-width: 100%;
        color: #fff;
        font-size: 100px;
        font-weight: 700;
        font-family: var(--font-alphabet);
        line-height: 1.1;
        z-index: 3;
    }
    #recruit-top-people > h3 {
        position: relative;
        margin: 0.8em 0 0 5.0vw;
        width: max-content;
        max-width: 100%;
        color: #fff;
        font-size: 26px;
        font-weight: 700;
        line-height: 1.1;
        z-index: 3;
    }
    #recruit-top-people > .people-flex {
        position: relative;
        margin: 60px auto 0;
        width: 90%;
        display: flex;
        align-items: flex-start;
        justify-content: flex-start;
        gap: 0 20px;
        z-index: 3;
    }
    #recruit-top-people > .people-flex .people-flex-item {
        margin: 0;
        width: 24%;
    }
    #recruit-top-people > .people-flex .people-flex-item:nth-child(2) {
        translate: 0 10%;
    }
    #recruit-top-people > .people-flex .people-flex-item .pic {
        position: relative;
        width: 100%;
        height: auto;
        aspect-ratio: 301 / 333;
    }
    #recruit-top-people > .people-flex .people-flex-item .pic figcaption {
        position: absolute;
        right: 0;
        bottom: 0;
        margin: 0;
        padding: 10px;
        width: max-content;
        height: auto;
        background: #fff;
    }
    #recruit-top-people > .people-flex .people-flex-item .pic figcaption span {
        display: block;
        color: #626262;
        font-size: 11px;
        font-weight: 400;
        line-height: 1.5;
    }
    #recruit-top-people > .people-flex .people-flex-item .pic figcaption span:nth-child(1) {
        margin: 0 0 0.5em;
        color: var(--fg-color);
        font-size: 14px;
        font-weight: 700;
    }
    #recruit-top-people > .people-flex .people-flex-item .pic img {
        width: 100%;
        height: 100%;
        object-fit: cover;
    }
    #recruit-top-people > .people-flex .people-flex-item p {
        margin: 0.5em 0 0;
        font-size: 16px;
        font-weight: 700;
        text-align: left;
        line-height: calc( 25 / 16 );
    }

    .recruit-wrap {
        margin: 0 auto;
        padding: 80px 0;
        width: 100%;
        display: flex;
        align-items: stretch;
        justify-content: space-between;
        background: #f1faff;
    }
    .recruit-wrap .recruit-sidebar {
        width: calc( 300px + 5.0vw );
        padding: 0 0 0 5.0vw;
    }
    .recruit-wrap .recruit-sidebar .recruit-sidebar-links {
        position: sticky;
        top: 100px;
    }
    .recruit-wrap .recruit-sidebar .recruit-sidebar-links a {
        display: block;
        margin: 0.4em 0 0;
        font-size: 16px;
        font-weight: 500;
    }
    .recruit-wrap .recruit-sidebar .recruit-sidebar-links a.active {
        color: #00aeef;
    }

    .recruit-wrap .recruit-contents {
        width: calc( 100% - 300px - 40px - 5.0vw );
    }
    .recruit-wrap .recruit-contents .recruit-team {
        width: 100%;
    }
    .recruit-wrap .recruit-contents .recruit-team + .recruit-team {
        margin-top: 80px;
    }
    .recruit-wrap .recruit-contents h2 {
        margin: 0 auto;
        width: max-content;
        max-width: 100%;
        font-size: 48px;
        font-weight: 700;
        line-height: 1.1;
        background: linear-gradient( to right, #0fabff, #00e3c1 );
        -webkit-background-clip: text;
        -webkit-text-fill-color: transparent;
    }
    .recruit-wrap .recruit-contents h2.left {
        margin: 0 auto 0 0;
    }
    .recruit-wrap .recruit-contents h2.normal {
        margin: 0 auto 0 0;
        color: #00aeef;
        font-size: 24px;
        background: none;
        -webkit-background-clip: initial;
        -webkit-text-fill-color: initial;
    }
    .recruit-wrap .recruit-contents h2:not(:first-of-type) {
        margin-top: 160px;
    }
    .recruit-wrap .recruit-contents h3 {
        margin: 0.2em auto 0;
        width: max-content;
        max-width: 100%;
        font-size: 20px;
        font-weight: 700;
        line-height: 1.1;
        background: linear-gradient( to right, #0fabff, #00e3c1 );
        -webkit-background-clip: text;
        -webkit-text-fill-color: transparent;
    }
    .recruit-wrap .recruit-contents h3.left {
        margin: 0.2em auto 0 0;
    }
    .recruit-wrap .recruit-contents h4 {
        margin: 1.5em auto;
        width: 100%;
        font-size: 36px;
        font-weight: 700;
        text-align: left;
        line-height: 1.2;
    }
    .recruit-wrap .recruit-contents :is(h3,h4).bar {
        margin: 1.5em auto 0 0;
        padding: 0.8em 1.0em;
        width: 90%;
        color: #fff;
        font-size: 24px;
        font-weight: 500;
        text-align: left;
        line-height: 1.0;
        background: #00aeef;
    }
    .recruit-wrap .recruit-contents p {
        margin: 1.5em auto 0 0;
        padding: 0;
        width: 90%;
        font-size: 20px;
        font-weight: 400;
        line-height: 1.8;
    }
    .recruit-wrap .recruit-contents p.narrow {
        width: 80%;
    }
    .recruit-wrap .recruit-contents p.list {
        margin: 1.0em auto 0;
        width: 100%;
        color: #00aeef;
        font-size: 24px;
        font-weight: 500;
        line-height: 1.8;
    }
    .recruit-wrap .recruit-contents p.list::before {
        content: "◆ ";
    }
    .recruit-wrap .recruit-contents p.indent {
        margin: 1.0em auto 0;
        text-indent: 1.5em;
        width: 100%;
        font-size: 20px;
        font-weight: 400;
        line-height: 1.8;
    }
    .recruit-wrap .recruit-contents .pic {
        margin: 60px auto 0 0;
        width: 90%;
        height: auto;
        aspect-ratio: 1015 / 345;
    }
    .recruit-wrap .recruit-contents .pic.business {
        margin: 20px auto 0 0;
        width: 90%;
        aspect-ratio: 1210 / 964;
    }
    .recruit-wrap .recruit-contents .pic img {
        width: 100%;
        height: 100%;
        object-fit: cover;
    }
    .recruit-wrap .recruit-contents .grid-area {
        margin: 80px auto 0 0;
        width: 90%;
        display: grid;
        grid-template-columns: repeat( 2, 1fr );
        gap: 40px 40px;
    }
    .recruit-wrap .recruit-contents :is(h3,h4).bar + .grid-area {
        margin-top: 40px;
    }
    .recruit-wrap .recruit-contents .grid-area .grid-item {
        margin: 0;
        width: 100%;
    }
    .recruit-wrap .recruit-contents .grid-area .grid-item.left-bar {
        padding-left: 20px;
        border-left: 1px solid #00e3c1;
    }
    .recruit-wrap .recruit-contents .grid-area .grid-item .pic {
        width: 100%;
        height: auto;
        aspect-ratio: 398 / 216;
    }
    .recruit-wrap .recruit-contents .grid-area .grid-item .pic img {
        width: 100%;
        height: 100%;
        object-fit: cover;
    }
    .recruit-wrap .recruit-contents .grid-area .grid-item :is(h3,h4) {
        margin: 0.8em 0;
        color: #00aeef;
        font-size: 18px;
        font-weight: 700;
        text-align: left;
        line-height: 1.2;
    }
    .recruit-wrap .recruit-contents .grid-area .grid-item p {
        margin: 1.0em 0;
        font-size: 16px;
        font-weight: 700;
        text-align: left;
        line-height: 1.8;
    }

    #recruit-interview {
        margin: 0 auto;
        padding: 80px 0;
        width: 100%;
        background: #f1faff;
    }
    #recruit-interview .interview-grid {
        margin: 0 auto;
        width: 90%;
        display: grid;
        grid-template-columns: repeat( 2, 1fr );
        gap: 40px 40px;
    }
    #recruit-interview .interview-grid .interview-grid-item {
        display: block;
        margin: 0;
        width: 100%;
    }
    #recruit-interview .interview-grid .interview-grid-item .pic {
        position: relative;
        margin: 0;
        width: 100%;
        height: auto;
        aspect-ratio: 562 / 246;
    }
    #recruit-interview .interview-grid .interview-grid-item .pic img {
        width: 100%;
        height: 100%;
        object-fit: cover;
    }
    #recruit-interview .interview-grid .interview-grid-item .pic figcaption {
        position: absolute;
        right: 0;
        bottom: 0;
        margin: 0;
        padding: 10px;
        width: max-content;
        height: auto;
        background: #fff;
    }
    #recruit-interview .interview-grid .interview-grid-item .pic figcaption span {
        display: block;
        color: #626262;
        font-size: 11px;
        font-weight: 400;
        line-height: 1.5;
    }
    #recruit-interview .interview-grid .interview-grid-item .pic figcaption span:nth-child(1) {
        margin: 0 0 0.5em;
        color: var(--fg-color);
        font-size: 14px;
        font-weight: 700;
    }
    #recruit-interview .interview-grid .interview-grid-item p {
        margin: 0.5em 0 0;
        font-size: 16px;
        font-weight: 700;
        text-align: left;
        line-height: calc( 25 / 16 );
    }

    #recruit-info-child {
        margin: 0 auto;
        padding: 80px 5%;
        width: 100%;
    }
    #recruit-info-child > h1 {
        margin: 0 0 1.5em;
        font-size: 32px;
        font-weight: 700;
        text-align: left;
    }
    .recruit-apply #recruit-info-child .recruit-info-child-content {
        padding: 40px;
        background: #fff;
    }
    #recruit-info-child .recruit-info-child-content .recruit-info-box {
        display: block;
        margin: 40px auto 0;
        padding: 40px;
        width: 100%;
        display: flex;
        align-items: center;
        justify-content: space-between;
        border: 1px solid #d6d6d6;
    }
    #recruit-info-child .recruit-info-child-content .recruit-info-box .recruit-info-pic {
        margin: 0;
        padding: 0;
        width: 25%;
        height: auto;
        aspect-ratio: 241 / 124;
    }
    #recruit-info-child .recruit-info-child-content .recruit-info-box .recruit-info-pic img {
        width: 100%;
        height: 100%;
        object-fit: cover;
    }
    #recruit-info-child .recruit-info-child-content .recruit-info-box .recruit-info-txt {
        margin: 0;
        padding: 0;
        width: 70%;
    }
    #recruit-info-child .recruit-info-child-content .recruit-info-box .recruit-info-txt h2 {
        margin: 0;
        font-size: 18px;
        font-weight: 700;
        text-align: left;
    }
    #recruit-info-child .recruit-info-child-content .recruit-info-box .recruit-info-txt p {
        margin: 1.5em 0 0;
        font-size: 16px;
        font-weight: 400;
        text-align: left;
        line-height: 1.8:
    }
    #recruit-info-child .recruit-info-child-content h2 {
        margin: 1.5em 0 0.5em;
        color: #00aeef;
        font-size: 24px;
        font-weight: 500;
        text-align: left;
    }
    #recruit-info-child .recruit-info-child-content h2:first-child {
        margin-top: 0;
    }
    #recruit-info-child .recruit-info-child-content :is(p,div) {
        margin: 1.5em 0 0;
        font-size: 16px;
        font-weight: 400;
        text-align: left;
        line-height: 1.8;
    }
    #recruit-info-child .recruit-info-child-content th {
        margin: 0;
        font-size: 18px;
        font-weight: 700;
        text-align: left;
        line-height: 1.8;
    }
    #recruit-info-child .recruit-info-child-content td {
        margin: 0;
        font-size: 16px;
        font-weight: 400;
        text-align: left;
        line-height: 1.8;
    }
    #recruit-info-child .recruit-info-child-content dl {
        margin: 20px 0 0 40px;
        width: calc( 100% - 40px );
        display: grid;
        grid-template-columns: 200px 1fr;
        gap: 0;
        border-top: 1px solid #d6d6d6;
    }
    #recruit-info-child .recruit-info-child-content dt {
        margin: 0;
        padding: 20px 0;
        font-size: 16px;
        font-weight: 500;
        text-align: left;
        line-height: 1.8;
        border-bottom: 1px solid #d6d6d6;
    }
    #recruit-info-child .recruit-info-child-content dd {
        margin: 0;
        padding: 20px 0;
        font-size: 16px;
        font-weight: 400;
        text-align: left;
        line-height: 1.8;
        border-bottom: 1px solid #d6d6d6;
    }
    #recruit-info-child .recruit-info-child-content .common-btn {
        margin: 80px 0 0 auto;
        display: flex;
        align-items: center;
        justify-content: center;
        gap: 0 10px;
        width: 240px;
        height: auto;
        aspect-ratio: 240 / 48;
        color: #fff;
        font-size: 14px;
        font-weight: 500;
        text-align: center;
        background: linear-gradient( to right, #0fabff, #00e3c1 );
    }
    #recruit-info-child .recruit-info-child-content .common-btn span:nth-child(2) {
        position: relative;
        display: inline-block;
        width: 1.6em;
        height: 1.0em;
    }
    #recruit-info-child .recruit-info-child-content .common-btn span:nth-child(2)::before {
        position: absolute;
        content: "";
        top: 0.5em;
        left: 0;
        width: 100%;
        height: 1px;
        background: #fff;
    }
    #recruit-info-child .recruit-info-child-content .common-btn span:nth-child(2)::after {
        position: absolute;
        content: "";
        top: 0.5em;
        right: 0;
        width: 0.6em;
        height: 1px;
        background: #fff;
        transform-origin: right center;
        transform: rotate( 40deg );
    }

    #recruit-info-child  .recruit-info-child-content .recruit-apply-form {
        margin: 0;
        width: 100%;
        display: grid;
        grid-template-columns: 1fr 1fr;
        gap: 40px;
    }
    #recruit-info-child  .recruit-info-child-content .recruit-apply-form > div {
        margin: 0;
        width: 100%;
    }
    #recruit-info-child  .recruit-info-child-content .recruit-apply-form > div.two-cols {
        grid-column: span 2;
    }
    #recruit-info-child  .recruit-info-child-content .recruit-apply-form > div label {
        font-size: 18px;
        font-weight: 500;
    }
    #recruit-info-child  .recruit-info-child-content .recruit-apply-form > div label::after {
        content: " 必須";
        color: #848484;
        font-size: 12px;
        font-weight: 400;
    }
    #recruit-info-child  .recruit-info-child-content .recruit-apply-form > div :is(input[type="text"],input[type="email"],input[type="date"],select) {
        margin: 0;
        padding: 0.5em;
        width: 100%;
        font-size: 16px;
        font-family: inherit;
        font-weight: 500;
        border: 1px solid #ccc;
        border-radius: 0.5em;
    }
    #recruit-info-child  .recruit-info-child-content input[type="submit"] {
        display: block;
        margin: 4.0em 0 0;
        padding: 0.5em 2.0em;
        width: max-conetnt;
        color: #fff;
        font-size: 18px;
        font-family: inherit;
        font-weight: 500;
        border: 0;
        background: linear-gradient( to right, #0fabff, #00e3c1 );
    }

    #recruit-interview-child {
        margin: 0 auto;
        padding: 80px 0;
        width: 100%;
    }
    #recruit-interview-child .recruit-interview-child-content {
        margin: 0 auto;
        width: 90%;
    }
    #recruit-interview-child .recruit-interview-child-content .recruit-interview-child-flex {
        margin: 0 auto;
        width: 100%;
        display: flex;
        align-items: center;
        justify-content: space-between;
    }
    #recruit-interview-child .recruit-interview-child-content .recruit-interview-child-flex + .recruit-interview-child-flex {
        margin-top: 80px;
    }
    #recruit-interview-child .recruit-interview-child-content .recruit-interview-child-flex .recruit-interview-child-head-pic {
        margin: 0;
        width: 55%;
        height: auto;
        aspect-ratio: 813 / 447;
    }
    #recruit-interview-child .recruit-interview-child-content .recruit-interview-child-flex .recruit-interview-child-head-txt {
        margin: 0;
        width: 40%;
        height: auto;
    }
    #recruit-interview-child .recruit-interview-child-content .recruit-interview-child-flex .recruit-interview-child-pic {
        margin: 0;
        width: 40%;
        height: auto;
        aspect-ratio: 499 / 260;
    }
    #recruit-interview-child .recruit-interview-child-content .recruit-interview-child-flex .recruit-interview-child-txt {
        margin: 0;
        width: 55%;
        height: auto;
    }
    #recruit-interview-child .recruit-interview-child-content h1 {
        margin: 0 0 0.5em;
        color: #00ccff;
        font-size: 32px;
        font-weight: 400;
        text-align: left;
    }
    #recruit-interview-child .recruit-interview-child-content h2 {
        margin: 0;
        font-size: 24px;
        font-weight: 700;
        text-align: left;
        line-height: 1.5;
    }
    #recruit-interview-child .recruit-interview-child-content h3 {
        margin: 0 0 1.0em;
        font-size: 24px;
        font-weight: 700;
        text-align: left;
        line-height: 1.5;
    }
    #recruit-interview-child .recruit-interview-child-content p {
        margin: 1.0em 0 0;
        font-size: 18px;
        font-weight: 400;
        text-align: left;
        line-height: 1.8;
    }
    #recruit-interview-child .recruit-interview-child-content hr {
        margin: 40px 0;
        width: 100%;
        height: 1px;
        background: #d6d6d6;
        border: 0;
    }
    #recruit-interview-child .recruit-interview-child-content .interview-attr {
        margin: 0;
        color: #626262;
        font-size: 14px;
        font-weight: 500;
        text-align: left;
    }
    #recruit-interview-child .recruit-interview-child-content .interview-name {
        margin: 0.5em 0 0;
        font-size: 20px;
        font-weight: 700;
        text-align: left;
    }

}


/**
 * 最大設定
 */
@media ( width >= 1200px ) {
}
