  @charset "utf-8";

html,
body,
div,
span,
object,
iframe,
h1,
h2,
h3,
h4,
h5,
h6,
p,
blockquote,
pre,
abbr,
address,
cite,
code,
del,
dfn,
em,
img,
ins,
kbd,
q,
samp,
small,
strong,
sub,
sup,
var,
b,
i,
dl,
dt,
dd,
ol,
ul,
li,
fieldset,
form,
label,
legend,
table,
caption,
tbody,
tfoot,
thead,
tr,
th,
td,
article,
aside,
canvas,
details,
figcaption,
figure,
footer,
header,
hgroup,
menu,
nav,
section,
summary,
time,
mark,
audio,
video {
    margin: 0;
    padding: 0;
    border: 0;
    outline: 0;
    vertical-align: baseline;
    background: transparent;
    box-sizing: border-box
}

html {
    font-size: 62.5%
}

body {
    font-size: 18px;
    line-height: 1.9;
    font-family: "游ゴシック体", YuGothic, "YuGothic M", sans-serif;
    color: #fff;
    overflow-wrap: break-word;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    font-feature-settings: "palt";
    letter-spacing: .05em;
    background-color: #011827;
    width: 100%
}

img.hoverImg {
    transition: 0.3s
}

a:hover img.hoverImg {
    opacity: .7
}

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

img {
    width: 100%;
    vertical-align: bottom
}

ul {
    list-style: none
}

blockquote,
q {
    quotes: none
}

blockquote:before,
blockquote:after,
q:before,
q:after {
    content: '';
    content: none
}

a {
    margin: 0;
    padding: 0;
    font-size: 100%;
    vertical-align: baseline;
    background: transparent;
    color: #3c3c3c;
    text-decoration: none;
    box-sizing: border-box
}

._pc {
    display: none !important
}

@media screen and (min-width: 767px) {
    ._pc {
        display: block !important
    }
}

._sp {
    display: block !important
}

@media screen and (min-width: 767px) {
    ._sp {
        display: none !important
    }
}

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

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

.swiper-wrapper {
    position: relative;
    width: 100%;
    height: 100%;
    z-index: 1;
    display: flex;
    transition-property: transform;
    transition-timing-function: var(--swiper-wrapper-transition-timing-function, initial);
    box-sizing: content-box
}

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

.swiper-horizontal {
    touch-action: pan-y
}

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

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

.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);
    -webkit-backface-visibility: hidden;
    backface-visibility: hidden
}

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

.swiper-3d .swiper-wrapper {
    transform-style: preserve-3d
}

.swiper-3d {
    perspective: 1200px
}

.swiper-3d .swiper-cube-shadow,
.swiper-3d .swiper-slide {
    transform-style: preserve-3d
}

.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-css-mode.swiper-horizontal>.swiper-wrapper {
    scroll-snap-type: x mandatory
}

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

.swiper-css-mode.swiper-free-mode>.swiper-wrapper {
    scroll-snap-type: none
}

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

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

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

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

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

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

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

.swiper-3d .swiper-slide-shadow,
.swiper-3d .swiper-slide-shadow-bottom,
.swiper-3d .swiper-slide-shadow-left,
.swiper-3d .swiper-slide-shadow-right,
.swiper-3d .swiper-slide-shadow-top {
    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-lazy-preloader {
    width: 42px;
    height: 42px;
    position: absolute;
    left: 50%;
    top: 50%;
    margin-left: -21px;
    margin-top: -21px;
    z-index: 10;
    transform-origin: 50%;
    box-sizing: border-box;
    border: 4px solid var(--swiper-preloader-color, var(--swiper-theme-color));
    border-radius: 50%;
    border-top-color: rgba(0, 0, 0, 0)
}

.swiper-watch-progress .swiper-slide-visible .swiper-lazy-preloader,
.swiper:not(.swiper-watch-progress) .swiper-lazy-preloader {
    animation: swiper-preloader-spin 1s infinite linear
}

.swiper-lazy-preloader-white {
    --swiper-preloader-color: #fff
}

.swiper-lazy-preloader-black {
    --swiper-preloader-color: #000
}

@keyframes swiper-preloader-spin {
    0% {
        transform: rotate(0deg)
    }

    100% {
        transform: rotate(360deg)
    }
}

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

.swiper-virtual.swiper-css-mode .swiper-wrapper::after {
    content: "";
    position: absolute;
    left: 0;
    top: 0;
    pointer-events: none
}

.swiper-virtual.swiper-css-mode.swiper-horizontal .swiper-wrapper::after {
    height: 1px;
    width: var(--swiper-virtual-size)
}

.swiper-virtual.swiper-css-mode.swiper-vertical .swiper-wrapper::after {
    width: 1px;
    height: var(--swiper-virtual-size)
}

:root {
    --swiper-navigation-size: 44px
}

.swiper-button-next,
.swiper-button-prev {
    position: absolute;
    top: var(--swiper-navigation-top-offset, 50%);
    width: calc(var(--swiper-navigation-size)/44*27);
    height: var(--swiper-navigation-size);
    margin-top: calc(0px - var(--swiper-navigation-size)/2);
    z-index: 10;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--swiper-navigation-color, var(--swiper-theme-color))
}

.swiper-button-next.swiper-button-disabled,
.swiper-button-prev.swiper-button-disabled {
    opacity: .35;
    cursor: auto;
    pointer-events: none
}

.swiper-button-next.swiper-button-hidden,
.swiper-button-prev.swiper-button-hidden {
    opacity: 0;
    cursor: auto;
    pointer-events: none
}

.swiper-navigation-disabled .swiper-button-next,
.swiper-navigation-disabled .swiper-button-prev {
    display: none !important
}

.swiper-button-next svg,
.swiper-button-prev svg {
    width: 100%;
    height: 100%;
    object-fit: contain;
    transform-origin: center
}

.swiper-rtl .swiper-button-next svg,
.swiper-rtl .swiper-button-prev svg {
    transform: rotate(180deg)
}

.swiper-button-prev,
.swiper-rtl .swiper-button-next {
    left: var(--swiper-navigation-sides-offset, 10px);
    right: auto
}

.swiper-button-next,
.swiper-rtl .swiper-button-prev {
    right: var(--swiper-navigation-sides-offset, 10px);
    left: auto
}

.swiper-button-lock {
    display: none
}

.swiper-button-next:after,
.swiper-button-prev:after {
    font-family: swiper-icons;
    font-size: var(--swiper-navigation-size);
    text-transform: none !important;
    letter-spacing: 0;
    font-variant: initial;
    line-height: 1
}

.swiper-button-prev:after,
.swiper-rtl .swiper-button-next:after {
    content: "prev"
}

.swiper-button-next,
.swiper-rtl .swiper-button-prev {
    right: var(--swiper-navigation-sides-offset, 10px);
    left: auto
}

.swiper-button-next:after,
.swiper-rtl .swiper-button-prev:after {
    content: "next"
}

.swiper-pagination {
    position: absolute;
    text-align: center;
    transition: .3s opacity;
    transform: translate3d(0, 0, 0);
    z-index: 10
}

.swiper-pagination.swiper-pagination-hidden {
    opacity: 0
}

.swiper-pagination-disabled>.swiper-pagination,
.swiper-pagination.swiper-pagination-disabled {
    display: none !important
}

.swiper-horizontal>.swiper-pagination-bullets,
.swiper-pagination-bullets.swiper-pagination-horizontal,
.swiper-pagination-custom,
.swiper-pagination-fraction {
    bottom: var(--swiper-pagination-bottom, 8px);
    top: var(--swiper-pagination-top, auto);
    left: 0;
    width: 100%
}

.swiper-pagination-bullets-dynamic {
    overflow: hidden;
    font-size: 0
}

.swiper-pagination-bullets-dynamic .swiper-pagination-bullet {
    transform: scale(0.33);
    position: relative
}

.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active {
    transform: scale(1)
}

.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-main {
    transform: scale(1)
}

.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-prev {
    transform: scale(0.66)
}

.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-prev-prev {
    transform: scale(0.33)
}

.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-next {
    transform: scale(0.66)
}

.swiper-pagination-bullets-dynamic .swiper-pagination-bullet-active-next-next {
    transform: scale(0.33)
}

