@charset "UTF-8";

.no-spin::-webkit-inner-spin-button,
.no-spin::-webkit-outer-spin-button {
    -webkit-appearance: none;
    margin: 0;
    -moz-appearance:textfield;
}

.swiper-container {
    margin-left: auto;
    margin-right: auto;
    position: relative;
    overflow: hidden;
    list-style: none;
    padding: 0;
    z-index: 1
}
.swiper-container-no-flexbox .swiper-slide {
    float: left
}
.swiper-container-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-container-android .swiper-slide,
.swiper-wrapper {
    transform: translate3d(0, 0, 0)
}
.swiper-container-multirow > .swiper-wrapper {
    flex-wrap: wrap
}
.swiper-container-free-mode > .swiper-wrapper {
    transition-timing-function: ease-out;
    margin: 0 auto
}
.swiper-slide {
    flex-shrink: 0;
    width: 100%;
    height: 100%;
    position: relative;
    transition-property: transform
}
.swiper-slide-invisible-blank {
    visibility: hidden
}
.swiper-container-autoheight,
.swiper-container-autoheight .swiper-slide {
    height: auto
}
.swiper-container-autoheight .swiper-wrapper {
    align-items: flex-start;
    transition-property: transform, height
}
.swiper-container-3d {
    perspective: 1200px
}
.swiper-container-3d .swiper-wrapper,
.swiper-container-3d .swiper-slide,
.swiper-container-3d .swiper-slide-shadow-left,
.swiper-container-3d .swiper-slide-shadow-right,
.swiper-container-3d .swiper-slide-shadow-top,
.swiper-container-3d .swiper-slide-shadow-bottom,
.swiper-container-3d .swiper-cube-shadow {
    transform-style: preserve-3d
}
.swiper-container-3d .swiper-slide-shadow-left,
.swiper-container-3d .swiper-slide-shadow-right,
.swiper-container-3d .swiper-slide-shadow-top,
.swiper-container-3d .swiper-slide-shadow-bottom {
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    pointer-events: none;
    z-index: 10
}
.swiper-container-3d .swiper-slide-shadow-left {
    background-image: linear-gradient(to left,rgba(0,0,0,.5),transparent)
}
.swiper-container-3d .swiper-slide-shadow-right {
    background-image: linear-gradient(to right,rgba(0,0,0,.5),transparent)
}
.swiper-container-3d .swiper-slide-shadow-top {
    background-image: linear-gradient(to top,rgba(0,0,0,.5),transparent)
}
.swiper-container-3d .swiper-slide-shadow-bottom {
    background-image: linear-gradient(to bottom,rgba(0,0,0,.5),transparent)
}
.swiper-container-wp8-horizontal,
.swiper-container-wp8-horizontal > .swiper-wrapper {
    touch-action: pan-y
}
.swiper-container-wp8-vertical,
.swiper-container-wp8-vertical > .swiper-wrapper {
    touch-action: pan-x
}
.swiper-button-prev.swiper-button-disabled,
.swiper-button-next.swiper-button-disabled {
    opacity: .35;
    cursor: auto;
    pointer-events: none
}
.swiper-button-lock {
    display: none
}
.swiper-pagination {
    position: absolute;
    text-align: center;
    transition: 0.3s opacity;
    transform: translate3d(0, 0, 0);
    z-index: 10
}
.swiper-pagination.swiper-pagination-hidden {
    opacity: 0
}
.swiper-pagination-fraction,
.swiper-pagination-custom,
.swiper-container-horizontal > .swiper-pagination-bullets {
    bottom: 10px;
    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: 8px;
    height: 8px;
    display: inline-block;
    border-radius: 100%;
    background: #000;
    opacity: .2
}
button.swiper-pagination-bullet {
    border: none;
    margin: 0;
    padding: 0;
    box-shadow: none;
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none
}
.swiper-pagination-clickable .swiper-pagination-bullet {
    cursor: pointer
}
.swiper-pagination-bullet-active {
    opacity: 1;
    background: #007aff
}
.swiper-container-vertical > .swiper-pagination-bullets {
    right: 10px;
    top: 50%;
    transform: translate3d(0, -50%, 0)
}
.swiper-container-vertical > .swiper-pagination-bullets .swiper-pagination-bullet {
    margin: 6px 0;
    display: block
}
.swiper-container-vertical > .swiper-pagination-bullets.swiper-pagination-bullets-dynamic {
    top: 50%;
    transform: translateY(-50%);
    width: 8px
}
.swiper-container-vertical > .swiper-pagination-bullets.swiper-pagination-bullets-dynamic .swiper-pagination-bullet {
    display: inline-block;
    transition: 0.2s top, 0.2s -webkit-transform;
    transition: 0.2s transform, 0.2s top;
    transition: 0.2s transform, 0.2s top, 0.2s -webkit-transform
}
.swiper-container-horizontal > .swiper-pagination-bullets .swiper-pagination-bullet {
    margin: 0 4px
}
.swiper-container-horizontal > .swiper-pagination-bullets.swiper-pagination-bullets-dynamic {
    left: 50%;
    transform: translateX(-50%);
    white-space: nowrap
}
.swiper-container-horizontal > .swiper-pagination-bullets.swiper-pagination-bullets-dynamic .swiper-pagination-bullet {
    transition: 0.2s left, 0.2s -webkit-transform;
    transition: 0.2s transform, 0.2s left;
    transition: 0.2s transform, 0.2s left, 0.2s -webkit-transform
}
.swiper-container-horizontal.swiper-container-rtl > .swiper-pagination-bullets-dynamic .swiper-pagination-bullet {
    transition: 0.2s right, 0.2s -webkit-transform;
    transition: 0.2s transform, 0.2s right;
    transition: 0.2s transform, 0.2s right, 0.2s -webkit-transform
}
.swiper-pagination-progressbar {
    background: rgba(0, 0, 0, .25);
    position: absolute
}
.swiper-pagination-progressbar .swiper-pagination-progressbar-fill {
    background: #007aff;
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    transform: scale(0);
    transform-origin: left top
}
.swiper-container-rtl .swiper-pagination-progressbar .swiper-pagination-progressbar-fill {
    transform-origin: right top
}
.swiper-container-horizontal > .swiper-pagination-progressbar,
.swiper-container-vertical > .swiper-pagination-progressbar.swiper-pagination-progressbar-opposite {
    width: 100%;
    height: 4px;
    left: 0;
    top: 0
}
.swiper-container-vertical > .swiper-pagination-progressbar,
.swiper-container-horizontal > .swiper-pagination-progressbar.swiper-pagination-progressbar-opposite {
    width: 4px;
    height: 100%;
    left: 0;
    top: 0
}
.swiper-pagination-white .swiper-pagination-bullet-active {
    background: #fff
}
.swiper-pagination-progressbar.swiper-pagination-white {
    background: rgba(255, 255, 255, .25)
}
.swiper-pagination-progressbar.swiper-pagination-white .swiper-pagination-progressbar-fill {
    background: #fff
}
.swiper-pagination-black .swiper-pagination-bullet-active {
    background: #000
}
.swiper-pagination-progressbar.swiper-pagination-black {
    background: rgba(0, 0, 0, .25)
}
.swiper-pagination-progressbar.swiper-pagination-black .swiper-pagination-progressbar-fill {
    background: #000
}
.swiper-pagination-lock {
    display: none
}
.swiper-scrollbar {
    border-radius: 10px;
    position: relative;
    -ms-touch-action: none;
    background: rgba(0, 0, 0, .1)
}
.swiper-container-horizontal > .swiper-scrollbar {
    position: absolute;
    left: 1%;
    bottom: 3px;
    z-index: 50;
    height: 5px;
    width: 98%
}
.swiper-container-vertical > .swiper-scrollbar {
    position: absolute;
    right: 3px;
    top: 1%;
    z-index: 50;
    width: 5px;
    height: 98%
}
.swiper-scrollbar-drag {
    height: 100%;
    width: 100%;
    position: relative;
    background: rgba(0, 0, 0, .5);
    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 > img,
.swiper-zoom-container>svg,
.swiper-zoom-container > canvas {
    max-width: 100%;
    max-height: 100%;
    -o-object-fit: contain;
    object-fit: contain
}
.swiper-slide-zoomed {
    cursor: move
}
.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%;
    -webkit-animation: swiper-preloader-spin 1s steps(12, end) infinite;
    animation: swiper-preloader-spin 1s steps(12, end) infinite
}
.swiper-lazy-preloader:after {
    display: block;
    content: "";
    width: 100%;
    height: 100%;
    background-image: url("data:image/svg+xml;charset=utf-8,%3Csvg%20viewBox%3D'0%200%20120%20120'%20xmlns%3D'http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg'%20xmlns%3Axlink%3D'http%3A%2F%2Fwww.w3.org%2F1999%2Fxlink'%3E%3Cdefs%3E%3Cline%20id%3D'l'%20x1%3D'60'%20x2%3D'60'%20y1%3D'7'%20y2%3D'27'%20stroke%3D'%236c6c6c'%20stroke-width%3D'11'%20stroke-linecap%3D'round'%2F%3E%3C%2Fdefs%3E%3Cg%3E%3Cuse%20xlink%3Ahref%3D'%23l'%20opacity%3D'.27'%2F%3E%3Cuse%20xlink%3Ahref%3D'%23l'%20opacity%3D'.27'%20transform%3D'rotate(30%2060%2C60)'%2F%3E%3Cuse%20xlink%3Ahref%3D'%23l'%20opacity%3D'.27'%20transform%3D'rotate(60%2060%2C60)'%2F%3E%3Cuse%20xlink%3Ahref%3D'%23l'%20opacity%3D'.27'%20transform%3D'rotate(90%2060%2C60)'%2F%3E%3Cuse%20xlink%3Ahref%3D'%23l'%20opacity%3D'.27'%20transform%3D'rotate(120%2060%2C60)'%2F%3E%3Cuse%20xlink%3Ahref%3D'%23l'%20opacity%3D'.27'%20transform%3D'rotate(150%2060%2C60)'%2F%3E%3Cuse%20xlink%3Ahref%3D'%23l'%20opacity%3D'.37'%20transform%3D'rotate(180%2060%2C60)'%2F%3E%3Cuse%20xlink%3Ahref%3D'%23l'%20opacity%3D'.46'%20transform%3D'rotate(210%2060%2C60)'%2F%3E%3Cuse%20xlink%3Ahref%3D'%23l'%20opacity%3D'.56'%20transform%3D'rotate(240%2060%2C60)'%2F%3E%3Cuse%20xlink%3Ahref%3D'%23l'%20opacity%3D'.66'%20transform%3D'rotate(270%2060%2C60)'%2F%3E%3Cuse%20xlink%3Ahref%3D'%23l'%20opacity%3D'.75'%20transform%3D'rotate(300%2060%2C60)'%2F%3E%3Cuse%20xlink%3Ahref%3D'%23l'%20opacity%3D'.85'%20transform%3D'rotate(330%2060%2C60)'%2F%3E%3C%2Fg%3E%3C%2Fsvg%3E");
    background-position: 50%;
    background-size: 100%;
    background-repeat: no-repeat
}
.swiper-lazy-preloader-white:after {
    background-image: url("data:image/svg+xml;charset=utf-8,%3Csvg%20viewBox%3D'0%200%20120%20120'%20xmlns%3D'http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg'%20xmlns%3Axlink%3D'http%3A%2F%2Fwww.w3.org%2F1999%2Fxlink'%3E%3Cdefs%3E%3Cline%20id%3D'l'%20x1%3D'60'%20x2%3D'60'%20y1%3D'7'%20y2%3D'27'%20stroke%3D'%23fff'%20stroke-width%3D'11'%20stroke-linecap%3D'round'%2F%3E%3C%2Fdefs%3E%3Cg%3E%3Cuse%20xlink%3Ahref%3D'%23l'%20opacity%3D'.27'%2F%3E%3Cuse%20xlink%3Ahref%3D'%23l'%20opacity%3D'.27'%20transform%3D'rotate(30%2060%2C60)'%2F%3E%3Cuse%20xlink%3Ahref%3D'%23l'%20opacity%3D'.27'%20transform%3D'rotate(60%2060%2C60)'%2F%3E%3Cuse%20xlink%3Ahref%3D'%23l'%20opacity%3D'.27'%20transform%3D'rotate(90%2060%2C60)'%2F%3E%3Cuse%20xlink%3Ahref%3D'%23l'%20opacity%3D'.27'%20transform%3D'rotate(120%2060%2C60)'%2F%3E%3Cuse%20xlink%3Ahref%3D'%23l'%20opacity%3D'.27'%20transform%3D'rotate(150%2060%2C60)'%2F%3E%3Cuse%20xlink%3Ahref%3D'%23l'%20opacity%3D'.37'%20transform%3D'rotate(180%2060%2C60)'%2F%3E%3Cuse%20xlink%3Ahref%3D'%23l'%20opacity%3D'.46'%20transform%3D'rotate(210%2060%2C60)'%2F%3E%3Cuse%20xlink%3Ahref%3D'%23l'%20opacity%3D'.56'%20transform%3D'rotate(240%2060%2C60)'%2F%3E%3Cuse%20xlink%3Ahref%3D'%23l'%20opacity%3D'.66'%20transform%3D'rotate(270%2060%2C60)'%2F%3E%3Cuse%20xlink%3Ahref%3D'%23l'%20opacity%3D'.75'%20transform%3D'rotate(300%2060%2C60)'%2F%3E%3Cuse%20xlink%3Ahref%3D'%23l'%20opacity%3D'.85'%20transform%3D'rotate(330%2060%2C60)'%2F%3E%3C%2Fg%3E%3C%2Fsvg%3E")
}
@-webkit-keyframes swiper-preloader-spin {
    100% {
        transform: rotate(360deg)
    }
}
@keyframes swiper-preloader-spin {
    100% {
        transform: rotate(360deg)
    }
}
.swiper-container .swiper-notification {
    position: absolute;
    left: 0;
    top: 0;
    pointer-events: none;
    opacity: 0;
    z-index: -1000
}
.swiper-container-fade.swiper-container-free-mode .swiper-slide {
    transition-timing-function: ease-out
}
.swiper-container-fade .swiper-slide {
    pointer-events: none;
    transition-property: opacity
}
.swiper-container-fade .swiper-slide .swiper-slide {
    pointer-events: none
}
.swiper-container-fade .swiper-slide-active,
.swiper-container-fade .swiper-slide-active .swiper-slide-active {
    pointer-events: auto
}
.swiper-container-cube {
    overflow: visible
}
.swiper-container-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-container-cube .swiper-slide .swiper-slide {
    pointer-events: none
}
.swiper-container-cube.swiper-container-rtl .swiper-slide {
    transform-origin: 100% 0
}
.swiper-container-cube .swiper-slide-active,
.swiper-container-cube .swiper-slide-active .swiper-slide-active {
    pointer-events: auto
}
.swiper-container-cube .swiper-slide-active,
.swiper-container-cube .swiper-slide-next,
.swiper-container-cube .swiper-slide-prev,
.swiper-container-cube .swiper-slide-next+.swiper-slide {
    pointer-events: auto;
    visibility: visible
}
.swiper-container-cube .swiper-slide-shadow-top,
.swiper-container-cube .swiper-slide-shadow-bottom,
.swiper-container-cube .swiper-slide-shadow-left,
.swiper-container-cube .swiper-slide-shadow-right {
    z-index: 0;
    -webkit-backface-visibility: hidden;
    backface-visibility: hidden
}
.swiper-container-cube .swiper-cube-shadow {
    position: absolute;
    left: 0;
    bottom: 0;
    width: 100%;
    height: 100%;
    background: #000;
    opacity: .6;
    filter:blur(50px);
    z-index: 0
}
.swiper-container-flip {
    overflow: visible
}
.swiper-container-flip .swiper-slide {
    pointer-events: none;
    -webkit-backface-visibility: hidden;
    backface-visibility: hidden;
    z-index: 1
}
.swiper-container-flip .swiper-slide .swiper-slide {
    pointer-events: none
}
.swiper-container-flip .swiper-slide-active,
.swiper-container-flip .swiper-slide-active .swiper-slide-active {
    pointer-events: auto
}
.swiper-container-flip .swiper-slide-shadow-top,
.swiper-container-flip .swiper-slide-shadow-bottom,
.swiper-container-flip .swiper-slide-shadow-left,
.swiper-container-flip .swiper-slide-shadow-right {
    z-index: 0;
    -webkit-backface-visibility: hidden;
    backface-visibility: hidden
}
.swiper-container-coverflow .swiper-wrapper {
    -ms-perspective: 1200px
}
:root {
    -ms-overflow-style: -ms-autohiding-scrollbar;
    overflow-y: scroll;
    -webkit-text-size-adjust: 100%
}
audio:not([controls]) {
    display: none
}
button {
    overflow: visible
}
details {
    display: block
}
input[type=number] {
/*    width: auto */
}
input[type=search] {
    -webkit-appearance: textfield
}
input[type=search]::-webkit-search-cancel-button,
input[type=search]::-webkit-search-decoration {
    -webkit-appearance: none
}
main {
    display: block
}
summary {
    display: block
}
pre {
    overflow: auto
}
progress {
    display: inline-block
}
small {
    font-size: 75%
}
template {
    display: none
}
textarea {
    overflow: auto
}
[hidden] {
    display: none
}
*,:before,:after {
    box-sizing: inherit
}
* {
    font-size: inherit;
    line-height: inherit
}
:before,:after {
    text-decoration: inherit;
    vertical-align: inherit
}
*,:before,:after {
    border-style: solid;
    border-width: 0
}
* {
    margin: 0;
    padding: 0
}
:root {
    box-sizing: border-box;
    cursor: default;
    font: 100% / 1.5 sans-serif;
    text-rendering: optimizeLegibility
}
html {
    background-color: #FFF;
    color: #000
}
audio,
canvas,
iframe,
img,
svg,
video {
    vertical-align: middle
}
button,
input,
select,
textarea {
    background-color: transparent
}
button,
input,
select,
textarea {
    color: inherit;
    font-family: inherit;
    font-style: inherit;
    font-weight: inherit
}
button,
[type=button],
[type=date],
[type=datetime],
[type=datetime-local],
[type=email],
[type=month],
[type=number],
[type=password],
[type=reset],
[type=search],
[type=submit],
[type=tel],
[type=text],
[type=time],
[type=url],
[type=week],
select,
textarea {
    min-height: 1.5em
}
code,
kbd,
pre,
samp {
    font-family: monospace, monospace
}
nav ol,
nav ul {
    list-style: none
}
select {
    -moz-appearance: none;
    -webkit-appearance: none
}
select::-ms-expand {
    display: none
}
select::-ms-value {
    color: currentColor
}
table {
    border-collapse: collapse;
    border-spacing: 0
}
textarea {
    resize: vertical
}
::-moz-selection {
    background-color: #b3d4fc;
    color: #4c2b03;
    text-shadow: none
}
::selection {
    background-color: #b3d4fc;
    color: #4c2b03;
    text-shadow: none
}
[aria-busy=true] {
    cursor: progress
}
[aria-controls] {
    cursor: pointer
}
[aria-disabled] {
    cursor: default
}
[hidden][aria-hidden=false] {
    clip: rect(0 0 0 0);
    display: inherit;
    position: absolute
}
[hidden][aria-hidden=false]:focus {
    clip: auto
}
@font-face {
    font-family: Noto Sans JP;
    font-display: swap;
    src: local(""), url('../fonts/noto-sans-jp-v40-japanese-regular.woff2') format("woff2"), url('../fonts/noto-sans-jp-v40-japanese-regular.woff') format("woff")
}
@font-face {
    font-family: Noto Sans JP;
    font-weight: 700;
    font-display: swap;
    src: local(""), url('../fonts/noto-sans-jp-v40-japanese-700.woff2') format("woff2"), url('../fonts/noto-sans-jp-v40-japanese-700.woff') format("woff")
}
html {
    width: 100%;
    height: 100%;
    -webkit-font-smoothing: subpixel-antialiased;
    -moz-osx-font-smoothing: auto;
    -webkit-tap-highlight-color: transparent
}
body {
    background-color: #FFF;
    color: #1f2a37;
    font-family: YakuHanJP_Noto, Noto Sans JP, sans-serif;
    font-size: 16px;
    font-weight: 400;
    line-height: 2;
    word-break: break-all;
    width: 100%;
    height: 100vh
}
@supports(-webkit-touch-callout:none) {
    body body {
        height: -webkit-fill-available
    }
}
@media(min-width:768px) and(max-width:999px) {
    body {
        font-size: 1.6vw
    }
}
@media(max-width:767px) {
    body {
        font-size: 3.4vw
    }
}
*,:before,:after {
    box-sizing: border-box
}
.l-wrapper {
    display: flex;
    flex-direction: column;
    min-height: 100vh
}
.l-block--lg {
    padding: 5em 0
}
.l-block--lg-t {
    padding-top: 5em
}
.l-block--lg-b {
    padding-bottom: 5em
}
.l-block--md {
    padding: 2.5em 0
}
.l-block--md-t {
    padding-top: 2.5em
}
.l-block--md-b {
    padding-bottom: 2.5em
}
.l-block--sm {
    padding: 1.25em 0
}
.l-block--sm-t {
    padding-top: 1.25em
}
.l-block--sm-b {
    padding-bottom: 1.25em
}
.l-block--center {
    text-align: center
}
.l-block--bg {
    margin-top: 5em;
    background: #f6f6f6
}
.l-block--narrow {
    width: 80%;
    margin: 0 auto
}
@media(max-width:767px) {
    .l-block--narrow {
        width: 100%
    }
}
.l-header {
    width: 100%;
    background: #fff;
    position: fixed;
    top: 0;
    left: 0;
    border-bottom: 1px solid #ccc;
    z-index: 999
}
.l-inner {
    /*max-width: 1056px;*/
    margin: 0 auto;
    padding: 0 1rem
}
.l-main {
    margin-top: 80px;
    padding-top: 3rem;
    padding-bottom: 3rem
}
.l-footer {
    margin-top: auto
}
.c-btn {
    position: relative;
    padding: 0.5em 2.5em;
    border-radius: 2em;
    text-decoration: none;
    background: #00316c;
    color: #fff;
    cursor: pointer;
    white-space: nowrap
}
.c-btn--shinsei {
    background: #999910
}
.c-btn--shouninkanri {
    background: #108499
}
.c-btn--lg {
    padding: 0.5em 5em
}
.c-btn--small {
    padding: 0.5em 1em;
    font-size: 0.75em
}
.c-btn--primary {
    background-color: #00316c
}
.c-btn--returnTop {
    font-size: 0.875em
}
.c-btn--hasIcon:before {
    display: inline-block;
    width: 0.75em;
    margin-right: 0.5em
}
.c-btn--edit {
    background: #406591
}
.c-btn--edit:before {
    content: url("../images/icon-edit.svg")
}
.c-btn--delete {
    background: #406591
}
.c-btn--delete:before {
    content: url("../images/icon-x.svg")
}
.c-btn--plus {
    background: #406591
}
.c-btn--plus:before {
    content: url('../images/icon-plus.svg')
}
.c-btn--upload:before {
    width: 1em;
    content: url('../images/icon-upload.svg')
}
.c-btn--download:before {
    width: 1em;
    content: url('../images/icon-download.svg')
}
.c-button {
    min-width: 192px;
    padding: 0.5em;
    border-radius: 3px;
    background: #4d6f98;
    color: #FFF;
    cursor: pointer
}
@media(max-width:767px) {
    .c-button {
        min-width: 160px;
        padding: 1em 0.5em
    }
}
.c-button--wide {
    width: 100%
}
.c-button--submit {
    background: #d00c3c
}
.c-button--reset {
    background: #636f7e
}
.c-button--kinmukanri {
    background: #641099
}
.c-buttonWrap {
    padding-top: 1rem;
    text-align: center
}
.c-buttonWrap--multi {
    display: flex;
    justify-content: space-between
}
.c-buttonWrap--multi .c-button:not(:first-child) {
    margin-left: 0.5em
}
input[type=text],
input[type=date],
input[type=time],
input[type=email],
input[type=password],
input[type=search],
input[type=number],
input[type=tel],
select {
    padding: 0 0.5em;
    border: 1px solid #b3c1d3
}
@media(max-width:767px) {
    input[type=text],
    input[type=date],
    input[type=time],
    input[type=email],
    input[type=password],
    input[type=search],
    input[type=number],
    input[type=tel],
    select {
        padding: 0.5em
        border: 1px solid #b3c1d3
    }
}
textarea {
    width: 100%;
    padding: 0 0.5em;
    border: 1px solid #b3c1d3
}
.c-input {
    border: 1px solid #b3c1d3
}
.c-input--wide {
    width: 100%
}
.c-input--md {
    width: 50%
}
.c-input--sm {
    width: 30%
}
.c-input--3em {
    font-size: 14px;
    display: inline-block;
    width: 3.0em;
    max-width: 100%;
    padding: 0.2em;
    border: 1px solid #b3c1d3
    box-sizing: border-box;
    margin: 0.2em 0;
}
.c-input--16em {
    font-size: 14px;
    display: inline-block;
    width: 12.0em;
    padding: 0.2em;
    border: 1px solid #b3c1d3
    box-sizing: border-box;
    margin: 0.2em 0;
}
.c-input--number {
    font-size: 14px;
    display: inline-block;
    width: 3.0em;
    padding: 0.2em;
    border: 1px solid #b3c1d3
    box-sizing: border-box;
    margin: 0.2em 0;
}
.c-checkbox {
    margin-right: 0.25em
}
.c-form-group:not(:first-child) {
    margin-top: 3em
}
@media(max-width:767px) {
    .c-form-group {
        width: 100%
    }
}
.c-form-group__title {
    font-weight: 700;
    margin-bottom: 0.5em;
    text-align: left
}
.c-form-group__body {
    display: flex;
    align-items: center
}
.c-form-group__item {
    margin-right: 1em
}
.c-form-group__item:not(:first-child) {
    margin-left: 1em
}
.c-form-group--center {
    display: flex;
    flex-direction: column;
    align-items: center
}
.c-form-group-box {
    display: flex
}
.c-form-group-box:not(:first-child) {
    margin-left: 1em
}
.c-form-group-box__wrap {
    display: flex
}
.c-select {
    padding-right: 2em;
    background: #FFF;
    background-image: url('../images/icon-angle-down.svg');
    background-repeat: no-repeat;
    background-size: 1em auto;
    background-position: right 3px center
}
.c-select--time {
    background-image: url('../images/icon-time.svg')
}
.p-field-checkbox {
    display: flex;
    align-items: center
}
.p-field-checkbox:not(:last-child) {
    margin-right: 1em
}
.js-datepicker {
    background-image: url('../images/Icon-calendar.svg');
    background-repeat: no-repeat;
    background-size: 1em;
    background-position: center right 3px
}
.wm-search__row {
    display: flex
}
.wm-search__row:not(:first-child) {
    margin-top: 1em
}
.wm-search__key {
    margin-right: 1em
}
.wm-search__value {
    display: flex
}
.c-heading {
    margin-bottom: 1em
}
.c-heading--primary {
    font-size: 2em;
    font-weight: 700;
    line-height: 1.5;
    color: #00316c;
    text-align: center
}
.c-message {
    font-size: 1.25em
}
.c-message--large {
    font-size: 2em;
    font-weight: 700;
    line-height: 1.5;
    color: #00316c;
    text-align: center
}
.swiper-button-next,
.swiper-button-prev {
    position: absolute;
    width: 2em;
    height: 2em;
    cursor: pointer;
    z-index: 999
}
.swiper-button-next {
    right: 0;
    background-image: url('../images/icon-arrow-next.svg');
    background-size: cover
}
.swiper-button-prev {
    left: 0;
    background-image: url('../images/icon-arrow-prev.svg');
    background-size: cover
}
.button-next {
    position: absolute;
    width: 2em;
    height: 2em;
    cursor: pointer;
/*    z-index: 999;*/
    right: 30%;
    background-image: url('../images/icon-arrow-next.svg');
    background-size: cover
}
.button-prev {
    position: absolute;
    width: 2em;
    height: 2em;
    cursor: pointer;
/*    z-index: 999;*/
    left: 30%;
    background-image: url('../images/icon-arrow-prev.svg');
    background-size: cover
}
.c-table {
    width: 100%;
    border: 1px solid
}
.c-table.-scroll {
    white-space: nowrap
}
.c-table th {
    padding: 0.5em;
    border-bottom: 2px solid;
    text-align: center
}
.c-table tr:nth-child(even) {
    background: #fff
}
.c-table tr:nth-child(odd) {
    background: #e9edf2
}
.c-table td {
    padding: 0.5em;
    text-align: center
}
.c-table--02 th {
    border-bottom: none;
    border-right: 1px solid;
    white-space: nowrap
}
.c-table--02 td {
    text-align: left;
    border-left: 4px double
}
/**
.c-table.-wmDetail tr:last-child {
    background: #00316c;
    color: #FFF;
    font-weight: 700
}
**/
.c-table.-narrow {
    width: auto
}
.c-table-wm02 {
    width: 100%;
    border: 1px solid
}
.c-table-wm02 th.-title {
    font-weight: 700;
    background: #dbe2ea;
    padding: .5em;
}
.c-table-wm02 td {
    padding: 0.5em
}
.c-table-wm02 td.-title {
    font-weight: 700;
    background: #dbe2ea
}
.c-table-wm02 td.-border {
    border-right: 4px double
}
.color-saturday {
    color: #0874c2
}
.color-sunday {
    color: #fc2e32
}
.scrollWrapper {
    overflow-x: auto
}
.not-recognized {
    color: #003eff
}
.p-header {
    position: relative;
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 1rem 0
}
.p-header__brand {
    /*width: 30%;*/
    display: flex;
    align-items: center;
    color: #00316c;
    text-decoration: none
}
@media(min-width:768px) {
    .p-header__brand {
        /*width: 30%*/
    }
}
@media(max-width:767px) {
    .p-header__brand {
        width: 40%
    }
}
.p-header__brand-logo {
    /*width: 40%;*/
    width: 120px;
    margin-right: 1rem
}
.p-header__brand-logo img {
    width: 100%;
    height: auto;
}
@media(max-width:767px) {
    .p-header__brand-logo {
        width: 100%
    }
}
.p-header__brand-text {
    font-weight: 700
}
@media(max-width:767px) {
    .p-header__brand-text {
/*        display: none;*/
        font-size: 10px;
        position: absolute;
        bottom: -5px;
    }
}
.p-header__date {
    position: relative;
    left: -3em;
    font-weight: 700;
    color: #00316c
}
@media(min-width:768px) {
    .p-header__date {
        font-size: 1.125em
    }
}
.p-gnav {
    padding: 3em 0;
    visibility: hidden;
    opacity: 0;
    transition: 0.3s;
    position: absolute;
    width: 100%;
    overflow-y: auto;
    background: #f6f6f6;
    border-bottom: 1px solid #ccc
}
@media(max-width:767px) {
    .p-gnav {
        height: calc(100vh - 62px)
    }
}
.p-gnav.is-active {
    visibility: visible;
    opacity: 1
}
.p-gnav__item > a {
    text-decoration: none;
    color: inherit
}
.p-menuBtn {
    position: absolute;
    display: inline-block;
    right: 0;
    width: 2em;
    height: 2em;
    text-align: center;
    cursor: pointer
}
.p-menuBtn__line {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translateX(-50%) translateY(-50%);
    display: block;
    width: 2rem;
    height: 1px;
    background: #00316c;
    transition: 0.3s
}
.p-menuBtn__line:nth-child(1) {
    margin-top: -8px
}
.p-menuBtn__line:nth-child(3) {
    margin-top: 8px
}
.p-menuBtn.is-active .p-menuBtn__line:nth-child(1) {
    transform: rotate(135deg) translateX(-50%) translateY(-50%);
    transform-origin: 0;
    margin-top: 0
}
.p-menuBtn.is-active .p-menuBtn__line:nth-child(2) {
    opacity: 0
}
.p-menuBtn.is-active .p-menuBtn__line:nth-child(3) {
    transform: rotate(-135deg) translateX(-50%) translateY(-50%);
    transform-origin: 0;
    margin-top: 0
}
.p-footer {
    padding: 1em 0;
    font-weight: 700;
    background: #8098b6;
    color: #FFF
}
.p-footer__copyright {
    text-align: center
}
.p-pageHeader__inner {
    /*max-width: 1056px;*/
    margin: 0 auto;
    padding: 0 1rem
}
.p-pageHeader__title {
    font-size: 1.5em;
    font-weight: 700;
    line-height: 1.5;
    letter-spacing: 0.2em;
    color: #00316c;
    text-align: center;
    border: 1px solid;
    padding: 1em;
    background: #e6eaf0
}
.p-pageBody {
    padding-top: 3rem
}
.p-pageBody__inner {
    /*max-width: 1056px;*/
    margin: 0 auto;
    padding: 0 1rem
}
.p-pagination {
    display: flex;
    align-items: center;
    margin-top: 2rem;
    font-size: 0.85em
}
.p-pagination__list {
    display: flex;
    align-items: center;
    margin-left: 1em
}
.p-pagination a {
    margin-left: 0.5em
}
.p-pagination__number {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 1.75em;
    height: 1.75em;
    text-decoration: none;
    border: 1px solid #406591;
    color: #00316c;
    line-height: 1
}
.p-pagination__number.is-current {
    background: #a0b2c8;
    color: #00316c;
    font-weight: 700
}
.p-pagination__prev {
    display: flex;
    align-items: center
}
.p-pagination__prev > img {
    width: 1.75em;
    height: auto
}
.p-pagination__next {
    display: flex;
    align-items: center
}
.p-pagination__next > img {
    width: 1.75em;
    height: auto
}
.p-returnTop {
    margin-top: 5rem;
    text-align: center
}
.p-search {
    text-align: center
}
.p-search__title {
    margin-bottom: 1em;
    font-weight: 700
}
.p-search__btn {
    position: relative;
    padding: 0 1em;
    background-color: #00316c;
    border: 1px solid #00316c;
    color: #FFF;
    white-space: nowrap;
}
.p-search__body {
    display: flex;
    justify-content: center
}
.p-section__inner {
    /*max-width: 1056px;*/
    margin: 0 auto;
    padding: 0 1rem
}
.p-section__inner--center {
    display: flex;
    flex-direction: column;
    align-items: center
}
.login-form__wrap {
    width: 30%;
    margin: auto
}
@media(max-width:767px) {
    .login-form__wrap {
        width: 100%
    }
}
.login-form__wrap--md {
    width: 50%
}
.login-form__list {
    list-style-type: none
}
.login-form__item {
    margin-bottom: 1em
}
.login-form__text {
    font-size: 0.875em
}
.top-head {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    margin-bottom: 2rem;
    text-align: center
}
.top-head__col {
    width: 49.2%;
    margin-right: 1.6%
}
.top-head__col:nth-of-type(2n) {
    margin-right: 0
}
.top-head__col:nth-of-type(n + 3) {
    margin-top: 1.6%
}
.top-head__profile {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    font-weight: 700;
    line-height: 1.5
}
.top-head__profile-id > ._head {
    margin-right: 0.5em
}
.top-head__profile-name {
    font-size: 2em
}
.top-head__time {
    padding: 0.25em 0;
    font-size: 2.5em;
    font-weight: 700;
    background: #ccd6e2
}
.top-head__time-small {
    font-size: 0.75em
}
.top-menu__wrap {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between
}
.top-menu__col {
    width: 24.85%;
    margin-right: .2%
}
.top-menu__col:nth-of-type(4n) {
    margin-right: 0
}
.top-menu__col:nth-of-type(n + 5) {
    margin-top: .2%
}
@media(max-width:767px) {
    .top-menu__col {
        width: 100%;
        margin-right: 0
    }
    .top-menu__col:nth-of-type(1n) {
        margin-right: 0
    }
    .top-menu__col:nth-of-type(n + 2) {
        margin-top: 0
    }
}
@media(max-width:767px) {
    .top-menu__col:not(:last-child) {
        margin-bottom: 2rem
    }
}
.top-menu__box {
    padding: 5%;
    transition: 0.3s
}
.top-menu__box--dakoku {
    border-color: #109936;
    background-color: rgba(16, 153, 54, .1)
}
.top-menu__box--shinsei {
    border-color: #999910;
    background-color: rgba(153, 153, 16, .1)
}
.top-menu__box--kinmukanri {
    border-color: #641099;
    background-color: rgba(100, 16, 153, .1)
}
.top-menu__box--shouninkanri {
    border-color: #108499;
    background-color: rgba(16, 132, 153, .1)
}
.top-menu__box--tourokukanri {
    border-color: #991b10;
    background-color: rgba(153, 27, 16, .1)
}
.top-menu__box-title {
    margin-bottom: 1em;
    border-bottom: 1px solid;
    font-size: 1.125rem;
    text-align: center
}
@media(min-width:768px) and(max-width:999px) {
    .top-menu__box-title {
        font-size: 1.8vw
    }
}
.top-menu__btns {
    list-style: none
}
.top-menu__btn {
    display: block;
    width: 100%;
    padding: 0.5em;
    border-radius: 3px;
    background: #bbb;
    color: #FFF;
    text-align: center;
    font-weight: 700;
    margin-bottom: 1em;
    cursor: pointer
}
.top-menu__btn:hover {
    opacity: .7
}
.top-menu__btn:not(:first-child) {
    margin-top: 2px
}
@media(min-width:768px) and(max-width:999px) {
    .top-menu__btn {
        font-size: 1.4vw
    }
}
.top-menu__btn--large {
    font-size: 1.5em
}
.top-menu__btn--dakoku {
    background: #109936
}
.top-menu__btn--shinsei {
    background: #999910
}
.top-menu__btn--kinmukanri {
    background: #641099
}
.top-menu__btn--tourokukanri {
    background: #991b10
}
.top-menu__btn--shouninkanri {
    background: #108499
}
.top-menu__footer {
    padding-top: 5em;
    text-align: center
}
.today-situation__day {
    margin-bottom: 1em;
    font-size: 1em;
    font-weight: 700
}
.u-mb-1 {
    margin-bottom: 1em
}
.u-mb-2 {
    margin-bottom: 2em
}
.u-noticeO {
    color: #ee7800
}
.u-noticeR {
    color: #e60033
}
@media(min-width:768px) {
    .u-sp {
        display: none
    }
}

