@font-face {
    font-family: "swiper-icons";
    src: url("data:application/font-woff;charset=utf-8;base64, d09GRgABAAAAAAZgABAAAAAADAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAABGRlRNAAAGRAAAABoAAAAci6qHkUdERUYAAAWgAAAAIwAAACQAYABXR1BPUwAABhQAAAAuAAAANuAY7+xHU1VCAAAFxAAAAFAAAABm2fPczU9TLzIAAAHcAAAASgAAAGBP9V5RY21hcAAAAkQAAACIAAABYt6F0cBjdnQgAAACzAAAAAQAAAAEABEBRGdhc3AAAAWYAAAACAAAAAj//wADZ2x5ZgAAAywAAADMAAAD2MHtryVoZWFkAAABbAAAADAAAAA2E2+eoWhoZWEAAAGcAAAAHwAAACQC9gDzaG10eAAAAigAAAAZAAAArgJkABFsb2NhAAAC0AAAAFoAAABaFQAUGG1heHAAAAG8AAAAHwAAACAAcABAbmFtZQAAA/gAAAE5AAACXvFdBwlwb3N0AAAFNAAAAGIAAACE5s74hXjaY2BkYGAAYpf5Hu/j+W2+MnAzMYDAzaX6QjD6/4//Bxj5GA8AuRwMYGkAPywL13jaY2BkYGA88P8Agx4j+/8fQDYfA1AEBWgDAIB2BOoAeNpjYGRgYNBh4GdgYgABEMnIABJzYNADCQAACWgAsQB42mNgYfzCOIGBlYGB0YcxjYGBwR1Kf2WQZGhhYGBiYGVmgAFGBiQQkOaawtDAoMBQxXjg/wEGPcYDDA4wNUA2CCgwsAAAO4EL6gAAeNpj2M0gyAACqxgGNWBkZ2D4/wMA+xkDdgAAAHjaY2BgYGaAYBkGRgYQiAHyGMF8FgYHIM3DwMHABGQrMOgyWDLEM1T9/w8UBfEMgLzE////P/5//f/V/xv+r4eaAAeMbAxwIUYmIMHEgKYAYjUcsDAwsLKxc3BycfPw8jEQA/gZBASFhEVExcQlJKWkZWTl5BUUlZRVVNXUNTQZBgMAAMR+E+gAEQFEAAAAKgAqACoANAA+AEgAUgBcAGYAcAB6AIQAjgCYAKIArAC2AMAAygDUAN4A6ADyAPwBBgEQARoBJAEuATgBQgFMAVYBYAFqAXQBfgGIAZIBnAGmAbIBzgHsAAB42u2NMQ6CUAyGW568x9AneYYgm4MJbhKFaExIOAVX8ApewSt4Bic4AfeAid3VOBixDxfPYEza5O+Xfi04YADggiUIULCuEJK8VhO4bSvpdnktHI5QCYtdi2sl8ZnXaHlqUrNKzdKcT8cjlq+rwZSvIVczNiezsfnP/uznmfPFBNODM2K7MTQ45YEAZqGP81AmGGcF3iPqOop0r1SPTaTbVkfUe4HXj97wYE+yNwWYxwWu4v1ugWHgo3S1XdZEVqWM7ET0cfnLGxWfkgR42o2PvWrDMBSFj/IHLaF0zKjRgdiVMwScNRAoWUoH78Y2icB/yIY09An6AH2Bdu/UB+yxopYshQiEvnvu0dURgDt8QeC8PDw7Fpji3fEA4z/PEJ6YOB5hKh4dj3EvXhxPqH/SKUY3rJ7srZ4FZnh1PMAtPhwP6fl2PMJMPDgeQ4rY8YT6Gzao0eAEA409DuggmTnFnOcSCiEiLMgxCiTI6Cq5DZUd3Qmp10vO0LaLTd2cjN4fOumlc7lUYbSQcZFkutRG7g6JKZKy0RmdLY680CDnEJ+UMkpFFe1RN7nxdVpXrC4aTtnaurOnYercZg2YVmLN/d/gczfEimrE/fs/bOuq29Zmn8tloORaXgZgGa78yO9/cnXm2BpaGvq25Dv9S4E9+5SIc9PqupJKhYFSSl47+Qcr1mYNAAAAeNptw0cKwkAAAMDZJA8Q7OUJvkLsPfZ6zFVERPy8qHh2YER+3i/BP83vIBLLySsoKimrqKqpa2hp6+jq6RsYGhmbmJqZSy0sraxtbO3sHRydnEMU4uR6yx7JJXveP7WrDycAAAAAAAH//wACeNpjYGRgYOABYhkgZgJCZgZNBkYGLQZtIJsFLMYAAAw3ALgAeNolizEKgDAQBCchRbC2sFER0YD6qVQiBCv/H9ezGI6Z5XBAw8CBK/m5iQQVauVbXLnOrMZv2oLdKFa8Pjuru2hJzGabmOSLzNMzvutpB3N42mNgZGBg4GKQYzBhYMxJLMlj4GBgAYow/P/PAJJhLM6sSoWKfWCAAwDAjgbRAAB42mNgYGBkAIIbCZo5IPrmUn0hGA0AO8EFTQAA") format("woff");
    font-weight: 400;
    font-style: normal
}

:root {
    --swiper-theme-color: #007aff
}

.swiper {
    margin-left: auto;
    margin-right: auto;
    position: relative;
    overflow: hidden;
    list-style: none;
    padding: 0;
    z-index: 1
}

.swiper-vertical>.swiper-wrapper {
    flex-direction: column
}

.swiper-wrapper {
    position: relative;
    width: 100%;
    height: 100%;
    z-index: 1;
    display: flex;
    transition-property: transform;
    box-sizing: content-box
}

.swiper-android .swiper-slide,
.swiper-wrapper {
    transform: translate3d(0px, 0, 0)
}

.swiper-pointer-events {
    touch-action: pan-y
}

.swiper-pointer-events.swiper-vertical {
    touch-action: pan-x
}

.swiper-slide {
    flex-shrink: 0;
    width: 100%;
    height: 100%;
    position: relative;
    transition-property: transform
}

.swiper-slide-invisible-blank {
    visibility: hidden
}

.swiper-autoheight,
.swiper-autoheight .swiper-slide {
    height: auto
}

.swiper-autoheight .swiper-wrapper {
    align-items: flex-start;
    transition-property: transform, height
}

.swiper-backface-hidden .swiper-slide {
    transform: translateZ(0);
    backface-visibility: hidden
}

.swiper-3d,
.swiper-3d.swiper-css-mode .swiper-wrapper {
    perspective: 1200px
}

.swiper-3d .swiper-wrapper,
.swiper-3d .swiper-slide,
.swiper-3d .swiper-slide-shadow,
.swiper-3d .swiper-slide-shadow-left,
.swiper-3d .swiper-slide-shadow-right,
.swiper-3d .swiper-slide-shadow-top,
.swiper-3d .swiper-slide-shadow-bottom,
.swiper-3d .swiper-cube-shadow {
    transform-style: preserve-3d
}

.swiper-3d .swiper-slide-shadow,
.swiper-3d .swiper-slide-shadow-left,
.swiper-3d .swiper-slide-shadow-right,
.swiper-3d .swiper-slide-shadow-top,
.swiper-3d .swiper-slide-shadow-bottom {
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    pointer-events: none;
    z-index: 10
}

.swiper-3d .swiper-slide-shadow {
    background: rgba(0, 0, 0, .15)
}

.swiper-3d .swiper-slide-shadow-left {
    background-image: linear-gradient(to left, rgba(0, 0, 0, 0.5), rgba(0, 0, 0, 0))
}

.swiper-3d .swiper-slide-shadow-right {
    background-image: linear-gradient(to right, rgba(0, 0, 0, 0.5), rgba(0, 0, 0, 0))
}

.swiper-3d .swiper-slide-shadow-top {
    background-image: linear-gradient(to top, rgba(0, 0, 0, 0.5), rgba(0, 0, 0, 0))
}

.swiper-3d .swiper-slide-shadow-bottom {
    background-image: linear-gradient(to bottom, rgba(0, 0, 0, 0.5), rgba(0, 0, 0, 0))
}

.swiper-css-mode>.swiper-wrapper {
    overflow: auto;
    scrollbar-width: none;
    -ms-overflow-style: none
}

.swiper-css-mode>.swiper-wrapper::-webkit-scrollbar {
    display: none
}

.swiper-css-mode>.swiper-wrapper>.swiper-slide {
    scroll-snap-align: start start
}

.swiper-horizontal.swiper-css-mode>.swiper-wrapper {
    scroll-snap-type: x mandatory
}

.swiper-vertical.swiper-css-mode>.swiper-wrapper {
    scroll-snap-type: y mandatory
}

.swiper-centered>.swiper-wrapper::before {
    content: "";
    flex-shrink: 0;
    order: 9999
}

.swiper-centered.swiper-horizontal>.swiper-wrapper>.swiper-slide:first-child {
    -webkit-margin-start: var(--swiper-centered-offset-before);
    margin-inline-start: var(--swiper-centered-offset-before)
}

.swiper-centered.swiper-horizontal>.swiper-wrapper::before {
    height: 100%;
    width: var(--swiper-centered-offset-after)
}

.swiper-centered.swiper-vertical>.swiper-wrapper>.swiper-slide:first-child {
    -webkit-margin-before: var(--swiper-centered-offset-before);
    margin-block-start: var(--swiper-centered-offset-before)
}

.swiper-centered.swiper-vertical>.swiper-wrapper::before {
    width: 100%;
    height: var(--swiper-centered-offset-after)
}