.swiper-pagination-bullet {
    width: var(--swiper-pagination-bullet-width, var(--swiper-pagination-bullet-size, 8px));
    height: var(--swiper-pagination-bullet-height, var(--swiper-pagination-bullet-size, 8px));
    display: inline-block;
    border-radius: var(--swiper-pagination-bullet-border-radius, 50%);
    background: var(--swiper-pagination-bullet-inactive-color, #000);
    opacity: var(--swiper-pagination-bullet-inactive-opacity, 0.2)
}

button.swiper-pagination-bullet {
    border: none;
    margin: 0;
    padding: 0;
    box-shadow: none;
    -webkit-appearance: none;
    appearance: none
}

.swiper-pagination-clickable .swiper-pagination-bullet {
    cursor: pointer
}

.swiper-pagination-bullet:only-child {
    display: none !important
}

.swiper-pagination-bullet-active {
    opacity: var(--swiper-pagination-bullet-opacity, 1);
    background: var(--swiper-pagination-color, var(--swiper-theme-color))
}

.swiper-pagination-vertical.swiper-pagination-bullets,
.swiper-vertical>.swiper-pagination-bullets {
    right: var(--swiper-pagination-right, 8px);
    left: var(--swiper-pagination-left, auto);
    top: 50%;
    transform: translate3d(0px, -50%, 0)
}

.swiper-pagination-vertical.swiper-pagination-bullets .swiper-pagination-bullet,
.swiper-vertical>.swiper-pagination-bullets .swiper-pagination-bullet {
    margin: var(--swiper-pagination-bullet-vertical-gap, 6px) 0;
    display: block
}

.swiper-pagination-vertical.swiper-pagination-bullets.swiper-pagination-bullets-dynamic,
.swiper-vertical>.swiper-pagination-bullets.swiper-pagination-bullets-dynamic {
    top: 50%;
    transform: translateY(-50%);
    width: 8px
}

.swiper-pagination-vertical.swiper-pagination-bullets.swiper-pagination-bullets-dynamic .swiper-pagination-bullet,
.swiper-vertical>.swiper-pagination-bullets.swiper-pagination-bullets-dynamic .swiper-pagination-bullet {
    display: inline-block;
    transition: .2s transform, .2s top
}

.swiper-horizontal>.swiper-pagination-bullets .swiper-pagination-bullet,
.swiper-pagination-horizontal.swiper-pagination-bullets .swiper-pagination-bullet {
    margin: 0 var(--swiper-pagination-bullet-horizontal-gap, 4px)
}

.swiper-horizontal>.swiper-pagination-bullets.swiper-pagination-bullets-dynamic,
.swiper-pagination-horizontal.swiper-pagination-bullets.swiper-pagination-bullets-dynamic {
    left: 50%;
    transform: translateX(-50%);
    white-space: nowrap
}

.swiper-horizontal>.swiper-pagination-bullets.swiper-pagination-bullets-dynamic .swiper-pagination-bullet,
.swiper-pagination-horizontal.swiper-pagination-bullets.swiper-pagination-bullets-dynamic .swiper-pagination-bullet {
    transition: .2s transform, .2s left
}

.swiper-horizontal.swiper-rtl>.swiper-pagination-bullets-dynamic .swiper-pagination-bullet {
    transition: .2s transform, .2s right
}

.swiper-pagination-fraction {
    color: var(--swiper-pagination-fraction-color, inherit)
}

.swiper-pagination-progressbar {
    background: var(--swiper-pagination-progressbar-bg-color, rgba(0, 0, 0, 0.25));
    position: absolute
}

.swiper-pagination-progressbar .swiper-pagination-progressbar-fill {
    background: var(--swiper-pagination-color, var(--swiper-theme-color));
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    transform: scale(0);
    transform-origin: left top
}

.swiper-rtl .swiper-pagination-progressbar .swiper-pagination-progressbar-fill {
    transform-origin: right top
}

.swiper-horizontal>.swiper-pagination-progressbar,
.swiper-pagination-progressbar.swiper-pagination-horizontal,
.swiper-pagination-progressbar.swiper-pagination-vertical.swiper-pagination-progressbar-opposite,
.swiper-vertical>.swiper-pagination-progressbar.swiper-pagination-progressbar-opposite {
    width: 100%;
    height: var(--swiper-pagination-progressbar-size, 4px);
    left: 0;
    top: 0
}

.swiper-horizontal>.swiper-pagination-progressbar.swiper-pagination-progressbar-opposite,
.swiper-pagination-progressbar.swiper-pagination-horizontal.swiper-pagination-progressbar-opposite,
.swiper-pagination-progressbar.swiper-pagination-vertical,
.swiper-vertical>.swiper-pagination-progressbar {
    width: var(--swiper-pagination-progressbar-size, 4px);
    height: 100%;
    left: 0;
    top: 0
}

.swiper-pagination-lock {
    display: none
}

.swiper-scrollbar {
    border-radius: var(--swiper-scrollbar-border-radius, 10px);
    position: relative;
    touch-action: none;
    background: var(--swiper-scrollbar-bg-color, rgba(0, 0, 0, 0.1))
}

.swiper-scrollbar-disabled>.swiper-scrollbar,
.swiper-scrollbar.swiper-scrollbar-disabled {
    display: none !important
}

.swiper-horizontal>.swiper-scrollbar,
.swiper-scrollbar.swiper-scrollbar-horizontal {
    position: absolute;
    left: var(--swiper-scrollbar-sides-offset, 1%);
    bottom: var(--swiper-scrollbar-bottom, 4px);
    top: var(--swiper-scrollbar-top, auto);
    z-index: 50;
    height: var(--swiper-scrollbar-size, 4px);
    width: calc(100% - 2*var(--swiper-scrollbar-sides-offset, 1%))
}

.swiper-scrollbar.swiper-scrollbar-vertical,
.swiper-vertical>.swiper-scrollbar {
    position: absolute;
    left: var(--swiper-scrollbar-left, auto);
    right: var(--swiper-scrollbar-right, 4px);
    top: var(--swiper-scrollbar-sides-offset, 1%);
    z-index: 50;
    width: var(--swiper-scrollbar-size, 4px);
    height: calc(100% - 2*var(--swiper-scrollbar-sides-offset, 1%))
}

.swiper-scrollbar-drag {
    height: 100%;
    width: 100%;
    position: relative;
    background: var(--swiper-scrollbar-drag-bg-color, rgba(0, 0, 0, 0.5));
    border-radius: var(--swiper-scrollbar-border-radius, 10px);
    left: 0;
    top: 0
}

.swiper-scrollbar-cursor-drag {
    cursor: move
}

.swiper-scrollbar-lock {
    display: none
}

.swiper-zoom-container {
    width: 100%;
    height: 100%;
    display: flex;
    justify-content: center;
    align-items: center;
    text-align: center
}

.swiper-zoom-container>canvas,
.swiper-zoom-container>img,
.swiper-zoom-container>svg {
    max-width: 100%;
    max-height: 100%;
    object-fit: contain
}

.swiper-slide-zoomed {
    cursor: move;
    touch-action: none
}

.swiper .swiper-notification {
    position: absolute;
    left: 0;
    top: 0;
    pointer-events: none;
    opacity: 0;
    z-index: -1000
}

.swiper-free-mode>.swiper-wrapper {
    transition-timing-function: ease-out;
    margin: 0 auto
}

.swiper-grid>.swiper-wrapper {
    flex-wrap: wrap
}

.swiper-grid-column>.swiper-wrapper {
    flex-wrap: wrap;
    flex-direction: column
}

.swiper-fade.swiper-free-mode .swiper-slide {
    transition-timing-function: ease-out
}

.swiper-fade .swiper-slide {
    pointer-events: none;
    transition-property: opacity
}

.swiper-fade .swiper-slide .swiper-slide {
    pointer-events: none
}

.swiper-fade .swiper-slide-active {
    pointer-events: auto
}

.swiper-fade .swiper-slide-active .swiper-slide-active {
    pointer-events: auto
}

.swiper-cube {
    overflow: visible
}

.swiper-cube .swiper-slide {
    pointer-events: none;
    -webkit-backface-visibility: hidden;
    backface-visibility: hidden;
    z-index: 1;
    visibility: hidden;
    transform-origin: 0 0;
    width: 100%;
    height: 100%
}

.swiper-cube .swiper-slide .swiper-slide {
    pointer-events: none
}

.swiper-cube.swiper-rtl .swiper-slide {
    transform-origin: 100% 0
}

.swiper-cube .swiper-slide-active,
.swiper-cube .swiper-slide-active .swiper-slide-active {
    pointer-events: auto
}

.swiper-cube .swiper-slide-active,
.swiper-cube .swiper-slide-next,
.swiper-cube .swiper-slide-prev {
    pointer-events: auto;
    visibility: visible
}

.swiper-cube .swiper-cube-shadow {
    position: absolute;
    left: 0;
    bottom: 0px;
    width: 100%;
    height: 100%;
    opacity: .6;
    z-index: 0
}

.swiper-cube .swiper-cube-shadow:before {
    content: "";
    background: #000;
    position: absolute;
    left: 0;
    top: 0;
    bottom: 0;
    right: 0;
    filter: blur(50px)
}

.swiper-cube .swiper-slide-next+.swiper-slide {
    pointer-events: auto;
    visibility: visible
}

.swiper-cube .swiper-slide-shadow-cube.swiper-slide-shadow-bottom,
.swiper-cube .swiper-slide-shadow-cube.swiper-slide-shadow-left,
.swiper-cube .swiper-slide-shadow-cube.swiper-slide-shadow-right,
.swiper-cube .swiper-slide-shadow-cube.swiper-slide-shadow-top {
    z-index: 0;
    -webkit-backface-visibility: hidden;
    backface-visibility: hidden
}

.swiper-flip {
    overflow: visible
}

.swiper-flip .swiper-slide {
    pointer-events: none;
    -webkit-backface-visibility: hidden;
    backface-visibility: hidden;
    z-index: 1
}

.swiper-flip .swiper-slide .swiper-slide {
    pointer-events: none
}

.swiper-flip .swiper-slide-active,
.swiper-flip .swiper-slide-active .swiper-slide-active {
    pointer-events: auto
}

.swiper-flip .swiper-slide-shadow-flip.swiper-slide-shadow-bottom,
.swiper-flip .swiper-slide-shadow-flip.swiper-slide-shadow-left,
.swiper-flip .swiper-slide-shadow-flip.swiper-slide-shadow-right,
.swiper-flip .swiper-slide-shadow-flip.swiper-slide-shadow-top {
    z-index: 0;
    -webkit-backface-visibility: hidden;
    backface-visibility: hidden
}

.swiper-creative .swiper-slide {
    -webkit-backface-visibility: hidden;
    backface-visibility: hidden;
    overflow: hidden;
    transition-property: transform, opacity, height
}

.swiper-cards {
    overflow: visible
}

.swiper-cards .swiper-slide {
    transform-origin: center bottom;
    -webkit-backface-visibility: hidden;
    backface-visibility: hidden;
    overflow: hidden
}

.inner {
    max-width: 1140px;
    margin: 0 auto;
    box-sizing: border-box;
    text-align: center;
    padding: 0 20px
}

.sp {
    display: none
}

.en {
    font-family: 'Lusitana', serif;
    font-weight: 400
}

.mincho {
    font-family: 'Noto Serif JP', serif;
    font-weight: 400
}

.common_ttlarea {
    position: relative;
    padding-top: 163px;
    text-align: center
}

.common_ttl {
    font-size: 50px;
    position: relative;
    line-height: 1;
    text-align: center;
    letter-spacing: 0
}

.common_ttl_jp {
    font-size: 18px;
    display: block;
    letter-spacing: .08em;
    line-height: 1.4;
    padding-top: 0
}

.common_ttl_jp.mt {
    padding-top: 8px
}

.common_subttl {
    position: relative;
    display: inline-block;
    padding: 0 53px;
    font-size: 34px
}

.common_subttl:before,
.common_subttl:after {
    content: '';
    position: absolute;
    top: 50%;
    display: inline-block;
    width: 45px;
    height: 1px;
    background-color: #006fbb
}

.common_subttl:before {
    left: 0
}

.common_subttl:after {
    right: 0
}

.line_yellow {
    background: linear-gradient(transparent 96%, #cda934 0%);
    display: inline
}

@media screen and (max-width:767px) {
    .pc {
        display: none
    }

    .sp {
        display: block
    }

    .inner {
        max-width: 100%;
        margin: 0 auto;
        padding: 0 20px
    }

    body {
        font-size: 15px
    }

    .common_ttlarea {
        padding-top: 60px
    }

    .common_ttl {
        font-size: 36px
    }

    .common_ttl_jp {
        font-size: 14px
    }

    .common_subttl {
        padding: 0 0;
        font-size: 20px;
        line-height: 1.5;
        letter-spacing: 0
    }

    .common_subttl:after {
        content: '';
        position: relative;
        top: auto;
        right: auto;
        display: block;
        width: 50px;
        height: 1px;
        margin: 12px auto 0;
        background-color: #006fbb
    }

    .common_subttl:before {
        display: none
    }
}

@media screen and (max-width:320px) {
    body {
        font-size: 14px
    }
}


header .header_logo {
    width: 325px
}

@media screen and (max-width:767px) {

    header .header_logo {
        width: 65%
    }
}

.header {
    position: fixed;
    top: 0;
    left: 0;
    display: flex;
    align-items: center;
    justify-content: space-between;
    width: 100%;
    padding: 0 0 0 1.4925373134vw;
    z-index: 10000001;
    transition: background-color .5s
}

@media screen and (min-width: 670px) {
    .header {
        padding: 0 0 0 20px
    }
}

@media screen and (min-width: 1300px) {
    .header {
        padding: 10px 20px
    }
}

.header--active {
    background-color: #011827
}

.header__logo {
    width: 44.1791044776vw;
    height: 5.671641791vw
}

@media screen and (min-width: 670px) {
    .header__logo {
        width: 337px;
        height: 43px
    }
}

.header__logo a {
    display: flex;
    align-items: center;
}

.header__logo img {
    width: 100%;
    height: auto;
}

.header__container {
    display: flex;
    align-items: center;
    gap: 1.9402985075vw
}

@media screen and (min-width: 670px) {
    .header__container {
        gap: 13px
    }
}

.header__icon--sp {
    width: 6.7164179104vw;
    display: flex;
    justify-content: right
}

@media screen and (min-width: 670px) {
    .header__icon--sp {
        width: 45px
    }
}

@media screen and (min-width: 1300px) {
    .header__icon--sp {
        display: none
    }
}

.header__icon img {
    width: 100%;
    height: auto
}

.header__gnav {
    color: #fff
}

.header__btn {
    background-color: #F7F8FC;
    padding: 2.5373134328vw 2.2388059701vw;
}

@media screen and (min-width: 1300px) {
    .header__btn {
        display: none;
    }
}

.gnav {
    display: none
}

@media screen and (min-width: 1300px) {
    .gnav {
        display: block
    }
}

.gnav__list {
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-end
}

.gnav__item {
    margin-right: 25px;
}

.gnav__item a {
    color: #fff;
    transition: .5s
}

.gnav__item a:hover {
    color: #0089ff
}

@media screen and (min-width: 670px) {
    .gnav__item img {
        margin-top: 10px;
    }
}

@media screen and (min-width: 1400px) {
    .gnav__item img {
        margin-top: 0;
    }
}

.sbtn {
    position: relative;
    display: block;
    width: 4.728358209vw;
    height: 3.7820895522vw;
    cursor: pointer
}

@media screen and (min-width: 670px) {
    .sbtn {
        width: 25px;
        height: 20px
    }
}

.sbtn span {
    position: absolute;
    left: 0;
    display: inline-block;
    width: 100%;
    height: 0.2985074627vw;
    background-color: #2E3951;
    transition: all .3s;
    box-sizing: border-box
}

@media screen and (min-width: 670px) {
    .sbtn span {
        height: 2px
    }
}

.sbtn span:nth-child(1) {
    top: 0
}

.sbtn span:nth-child(2) {
    top: 1.7vw;
}

@media screen and (min-width: 670px) {
    .sbtn span:nth-child(2) {
        top: 9px
    }
}

.sbtn span:nth-child(3) {
    bottom: 0
}

.sbtn--active span:nth-child(1) {
    transform: translateY(1.3432835821vw) rotate(-45deg)
}

@media screen and (min-width: 670px) {
    .sbtn--active span:nth-child(1) {
        transform: translateY(9px) rotate(-45deg)
    }
}

.sbtn--active span:nth-child(2) {
    opacity: 0
}

.sbtn--active span:nth-child(3) {
    transform: translateY(-1.3432835821vw) rotate(45deg)
}

@media screen and (min-width: 670px) {
    .sbtn--active span:nth-child(3) {
        transform: translateY(-9px) rotate(45deg)
    }
}

.smenu {
    position: fixed;
    top: 0;
    right: 0;
    width: 100%;
    height: 100vh;
    background-color: #fff;
    z-index: 10000000;
    overflow: hidden;
    transform: translateX(calc(100% - -14.9253731343vw));
    transition: .3s
}

@media screen and (min-width: 670px) {
    .smenu {
        transform: translateX(100%)
    }
}

.smenu--active {
    transform: translateX(0)
}

@media screen and (min-width: 670px) {
    .smenu--active {
        box-shadow: 0px 5px 5px 0px rgba(0, 0, 0, .35)
    }
}

@media screen and (min-width: 670px) {
    .smenu {
        max-width: 375px
    }
}

@media screen and (min-width: 1300px) {
    .smenu {
        display: none
    }
}

.smenu__inner {
    width: 100%;
    height: 100%;
    overflow-y: auto
}

.smenu__heading {
    display: flex;
    align-items: center;
    height: 8.9552238806vw;
    padding: 0 2.9850746269vw;
    background-color: #011827
}

@media screen and (min-width: 670px) {
    .smenu__heading {
        height: 60px;
        padding: 0 20px
    }
}

.smenu__heading span {
    display: none
}

@media screen and (min-width: 670px) {
    .smenu__heading span {
        display: block
    }
}

.smenu__title {
    color: #fff;
    font-weight: 600;
    font-size: 4.776119403vw
}

@media screen and (min-width: 670px) {
    .smenu__title {
        font-size: clamp(1.6rem, 100vw - (670px + 1400px)/2, 1.8rem)
    }
}

@media screen and (min-width: 1920px) {
    .smenu__title {
        font-size: 1.8rem
    }
}

@media screen and (min-width: 670px) {
    .smenu__title {
        display: flex;
        align-items: center;
        width: 100%;
        line-height: 1
    }
}

.smenu__title span {
    font-family: "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", serif;
    font-weight: 600;
    font-size: 3.7313432836vw
}

@media screen and (min-width: 670px) {
    .smenu__title span {
        font-size: clamp(1.4rem, 100vw - (670px + 1400px)/2, 1.5rem)
    }
}

@media screen and (min-width: 1920px) {
    .smenu__title span {
        font-size: 1.5rem
    }
}

@media screen and (min-width: 670px) {
    .smenu__title span {
        display: flex;
        align-items: center;
        margin: 0;
        padding: 0;
        line-height: 1
    }
}

.smenu__group {
    display: grid;
    grid-template-columns: repeat(1, 1fr)
}

.smenu__list {
    max-height: 0;
    overflow: hidden
}

.smenu__list--active {
    display: grid
}

.smenu__unit--app {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 3.7313432836vw;
    padding: 3.7313432836vw 5.223880597vw 7.4626865672vw
}

@media screen and (min-width: 670px) {
    .smenu__unit--app {
        gap: 20px;
        padding: 20px
    }
}

.smenu__item {
    background-color: #fff;
    border-bottom: 0.1492537313vw solid #98a8cc;
    list-style: none !important;
}

@media screen and (min-width: 670px) {
    .smenu__item {
        border-bottom: 1px solid #98a8cc
    }
}

.smenu__item a {
    display: flex;
    width: 100%;
    padding: 4.1791044776vw 4.776119403vw;
    color: #000;
    font-weight: 700;
    font-size: 4.4776119403vw
}

@media screen and (min-width: 670px) {
    .smenu__item a {
        font-size: clamp(1.3rem, 100vw - (670px + 1400px)/2, 1.5rem)
    }
}

@media screen and (min-width: 1920px) {
    .smenu__item a {
        font-size: 1.5rem
    }
}

@media screen and (min-width: 670px) {
    .smenu__item a {
        padding: 20px;
        background-size: 11px 22px;
        background-position: center right 17.5px
    }
}

.smenu__item a:hover {
    color: #fff;
    background-color: #0089ff
}

.smenu__icon {
    padding: 20px;
    display: flex;
    justify-content: left;
}

#main {
    position: relative;
    width: 100%;
    height: 70vh;
    background-color: #011827;
    overflow-x: hidden;
    box-sizing: border-box
}

@media screen and (min-width: 670px) {
    #main {
        height: 100vh;
    }
}