/* 20220603 */
.scrollContainer {
    overflow: auto;
    width: 100%;
    height: 500px;
    border: 1px solid;
}
.scrollContainer table {
    margin: 0;
    border-spacing: 0;
    border: none;
}
.scrollContainer td {
    white-space: nowrap;
    padding: 5px;
}
.scrollContainer th {
    white-space: nowrap;
    position: sticky;
    top: 0;
    left: 0;
    border: none;
}
.scrollContainer tr:first-child th {
    border-bottom: 2px solid;
    background: #FFF;
}
.scrollContainer tr:first-child th:first-child {
    z-index: 1;
}
.scrollContainer tr:nth-child(odd) {
    background: #FFF;
}
.scrollContainer tr:nth-child(odd) th {
    background: #FFF;
}
.scrollContainer tr:nth-child(even) {
    background: #dbe2ea;
}
.scrollContainer tr:nth-child(even) th {
    background: #dbe2ea;
}

@media print{
  body {
    font-family: 'メイリオ',Meiryo,'ヒラギノ角ゴ Pro W3','Hiragino Kaku Gothic Pro','ＭＳ Ｐゴシック',sans-serif!important;
    font-size: 5px;
    -webkit-print-color-adjust: exact;
    break-inside: avoid;
    line-height: 1.2;
  }
  .l-wrapper {
    min-height: auto;
  }
  .l-header {
    position: relative;
  }
  .l-main {
    margin-top: 0;
  }
  .p-pageBody__inner {
    max-width: 100%;
  }
  .scrollContainer {
    height: auto;
  }
  .scrollContainer td {
    padding: 0;
  }
  table th,td {
    padding: 0;
  }
  .p-menuBtn {
    display: none;
  }
  .p-header {
    padding: 0;
  }
  .p-header__brand {
    display: none;
  }
  .l-header {
    border: none
  }
  .l-main {
    padding-top: 0;
    padding-bottom: 0;
  }
  .p-pageHeader__inner {
    max-width: 100%;
  }
  .p-pageBody {
    padding-top: 0;
  }
  .today-situation__day {
    margin-bottom: 0;
  }
  .c-table th {
    padding: 0;
  }
  .c-table td {
    padding: 0;
  }
  .c-button {
    display: none;
  }
  .p-pageHeader__title {
    font-size: 1em;
    padding: 0;
  }
  input[type=text], input[type=date], input[type=time], input[type=email], input[type=password], input[type=search], select {
    border: none;
  }
  .l-block--sm-b {
    margin-bottom: 0;
  }
  .l-block--md-b {
    padding-bottom: 0;
  }
  .l-footer {
    display: none;
  }


}