.swiper-centered>.swiper-wrapper>.swiper-slide {
    scroll-snap-align: center center;
    scroll-snap-stop: always
}

body {
    margin: 0;
    padding: 0;
    border: none
}

img,
div,
p,
blockquote,
h1,
h2,
h3,
h4,
h5,
h6,
ul,
ol,
li,
dl,
dt,
dd,
form,
fieldset,
textarea,
address,
main,
article,
aside,
figure,
footer,
header,
hgroup,
nav,
section {
    margin: 0;
    padding: 0;
    border: 0;
    font-size: 100%;
    text-decoration: none;
    list-style-type: none
}

main,
article,
aside,
figure,
footer,
header,
hgroup,
nav,
section {
    display: block
}

h1,
h2,
h3,
h4,
h5,
h6 {
    font-weight: inherit
}

table {
    border: none;
    border-collapse: collapse;
    border-spacing: 0
}

th,
td {
    text-align: left;
    vertical-align: top
}

caption {
    text-align: left
}

a,
a:focus,
a:hover,
a:active {
    outline: 0
}

input,
input:focus,
input:hover,
input:active,
textarea,
textarea:focus,
textarea:hover,
textarea:active {
    outline: 0
}

img {
    vertical-align: top
}

html {
    font-size: 10px
}

@media only screen and (min-width: 1500px) {
    html {
        font-size: 12.5px
    }
}

body {
    color: #000;
    font-family: "Noto Sans JP", "Hiragino Kaku Gothic ProN", "Hiragino Sans", Meiryo, sans-serif;
    font-size: 1.4rem;
    line-height: 2;
    -webkit-text-size-adjust: 100%;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale
}

@media only screen and (max-width: 1023px) {
    html {
        font-size: 2.57vw
    }
    body {
        line-height: 1.72
    }
}

::-moz-selection {
    background: #098bde;
    color: #fff
}

::selection {
    background: #098bde;
    color: #fff
}

@keyframes anchor {
    0% {
        background-position: right bottom;
        background-size: 100% auto
    }
    50% {
        background-position: right bottom;
        background-size: 0% auto
    }
    50.1% {
        background-position: left bottom;
        background-size: 0% auto
    }
    100% {
        background-position: left bottom;
        background-size: 100% auto
    }
}

a {
    background: linear-gradient(to top, currentColor 0px, currentColor 1.1px, transparent 1px) no-repeat right bottom;
    background-size: 100% auto;
    color: inherit;
    text-decoration: none
}

a[href^=tel] {
    background: none;
    cursor: default
}

@media(hover: hover) {
    a:hover {
        animation: anchor .4s cubic-bezier(0.645, 0.045, 0.355, 1) 0s
    }
}

img {
    width: 100%;
    height: auto
}

input[type=text],
input[type=tel],
input[type=email],
input[type=password],
textarea {
    box-sizing: border-box;
    margin: 0;
    padding: 0;
    color: #000;
    font-family: "Noto Sans JP", "Hiragino Kaku Gothic ProN", "Hiragino Sans", Meiryo, sans-serif;
    outline: 0;
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none
}

input[type=text]::-moz-placeholder,
input[type=tel]::-moz-placeholder,
input[type=email]::-moz-placeholder,
input[type=password]::-moz-placeholder,
textarea::-moz-placeholder {
    color: #999
}

input[type=text]:-moz-placeholder-shown,
input[type=tel]:-moz-placeholder-shown,
input[type=email]:-moz-placeholder-shown,
input[type=password]:-moz-placeholder-shown,
textarea:-moz-placeholder-shown {
    color: #999
}

input[type=text]::placeholder,
input[type=text]:placeholder-shown,
input[type=tel]::placeholder,
input[type=tel]:placeholder-shown,
input[type=email]::placeholder,
input[type=email]:placeholder-shown,
input[type=password]::placeholder,
input[type=password]:placeholder-shown,
textarea::placeholder,
textarea:placeholder-shown {
    color: #999
}

input[type=text]::-webkit-input-placeholder,
input[type=tel]::-webkit-input-placeholder,
input[type=email]::-webkit-input-placeholder,
input[type=password]::-webkit-input-placeholder,
textarea::-webkit-input-placeholder {
    color: #999
}

input[type=text]:-moz-placeholder,
input[type=tel]:-moz-placeholder,
input[type=email]:-moz-placeholder,
input[type=password]:-moz-placeholder,
textarea:-moz-placeholder {
    color: #999
}

input[type=text]::-moz-placeholder,
input[type=tel]::-moz-placeholder,
input[type=email]::-moz-placeholder,
input[type=password]::-moz-placeholder,
textarea::-moz-placeholder {
    color: #999
}

input[type=text]:-ms-input-placeholder,
input[type=tel]:-ms-input-placeholder,
input[type=email]:-ms-input-placeholder,
input[type=password]:-ms-input-placeholder,
textarea:-ms-input-placeholder {
    color: #999
}

input::-ms-clear {
    visibility: hidden
}

input::-ms-reveal {
    visibility: hidden
}

select {
    box-sizing: border-box;
    margin: 0;
    padding: 0;
    color: #000;
    font-family: "Noto Sans JP", "Hiragino Kaku Gothic ProN", "Hiragino Sans", Meiryo, sans-serif;
    outline: 0;
    cursor: pointer;
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none
}

select::-ms-expand {
    display: none
}

button {
    box-sizing: border-box;
    outline: 0;
    cursor: pointer;
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none
}

.symbols {
    display: none;
    position: absolute;
    top: 0;
    left: 0
}

.header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    position: fixed;
    padding: 2.5rem;
    height: 13rem;
    width: 100%;
    background-color: #FFF;
    box-sizing: border-box;
    z-index: 10
}

.header__logo {
    display: flex;
    align-items: center;
    background: none;
    font-family: "Figtree", "Noto Sans JP", "Hiragino Kaku Gothic ProN", "Hiragino Sans", Meiryo, sans-serif;
    font-size: 2rem;
    font-weight: 600;
    line-height: 1.2
}

.header__logo img {
    width: 29.4rem
}

.header__logo .txt {
    display: flex;
    align-items: center;
    -moz-column-gap: 2rem;
    column-gap: 2rem;
    margin-left: 2rem
}

.header__logo .txt::before {
    content: "";
    display: block;
    width: 1px;
    height: 2rem;
    background: #e0e0e0
}

.header__home {
    transition: all .4s cubic-bezier(0.645, 0.045, 0.355, 1) 0s;
    transition-property: border-color, background, color;
    box-sizing: border-box;
    display: flex;
    justify-content: center;
    align-items: center;
    width: 17.5rem;
    height: 4rem;
    border: #e0e0e0 solid 1px;
    border-radius: 2rem;
    background: none;
    font-weight: 500;
    line-height: 1.5
}

@media(hover: hover) {
    .header__home:hover {
        border-color: #098bde;
        background: #098bde;
        color: #fff
    }
}

@media only screen and (max-width: 1023px) {
    .header {
        height: 9.5rem;
    }
    .header__logo {
        display: block;
        position: fixed;
        top: 2rem;
        left: 2rem;
        z-index: 11;
        font-size: 1.3rem
    }
    .header__logo img {
        width: 24.5rem
    }
    .header__logo .txt {
        display: block;
        margin-left: 4.5rem;
        font-size: 1.8rem;
    }
    .header__logo .txt::before {
        display: none
    }
    .header__home {
        display: block;
        overflow: hidden;
        text-indent: -5260px;
        transition-property: border-color;
        position: fixed;
        top: 2.5rem;
        right: 2rem;
        z-index: 10;
        width: 3.5rem;
        height: 3.5rem;
        border-radius: 50;
        background: url(../img/recruit/header_home.png) no-repeat center center !important;
        background-size: 1.5rem auto !important
    }
}

.main {
    position: relative
}

.main__head {
    position: relative;
    z-index: 1;
    padding-top: 16rem;
    margin-right: 29.5rem;
    margin-left: max(5.5rem, (100% - 106rem)/2)
}

.main__breadcrumbs {
    display: flex;
    margin-bottom: 8rem;
    font-size: 1.2rem;
    line-height: 1.5;
    white-space: nowrap
}

.main__breadcrumbs li {
    position: relative;
    overflow: hidden;
    text-overflow: ellipsis
}

.main__breadcrumbs li:not(:last-child) {
    flex-shrink: 0;
    width: auto;
    padding-right: 1.5rem;
    margin-right: 1.5rem
}

.main__breadcrumbs li:not(:last-child)::after {
    content: "";
    display: block;
    position: absolute;
    top: calc(50% - .6rem);
    right: 0;
    width: 1px;
    height: 1.2rem;
    background: #e0e0e0
}

.main__breadcrumbs li a {
    color: #a7a7a7
}

.main__ttl {
    padding-bottom: 12rem
}

.main__ttl .en {
    font-family: "Figtree", "Noto Sans JP", "Hiragino Kaku Gothic ProN", "Hiragino Sans", Meiryo, sans-serif;
    font-size: 8rem;
    font-weight: 600;
    line-height: 1
}

.main__ttl .en .line-2 {
    --delay: 0.1s
}

.main__ttl .ja {
    margin-top: 1rem;
    color: #098bde;
    font-size: 2rem;
    font-weight: 500;
    line-height: 1.5
}

.main__eyecatch {
    --y: 0;
    display: block;
    overflow: hidden;
    position: relative;
    z-index: 3;
    aspect-ratio: 1300/400;
    margin-bottom: 8rem;
    padding-top: 13rem;
    background: #fff
}

.main__eyecatch img {
    transform: translateY(max(-33.33%, -1 * var(--y) * 0.25px))
}