#main .movie-wrap {
    width: 100%;
    height: 100%;
    padding: 0;
    position: relative;
    overflow: hidden;
    z-index: 1
}

#main .movie-wrap .movie {
    position: absolute;
    width: 100%;
    height: 100%;
    box-sizing: border-box;
    z-index: -1;
    margin: auto;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0
}

#main .movie-wrap .movie video {
    height: 100vh;
    width: calc(100% * 2048 / 1080);
    min-width: 100%;
    min-height: 100%;
    position: absolute;
    top: 50%;
    left: 50%;
    display: block;
    -webkit-transform: translate(-50%, -50%);
    -ms-transform: translate(-50%, -50%);
    -o-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
    z-index: 1;
    opacity: .4;
    object-fit: cover
}

@media screen and (min-aspect-ratio:2048/1080) {
    #main .movie-wrap .movie video {
        width: 100%;
        height: calc(100vh * 1080 / 2048)
    }
}

#main .kv_txtarea {
    position: absolute;
    top: 50%;
    left: 50%;
    -webkit-transform: translate(-50%, -50%);
    -ms-transform: translate(-50%, -50%);
    -o-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
    z-index: 2;
    text-align: center;
    max-width: 800px;
    margin: 0 auto;
    width: 100%
}

#main .kv_txtarea .kv_ttl {
    font-size: 70px;
    line-height: 1.2;
    letter-spacing: .05em
}

#main .kv_txtarea .kv_lead {
    font-size: 32px;
    line-height: 1.4;
    letter-spacing: .1em;
    padding-top: 12px
}

#main .kv_txtarea .kv_salary {
    display: flex;
    justify-content: center;
    align-items: flex-end
}

#main .kv_txtarea .kv_salary .kv_salary_left {
    font-size: 20px;
    line-height: 1.3;
    border: 1px solid #fff;
    padding: 7px 15px 9px;
    margin-right: 20px
}

#main .kv_txtarea .kv_salary .kv_salary_right {
    text-align: left
}

#main .kv_txtarea .kv_salary .kv_salary_right .kv_salary_average {
    font-size: 44px;
    line-height: .8
}

#main .kv_txtarea .kv_salary .kv_salary_right .kv_salary_average span {
    font-size: 76px;
    margin: 0 3px
}

#main .kv_txtarea .kv_salary_average_note {
    font-size: 28px;
    line-height: 1;
    padding-top: 12px
}

#main .kv_txtarea .kv_salary_average_note span {
    font-size: 44px;
    padding: 0 3px
}

#main .kv_txtarea .kv_no1 {
    max-width: 450px;
    margin: 0 auto;
    padding-top: 20px
}

#main .kv_txtarea .kv_no1 dd {
    font-size: 12px
}

@media screen and (max-width:767px) {
    #main .movie-wrap .movie video {
        opacity: .4
    }

    #main .kv_txtarea {
        padding: 0 20px
    }

    #main .kv_txtarea .kv_ttl {
        font-size: 36px;
        line-height: 1.3
    }

    #main .kv_txtarea .kv_lead {
        font-size: 20px;
        line-height: 1.5;
        padding-top: 6px
    }

    #main .kv_txtarea .kv_salary .kv_salary_left {
        font-size: 12px;
        line-height: 1.2;
        border: 1px solid #fff;
        padding: 5px 5px 5px;
        margin-right: 10px
    }

    #main .kv_txtarea .kv_salary .kv_salary_right {
        text-align: left
    }

    #main .kv_txtarea .kv_salary .kv_salary_right .kv_salary_average {
        font-size: 28px;
        line-height: .9
    }

    #main .kv_txtarea .kv_salary .kv_salary_right .kv_salary_average span {
        font-size: 40px;
        margin: 0 3px
    }

    #main .kv_txtarea .kv_salary_average_note {
        font-size: 16px;
        padding-top: 9px
    }

    #main .kv_txtarea .kv_salary_average_note span {
        font-size: 26px;
        padding: 0 2px
    }

    #main .kv_txtarea .kv_no1 {
        max-width: 90%;
        margin: 0 auto;
        padding-top: 15px
    }

    #main .kv_txtarea .kv_no1 dd {
        font-size: 10px
    }
}