/* 20220927  */
body {
  font-size: 14px;
}

.l-container {
  display: flex;
  -webkit-justify-content: space-between;
          justify-content: space-between;
}
.l-main {
  width: calc( 100% - 180px);
  /*margin-left: 180px;*/
  padding-top: 0;
}
.l-sidebar {
  position: sticky;
  width: 180px;
  min-height: 100vh;
  margin-top: 70px;
  background: #354053;
  padding: 1em;
}
.l-sidebar ul {
  list-style: none;
}

.p-side-nav__item {
  padding: 1em 0;
  border-bottom: 1px solid #293445;
}
.p-side-nav__ttl {
  font-size: 14px;
  color: #EEE;
}

.p-side-childNav__item > a {
  text-decoration: none;
  display: block;
  width: 100%;
  padding: .27em .5em;
  color: #b4bcc7;
  font-size: 13px;
  transition: .3s;
}
.p-side-childNav__item > a:hover {
  background-color: #9fabbd;
  color: #293445
}
.l-footer {
    width: 100%;
  /*margin-left: 180px;*/
}
.l-header {
  border-bottom: none;
}
.btn-wrapper {
    display: flex;
    justify-content: center;
    gap: 10px;
}

@media (max-width:  767px) {
  body {
    font-size: 13px;
  }
  .l-contianer {
    display: block;
  }
  .l-main {
    width: 100%;
    margin-left: inherit;
  }
  .l-sidebar {
    display: none;
  }
  .js-scrollable table td, .js-scrollable table th {
    white-space: nowrap;
  }
  .scroll-hint-icon {
    top: 15%;
  }
  .l-footer {
    margin-left: inherit;
  }

  .btn-wrapper {
    margin-top: 1em;
  }
  .btn-wrapper .c-buttonWrap {
    padding-top: 0;
  }

  .btn-wrapper .c-button {
    min-width: inherit;
  }

  .login-form__wrap--md {
    width: 100%;
  }
  input[type=text], input[type=date], input[type=time], input[type=email], input[type=password], input[type=search], input[type=number], input[type=tel], select {
    font-size: 16px;
    margin-bottom: 10px;
    background-color: #fff
  }

  input[type=time],
  input[type=date] {
    width: 6em;
    height: 2em;
  }
  .l-header {
    padding-bottom: 1em;
  }

}