.main__eyecatch~.main__aside .main__asideInner {
    padding-top: 13rem;
    align-items: flex-start
}

.main__aside {
    box-sizing: border-box;
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    z-index: 2;
    width: 24rem;
    padding-right: 3rem;
    padding-left: 5.5rem;
    border-left: #e0e0e0 solid 1px
}

.main__asideInner {
    box-sizing: border-box;
    display: flex;
    align-items: center;
    overflow: hidden;
    position: sticky;
    top: 0;
    height: 100vh;
    height: 100svh
}

.main__anclinks {
    display: flex;
    flex-direction: column;
    row-gap: 2rem;
    font-weight: 500;
    line-height: 1.5
}

.main__anclinks li a {
    display: inline-block;
    position: relative;
    padding-left: 1.5rem;
    background: none
}

.main__anclinks li a::before {
    content: "";
    display: block;
    position: absolute;
    top: calc(.75em - .3rem);
    left: 0;
    width: .6rem;
    height: .6rem;
    border-radius: 50%;
    background: #098bde;
    opacity: 0
}

.main__anclinks li a.active::before {
    opacity: 1
}

.main__anclinks[data-scrollvisible-target] {
    transition: all .4s cubic-bezier(0.645, 0.045, 0.355, 1) 0s;
    transition-property: transform, opacity;
    transform: translateX(10rem);
    opacity: 0
}

.main__anclinks[data-scrollvisible-target].visibled {
    transform: translateX(0);
    opacity: 1
}

.main__body {
    position: relative;
    z-index: 1;
    margin-right: 24rem
}

.main__cv {
    box-sizing: border-box;
    display: flex;
    align-items: flex-end;
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    z-index: 4;
    width: 20rem;
    pointer-events: none
}

.main__cvInner {
    position: sticky;
    bottom: 3rem;
    width: 100%;
    padding: 3rem 1.5rem;
    border-radius: 3rem 0 0 3rem;
    background: #fff;
    box-shadow: 0 1rem 3rem rgba(0, 0, 0, .1);
    pointer-events: auto
}

.main__cvInner dt {
    display: table;
    position: relative;
    margin: 0 auto 2rem;
    color: #098bde;
    font-family: "Figtree", "Noto Sans JP", "Hiragino Kaku Gothic ProN", "Hiragino Sans", Meiryo, sans-serif;
    font-size: 2rem;
    font-weight: 500;
    line-height: 1.2
}

.main__cvInner dt::before,
.main__cvInner dt::after {
    content: "";
    display: block;
    position: absolute;
    top: calc(50% - 1.2rem);
    width: 1px;
    height: 2.4rem;
    background: currentColor
}

.main__cvInner dt::before {
    transform: rotate(-25deg);
    left: -1.5rem
}

.main__cvInner dt::after {
    transform: rotate(25deg);
    right: -1.5rem
}

.main__cvInner .links {
    display: grid;
    row-gap: 1.5rem
}

.main__cvInner .links a {
    display: flex;
    justify-content: center;
    align-items: center;
    height: 6rem;
    border-radius: 3rem;
    background: #098bde;
    color: #fff;
    font-size: 1.6rem;
    font-weight: 500;
    line-height: 1.5
}

@media only screen and (max-width: 1023px) {
    .main__head {
        padding-top: 9.5rem;
        margin-right: 3rem;
        margin-left: 3rem
    }
    .main__breadcrumbs {
        margin-bottom: 3rem;
        font-size: 1.1rem
    }
    .main__breadcrumbs li:not(:last-child) {
        padding-right: 1rem;
        margin-right: 1rem
    }
    .main__ttl {
        padding-bottom: 5rem
    }
    .main__ttl .en {
        font-family: "Figtree", "Noto Sans JP", "Hiragino Kaku Gothic ProN", "Hiragino Sans", Meiryo, sans-serif;
        font-size: 5.1rem
    }
    .main__ttl .en .sp-line-2 {
        --delay: 0.1s
    }
    .main__ttl .en .sp-line-3 {
        --delay: 0.2s
    }
    .main__ttl .ja {
        margin-top: .5rem;
        font-size: 1.6rem
    }
    .main__eyecatch {
        aspect-ratio: auto;
        padding-top: 9.5rem
    }
    .main__eyecatch img {
        transform: none
    }
    .main__aside {
        position: static;
        width: auto;
        margin-bottom: 8rem;
        padding-left: 3rem;
        border-left: none
    }
    .main__asideInner {
        display: block;
        overflow: visible;
        position: static;
        height: auto
    }
    .main__anclinks {
        display: grid;
        grid-template-columns: 1fr 1fr;
        -moz-column-gap: 1rem;
        column-gap: 1rem;
        row-gap: 1rem
    }
    .main__anclinks li {
        display: flex
    }
    .main__anclinks li a {
        display: flex;
        justify-content: center;
        align-items: center;
        flex-grow: 1;
        padding: 1.5rem;
        border: #e0e0e0 solid 1px;
        border-radius: .8rem
    }
    .main__anclinks li a::before {
        display: none
    }
    .main__anclinks li a.active::before {
        opacity: 1
    }
    .main__anclinks[data-scrollvisible-target] {
        transition: none;
        transform: none;
        opacity: 1
    }
    .main__body {
        position: relative;
        margin-right: 0
    }
    .main__cv {
        display: block;
        position: fixed;
        top: auto;
        width: 100%;
        padding: 0 1rem
    }
    .main__cvInner {
        position: static;
        padding: 2rem 0;
        border-radius: 3rem 3rem 0 0
    }
    .main__cvInner dt {
        display: none
    }
    .main__cvInner .links {
        display: flex;
        justify-content: center;
        -moz-column-gap: 1rem;
        column-gap: 1rem
    }
    .main__cvInner .links a {
        width: 14.5rem;
        height: 4rem;
        border-radius: 2rem;
        font-size: 1.3rem
    }
}

.section {
    scroll-margin-top: 10rem
}

.section:not(:last-child) {
    padding-bottom: 14rem
}

.section__container {
    box-sizing: border-box;
    max-width: 117rem;
    margin-right: auto;
    margin-left: auto;
    padding-right: 5.5rem;
    padding-left: 5.5rem;
    max-width: 93rem
}

@media only screen and (max-width: 1023px) {
    .section__container {
        max-width: none;
        padding-right: 3rem;
        padding-left: 3rem
    }
}

.section__ttl {
    margin-bottom: 7rem
}

.section__ttl .ja {
    position: relative;
    margin-bottom: 1rem;
    padding-left: 1.2rem;
    color: #098bde;
    font-size: 1.5rem;
    font-weight: 500;
    line-height: 1.5
}

.section__ttl .ja::before {
    content: "";
    display: block;
    position: absolute;
    top: calc(.75em - .3rem);
    left: 0;
    width: .6rem;
    height: .6rem;
    border-radius: 50%;
    background: currentColor
}

.section__ttl .en {
    --delay: 0.1s;
    font-family: "Figtree", "Noto Sans JP", "Hiragino Kaku Gothic ProN", "Hiragino Sans", Meiryo, sans-serif;
    font-size: 5.9rem;
    font-weight: 600;
    line-height: 1.2
}

.section__ttl.js-cliptext .ja::before {
    opacity: 0
}

.section__ttl.js-cliptext.visibled .ja::before {
    transition: opacity .4s cubic-bezier(0.645, 0.045, 0.355, 1) 0s;
    opacity: 1
}

@media only screen and (max-width: 1023px) {
    .section:not(:last-child) {
        padding-bottom: 10rem
    }
    .section__ttl {
        margin-bottom: 3.5rem
    }
    .section__ttl .ja {
        margin-bottom: .5rem;
        font-size: 1.3rem
    }
    .section__ttl .en {
        font-size: 4.3rem
    }
}

.footer {
    margin-top: 14rem
}

.footer__container {
    box-sizing: border-box;
    max-width: 117rem;
    margin-right: auto;
    margin-left: auto;
    padding-right: 5.5rem;
    padding-left: 5.5rem;
    max-width: 121rem
}

@media only screen and (max-width: 1023px) {
    .footer__container {
        max-width: none;
        padding-right: 3rem;
        padding-left: 3rem
    }
}

.footer__entry {
    position: relative;
    z-index: 1
}