@media screen and (max-width:320px) {
    #main .kv_txtarea .kv_ttl {
        font-size: 32px
    }

    #main .kv_txtarea .kv_lead {
        font-size: 18px
    }

    #main .kv_txtarea .kv_salary .kv_salary_left {
        font-size: 12px
    }

    #main .kv_txtarea .kv_salary .kv_salary_right .kv_salary_average {
        font-size: 24px;
        line-height: 1.1
    }

    #main .kv_txtarea .kv_salary .kv_salary_right .kv_salary_average span {
        font-size: 36px;
        margin: 0 3px
    }

    #main .kv_txtarea .kv_salary .kv_salary_right .kv_salary_average_note {
        font-size: 14px;
        line-height: 1
    }

    #main .kv_txtarea .kv_salary .kv_salary_right .kv_salary_average_note span {
        font-size: 11px
    }

    #main .kv_txtarea .kv_no1 {
        max-width: 100%
    }
}

.pnav {
    padding: 8.223880597vw 4.223881vw;
    background-color: #011827
}

@media screen and (min-width: 670px) {
    .pnav {
        padding: 98px 35px
    }
}

@media screen and (min-width: 670px) {
    .pnav {
        display: none
    }
}

.pnav__inner {
    max-width: 1100px;
    margin: 0 auto
}

.pnav__list {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 3.7313432836vw;
    border-bottom: 1px solid #bfbfbf
}

@media screen and (min-width: 670px) {
    .pnav__list {
        gap: 25px
    }
}

.pnav__list--bottom {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    align-items: center;
    gap: 3.7313432836vw;
    border-bottom: 1px solid #bfbfbf
}

.pnav__list:first-child {
    justify-content: center;
    border-top: 1px solid #bfbfbf
}

.pnav__item {
    padding: 1.4925373134vw 2.7313432836vw 1.4925373134vw 0;
    line-height: 1.5;
}

@media screen and (min-width: 670px) {
    .pnav__item {
        padding: 10px 0
    }
}

.pnav__item a {
    display: inline-block;
    width: fit-content;
    position: relative;
}

.pnav__item a::before,
.pnav__item a::after {
    content: "";
    position: absolute;
    top: 38.5%;
    right: -2.1vw;
    width: 0.2985074627vw;
    height: 1.3582089552vw;
    border-radius: 9999px;
    background-color: #006FBB;
    transform-origin: 50% calc(100% - 1px)
}

@media screen and (min-width: 670px) {

    .pnav__item a::before,
    .pnav__item a::after {
        right: -25px;
        width: 2px;
        height: 9.1px
    }
}

.pnav__item a::before {
    transform: rotate(45deg)
}

.pnav__item a::after {
    transform: rotate(-45deg)
}

.pnav__br {
    display: block;
}

@media screen and (min-width: 430px) {
    .pnav__br {
        display: none;
    }
}

.pnav a {
    transition: .5s;
    color: #fff;
    font-size: 90%;
}

.pnav a:hover {
    color: #006FBB
}

#intro {
    margin-top: 70px
}

#intro .intro_ttl {
    font-size: 40px;
    line-height: 1.4;
    letter-spacing: .08em
}

#intro .project_img_head {
    display: flex;
    padding-left: 8%;
    align-items: baseline;
    margin-top: 60px
}

#intro .project_img_head .project02 {
    padding-left: 80px
}

#intro .project_img_bottom {
    display: flex;
    padding-right: 4%;
    margin-top: 70px
}

#intro .project_img_bottom .project04 {
    padding: 0 80px
}

#intro .project_img_bottom .project03 .project_name {
    padding-left: 20px
}

#intro .project_name {
    font-size: 16px;
    line-height: 1.3;
    margin-top: 20px
}

#intro .project_name span {
    font-size: 26px;
    display: block
}

#intro .intro_fin {
    border-top: 1px solid #555;
    border-bottom: 1px solid #555;
    padding: 30px 0;
    margin-top: 80px;
    font-size: 28px
}

@media screen and (max-width:767px) {
    #intro {
        margin-top: 50px
    }

    #intro .intro_ttl {
        font-size: 22px;
        line-height: 1.4;
        letter-spacing: .05em
    }

    #intro .project_img_head {
        display: flex;
        padding-left: 0%;
        margin-top: 35px;
        gap: 20px;
        padding: 0 20px;
    }

    #intro .project_img_head .project01 {
        width: 50%;
        padding: 0;
    }

    #intro .project_img_head .project02 {
        width: 50%;
        padding: 0;
    }

    #intro .project_img_head .project_img {
        position: relative;
        width: 100%;
        height: 50vw;
        max-height: 350px;
        overflow: hidden;
    }

    #intro .project_img_head .project_img img {
        position: absolute;
        top: 50%;
        left: 50%;
        transform: translate(-50%, -50%);
        min-width: 100%;
        min-height: 100%;
        height: auto;
        object-fit: cover;
    }

    #intro .project_img_bottom {
        display: block;
        padding-right: 0%;
        margin-top: 30px
    }

    #intro .project_img_bottom .project03 {
        padding-right: 60px
    }

    #intro .project_img_bottom .project04 {
        padding: 30px 50px 30px
    }

    #intro .project_img_bottom .project05 {
        padding: 0 0 30px 100px
    }

    #intro .project_img_bottom .project03 .project_name {
        padding-left: 20px
    }

    #intro .project_name {
        font-size: 14px;
        line-height: 1.4;
        margin-top: 10px
    }

    #intro .project_name span {
        font-size: 20px
    }

    #intro .intro_fin {
        padding: 28px 0;
        margin: 20px 20px;
        line-height: 1.6;
        font-size: 18px
    }
}


#reason .reason_list {
    margin-top: -10px
}

#reason .reason_list .reason_item {
    position: relative;
    display: flex;
    align-items: flex-start;
    margin-top: 80px
}

#reason .reason_list .reason_item:nth-child(even) {
    flex-direction: row-reverse
}

#reason .reason_list .reason_item .reason_img {
    position: relative;
    width: 48%;
}

#reason .reason_list .reason_item .reason_txt {
    margin-left: 50px;
    margin-top: 20px;
    width: 34%;
    z-index: 1
}

#reason .reason_list .reason_item:nth-child(even) .reason_txt {
    margin-right: 50px;
    margin-left: 0
}

#reason .reason_list .reason_item .reason_txt .reason_number {
    font-size: 13px;
    color: #cda934;
    line-height: 1.5;
    padding-bottom: 5px;
    position: relative
}

#reason .reason_list .reason_item .reason_txt .reason_ttl {
    font-size: 28px;
    line-height: 1.4;
    position: relative;
    padding-bottom: 35px
}

#reason .reason_list .reason_item .reason_txt .reason_ttl::after {
    content: "";
    background-color: #555;
    width: calc(100% + 120px);
    height: 1px;
    position: absolute;
    left: -120px;
    display: block;
    margin-top: 17px
}

#reason .reason_list .reason_item:nth-child(even) .reason_txt .reason_ttl::after {
    right: -120px;
    left: auto
}

#reason .reason_list .reason_item .reason_txt .reason_detail {
    text-align: justify;
    line-height: 1.9
}

@media screen and (max-width:767px) {

    #reason .reason_list {
        margin-top: -10px
    }

    #reason .reason_list .reason_item {
        display: block;
        margin-top: 50px
    }

    #reason .reason_list .reason_item .reason_img {
        position: relative;
        width: 100%;
        height: 28vw;
        overflow: hidden;
    }

    #reason .reason_list .reason_item .reason_img img {
        margin-top: -3%;
    }

    #reason .reason_list .reason_item .reason_txt {
        margin: 0;
        padding: 25px 20px 0;
        width: 100%
    }

    #reason .reason_list .reason_item:nth-child(even) .reason_txt {
        padding: 25px 20px 0;
        margin: 0
    }

    #reason .reason_list .reason_item .reason_txt .reason_number {
        font-size: 12px;
        padding-bottom: 0
    }

    #reason .reason_list .reason_item .reason_txt .reason_ttl {
        font-size: 20px;
        line-height: 1.4;
        padding-bottom: 14px
    }

    #reason .reason_list .reason_item .reason_txt .reason_ttl::after {
        width: 100%;
        position: relative;
        left: 0;
        margin-top: 14px
    }

    #reason .reason_list .reason_item:nth-child(even) .reason_txt .reason_ttl::after {
        right: 0;
        left: auto
    }
}

#work {
    padding-top: 140px
}

#work .work_lead {
    text-align: center;
    padding-top: 16px;
    padding-bottom: 40px
}

#work .work_list--pc {
    display: flex;
    justify-content: space-between
}

#work .work_list--pc .work_item .work_name {
    font-size: 20px;
    padding-top: 15px;
    text-align: center
}

#work .work_swiper--sp {
    display: none;
}

@media screen and (max-width:767px) {
    #work {
        padding-top: 50px
    }

    #work .work_lead {
        text-align: left;
        padding: 15px 20px
    }

    #work .work_list--pc {
        display: none;
    }

    #work .work_swiper--sp {
        display: block;
    }
}

#day {
    padding-bottom: 140px
}

@media screen and (max-width:767px) {
    #day {
        padding-bottom: 50px
    }
}

#day .common_ttl {
    line-height: 1.5;
}

.day_text {
    margin: 4.4776119403vw 0;
    color: #FFFFFF
}

@media screen and (min-width: 767px) {
    .day_text {
        margin: 20px 0 50px 0
    }
}

.day_content {
    width: 100%;
    position: relative;
    display: flex;
    flex-wrap: wrap;
    align-items: flex-start;
    justify-content: space-between;
    gap: 4.4776119403vw;
    margin: 0 0 4.4776119403vw 0
}

@media screen and (min-width: 767px) {
    .day_content {
        justify-content: center
    }
}

@media screen and (min-width: 960px) {
    .day_content {
        flex-wrap: nowrap;
        gap: 40px;
        margin: 0 0 50px 0
    }
}

@media screen and (min-width: 1300px) {
    .day_content {
        gap: 60px
    }
}

.day_swiper {
    width: 100%
}

@media screen and (min-width: 767px) {
    .day_swiper {
        height: auto;
        max-width: 300px;
        margin: 0 -40px 0 0;
        order: 2
    }
}

@media screen and (min-width: 960px) {
    .day_swiper {
        max-width: 350px
    }
}

@media screen and (min-width: 1200px) {
    .day_swiper {
        max-width: 600px;
        margin: 0 -160px 0 0
    }
}

.day_swiper .swiper-pagination-bullet {
    background-color: #f6f0fa
}

.day_swiper .swiper-pagination-bullet-active {
    background-color: #006fbb
}