.c-fx  {
  display: flex;
}
.c-fx--sb {
  -webkit-justify-content: space-between;
          justify-content: space-between;
}
.c-fx--sc {
  -webkit-justify-content: center;
          justify-content: center;
      gap: 20px;
}
.c-fx.c-fx--sc .button-prev,
.c-fx.c-fx--sc .button-next {
  position: relative;
  left: inheit;
  right: inherit:
}
.c-fx.c-fx--sb .button-prev,
.c-fx.c-fx--sb .button-next {
  position: relative;
  left: inheit;
  right: inherit:
}

.p-search__btn {
  /*padding: 0 .0.5em;*/
}


@media (min-width: 768px) {
  .p-menuBtn {
    display: none;
  }
  .l-main {
    position: relative;
    min-height: calc(100vh - 126px);
  }
  .c-buttonWrap.-poa {
    position: absolute;
    left: 50%;
    transform: translateX(-50%);
    bottom: 25px;
  }

  .c-buttonWrap.-b01 {
    margin-left: -207px
  }
  .c-buttonWrap.-b03 {
    margin-left: 207px
  }

  .c-buttonWrap.-b0101 {
    margin-left: -100px
  }
  .c-buttonWrap.-b0202 {
    margin-left: 100px
  }

}

.c-fx-fw {
    flex-wrap: wrap;
}

.c-fx-jc-c {
    justify-content: center;
}


@media (max-width: 767px) {
    .u-sp-w100 {
        width: 100%
    }
    .u-sp-tac {
        text-align: center
    }
}

#login.page .l-main {
    width: 100%;
}

span.scroll-hint-icon {
    display: none;
}