.footer .f-entry {
    box-sizing: border-box;
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    align-items: center;
    min-height: 31rem;
    padding: 8rem;
    background-image: linear-gradient(130deg, #00beff 0%, #0098ec 35%, #007bd7 55%, #0062c4 75%, #004bb1 100%);
    color: #fff
}

.footer .f-entry__txt {
    position: relative;
    z-index: 1;
    font-size: 1.8rem;
    font-weight: 500;
    line-height: 1.5
}

.footer .f-entry__ttl {
    margin-bottom: .3rem;
    font-family: "Figtree", "Noto Sans JP", "Hiragino Kaku Gothic ProN", "Hiragino Sans", Meiryo, sans-serif;
    font-size: 6.7rem;
    font-weight: 600;
    line-height: 1.2
}

.footer .f-entry__links {
    display: flex;
    -moz-column-gap: 2rem;
    column-gap: 2rem
}

.footer .f-entry__links a {
    display: flex;
    justify-content: center;
    align-items: center;
    width: 30rem;
    height: 7rem;
    background: #fff;
    border-radius: 3rem;
    color: #098bde;
    font-size: 1.6rem;
    font-weight: 500;
    line-height: 1.5
}

.footer .f-entry__banners {
    color: #000;
    font-size: 1.5rem;
    line-height: 1.47
}


.footer .f-entry__banners .banner__link {
    box-sizing: border-box;
    display: flex;
    justify-content: center;
    align-items: center;
    width: 100%;
    padding: 2rem 3rem;
    border-radius: 2rem;
    background: #fff
}

.footer .f-entry__banners .banner__ttl {
    padding-bottom: 1rem;
    font-size: 2rem;
    font-weight: 500
}
.footer .f-entry__banners .banner__ttl + p{
    margin-bottom: 1rem;
    padding-bottom: 1rem;
    border-bottom: #e0e0e0 solid 1px;
}

.footer .f-entry__banners .banner__line {
    display: flex;
    align-items: center
}

.footer .f-entry__banners .banner__line .icon {
    flex-shrink: 0;
    width: 4rem;
    margin-right: 1rem
}

.footer .f-entry__banners .banner__tel {
    display: flex;
    align-items: center;
    font-size: 2.2rem;
    font-weight: 500;
    line-height: 1.2
}

.footer .f-entry__banners .banner__tel .icon {
    flex-shrink: 0;
    width: 2rem;
    margin-right: 1rem
}

.footer .f-entry__banners .banner--mynavi img {
    max-width: 23.8rem
}

.footer .f-entry__banners .banner--indeed .txt {
    display: block;
    font-size: 1.5rem;
    font-weight: 500;
    line-height: 1.5
}

.footer .f-entry__banners .banner--indeed .indeed {
    display: inline-block;
    position: relative;
    top: .05em;
    margin-right: .5rem;
    color: #013a9b;
    font-size: 2.9rem
}

.footer__body {
    position: relative;
    z-index: 0;
    margin-top: -16.5rem;
    padding: 24.5rem 0 9rem;
    background: #ededed
}

.footer__row {
    display: flex;
    justify-content: space-between;
    -moz-column-gap: 5.5rem;
    column-gap: 5.5rem;
    align-items: flex-start
}

.footer__row:not(:first-child) {
    margin-top: 8rem
}

.footer__logo {
    display: block;
    width: 35rem;
    background: none
}

.footer__banner {
    display: flex;
    grid-template-columns: 1fr 1fr;
    column-gap: 3rem;
    width: 30rem;
}

.footer__banner a {
    display: block;
    transition: opacity .4s cubic-bezier(0.645, 0.045, 0.355, 1) 0s
}

@media(hover: hover) {
    .footer__banner a:hover {
        opacity: .7
    }
}

.footer__lower {
    align-items: center
}

.footer__lower .footer__col {
    display: flex;
    -moz-column-gap: 3rem;
    column-gap: 3rem;
    align-items: center
}

.footer__links {
    font-size: 1.2rem;
    line-height: 1.5
}

.footer__copyright {
    font-size: 1.2rem
}


@media only screen and (max-width: 1023px) {
    .footer {
        margin-top: 10rem
    }
    .footer__container {
        max-width: none
    }
    .footer__banner {
        display: grid;
        width: auto;
        margin-top: 3rem;
        grid-template-columns: 1fr;
        row-gap: 2rem;
    }
    .footer .f-entry {
        display: block;
        min-height: 0;
        padding: 4rem 3rem
    }
    .footer .f-entry__txt {
        font-size: 1.6rem
    }
    .footer .f-entry__ttl {
        margin-bottom: 0;
        font-size: 5.1rem
    }
    .footer .f-entry__links {
        display: grid;
        row-gap: 1.5rem;
        margin-top: 3rem
    }
    .footer .f-entry__links a {
        width: auto;
        font-size: 1.5rem
    }
    .footer .f-entry__banners {
        grid-template-columns: 1fr;
        row-gap: 2rem;
        margin-top: 3rem;
        font-size: 1.4rem;
        line-height: 1.43
    }
    .footer .f-entry__banners .banner__link {
        aspect-ratio: 270/138
    }
    .footer .f-entry__banners .banner--mynavi img {
        max-width: 20.2rem
    }
    .footer .f-entry__banners .banner--indeed .txt {
        font-size: 1.4rem
    }
    .footer .f-entry__banners .banner--indeed .indeed {
        font-size: 2.7rem
    }
    .footer__body {
        margin-top: -13rem;
        padding: 19rem 0 9.5rem
    }
    .footer__row {
        display: block
    }
    .footer__row:not(:first-child) {
        margin-top: 4rem
    }
    .footer__logo {
        width: 28rem
    }
    .footer__lower {
        display: flex;
        align-items: flex-start;
        flex-direction: column;
        row-gap: 1.5rem
    }
    .footer__lower .footer__col {
        display: block
    }
}

.c-drawline {
    transition: background-size .4s cubic-bezier(0.645, 0.045, 0.355, 1) 0s;
    background: linear-gradient(to top, currentColor 0px, currentColor 1.1px, transparent 1px) no-repeat right bottom;
    background-position: right bottom;
    background-size: 0% auto
}

@media(hover: hover) {
    a.c-drawline:hover,
    a:hover .c-drawline {
        animation: none;
        background-position: left bottom;
        background-size: 100% auto
    }
}

@keyframes arw-r {
    0% {
        transform: translateX(0);
        opacity: 1
    }
    50% {
        transform: translateX(100%);
        opacity: 0
    }
    50.1% {
        transform: translateX(-100%);
        opacity: 0
    }
    100% {
        transform: translateX(0);
        opacity: 1
    }
}

.c-arw {
    box-sizing: border-box;
    display: flex;
    justify-content: center;
    align-items: center;
    flex-shrink: 0;
    position: relative;
    aspect-ratio: 1/1;
    border-radius: 50%
}

.c-arw::before {
    transition: all .4s cubic-bezier(0.645, 0.045, 0.355, 1) 0s;
    transition-property: transform, background;
    box-sizing: border-box;
    content: "";
    display: block;
    position: absolute;
    inset: 0;
    border-radius: 50%
}

.c-arw .arw {
    transition: fill .4s cubic-bezier(0.645, 0.045, 0.355, 1) 0s;
    display: block;
    position: relative;
    z-index: 1;
    aspect-ratio: 1/1
}

@media(hover: hover) {
    a:hover .c-arw .arw--r {
        animation: arw-r .4s cubic-bezier(0.645, 0.045, 0.355, 1) 0s
    }
}

.c-form {
    scroll-margin-top: 10rem
}

.c-form__message {
    margin-bottom: 4rem;
    font-size: 1.5rem;
    font-weight: 500
}

.c-form__message:not(:first-child) {
    margin-top: 10rem
}

.c-form__item {
    padding: 3rem 0;
    border-top: #e0e0e0 solid 1px;
    border-bottom: #e0e0e0 solid 1px
}

.c-form__item+.c-form__item {
    border-top: none
}

.c-form__item dt {
    display: flex;
    align-items: center;
    margin-bottom: 2rem;
    font-size: 1.5rem;
    font-weight: 500;
    line-height: 1.5
}

.c-form__item dt .req {
    box-sizing: border-box;
    display: flex;
    align-items: center;
    height: 2rem;
    margin-left: 1rem;
    padding: 0 .5rem;
    border: currentColor solid 1px;
    border-radius: .5rem;
    color: #098bde;
    font-size: 1.2rem;
    font-weight: 500;
    line-height: 1
}

.c-form__name {
    display: grid;
    grid-template-columns: 1fr 1fr;
    -moz-column-gap: 2rem;
    column-gap: 2rem;
    max-width: 43rem
}

.c-form__name .c-form-text {
    margin-top: 0 !important
}

.c-form__age {
    display: flex;
    align-items: center;
    -moz-column-gap: 1rem;
    column-gap: 1rem
}

.c-form__age .c-form-text {
    width: 20.5rem
}

.c-form__vlist li+li {
    margin-top: .5rem
}

.c-form__caption {
    margin-top: .5rem;
    font-size: 1.2rem;
    line-height: 1.5
}

.c-form__privacy {
    padding: 7rem 0 0;
    border-bottom: none
}

.c-form__privacy dt {
    justify-content: center
}

.c-form__privacy dd {
    text-align: center
}

.c-form__privacyInner {
    box-sizing: border-box;
    display: flex;
    justify-content: center;
    align-items: center;
    height: 8.5rem;
    border: #e0e0e0 solid 1px;
    border-radius: 2rem
}

.c-form__btns {
    display: flex;
    justify-content: center;
    -moz-column-gap: 3rem;
    column-gap: 3rem;
    margin-top: 6rem
}

.c-form__btns li {
    flex: 1;
    max-width: 26rem
}

.c-form__btn {
    transition: all .4s cubic-bezier(0.645, 0.045, 0.355, 1) 0s;
    transition-property: background, color;
    display: flex;
    justify-content: center;
    align-items: center;
    width: 100%;
    height: 5rem;
    margin: 0;
    padding: 0;
    border: #098bde solid 1px;
    border-radius: 2.5rem;
    background: #098bde;
    color: #fff;
    font-family: "Noto Sans JP", "Hiragino Kaku Gothic ProN", "Hiragino Sans", Meiryo, sans-serif;
    font-size: 1.5rem;
    font-weight: 500;
    line-height: 1.5
}

@media(hover: hover) {
    .c-form__btn:hover {
        background: none;
        color: #098bde
    }
}

.c-form__btn--secondary {
    background: none;
    color: #098bde
}

.c-form__note {
    margin-top: 3rem;
    font-size: 1.2rem
}
.wpcf7-turnstile{
    display: flex;
    justify-content: center;
    margin-top: 3rem;
}
.c-form-step {
    display: flex;
    flex-direction: column;
    row-gap: 2rem;
    font-weight: 500;
    line-height: 1.5
}

.c-form-step li {
    position: relative;
    padding-left: 1.5rem
}

.c-form-step li::before {
    content: "";
    display: block;
    position: absolute;
    top: calc(.75em - .3rem);
    left: 0;
    width: .7rem;
    height: .7rem;
    border-radius: 50%;
    background: #e0e0e0
}

.c-form-step li:not(:last-child)::after {
    content: "";
    display: block;
    position: absolute;
    top: calc(100% - .25rem);
    left: .3rem;
    width: 1px;
    height: 2.5rem;
    background: #e0e0e0
}

.c-form-step li.active::before {
    background: #098bde
}

.c-form-text,
.c-form-select {
    display: block;
    max-width: 44rem
}

.c-form-text:not(:first-child),
.c-form-select:not(:first-child) {
    margin-top: 1.5rem
}

.c-form-text .label,
.c-form-select .label {
    display: block;
    margin-bottom: .5rem;
    line-height: 1.5
}

.c-form-text--s,
.c-form-select--s {
    max-width: 33rem
}

.c-form-text--l,
.c-form-select--l {
    max-width: 53rem
}

.c-form-text input {
    width: 100%;
    height: 5rem;
    margin: 0;
    padding: 0 1.5rem;
    border: none;
    border-radius: .4rem;
    background: #f2f2f2;
    font-size: 1.4rem;
    line-height: 1.72
}

.c-form-text input.invalid {
    background: rgba(255, 0, 0, .05)
}

.c-form-select .select {
    position: relative
}

.c-form-select .select::after {
    transform: rotate(45deg);
    transform-origin: right bottom;
    content: "";
    box-sizing: border-box;
    position: absolute;
    right: 2.2rem;
    bottom: calc(50% - .3rem);
    z-index: 1;
    width: 1rem;
    height: 1rem;
    border-right: #000 solid 1px;
    border-bottom: #000 solid 1px;
    pointer-events: none
}

.c-form-select .select select {
    position: relative;
    z-index: 0;
    width: 100%;
    height: 5rem;
    margin: 0;
    padding: 0 4.5rem 0 1.5rem;
    border: none;
    border-radius: .4rem;
    background: #f2f2f2;
    font-size: 1.4rem;
    line-height: 1.72
}

.c-form-select .select select.invalid {
    background: rgba(255, 0, 0, .05)
}

.c-form-textarea textarea {
    width: 100%;
    height: 30rem;
    margin: 0;
    padding: 1.5rem;
    border: none;
    border-radius: .4rem;
    background: #f2f2f2;
    font-size: 1.4rem;
    line-height: 1.72;
    resize: vertical
}

.c-form-textarea textarea.invalid {
    background: rgba(255, 0, 0, .05)
}

.c-form-checkbox {
    display: flex;
    align-items: flex-start;
    font-weight: 500;
    line-height: 1.72
}

.c-form-checkbox input[type=checkbox] {
    box-sizing: border-box;
    position: relative;
    top: calc(.86em - 1rem);
    width: 2rem;
    height: 2rem;
    margin: 0 1rem 0 0;
    padding: 0;
    border: #e0e0e0 solid 1px;
    border-radius: .4rem;
    outline: 0;
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none
}

.c-form-checkbox input[type=checkbox]::before {
    content: "";
    transform: rotate(-45deg);
    box-sizing: border-box;
    display: block;
    position: absolute;
    top: .2rem;
    left: .1rem;
    width: 1.5rem;
    height: 1rem;
    border-bottom: #098bde solid 3px;
    border-left: #098bde solid 3px;
    opacity: 0
}

.c-form-checkbox input[type=checkbox]:checked::before {
    opacity: 1
}

.c-form-radio {
    display: flex;
    align-items: flex-start;
    font-weight: 500;
    line-height: 1.72
}

.c-form-radio input[type=radio] {
    box-sizing: border-box;
    display: flex;
    justify-content: center;
    align-items: center;
    position: relative;
    top: calc(.86em - .8rem);
    width: 1.6rem;
    height: 1.6rem;
    margin: 0 1rem 0 0;
    padding: 0;
    border: #999 solid 1px;
    border-radius: 50%;
    outline: 0;
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none
}

.c-form-radio input[type=radio]::before {
    content: "";
    display: block;
    width: .8rem;
    height: .8rem;
    border-radius: 50%;
    background: #098bde;
    opacity: 0
}

.c-form-radio input[type=radio]:checked::before {
    opacity: 1
}

.c-form-error {
    margin-top: .5rem;
    color: red;
    line-height: 1.5
}

@media only screen and (max-width: 1023px) {
    .c-form__message {
        margin-bottom: 3rem;
        font-size: 1.4rem
    }
    .c-form__message:not(:first-child) {
        margin-top: 7rem
    }
    .c-form__item {
        padding: 2.5rem 0
    }
    .c-form__item dt {
        align-items: center;
        margin-bottom: 1.5rem;
        font-size: 1.4rem
    }
    .c-form__name {
        max-width: none
    }
    .c-form__age .c-form-text {
        width: 15.5rem
    }
    .c-form__privacy {
        padding: 4rem 0 0
    }
    .c-form__privacyInner {
        height: auto;
        border: none;
        border-radius: 0
    }
    .c-form__btns {
        flex-direction: column;
        align-items: center;
        row-gap: 2rem;
        margin-top: 4rem
    }
    .c-form__btns li {
        width: 26rem
    }
    .c-form__btn {
        font-size: 1.4rem
    }
    .c-form__note {
        margin-top: 2rem
    }
    .c-form-step {
        flex-direction: row;
        justify-content: center;
        -moz-column-gap: 10.5rem;
        column-gap: 10.5rem;
        padding: 2rem 0;
        border: #e0e0e0 solid 1px;
        border-radius: .8rem
    }
    .c-form-step li {
        width: .7rem;
        height: .7rem;
        padding-top: 3rem;
        padding-left: 0
    }
    .c-form-step li .label {
        transform: translateX(-50%);
        position: absolute;
        top: 0;
        left: 50%;
        white-space: nowrap
    }
    .c-form-step li::before {
        position: static
    }
    .c-form-step li:not(:last-child)::after {
        top: auto;
        bottom: .3rem;
        left: calc(100% + 1rem);
        width: 8.5rem;
        height: 1px
    }
    .c-form-text,
    .c-form-select {
        max-width: none
    }
    .c-form-text:not(:first-child),
    .c-form-select:not(:first-child) {
        margin-top: 1rem
    }
    .c-form-text--s,
    .c-form-select--s {
        max-width: none
    }
    .c-form-text--l,
    .c-form-select--l {
        max-width: none
    }
    .c-form-textarea textarea {
        height: 25rem
    }
}

.js-cliptext {
    --delay: 0s
}

.js-cliptext__line {
    display: inline-block;
    -webkit-clip-path: polygon(0% 105%, 100% 105%, 100% 105%, 0% 105%);
    clip-path: polygon(0% 105%, 100% 105%, 100% 105%, 0% 105%);
    opacity: 0
}

.js-cliptext.visibled .js-cliptext__line {
    transition: -webkit-clip-path .6s cubic-bezier(0.645, 0.045, 0.355, 1) var(--delay);
    transition: clip-path .6s cubic-bezier(0.645, 0.045, 0.355, 1) var(--delay);
    transition: clip-path .6s cubic-bezier(0.645, 0.045, 0.355, 1) var(--delay), -webkit-clip-path .6s cubic-bezier(0.645, 0.045, 0.355, 1) var(--delay);
    transition-property: opacity, -webkit-clip-path;
    transition-property: clip-path, opacity;
    transition-property: clip-path, opacity, -webkit-clip-path;
    -webkit-clip-path: polygon(0% -5%, 100% -5%, 100% 105%, 0% 105%);
    clip-path: polygon(0% -5%, 100% -5%, 100% 105%, 0% 105%);
    opacity: 1
}

@keyframes js-modal-open {
    0% {
        opacity: 0
    }
    100% {
        opacity: 1
    }
}

.js-modal {
    box-sizing: border-box;
    max-width: calc(100vw - 4rem);
    max-height: calc(100vh - 4rem);
    padding: 0;
    border: none;
    background: #fff
}

.js-modal::backdrop {
    animation: js-modal-open .4s cubic-bezier(0.645, 0.045, 0.355, 1) 0s;
    background: rgba(0, 0, 0, .8)
}

.js-modal[open] {
    animation: js-modal-open .4s cubic-bezier(0.645, 0.045, 0.355, 1) 0s
}

.js-modal.close {
    transition: all .4s cubic-bezier(0.645, 0.045, 0.355, 1) 0s;
    transition-property: visibility, opacity;
    visibility: hidden;
    opacity: 0
}

.js-modal.close::backdrop {
    transition: opacity .4s cubic-bezier(0.645, 0.045, 0.355, 1) 0s;
    opacity: 0
}

.js-modal__close {
    display: block;
    overflow: hidden;
    text-indent: -5260px;
    transition: border-color .4s cubic-bezier(0.645, 0.045, 0.355, 1) 0s;
    box-sizing: border-box;
    position: absolute;
    top: 1.5rem;
    right: 1.5rem;
    z-index: 1;
    width: 4rem;
    height: 4rem;
    margin: 0;
    padding: 0;
    border: #e0e0e0 solid 1px;
    border-radius: 50%;
    background: none
}

.js-modal__close::before,
.js-modal__close::after {
    content: "";
    display: block;
    position: absolute;
    top: calc(50% - 1px);
    left: calc(50% - 1rem);
    width: 2rem;
    height: 2px;
    background: #000
}

.js-modal__close::before {
    transform: rotate(45deg)
}

.js-modal__close::after {
    transform: rotate(-45deg)
}

@media(hover: hover) {
    .js-modal__close:hover {
        border-color: #098bde
    }
}

.js-modal__container {
    overscroll-behavior: none;
    box-sizing: border-box;
    overflow: auto;
    position: relative;
    z-index: 0;
    height: 100%
}

.modal-line {
    width: 60rem;
    height: 55rem
}

.modal-line__body {
    box-sizing: border-box;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    min-height: 100%;
    padding: 4rem;
    font-size: 1.4rem;
    line-height: 2;
    text-align: center
}

.modal-line__body dt {
    display: flex;
    margin-bottom: 4rem;
    color: #098bde;
    align-items: center;
    font-size: 1.5rem;
    font-weight: 500;
    line-height: 1.5
}

.modal-line__body dt::before {
    content: "";
    display: block;
    width: .7rem;
    height: .7rem;
    margin-right: .5rem;
    border-radius: 50%;
    background: currentColor
}

.modal-line__qr {
    max-width: 24.3rem;
    margin-bottom: 3rem
}

@keyframes home-main {
    0% {
        transform: translateX(0)
    }
    100% {
        transform: translateX(-100%)
    }
}

.p-home-main {
    overflow: hidden;
    display: flex;
    position: relative;
    z-index: 3;
    padding-top: 13rem;
    background: #fff
}

.p-home-main__img {
    flex-shrink: 0;
    position: relative;
    opacity: 0
}

.p-home-main__img::before {
    content: "";
    display: block;
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    width: 200%;
    min-width: 200vw;
    background: url(../img/recruit/recruit-top.jpg) repeat-x left top;
    background-size: auto 100%
}

.p-home-main__img img {
    position: relative;
    z-index: 1;
    width: auto;
    height: 40rem
}

.p-home-main.loaded .p-home-main__img {
    transition: opacity .4s cubic-bezier(0.645, 0.045, 0.355, 1) 0s;
    opacity: 1
}

.p-home-main.animating .p-home-main__img {
    animation: home-main 50s linear 0s infinite normal;
    will-change: transform
}

.p-home-main.animating.paused .p-home-main__img {
    animation-play-state: paused
}

.p-home-main~.main__aside .main__asideInner {
    padding-top: 18rem;
    align-items: flex-start
}

@media only screen and (max-width: 1023px) {
    .p-home-main {
        padding-top: 9.5rem
    }
    .p-home-main__img img {
        height: 23rem
    }
    .p-home-main~.main__aside {
        display: none
    }
}

.p-home-copy {
    margin: 5rem 0 6rem;
    padding: 0 28.5rem 0 4.5rem;
    font-size: 4.6rem;
    font-weight: 500;
    line-height: 1.74
}

.p-home-copy .line {
    display: flex;
    align-items: center
}

.p-home-copy .line:nth-child(2) {
    --delay: 0.1s;
    margin-left: 9rem
}

.p-home-copy .dream {
    display: block;
    position: relative;
    top: -0.15em;
    margin-right: -0.3em;
    font-size: 6rem;
    line-height: 1
}

.p-home-copy .team {
    display: block;
    position: relative;
    top: -0.1em;
    margin-right: 1rem;
    color: #098bde;
    font-size: 7rem;
    line-height: 1;
    letter-spacing: .04em
}

@media only screen and (max-width: 1023px) {
    .p-home-copy {
        margin: 4rem 0 2rem;
        padding: 0 0 0 1rem;
        font-size: 2.4rem;
        line-height: 1.92
    }
    .p-home-copy .line:nth-child(2) {
        margin-left: 1rem
    }
    .p-home-copy .dream {
        font-size: 3.6rem
    }
    .p-home-copy .team {
        margin-right: .5rem;
        font-size: 4rem
    }
}

.p-home-message {
    font-size: 1.7rem;
    line-height: 2.59
}

.p-home-message p+p {
    margin-top: 2.59em
}

@media only screen and (max-width: 1023px) {
    .p-home-message {
        font-size: 1.5rem;
        line-height: 1.74
    }
    .p-home-message p+p {
        margin-top: 1.74em
    }
}

.p-home-service__img {
    overflow: hidden;
    position: relative;
    aspect-ratio: 820/651;
    margin-top: 7rem;
    background: url(https://placehold.jp/1640x1442.png) no-repeat center center;
    background-size: contain
}

.p-home-service__img .inner {
    visibility: hidden
}

@media only screen and (max-width: 1023px) {
    .p-home-service__img {
        display: flex;
        flex-direction: column;
        justify-content: center;
        align-items: center;
        aspect-ratio: auto;
        height: 65rem;
        margin: 5rem -3rem 0;
        background: none
    }
    .p-home-service__img::before {
        content: "";
        display: block;
        position: absolute;
        top: 0;
        right: -21.5rem;
        bottom: 0;
        left: -21.5rem;
        border-radius: 50%;
        background: rgba(0, 155, 112, .1)
    }
    .p-home-service__img .inner {
        visibility: visible
    }
    .p-home-service__img .ttl {
        font-size: 2rem;
        font-weight: 500;
        line-height: 1;
        text-align: center
    }
    .p-home-service__img .ttl .en {
        color: #098bde;
        font-size: 3.2rem
    }
    .p-home-service__img .items {
        position: relative;
        width: 33rem;
        height: 44rem;
        margin-top: 4.5rem
    }
    .p-home-service__img .items::before {
        transition: opacity .4s cubic-bezier(0.645, 0.045, 0.355, 1) 0s;
        content: "";
        box-sizing: border-box;
        display: block;
        position: absolute;
        top: calc(50% - 12.5rem);
        left: calc(50% - 12.5rem);
        z-index: 0;
        width: 25rem;
        height: 25rem;
        border-radius: 50%;
        border: rgba(0, 155, 112, .3) solid 2rem
    }
    .p-home-service__img .items .item {
        transition: all .4s cubic-bezier(0.645, 0.045, 0.355, 1) 0s;
        transition-property: transform, top, left, z-index, width, height, opacity;
        position: absolute;
        top: 0;
        left: 0;
        z-index: 1;
        width: 14rem;
        height: 14rem;
        border-radius: 50%;
        background: #fff;
        box-shadow: 0 1rem 3rem rgba(0, 0, 0, .1)
    }
    .p-home-service__img .items .item dt {
        transition: transform .4s cubic-bezier(0.645, 0.045, 0.355, 1) 0s;
        transform: translateY(5rem);
        position: absolute;
        top: 0;
        right: 0;
        left: 0;
        color: #098bde;
        font-size: 1.5rem;
        font-weight: 500;
        line-height: 1.5;
        text-align: center
    }
    .p-home-service__img .items .item--1 {
        top: 0;
        left: 9.5rem
    }
    .p-home-service__img .items .item--2 {
        top: 15rem;
        left: 19rem
    }
    .p-home-service__img .items .item--3 {
        top: 30rem;
        left: 9.5rem
    }
    .p-home-service__img .items .item--4 {
        top: 15rem;
        left: 0
    }
    .p-home-service__img .items .item .list {
        transition: all .4s cubic-bezier(0.645, 0.045, 0.355, 1) 0s;
        transition-property: visibility, opacity;
        display: flex;
        flex-direction: column;
        align-items: center;
        overflow: hidden;
        position: absolute;
        top: 9rem;
        right: 0;
        left: 0;
        visibility: hidden;
        height: 0;
        opacity: 0
    }
    .p-home-service__img .items .item .list li::before {
        content: "・"
    }
    .p-home-service__img .items .item .icon {
        transition: transform .4s cubic-bezier(0.645, 0.045, 0.355, 1) 0s;
        transform: translateY(-1.7rem);
        display: block;
        position: absolute;
        bottom: 0;
        left: calc(50% - 1.6rem);
        width: 3.2rem;
        height: 3.2rem;
        border-radius: 50%;
        background: #dedede
    }
    .p-home-service__img .items .item .icon::before,
    .p-home-service__img .items .item .icon::after {
        content: "";
        display: block;
        position: absolute;
        top: calc(50% - .1rem);
        left: calc(50% - .8rem);
        width: 1.6rem;
        height: .2rem;
        background: #098bde
    }
    .p-home-service__img .items .item .icon::after {
        transform: rotate(90deg)
    }
    .p-home-service__img .items.zoom::before {
        opacity: 0
    }
    .p-home-service__img .items.zoom .item:not(.active) {
        opacity: 0;
        pointer-events: none
    }
    .p-home-service__img .items.zoom .item.active {
        top: 7rem !important;
        left: 1.5rem !important;
        z-index: 2;
        width: 30rem;
        height: 30rem
    }
    .p-home-service__img .items.zoom .item.active dt {
        transform: translateY(5.5rem)
    }
    .p-home-service__img .items.zoom .item.active .list {
        transition-delay: .2s;
        visibility: visible;
        height: auto;
        opacity: 1
    }
    .p-home-service__img .items.zoom .item.active .icon {
        transform: translateY(-3.8rem)
    }
    .p-home-service__img .items.zoom .item.active .icon::after {
        opacity: 0
    }
}

.p-home-organization__img {
    display: block;
    margin-top: 7rem
}

@media only screen and (max-width: 1023px) {
    .p-home-organization__img {
        margin: 5rem -3rem 0
    }
}

.p-home-team__offices {
    margin-top: 7rem;
    border-top: #e0e0e0 solid 1px
}

.p-home-team__offices .office {
    display: flex;
    align-items: flex-start;
    -moz-column-gap: 4rem;
    column-gap: 4rem;
    padding: 7rem 0;
    border-bottom: #e0e0e0 solid 1px
}

.p-home-team__offices .office__img {
    flex-shrink: 0;
    width: 30rem
}

.p-home-team__offices .office__txt {
    flex-grow: 1
}

.p-home-team__offices .office__ttl {
    margin-bottom: 2rem;
    font-size: 2.2rem;
    font-weight: 500;
    line-height: 1.46
}

.p-home-team__offices .office__more {
    margin-top: 4rem
}

.p-home-team__offices .office__more a {
    transition: all .4s cubic-bezier(0.645, 0.045, 0.355, 1) 0s;
    transition-property: background, color;
    box-sizing: border-box;
    display: flex;
    justify-content: center;
    align-items: center;
    width: 15rem;
    height: 4rem;
    border: #098bde solid 1px;
    border-radius: 2rem;
    background: none;
    color: #098bde;
    font-family: "Figtree", "Noto Sans JP", "Hiragino Kaku Gothic ProN", "Hiragino Sans", Meiryo, sans-serif;
    font-size: 1.6rem;
    font-weight: 600;
    line-height: 1.2
}

@media(hover: hover) {
    .p-home-team__offices .office__more a:hover {
        background: #098bde;
        color: #fff
    }
}

@media only screen and (max-width: 1023px) {
    .p-home-team__offices {
        margin-top: 5rem
    }
    .p-home-team__offices .office {
        display: block;
        padding: 4rem 0
    }
    .p-home-team__offices .office__img {
        width: 100%
    }
    .p-home-team__offices .office__txt {
        margin-top: 2rem
    }
    .p-home-team__offices .office__ttl {
        margin-bottom: 1.5rem;
        font-size: 1.8rem;
        line-height: 1.56
    }
    .p-home-team__offices .office__more {
        margin-top: 2rem
    }
    .p-home-team__offices .office__more a {
        width: 13rem;
        font-size: 1.5rem
    }
}

.p-team-office .section__ttl {
    margin-bottom: 4rem
}

.p-team-office__ttl {
    --delay: 0.1s;
    font-size: 3rem;
    font-weight: 500;
    line-height: 1.67
}

.p-team-office__ttl .js-cliptext__line:nth-of-type(2) {
    --delay: 0.2s
}

.p-team-office__lead {
    font-size: 1.7rem;
    line-height: 2.59
}

.p-team-office__blocks {
    margin-top: 7rem
}

.p-team-office__blocks .block {
    padding-top: 7rem;
    border-top: #e0e0e0 solid 1px
}

.p-team-office__blocks .block+.block {
    margin-top: 7rem
}

.p-team-office__blocks .block__slider {
    overflow: hidden
}

.p-team-office__blocks .block__slider .dots {
    display: flex;
    justify-content: flex-end;
    -moz-column-gap: .5rem;
    column-gap: .5rem;
    margin-top: 2rem;
    padding: 1px
}

.p-team-office__blocks .block__slider .dots .swiper-pagination-bullet {
    opacity: .6;
    cursor: pointer;
    color: #000
}

.p-team-office__blocks .block__slider .dots .swiper-pagination-bullet .icon {
    display: block;
    position: relative
}

.p-team-office__blocks .block__slider .dots .swiper-pagination-bullet .icon::before {
    content: "";
    display: block;
    position: absolute;
    top: calc(50% - .4rem);
    left: calc(50% - .4rem);
    width: .8rem;
    height: .8rem;
    border-radius: 50%;
    background: currentColor
}

.p-team-office__blocks .block__slider .dots .swiper-pagination-bullet .line {
    transform: rotate(-90deg);
    display: block;
    overflow: visible;
    width: 2.4rem;
    height: 2.4rem
}

.p-team-office__blocks .block__slider .dots .swiper-pagination-bullet .line circle {
    fill: none;
    stroke: currentColor;
    stroke-width: 1px;
    stroke-dasharray: 0 315%;
    opacity: 0
}

.p-team-office__blocks .block__slider .dots .swiper-pagination-bullet-active {
    color: #098bde;
    opacity: 1
}

.p-team-office__blocks .block__slider .dots .swiper-pagination-bullet-active .line circle {
    opacity: 1
}

.p-team-office__blocks .block__ttl {
    margin-bottom: 2rem;
    font-size: 2.2rem;
    font-weight: 500;
    line-height: 1.46
}

.p-team-office__flow {
    margin-top: 7rem;
    padding-top: 7rem;
    border-top: #e0e0e0 solid 1px
}

.p-team-office__flow .ttl {
    margin-bottom: 4rem;
    font-size: 2.2rem;
    font-weight: 500;
    line-height: 1.46
}

.p-team-office__flow .timeline {
    position: relative;
    padding: 3rem 0 6rem 1.6rem
}

.p-team-office__flow .timeline::before {
    content: "";
    display: block;
    position: absolute;
    top: 0;
    bottom: 0;
    z-index: 0;
    left: 2rem;
    width: 1px;
    background: #e0e0e0
}

.p-team-office__flow .timeline .item {
    display: flex;
    align-items: flex-start;
    position: relative;
    z-index: 1
}

.p-team-office__flow .timeline .item+.item {
    margin-top: 3rem
}

.p-team-office__flow .timeline .item::before {
    content: "";
    display: block;
    position: relative;
    top: .7rem;
    width: .9rem;
    height: .9rem;
    margin-right: 1.5rem;
    border-radius: 50%;
    background: #098bde
}

.p-team-office__flow .timeline .item>dt {
    display: flex;
    flex-shrink: 0;
    align-items: center;
    width: 7rem;
    color: #098bde;
    font-family: "Figtree", "Noto Sans JP", "Hiragino Kaku Gothic ProN", "Hiragino Sans", Meiryo, sans-serif;
    font-size: 2rem;
    font-weight: 600;
    line-height: 1.2
}

.p-team-office__flow .timeline .item>dd {
    display: flex;
    align-items: flex-start;
    flex-grow: 1;
    -moz-column-gap: 5.5rem;
    column-gap: 5.5rem
}

.p-team-office__flow .timeline .item__txt {
    flex-grow: 1;
    line-height: 1.72
}

.p-team-office__flow .timeline .item__ttl {
    font-size: 1.6rem;
    font-weight: 500;
    line-height: 1.5
}

.p-team-office__flow .timeline .item__ttl:not(:last-child) {
    margin-bottom: 1rem
}

.p-team-office__flow .timeline .item__img {
    flex-shrink: 0;
    width: 21rem
}

.p-team-office__links {
    display: grid;
    grid-template-columns: 1fr 1fr;
    -moz-column-gap: 2rem;
    column-gap: 2rem;
    row-gap: 2rem;
    margin-top: 7rem;
    padding-top: 10rem;
    border-top: #e0e0e0 solid 1px
}

.p-team-office__links li {
    display: flex
}

.p-team-office__links .link {
    transition: border-color .4s cubic-bezier(0.645, 0.045, 0.355, 1) 0s;
    box-sizing: border-box;
    display: flex;
    align-items: flex-start;
    width: 100%;
    padding: 1rem 2rem 1rem 1rem;
    border: #e0e0e0 solid 1px;
    border-radius: 1.5rem;
    background: none
}

@media(hover: hover) {
    .p-team-office__links .link:hover {
        border-color: #098bde
    }
    .p-team-office__links .link:hover .c-arw::before {
        transform: scale(1.36);
        background: #098bde
    }
    .p-team-office__links .link:hover .c-arw .arw {
        fill: #fff
    }
}

.p-team-office__links .link__img {
    flex-shrink: 0;
    width: 13rem;
    margin-right: 2rem
}

.p-team-office__links .link__txt {
    flex-grow: 1;
    padding-top: .5rem;
    font-size: 1.2rem;
    line-height: 1.67
}

.p-team-office__links .link__txt dt {
    margin-bottom: .5rem;
    font-size: 1.6rem;
    font-weight: 500;
    line-height: 1.5
}

.p-team-office__links .link .c-arw {
    flex-shrink: 0;
    align-self: center;
    width: 2.8rem;
    margin-left: 1rem
}

.p-team-office__links .link .c-arw::before {
    border: #098bde solid 1px
}

.p-team-office__links .link .c-arw .arw {
    width: 1.1rem;
    fill: #098bde
}

@media only screen and (max-width: 1023px) {
    .p-team-office .section__ttl {
        margin-bottom: 2rem
    }
    .p-team-office__ttl {
        font-size: 2.2rem;
        line-height: 1.46
    }
    .p-team-office__lead {
        font-size: 1.5rem;
        line-height: 1.8
    }
    .p-team-office__blocks .block {
        padding-top: 4rem
    }
    .p-team-office__blocks .block+.block {
        margin-top: 4rem
    }
    .p-team-office__blocks .block__slider .dots {
        margin-top: 1.5rem
    }
    .p-team-office__blocks .block__ttl {
        font-size: 1.8rem;
        line-height: 1.56
    }
    .p-team-office__flow {
        padding-top: 4rem
    }
    .p-team-office__flow .ttl {
        margin-bottom: 6rem;
        font-size: 1.8rem;
        line-height: 1.56
    }
    .p-team-office__flow .timeline {
        padding: 2rem 0 2rem .7rem
    }
    .p-team-office__flow .timeline::before {
        left: 1rem
    }
    .p-team-office__flow .timeline .item {
        display: block;
        padding-left: 2.2rem
    }
    .p-team-office__flow .timeline .item::before {
        position: absolute;
        left: 0;
        width: .7rem;
        height: .7rem;
        margin-right: 0
    }
    .p-team-office__flow .timeline .item+.item {
        margin-top: 5rem
    }
    .p-team-office__flow .timeline .item>dt {
        width: auto;
        margin-bottom: 1.5rem;
        font-size: 1.8rem
    }
    .p-team-office__flow .timeline .item>dd {
        display: block
    }
    .p-team-office__flow .timeline .item__ttl {
        font-size: 1.5rem
    }
    .p-team-office__flow .timeline .item__ttl:not(:last-child) {
        margin-bottom: .5rem
    }
    .p-team-office__flow .timeline .item__img {
        margin-top: 2rem;
        width: 100%
    }
    .p-team-office__links {
        grid-template-columns: 1fr;
        row-gap: 3rem;
        margin-top: 7rem;
        padding-top: 0;
        border-top: none
    }
    .p-team-office__links li {
        display: block
    }
    .p-team-office__links .link {
        display: block;
        padding: 2rem
    }
    .p-team-office__links .link__img {
        width: auto;
        margin-right: 0;
        margin-bottom: 1.5rem
    }
    .p-team-office__links .link__txt {
        padding-top: 0
    }
    .p-team-office__links .link__txt dt {
        margin-bottom: 1rem;
        font-size: 1.5rem
    }
    .p-team-office__links .link .c-arw {
        margin-top: 1rem;
        margin-left: auto
    }
    .p-team-office__links .link .c-arw::before {
        border: #098bde solid 1px
    }
}

.p-apply-guide__table {
    width: 100%
}

.p-apply-guide__table tr {
    border-top: #e0e0e0 solid 1px;
    border-bottom: #e0e0e0 solid 1px
}

.p-apply-guide__table th,
.p-apply-guide__table td {
    padding: 2.6rem 0
}

.p-apply-guide__table th {
    width: 16.5rem;
    font-weight: 500
}

@media only screen and (max-width: 1023px) {
    .p-apply-guide__table {
        display: block
    }
    .p-apply-guide__table thead,
    .p-apply-guide__table tbody,
    .p-apply-guide__table tfoot {
        display: block
    }
    .p-apply-guide__table tr {
        display: block;
        padding: 2rem 0
    }
    .p-apply-guide__table tr:not(:first-child) {
        border-top: none
    }
    .p-apply-guide__table th,
    .p-apply-guide__table td {
        display: block;
        padding: 0
    }
    .p-apply-guide__table th {
        width: auto;
        margin-bottom: .2rem
    }
}

.p-apply-entry__message:not(:last-child) {
    margin-bottom: 7rem
}

.p-apply-entry__message .req {
    color: #098bde
}

@media only screen and (max-width: 1023px) {
    .p-apply-entry__message:not(:last-child) {
        margin-bottom: 4rem
    }
}

.clearfix {
    zoom: 1
}

.clearfix:after {
    content: "";
    display: block;
    clear: both;
    height: 0
}

.pc-hidden {
    display: none
}

@media only screen and (max-width: 1023px) {
    .sp-hidden {
        display: none
    }
    .pc-hidden {
        display: block
    }
    br.pc-hidden {
        display: inline-block
    }
}

.section__container {
	counter-reset: service-number 0;
}
.section__container .item {
	counter-increment: service-number 1;
    display: flex;
    flex-direction: column;
    padding: 3rem 0;
    border-bottom: #e0e0e0 solid 1px;
}
.section__container .item:last-of-type{
    margin-bottom: 2rem
}
.section__container .item__icons {
	display: grid;
	grid-template-columns: 1fr 1fr;
	gap: .5rem;
	flex-shrink: 0;
	width: 26.5rem
}
.section__container .item__txt {
	flex-grow: 1
}
.section__container .item__ttl {
	display: flex;
	align-items: flex-start;
	-moz-column-gap: 1.5rem;
	column-gap: 1.5rem;
	margin-bottom: 1rem;
	font-size: 2.2rem;
	font-weight: 500;
	line-height: 1.46
}
.section__container .item__ttl::before {
	content: counter(service-number);
	display: flex;
	justify-content: center;
	align-items: center;
	position: relative;
	top: .1rem;
	width: 3rem;
	height: 3rem;
	background: #098bde;
	color: #fff;
	font-family: "Figtree", "Noto Sans JP", "Hiragino Kaku Gothic ProN", "Hiragino Sans", Meiryo, sans-serif;
	font-size: 2.3rem;
	font-weight: 600;
	line-height: 1.2
}
@media only screen and (max-width: 1023px) {
    .section__container .item__ttl {
        -moz-column-gap: 1rem;
		column-gap: 1rem;
		margin-bottom: 2rem;
		font-size: 1.8rem;
		line-height: 1.56
    }
    .section__container .item__ttl::before {
        width: 2.5rem;
        height: 2.5rem;
        font-size: 1.8rem
    }
}
.p-home-education {
    display: flex;
    flex-direction: column;
    row-gap: 2rem;
    font-size: 1.6rem;
    line-height: 1.9;
    counter-reset: edu-step;
    margin-top: 4rem;
  }
  
  .p-home-education dt {
    position: relative;
    padding-left: 4.5rem;
    font-weight: 600;
    color: #098bde;
    font-size: 1.9rem;
    line-height: 1.5;
    counter-increment: edu-step;
  }
  
  .p-home-education dt::before {
    content: counter(edu-step, decimal-leading-zero);
    position: absolute;
    top: 0;
    left: 0;
    width: 3.2rem;
    height: 3.2rem;
    background: #098bde;
    color: #fff;
    font-family: "Figtree", sans-serif;
    font-size: 1.6rem;
    font-weight: 600;
    line-height: 3.2rem;
    text-align: center;
    border-radius: 50%;
  }
  
  .p-home-education dd {
    padding-left: 4.5rem;
    font-size: 1.5rem;
    color: #333;
  }
  .p-home-education dd li{
    list-style-type: disc;
  }
  
  @media only screen and (max-width: 1023px) {
    .p-home-education {
      font-size: 1.4rem;
      row-gap: 3rem;
    }
  
    .p-home-education dt {
      font-size: 1.6rem;
      padding-left: 3.8rem;
    }
  
    .p-home-education dt::before {
      width: 2.8rem;
      height: 2.8rem;
      font-size: 1.4rem;
      line-height: 2.8rem;
    }
  
    .p-home-education dd {
      padding-left: 3.8rem;
      font-size: 1.4rem;
    }
  }
  /* ===== インタビューブロック全体 ===== */
.interview-block {
    display: flex;
    flex-wrap: wrap;
    margin-bottom: 8rem;
    scroll-margin-top: 10rem;
  }
  
  /* ===== 左右交互にするための調整（偶数番目反転） ===== */
  .interview-block:nth-child(even) {
    flex-direction: row-reverse;
  }
  
  /* ===== 画像部分 ===== */
  .interview-block__image {
    flex: 1 1 40%;
    max-width: 40%;
    padding: 2rem;
    box-sizing: border-box;
  }
  
  .interview-block__image img {
    width: 100%;
    height: auto;
    border-radius: 1rem;
  }
  
  /* ===== テキスト内容部分 ===== */
  .interview-block__content {
    flex: 1 1 60%;
    max-width: 60%;
    padding: 2rem;
    box-sizing: border-box;
  }
  
  .interview-block__header {
    font-size: 1.6rem;
    font-weight: 500;
    margin-bottom: 1rem;
  }
  
  .interview-block__name span {
    display: inline-block;
    margin-right: 1rem;
    font-size: 1.4rem;
    color: #555;
  }
  
  .interview-block__section h4 {
    font-size: 1.6rem;
    margin-top: 2.5rem;
    color: #098bde;
    border-left: 4px solid #098bde;
    padding-left: 1rem;
  }
  
  .interview-block__section p {
    margin-top: 1rem;
    line-height: 1.8;
    font-size: 1.4rem;
  }
  
  /* ===== スケジュール部分 ===== */
  .interview-schedule {
    margin-top: 4rem;
    padding: 2rem;
    background: #f9f9f9;
    border-radius: 1rem;
  }
  
  .interview-schedule h2 {
    font-size: 1.8rem;
    color: #098bde;
    margin-bottom: 2rem;
    border-left: 4px solid #098bde;
    padding-left: 1rem;
  }
  
  .interview-schedule ol {
    list-style: none;
    padding: 0;
    margin: 0;
  }
  
  .interview-schedule li {
    display: flex;
    align-items: center;
    margin-bottom: 1.5rem;
    padding-left: 2rem;
    position: relative;
  }
  
  .interview-schedule__time {
    font-weight: bold;
    font-size: 1.4rem;
    margin-right: 1rem;
    color: #333;
    min-width: 5rem;
  }
  
  .interview-schedule__name {
    font-size: 1.4rem;
    color: #555;
    line-height: 1.6;
  }
  .interview-block {
    padding: 6rem 0;
    border-bottom: 1px solid #e0e0e0;
  }
  .interview-inner {
    display: grid;
    flex-wrap: wrap;
    gap: 3rem;
    align-items: center;
    grid-template-columns: 2fr 1fr;
  }
  .interview-profile > h3{
    display: flex;
    flex-direction: column;
  }
  .interview-contents {
    margin-top: 4rem;
  }
  .interview-section {
    margin-bottom: 3rem;
  }
  .interview-section .block__ttl{
    margin-bottom: 3rem;
	font-size: 2.2rem;
	font-weight: 500;
	line-height: 1.46
  }

  .interview-schedule {
    margin-top: 4rem;
  }
  .schedule-list {
    list-style: none;
    padding-left: 0;
  }
  .schedule-list li {
    display: flex;
    gap: 1rem;
    margin-bottom: 1.5rem;
  }
  .schedule-list .time {
    font-weight: bold;
    width: 5rem;
  }
  .schedule-list .label {
    flex: 1;
  }
  /* ===== レスポンシブ ===== */
  @media only screen and (max-width: 768px) {
    .interview-block {
      flex-direction: column !important;
    }

    .interview-block__image,
    .interview-block__content {
      max-width: 100%;
      flex: 1 1 100%;
    }
    .interview-inner{
        grid-template-columns: 1fr 1fr;
    }
  }
  