.day_swiper .swiper-pagination-bullet {
    width: 7.4626865672vw;
    height: 0.447761194vw;
    margin: 0 0.447761194vw;
    border: 0 !important;
    border-radius: 0 !important;
    opacity: 1 !important
}

@media screen and (min-width: 767px) {
    .day_swiper .swiper-pagination-bullet {
        width: 50px;
        height: 3px;
        margin: 0 3px
    }
}

.day_swiper .swiper-pagination {
    height: 1.4925373134vw;
    bottom: 2.9850746269vw
}

@media screen and (min-width: 767px) {
    .day_swiper .swiper-pagination {
        height: 10px;
        bottom: 20px;
        text-align: left;
        padding: 0 0 0 5px
    }
}

.day_swiper .swiper-pagination-bullet {
    border-radius: 50%;
    border: 2px solid #fff
}

.day_img {
    width: 100%
}

.day_img img {
    object-fit: cover;
    width: 100%;
    height: 100%
}

.day_list {
    order: 1;
}

@media screen and (min-width: 767px) {
    .day_list {
        max-width: 50%;
    }

}

.day_item {
    display: flex;
    align-items: center;
    flex-wrap: wrap;
    padding: 2.9850746269vw 0;
    color: #FFFFFF;
    border-bottom: 0.1492537313vw solid #FFFFFF
}

@media screen and (min-width: 767px) {
    .day_item {
        padding: 20px 0;
        border-bottom: 1px solid #FFFFFF
    }
}

.day_time {
    display: flex;
    align-items: center;
    margin: 0 2.2388059701vw 0 0;
    font-family: "游明朝体", "Yu Mincho", YuMincho, "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "MS P明朝", "MS PMincho", serif;
    font-weight: 700;
    font-size: 4.4776119403vw
}

@media screen and (min-width: 767px) {
    .day_time {
        font-size: clamp(3rem, 100vw - (670px + 1400px)/2, 3rem)
    }
}

@media screen and (min-width: 1920px) {
    .day_time {
        font-size: 3rem
    }
}

@media screen and (min-width: 767px) {
    .day_time {
        margin: 0 15px 0 0
    }
}

.day_time span {
    display: flex;
    align-items: center
}

.day_time span:first-child:after {
    content: "";
    display: block;
    width: 2.3880597015vw;
    height: 0.2985074627vw;
    margin: 0 0.7462686567vw;
    background-color: #006fbb
}

@media screen and (min-width: 767px) {
    .day_time span:first-child:after {
        width: 16px;
        height: 2px;
        margin: 0 5px
    }
}

.day_name {
    font-weight: 600;
    font-size: 3.7313432836vw;
    margin-bottom: 0.7313432836vw;
}

@media screen and (min-width: 767px) {
    .day_name {
        font-size: clamp(2.5rem, 100vw - (767px + 1400px)/2, 2.5rem);
        margin-bottom: 10px;
    }
}

@media screen and (min-width: 1920px) {
    .day_name {
        font-size: 2.5rem
    }
}

.day_description {
    width: 100%;
    margin: 0.7462686567vw 0 0 0;
    text-align: left;
}

@media screen and (min-width: 767px) {
    .day_description {
        margin: 15px 0 0 0
    }
}

.day_btn {
    width: 100%;
    height: 11.9402985075vw;
    max-width: 49.2537313433vw;
    margin: 0 auto
}

@media screen and (min-width: 767px) {
    .day_btn {
        height: 80px;
        max-width: 537px
    }
}

.day_btn a {
    display: flex;
    align-items: center;
    justify-content: center;
    width: inherit;
    height: inherit;
    letter-spacing: .3rem;
    color: #fff;
    background-image: url(/img/btn_icon2.svg);
    background-size: 2.9850746269vw 0.8955223881vw;
    background-repeat: no-repeat;
    background-position: center right 2.2388059701vw;
    background-color: #006fbb;
    transition: .5s;
    box-shadow: #006fbb 0px 0.7462686567vw;
    font-weight: 600;
    font-size: 4.4776119403vw
}

@media screen and (min-width: 767px) {
    .day_btn a {
        font-size: clamp(2.4rem, 100vw - (767px + 1400px)/2, 3rem)
    }
}

@media screen and (min-width: 1920px) {
    .day_btn a {
        font-size: 3rem
    }
}

@media screen and (min-width: 767px) {
    .day_btn a {
        background-image: url(/img/btn_icon1.svg);
        background-position: center right 25px;
        background-size: 56px 11px;
        box-shadow: #006fbb 0px 5px
    }
}

.day_btn a:hover {
    filter: brightness(0.7)
}



#salary {
    margin-top: 150px;
    background-color: #031f33;
    padding-bottom: 140px
}

#salary .salary_wrap {
    display: flex;
    justify-content: space-between;
    flex-direction: row-reverse;
    align-items: center;
    margin-top: 40px
}

#salary .salary_wrap .salary_img {
    width: 45%
}

#salary .salary_wrap .salary_txt {
    width: 55%;
    text-align: left;
    padding-right: 60px
}

#salary .salary_wrap .salary_txt .salary_career {
    border: 1px solid #fff;
    text-align: center;
    padding: 3px 0;
    font-size: 26px;
    line-height: 1.4
}

#salary .salary_wrap .salary_txt .salary_strong {
    color: #cda934;
    font-size: 46px;
    line-height: 1.1;
    text-align: center;
    padding-top: 7px
}

#salary .salary_wrap .salary_txt .salary_strong em {
    font-size: 82px;
    font-style: normal;
    padding: 0 3px
}

#salary .salary_wrap .salary_txt .salary_detail {
    padding-top: 45px;
    margin-bottom: 45px
}

#salary .salary_wrap .salary_txt .salary_fin {
    border-top: 1px solid #555;
    border-bottom: 1px solid #555;
    text-align: center;
    font-size: 26px;
    line-height: 1.7;
    padding: 17px 0
}

@media screen and (max-width:767px) {
    #salary {
        margin-top: 50px;
        padding-bottom: 50px
    }

    #salary .salary_wrap {
        display: block;
        margin-top: 25px
    }

    #salary .salary_wrap .salary_img {
        width: 100%;
        height: 40vw;
        overflow: hidden;
    }

    #salary .salary_wrap .salary_img img {
        margin-top: -3%;
    }

    #salary .salary_wrap .salary_txt {
        width: 100%;
        padding-top: 30px;
        padding-right: 0
    }

    #salary .salary_wrap .salary_txt .salary_career {
        padding: 3px 0;
        font-size: 18px;
        line-height: 1.4
    }

    #salary .salary_wrap .salary_txt .salary_strong {
        font-size: 30px
    }

    #salary .salary_wrap .salary_txt .salary_strong em {
        font-size: 60px;
        padding: 0 2px
    }

    #salary .salary_wrap .salary_txt .salary_detail {
        padding-top: 20px;
        margin-bottom: 25px
    }

    #salary .salary_wrap .salary_txt .salary_fin {
        font-size: 18px;
        line-height: 1.6;
        padding: 17px 0
    }
}

#support {
    margin-top: 150px;
    padding-bottom: 150px
}

#support .support_copy {
    font-size: 30px;
    line-height: 1.4;
    padding-top: 40px;
    padding-bottom: 15px
}

#support .support_allowance_ttl {
    font-size: 20px;
    border: 1px solid #fff;
    max-width: 450px;
    margin: 0 auto;
    padding: 1px;
    margin-top: 45px
}

#support .support_allowance_number {
    font-size: 24px;
    line-height: 1.3;
    margin-top: 8px
}

#support .support_allowance_number em {
    font-size: 36px;
    font-style: normal;
    padding: 0 3px
}

#support .support_allowance_list {
    display: flex;
    justify-content: space-between;
    margin-top: 50px
}

#support .support_allowance_list .support_allowance_item {
    border-left: 1px solid #555;
    width: 25%;
    padding: 14px 30px 10px
}

#support .support_allowance_list .support_allowance_item:last-child {
    border-right: 1px solid #555
}

#support .support_allowance_list .support_allowance_item .allowance_price {
    font-size: 24px;
    border-bottom: 1px solid #555;
    padding-bottom: 13px;
    margin-bottom: 25px
}

#support .support_allowance_list .support_allowance_item .allowance_name_list {
    text-align: left;
    font-size: 16px
}

#support .support_allowance_list .support_allowance_item .allowance_name_list .allowance_name_item {
    position: relative;
    padding-left: 12px;
    line-height: 1.5;
    padding-bottom: 8px
}

#support .support_allowance_list .support_allowance_item .allowance_name_list .allowance_name_item::before {
    content: "?";
    position: absolute;
    left: 0;
    top: 0
}

@media screen and (max-width:767px) {
    #support {
        margin-top: 50px;
        padding-bottom: 50px
    }

    #support .support_copy {
        font-size: 20px;
        line-height: 1.5;
        padding-top: 30px;
        padding-bottom: 15px
    }

    #support .support_lead {
        text-align: left
    }

    #support .support_allowance_ttl {
        font-size: 16px;
        margin-top: 30px
    }

    #support .support_allowance_number {
        font-size: 18px;
        margin-top: 8px
    }

    #support .support_allowance_number em {
        font-size: 26px;
        padding: 0 2px
    }

    #support .support_allowance_list {
        display: block;
        margin-top: 30px
    }

    #support .support_allowance_list .support_allowance_item {
        border-left: none;
        width: 100%;
        padding: 0;
        margin-bottom: 20px
    }

    #support .support_allowance_list .support_allowance_item:last-child {
        border-right: none
    }

    #support .support_allowance_list .support_allowance_item .allowance_price {
        font-size: 18px;
        line-height: 1.3;
        padding-bottom: 3px;
        margin-bottom: 8px
    }

    #support .support_allowance_list .support_allowance_item .allowance_name_list {
        text-align: left;
        font-size: 14px
    }

    #support .support_allowance_list .support_allowance_item .allowance_name_list .allowance_name_item {
        position: relative;
        padding-left: 12px;
        line-height: 1.5;
        padding-bottom: 5px
    }

    #support .support_allowance_list .support_allowance_item .allowance_name_list .allowance_name_item::before {
        content: "?";
        position: absolute;
        left: 0;
        top: 0
    }
}

#interview {
    background-color: #031f33;
    padding-bottom: 140px
}

#interview .interview_list {
    margin-top: -5px;
    margin-bottom: 80px
}

#interview .interview_list .interview_item {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    margin-top: 55px
}

#interview .interview_list .interview_item:nth-child(even) {
    flex-direction: row-reverse
}

#interview .interview_list .interview_item .interview_img {
    width: 19%;
    padding-right: 30px
}

#interview .interview_list .interview_item:nth-child(even) .interview_img {
    padding-left: 30px;
    padding-right: 0
}

#interview .interview_list .interview_item .interview_txt {
    width: 81%;
    border: 1px solid #555;
    position: relative;
    padding: 35px 45px;
    border-radius: 20px;
    text-align: left;
    font-size: 18px;
    letter-spacing: 0
}

#interview .interview_list .interview_item .interview_txt::before {
    content: ' ';
    width: 0;
    height: 0;
    position: absolute;
    border: 15px solid transparent;
    border-top-color: #0a8cb9;
    border-left-color: transparent;
    border-right-color: #0a8cb9;
    left: -20px;
    right: auto
}

#interview .interview_list .interview_item:nth-child(even) .interview_txt::before {
    content: ' ';
    width: 0;
    height: 0;
    position: absolute;
    border: 15px solid transparent;
    border-top-color: #0a8cb9;
    border-right-color: transparent;
    border-left-color: #0a8cb9;
    right: -20px;
    left: auto
}

#interview .employee_lead {
    padding-top: 8px;
    padding-bottom: 35px
}

#interview .employee_list--pc {
    display: grid;
    grid-template-columns: repeat(6, 1fr);
    grid-column-gap: 30px
}

#interview .employee_swiper {
    display: none;
}

@media screen and (max-width:767px) {
    #interview {
        padding-bottom: 50px
    }

    #interview .interview_list {
        margin-top: 10px;
        margin-bottom: 50px
    }

    #interview .interview_list .interview_item {
        margin-top: 30px
    }

    #interview .interview_list .interview_item .interview_img {
        width: 22%;
        padding-right: 10px
    }

    #interview .interview_list .interview_item:nth-child(even) .interview_img {
        padding-left: 10px;
        padding-right: 0
    }

    #interview .interview_list .interview_item .interview_txt {
        width: 78%;
        padding: 15px 20px;
        border-radius: 10px;
        font-size: 15px
    }

    #interview .interview_list .interview_item .interview_txt::before {
        content: ' ';
        width: 0;
        height: 0;
        position: absolute;
        border: 8px solid transparent;
        border-top-color: #0a8cb9;
        border-left-color: transparent;
        border-right-color: #0a8cb9;
        left: -10px;
        right: auto
    }

    #interview .interview_list .interview_item:nth-child(even) .interview_txt::before {
        content: ' ';
        width: 0;
        height: 0;
        position: absolute;
        border: 8px solid transparent;
        border-top-color: #0a8cb9;
        border-right-color: transparent;
        border-left-color: #0a8cb9;
        right: -10px;
        left: auto
    }

    #interview .employee_lead {
        padding-top: 15px;
        text-align: left;
        padding-bottom: 20px
    }

    #interview .employee_list--pc {
        display: none;
    }

    #interview .employee_swiper {
        display: block;
    }
}

#no1 {
    background: url(/img/bg_no1.jpg) center top no-repeat;
    background-size: cover;
    position: relative;
    min-height: 650px
}

#no1 .no1_txt {
    position: absolute;
    left: 5%;
    top: 16%;
    text-align: center
}

#no1 .no1_txt .no1_because {
    font-size: 30px;
    line-height: 1.1
}

#no1 .no1_lead {
    font-size: 46px;
    line-height: 1.3
}

#no1 .no1_list {
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
    text-align: center;
    margin-top: 25px;
    max-width: 800px
}

#no1 .no1_list .no1_item {
    width: 49.333%;
    padding: 10px 10px
}

#no1 .no1_note {
    font-size: 10px;
    line-height: 1.2;
    text-align: left;
    padding-top: 5px;
    padding-left: 10px;
    max-width: 800px;
}

#no1 .no1_fin_sub {
    font-size: 34px;
    line-height: 1.2;
    padding-top: 24px
}

#no1 .no1_fin_ttl {
    font-size: 46px;
    line-height: 1.5
}

@media screen and (max-width:767px) {
    #no1 {
        background: url(/img/bg_no1_sp.jpg) left top no-repeat;
        background-size: cover;
        position: relative;
        min-height: 550px;
        padding: 70px 0
    }

    #no1 .no1_txt {
        position: relative;
        left: 0;
        top: 0;
        padding: 0 20px 0;
        text-align: center
    }

    #no1 .no1_txt .no1_because {
        font-size: 22px;
        line-height: 1.3
    }

    #no1 .no1_lead {
        font-size: 24px
    }

    #no1 .no1_list {
        display: grid;
        grid-template-columns: 1fr 1fr;
        margin-top: 15px
    }

    #no1 .no1_list .no1_item {
        width: 100%;
        padding: 6px;
        margin: 0
    }

    #no1 .no1_list .no1_item:first-child {
        grid-column: 1 / 3
    }

    #no1 .no1_list .no1_item img {
        width: 100%
    }

    #no1 .no1_list .no1_item:first-child img {
        width: 48%
    }

    #no1 .no1_note {
        font-size: 10px;
        line-height: 1.2;
        text-align: center;
        padding-top: 2px
    }

    #no1 .no1_fin_sub {
        font-size: 20px;
        line-height: 1.2;
        padding-top: 26px;
        padding-bottom: 4px
    }

    #no1 .no1_fin_ttl {
        font-size: 30px;
        line-height: 1.4
    }
}

#aboutus {
    padding-top: 140px;
}

#aboutus .aboutus_copy {
    font-size: 30px;
    line-height: 1.3;
    padding-top: 38px
}

#aboutus .aboutus_copy span {
    font-size: 40px;
    padding: 0 3px
}

#aboutus .aboutus_chart {
    padding: 45px 0 0;
    max-width: 900px;
    margin: 0 auto
}

#aboutus .aboutus_list .aboutus_item {
    display: flex;
    justify-content: space-between;
    margin-top: 75px
}

#aboutus .aboutus_list .aboutus_item:nth-child(even) {
    flex-direction: row-reverse
}

#aboutus .aboutus_list .aboutus_item .aboutus_img {
    width: 45%
}

#aboutus .aboutus_list .aboutus_item .aboutus_txt {
    width: 55%;
    padding-left: 50px;
    text-align: justify;
    margin-top: -10px
}

#aboutus .aboutus_list .aboutus_item:nth-child(even) .aboutus_txt {
    padding-left: 0;
    padding-right: 50px
}

#aboutus .aboutus_list .aboutus_item .aboutus_txt .aboutus_ttl {
    font-size: 23px;
    letter-spacing: 0;
    line-height: 1.6;
    position: relative
}

#aboutus .aboutus_list .aboutus_item .aboutus_txt .aboutus_ttl::after {
    content: "";
    background-color: #555;
    height: 1px;
    width: 40px;
    display: block;
    margin: 20px auto 22px 0
}

#aboutus .aboutus_list .aboutus_item .aboutus_txt .aboutus_detail {
    font-size: 16px
}

@media screen and (max-width:767px) {
    #aboutus {
        padding-top: 50px;
    }

    #aboutus .aboutus_copy {
        font-size: 19px;
        line-height: 1.4;
        padding-top: 22px
    }

    #aboutus .aboutus_copy span {
        font-size: 24px;
        padding: 0 2px
    }

    #aboutus .aboutus_chart {
        padding: 25px 0 0;
        max-width: 90%;
        margin: 0 auto
    }

    #aboutus .aboutus_list .aboutus_item {
        display: block;
        margin-top: 40px
    }

    #aboutus .aboutus_list .aboutus_item .aboutus_img {
        width: 100%
    }

    #aboutus .aboutus_list .aboutus_item .aboutus_txt {
        width: 100%;
        padding-left: 0;
        margin-top: 20px
    }

    #aboutus .aboutus_list .aboutus_item:nth-child(even) .aboutus_txt {
        padding-left: 0;
        padding-right: 0
    }

    #aboutus .aboutus_list .aboutus_item .aboutus_txt .aboutus_ttl {
        font-size: 18px;
        letter-spacing: 0;
        line-height: 1.6;
        position: relative
    }

    #aboutus .aboutus_list .aboutus_item .aboutus_txt .aboutus_ttl::after {
        margin: 15px auto 17px 0
    }

    #aboutus .aboutus_list .aboutus_item .aboutus_txt .aboutus_detail {
        font-size: 15px
    }
}

#company {
    padding: 140px 0 140px
}

#company .company_list {
    margin-top: 30px
}

#company .company_list .company_item {
    border-bottom: 1px solid #555;
    padding: 45px 0;
    display: flex;
    text-align: left
}

#company .company_list .company_item .company_ttl {
    color: #0a8cb9;
    width: 20%;
    font-weight: 700
}

#company .company_list .company_item .company_detail {
    width: 80%;
    line-height: 1.7
}

#company .company_list .company_item .company_detail strong {
    padding-bottom: 4px
}

@media screen and (max-width:767px) {
    #company {
        padding: 50px 0 50px
    }

    #company .company_list {
        margin-top: 0
    }

    #company .company_list .company_item {
        border-bottom: 1px solid #555;
        padding: 30px 0;
        display: block
    }

    #company .company_list .company_item .company_ttl {
        width: 100%;
        font-size: 17px;
        padding-bottom: 5px
    }

    #company .company_list .company_item .company_detail {
        width: 100%;
        line-height: 1.6
    }
}

#welfare {
    padding-bottom: 150px
}

#welfare .welfare_copy {
    font-size: 30px;
    line-height: 1.5;
    padding-top: 38px
}

#welfare .welfare_list {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 15px;
    margin-top: 40px
}

#welfare .welfare_list .welfare_item {
    background-color: #031f33;
    padding: 26px 5px;
}

#welfare .welfare_list .welfare_item .welfare_name {
    font-size: 24px;
}

#welfare .welfare_list .welfare_item .welfare_description {
    font-size: 16px;
    margin: 20px 0 0 0;
}

#welfare .start {
    border: 1px solid #555;
    margin-top: 50px;
    padding: 40px 70px
}

#welfare .start .start_copy {
    font-size: 24px;
    line-height: 1.3
}

#welfare .start .start_ttl {
    font-size: 30px;
    position: relative
}

#welfare .start .start_ttl::before {
    content: "";
    position: relative;
    display: inline-block;
    width: 50px;
    height: 35px;
    top: -3px;
    margin-right: 13px;
    vertical-align: middle;
    background: url(/img/icon_money.png) no-repeat center center;
    background-size: contain
}

#welfare .start .start_detail {
    border-top: 1px solid #555;
    margin-top: 22px;
    padding-top: 22px
}

#welfare .start .pc {
    display: block;
}



@media screen and (max-width:767px) {
    #welfare {
        padding-bottom: 50px
    }

    #welfare .welfare_copy {
        font-size: 20px;
        line-height: 1.5;
        padding-top: 30px
    }

    #welfare .welfare_list {
        grid-template-columns: repeat(2, 1fr);
        gap: 8px;
        margin-top: 25px
    }

    #welfare .welfare_list .welfare_item {
        padding: 20px 5px;
        line-height: 1.4;
        display: flex;
        align-items: center;
        justify-content: center;
        flex-direction: column;
    }

    #welfare .welfare_list .welfare_item .welfare_name {
        font-size: 21px;
    }

    #welfare .welfare_list .welfare_item .welfare_description {
        margin: 1.4925373134vw 0 0 0;
        font-size: 16px;
    }

    #welfare .start {
        margin-top: 40px;
        padding: 30px 20px
    }

    #welfare .start .start_copy {
        font-size: 18px;
        line-height: 1.3;
        padding-bottom: 8px
    }

    #welfare .start .start_ttl {
        font-size: 20px;
        position: relative;
        line-height: 1.3;
        letter-spacing: 0
    }

    #welfare .start .start_ttl span {
        font-size: 10px
    }

    #welfare .start .start_ttl::before {
        width: 35px;
        height: 24px;
        top: -2px;
        margin-right: 8px
    }

    #welfare .start .start_detail {
        margin-top: 18px;
        text-align: left;
        padding-top: 18px
    }

    #welfare .start .pc {
        display: none;
    }
}

#get {
    background: url(/img/bg_fin.jpg) center center no-repeat;
    background-size: cover;
    position: relative;
    min-height: 600px;
    display: flex;
    align-items: center;
    justify-content: center
}

#get .get_txt {
    text-align: center
}

#get .get_txt .get_logo {
    max-width: 325px;
    margin: 0 auto
}

#get .get_txt .get_ttl {
    font-size: 44px;
    line-height: 1.4;
    padding-top: 20px
}

@media screen and (max-width:767px) {
    #get {
        min-height: 400px;
        padding: 70px 20px
    }

    #get .get_txt .get_logo {
        max-width: 75%
    }

    #get .get_txt .get_ttl {
        font-size: 23px;
        line-height: 1.5;
        padding-top: 15px
    }
}

#recruitment {
    padding: 140px 0 140px 0
}

#recruitment .recruitment_list {
    margin-top: 30px
}

#recruitment .recruitment_list .recruitment_item {
    border-bottom: 1px solid #555;
    padding: 45px 0;
    display: flex;
    text-align: left
}

#recruitment .recruitment_list .recruitment_item .recruitment_ttl {
    color: #0a8cb9;
    width: 20%;
    font-weight: 700
}

#recruitment .recruitment_list .recruitment_item .recruitment_detail {
    width: 80%;
    line-height: 1.7
}

#recruitment .recruitment_list .recruitment_item .recruitment_detail strong {
    padding-bottom: 4px
}

#recruitment .recruitment_list .recruitment_item .recruitment_detail .recruitment_link {
    color: #FFF;
    text-decoration: underline;
}

#recruitment .recruitment_list .recruitment_item .recruitment_detail .recruitment_link:hover {
    opacity: 0.5;
    transition: 0.5s ease;
}

@media screen and (max-width:767px) {
    #recruitment {
        padding: 50px 0
    }

    #recruitment .recruitment_list {
        margin-top: 0
    }

    #recruitment .recruitment_list .recruitment_item {
        border-bottom: 1px solid #555;
        padding: 30px 0;
        display: block
    }

    #recruitment .recruitment_list .recruitment_item .recruitment_ttl {
        width: 100%;
        font-size: 17px;
        padding-bottom: 5px
    }

    #recruitment .recruitment_list .recruitment_item .recruitment_detail {
        width: 100%;
        line-height: 1.6
    }
}

footer {
    text-align: center;
    font-size: 15px;
    letter-spacing: 0;
    padding: 40px 0 160px
}

.footer--not-top {
    padding: 40px 0 !important
}

#fixed_banner {
    display: flex;
    align-items: center;
    background-color: rgba(3, 31, 51, .8);
    width: 100%;
    height: 50px;
    position: fixed;
    z-index: 9998
}

#fixed_banner ul {
    text-align: center
}

#fixed_banner ul li img {
    width: 80%
}

#fixed_gift {
    align-items: center;
    width: 40%;
    height: 50px;
    position: fixed;
    z-index: 9998;
    top: 7%;
    right: 0;
}

@media screen and (min-width:767px) {
    #fixed_gift {
        width: 15%;
    }
}

@media screen and (min-width: 1300px) {
    #fixed_gift {
        top: 7%;
    }
}

#fixed_gift:hover {
    cursor: pointer;
    opacity: .7;
    -webkit-transition: 0.3s ease-in-out;
    -o-transition: 0.3s ease-in-out;
    transition: 0.3s ease-in-out
}

.fade {
    opacity: 0;
    transform: translate(0, 0);
    transition: all 1.5s;
}

.fadebottom {
    transform: translate(0, 30px);
}

#fixed_gift.scrollin {
    opacity: 1 !important;
    transform: translate(0, 0) !important;
}

#fixed_cv {
    position: fixed;
    bottom: 0;
    text-align: center;
    width: 100%;
    z-index: 9998;
    box-sizing: border-box;
    padding: 18px 0
}

#fixed_cv ul {
    display: flex;
    justify-content: center
}

#fixed_cv ul li {
    margin: 0 5px
}

#fixed_cv ul li .fixed_btn {
    width: 350px;
    height: 60px;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-direction: column;
    background-color: #CB560E;
    border-radius: 50px;
    color: #fff;
    font-weight: 700;
    font-size: 20px;
    line-height: 1.3;
    position: relative;
    -webkit-transition: 0.3s ease-in-out;
    -o-transition: 0.3s ease-in-out;
    transition: 0.3s ease-in-out
}

#fixed_cv ul li .fixed_btn::after {
    content: "";
    position: absolute;
    width: 18px;
    height: 8px;
    top: 40%;
    right: 20px;
    vertical-align: middle;
    background: url(/img/icon_arrow.svg) no-repeat center center;
    background-size: contain
}

#fixed_cv ul li .fixed_btn.fresh_btn {
    background-color: #D17D09
}

#fixed_cv ul li .fixed_btn:hover {
    opacity: .7;
    -webkit-transition: 0.3s ease-in-out;
    -o-transition: 0.3s ease-in-out;
    transition: 0.3s ease-in-out
}

#fixed_cv ul li .small_text {
    font-size: 14px;
    font-weight: normal;
}

#fixed_pagetop {
    position: fixed;
    bottom: 0;
    right: 20px;
    text-align: center;
    z-index: 9999;
    box-sizing: border-box;
    padding-bottom: 20px
}

#fixed_pagetop span {
    position: relative;
    margin: auto;
    width: 50px;
    height: 50px;
    border-radius: 50%;
    background: #555;
    display: block
}

#fixed_pagetop span::after {
    content: "";
    position: absolute;
    margin: auto;
    top: 5px;
    bottom: 0;
    left: 18px;
    width: 13px;
    height: 13px;
    border-top: 2px solid #fff;
    border-right: 2px solid #fff;
    transform: rotate(-45deg)
}

.cta_button {
    text-align: center;
    padding: 80px 0 0 0;
}

.cta_button ul {
    display: flex;
    justify-content: center
}

.cta_button ul li {
    margin: 0 5px;
}

.cta_button ul li .cta_btn {
    display: flex;
    align-items: center;
    justify-content: center;
    flex-direction: column;
    width: 350px;
    height: 80px;
    background-color: #CB560E;
    color: #fff;
    font-weight: 700;
    font-size: 20px;
    line-height: 1.4;
    position: relative;
    -webkit-transition: 0.3s ease-in-out;
    -o-transition: 0.3s ease-in-out;
    transition: 0.3s ease-in-out
}

.cta_button ul li .cta_btn span {
    font-size: 14px;
    font-weight: normal;
}

.cta_button ul li .cta_btn::after {
    content: "";
    position: absolute;
    width: 18px;
    height: 8px;
    top: 40%;
    right: 20px;
    vertical-align: middle;
    background: url(/img/icon_arrow.svg) no-repeat center center;
    background-size: contain
}

.cta_button ul li .cta_btn.fresh_btn {
    background-color: #D17D09
}

.cta_button ul li .cta_btn:hover {
    opacity: .7;
    -webkit-transition: 0.3s ease-in-out;
    -o-transition: 0.3s ease-in-out;
    transition: 0.3s ease-in-out
}


.official {
    text-align: center;
    display: block;
    margin-top: 60px
}

.official a {
    color: #fff;
    font-size: 15px;
    border-bottom: solid 1px #fff;
    position: relative;
    padding-right: 22px
}

.official a:hover {
    opacity: .7;
    transition: 0.3s
}

.official a::after {
    content: "";
    background-image: url(/img/icon_link.png);
    background-repeat: no-repeat;
    background-size: 15px;
    position: absolute;
    right: 0;
    top: 4px;
    width: 15px;
    height: 15px
}

.annotation {
    max-width: 1140px;
    margin: 0 auto;
    box-sizing: border-box;
    text-align: left;
    padding: 20px 20px 0;
    font-size: 10px;
}

@media screen and (max-width:767px) {
    footer {
        font-size: 11px;
        padding: 50px 0 120px
    }

    #fixed_cv {
        padding: 0 0;
        background-color: transparent
    }

    #fixed_cv ul li {
        margin: 0;
        width: 50%
    }

    #fixed_cv ul li .fixed_btn {
        width: 100%;
        height: 50px;
        border-radius: 0;
        font-size: 16px;
        line-height: 1.3;
        -webkit-transition: none;
        -o-transition: none;
        transition: none
    }

    #fixed_cv ul li .fixed_btn::after {
        display: none
    }

    #fixed_cv ul li .fixed_btn:hover {
        opacity: 1;
        -webkit-transition: none;
        -o-transition: none;
        transition: none
    }

    #fixed_cv ul li .small_text {
        font-size: 12px;
        font-weight: normal;
    }

    .cta_button {
        padding: 30px 0 0 0;
        background-color: transparent
    }

    .cta_button ul {
        gap: 10px;
    }

    .cta_button ul li {
        margin: 0;
        width: 45%
    }

    .cta_button ul li .cta_btn {
        width: 100%;
        height: 80px;
        border-radius: 0;
        font-size: 20px;
        line-height: 1.3;
        -webkit-transition: none;
        -o-transition: none;
        transition: none;
    }

    @media screen and (max-width:550px) {
        .cta_button ul li .cta_btn {
            font-size: 16px;
        }
    }

    .cta_button ul li .cta_btn::after {
        display: none
    }

    .cta_button ul li .cta_btn:hover {
        opacity: 1;
        -webkit-transition: none;
        -o-transition: none;
        transition: none
    }

    .cta_button ul li .cta_btn span {
        font-size: 12px;
        font-weight: normal;
    }

    #fixed_pagetop {
        padding-bottom: 110px;
        right: 10px
    }

    #fixed_pagetop span {
        width: 40px;
        height: 40px
    }

    #fixed_pagetop span::after {
        top: 4px;
        left: 14px;
        width: 10px;
        height: 10px
    }
}

@media screen and (min-width:767px) {
    #fixed_banner {
        display: none
    }

    #fixed_banner-pc {
        background-color: rgba(3, 31, 51, .8);
        width: 100%;
        height: 160px;
        position: fixed;
        z-index: 9998
    }

    #fixed_banner-pc ul {
        text-align: center
    }

    #fixed_banner-pc ul li img {
        width: 600px;
        padding: 10px
    }
}

.fadein {
    -webkit-transition: .8s;
    -o-transition: .8s;
    transition: .8s !important;
    opacity: 0;
    -ms-transform: translate(0, 60px);
    transform: translate(0, 60px);
    -webkit-transform: translate(0, 60px)
}

.fadein_af {
    opacity: 1;
    -ms-transform: translate(0, 0);
    transform: translate(0, 0);
    -webkit-transform: translate(0, 0)
}

.del_01 {
    -webkit-transition-delay: 0.2s !important;
    -o-transition-delay: 0.2s !important;
    transition-delay: 0.2s !important
}

.del_02 {
    -webkit-transition-delay: 0.4s !important;
    -o-transition-delay: 0.4s !important;
    transition-delay: 0.4s !important
}

.del_03 {
    -webkit-transition-delay: 0.6s !important;
    -o-transition-delay: 0.6s !important;
    transition-delay: 0.6s !important
}

.section_border {
    display: block;
    bottom: 0;
    margin: 33px auto 20px;
    width: 0%;
    height: 1px;
    background-color: #fff;
    border: 0;
    transition: transform 1000ms ease, width 800ms ease;
    -webkit-transition-delay: 0.8s !important;
    -o-transition-delay: 0.8s !important;
    transition-delay: 0.8s !important
}

.section_border_af {
    opacity: 1;
    background: #fff;
    width: 100%;
    transform: translate3d(0%, 0%, 0);
    height: 1px
}

.section {
    width: 100%;
    padding: 8.9552238806vw 0;
}

@media screen and (min-width: 670px) {
    .section {
        padding: 80px 0;
    }
}

#form.anchar {
    padding-top: 8.9552238806vw;
    margin-top: -8.9552238806vw;
}

@media screen and (min-width: 670px) {
    #form.anchar {
        padding-top: 100px;
        margin-top: -100px;
    }
}

.section__inner {
    max-width: 1000px;
    margin: 0 auto;
    padding: 0 5.223880597vw
}

@media screen and (min-width: 670px) {
    .section__inner {
        padding: 0 35px
    }
}

@media screen and (min-width: 1300px) {
    .section__inner {
        padding: 0
    }
}

.section__title {
    margin: 0 0 4.4776119403vw 0;
    font-weight: 600;
    font-size: 7.4626865672vw
}

@media screen and (min-width: 670px) {
    .section__title {
        font-size: clamp(7rem, 100vw - (670px + 1400px)/2, 7rem)
    }
}

@media screen and (min-width: 1920px) {
    .section__title {
        font-size: 7rem
    }
}

@media screen and (min-width: 670px) {
    .section__title {
        margin: 0 0 25px 0
    }
}

.section__title span {
    color: #ef4b0e
}

.section__text {
    margin: 0 0 4.4776119403vw 0
}

@media screen and (min-width: 670px) {
    .section__text {
        margin: 0 0 25px 0
    }
}

.section__text span {
    color: #ef4b0e
}

.ttl_border::before {
    display: block;
    position: absolute;
    top: 0;
    left: 50%;
    margin: 0 auto;
    text-align: center;
    width: 1px;
    height: 0;
    content: "";
    background-color: #006fbb;
    box-sizing: border-box;
    transition: height 800ms ease
}

.ttl_border_af::before {
    transform: translate3d(0%, 0%, 0);
    opacity: 1;
    height: 150px
}

@media only screen and (max-width:768px) {
    .section_border {
        margin: 20px auto 15px
    }

    .ttl_border_af::before {
        height: 50px
    }

    .del_01 {
        -webkit-transition-delay: 0s !important;
        -o-transition-delay: 0s !important;
        transition-delay: 0s !important
    }

    .del_02 {
        -webkit-transition-delay: 0s !important;
        -o-transition-delay: 0s !important;
        transition-delay: 0s !important
    }

    .del_03 {
        -webkit-transition-delay: 0s !important;
        -o-transition-delay: 0s !important;
        transition-delay: 0s !important
    }
}

.form {
    display: flex;
    flex-direction: column;
    gap: 30px
}

.form__attention {
    font-size: 16px;
    font-weight: bold;
    text-align: center;
}

.form__attention br {
    display: none;
}

@media screen and (min-width: 670px) {
    .form__attention br {
        display: block;
    }
}

.form__row label.error {
    display: block;
    width: 100%;
    color: #ef4b0e;
    margin: 1.4925373134vw 0 0 0
}

@media screen and (min-width: 670px) {
    .form__row label.error {
        margin: 10px 0 0 0
    }
}

.form__heading {
    display: flex;
    align-items: center;
    margin: 0 0 10px 0;
    font-weight: 500;
    font-size: 2.9850746269vw
}

@media screen and (min-width: 670px) {
    .form__heading {
        font-size: clamp(2rem, 100vw - (670px + 1400px)/2, 2rem)
    }
}

@media screen and (min-width: 1920px) {
    .form__heading {
        font-size: 2rem
    }
}

.form__heading a {
    color: #fff;
    text-decoration: underline;
    text-underline-offset: 0.7462686567vw;
    transition: .5s
}

@media screen and (min-width: 670px) {
    .form__heading a {
        text-underline-offset: 5px
    }
}

.form__heading a:hover {
    color: #ef4b0e
}

.form__heading span {
    margin: 0 0 0 10px;
    padding: 0 10px;
    color: #ef4b0e;
    border: 1px solid #ef4b0e;
    font-weight: 500;
    font-size: 2.0895522388vw
}

@media screen and (min-width: 670px) {
    .form__heading span {
        font-size: clamp(1.4rem, 100vw - (670px + 1400px)/2, 1.4rem)
    }
}

@media screen and (min-width: 1920px) {
    .form__heading span {
        font-size: 1.4rem
    }
}

.form__input {
    display: flex;
    flex-wrap: wrap;
    gap: 20px
}

.form__input input,
.form__input textarea,
.form__input select {
    font-weight: 500;
    font-size: 2.9850746269vw
}

@media screen and (min-width: 670px) {

    .form__input input,
    .form__input textarea,
    .form__input select {
        font-size: clamp(1.6rem, 100vw - (670px + 1400px)/2, 1.6rem)
    }
}

@media screen and (min-width: 1920px) {

    .form__input input,
    .form__input textarea,
    .form__input select {
        font-size: 1.6rem
    }
}

.form__input input[type=text],
.form__input input[type=email],
.form__input input[type=tel],
.form__input textarea {
    width: 100%;
    padding: 20px
}

.form__input select {
    padding: 20px;
    cursor: pointer
}

.form__input .pref {
    width: 37.3134328358vw
}

@media screen and (min-width: 670px) {
    .form__input .pref {
        width: 250px
    }
}

.form__unit {
    display: flex;
    align-items: center
}

.form__unit span {
    margin: 0 0 0 0.7462686567vw
}

@media screen and (min-width: 670px) {
    .form__unit span {
        margin: 0 0 0 5px
    }
}

.form__radio {
    position: relative;
    width: 100%;
    padding: 20px;
    color: #fff;
    border: 1px solid #fff;
    cursor: pointer
}

@media screen and (min-width: 670px) {
    .form__radio {
        max-width: 240px
    }
}

.form__radio input[type=radio] {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    visibility: hidden
}

.form__radio:has(input[type=radio]:checked) {
    color: #011422;
    background-color: #fff;
    border: none
}

.form__checkbox {
    display: flex;
    align-items: center;
    gap: 10px;
    white-space: nowrap;
    cursor: pointer
}

.form__checkbox input[type=checkbox] {
    position: relative;
    width: 30px;
    height: 30px;
    background: #f7f8fc;
    border: none;
    border-radius: 0;
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none
}

.form__checkbox input[type=checkbox]:checked:before {
    position: absolute;
    top: 2px;
    left: 9px;
    transform: rotate(50deg);
    width: 10px;
    height: 15px;
    border-right: 4px solid #ef4b0e;
    border-bottom: 4px solid #ef4b0e;
    content: ""
}

.form__btns {
    cursor: pointer;
    display: flex;
    gap: 1.4925373134vw
}

@media screen and (min-width: 670px) {
    .form__btns {
        gap: 10px
    }
}

.form__btn {
    width: 100%;
    height: 8.9552238806vw;
    max-width: 41.0447761194vw;
    margin: 0 auto
}

@media screen and (min-width: 670px) {
    .form__btn {
        height: 80px;
        max-width: 537px
    }
}

.form__btn button {
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    width: inherit;
    height: inherit;
    letter-spacing: .3rem;
    color: #fff;
    background-image: url(/img/btn_icon1.svg);
    background-size: 2.9850746269vw 0.8955223881vw;
    background-repeat: no-repeat;
    background-position: center right 2.2388059701vw;
    background-color: #ef4b0e;
    transition: .5s;
    font-weight: 600;
    font-size: 2.9850746269vw
}

@media screen and (min-width: 670px) {
    .form__btn button {
        font-size: clamp(2.4rem, 100vw - (670px + 1400px)/2, 3rem)
    }
}

@media screen and (min-width: 1920px) {
    .form__btn button {
        font-size: 3rem
    }
}

@media screen and (min-width: 670px) {
    .form__btn button {
        background-position: center right 25px;
        background-size: 56px 11px
    }
}

.form__btn button:hover {
    filter: brightness(0.7)
}

.form__btn--next button {
    border: none;
    display: flex;
    align-items: center;
    justify-content: center;
    width: inherit;
    height: inherit;
    letter-spacing: .3rem;
    color: #fff;
    background-image: url(/img/btn_icon1.svg);
    background-size: 2.9850746269vw 0.8955223881vw;
    background-repeat: no-repeat;
    background-position: center right 2.2388059701vw;
    background-color: #ef4b0e;
    transition: .5s;
    font-weight: 600;
    font-size: 2.9850746269vw
}

@media screen and (min-width: 670px) {
    .form__btn--next button {
        font-size: clamp(2.4rem, 100vw - (670px + 1400px)/2, 3rem)
    }
}

@media screen and (min-width: 1920px) {
    .form__btn--next button {
        font-size: 3rem
    }
}

@media screen and (min-width: 670px) {
    .form__btn--next button {
        background-position: center right 25px;
        background-size: 56px 11px
    }
}

.form__btn--next button:hover {
    filter: brightness(0.7)
}

.form__btn--prev button {
    display: flex;
    align-items: center;
    justify-content: center;
    width: inherit;
    height: inherit;
    letter-spacing: .3rem;
    color: #ef4b0e;
    background-size: 2.9850746269vw 0.8955223881vw;
    background-repeat: no-repeat;
    background-position: center right 2.2388059701vw;
    background-color: #fff;
    background-image: url(/img/btn_icon1.svg);
    transition: .5s;
    font-weight: 600;
    font-size: 2.9850746269vw
}

@media screen and (min-width: 670px) {
    .form__btn--prev button {
        font-size: clamp(2.4rem, 100vw - (670px + 1400px)/2, 3rem)
    }
}

@media screen and (min-width: 1920px) {
    .form__btn--prev button {
        font-size: 3rem
    }
}

@media screen and (min-width: 670px) {
    .form__btn--prev button {
        background-position: center right 25px;
        background-size: 56px 11px
    }
}

.form__btn--prev button:hover {
    filter: brightness(0.7)
}