@charset "UTF-8";

:root {
    --breakpoint-sm: 768px;
    --breakpoint-md: 1100px;
    --breakpoint-lg: 1400px;
    --padding-x-base: 2.4rem;
    --width-content-site: 121.6rem;
    --font-base: "Roboto", "Noto Sans JP", "Helvetica Neue", Arial, "Hiragino Kaku Gothic ProN", "Hiragino Sans", Meiryo, sans-serif;
    --font-inter: "Inter", var(--font-base);
    --font-weight-light: 300;
    --font-weight-regular: 400;
    --font-weight-medium: 500;
    --font-weight-semibold: 600;
    --font-weight-bold: 700;
    --font-weight-black: 900;
    --line-height-body: 1.8;
    --color-text-base: 0 0 0;
    --color-text-title: 33 39 42;
    --color-theme-primary: 2 119 209;
    --color-theme-primary-dark: 3, 87, 189;
    --color-theme-primary-light: 1, 154, 230;
    --color-theme-accent: 2 113 205;
    --color-bg-body: 255 255 255;
    --color-bg: 244 247 255;
    --color-table-border: 235 235 235;
    --gradient-theme-primary: rgb(var(--color-theme-primary-dark)), rgb(var(--color-theme-primary-light));
    --opacity-hover: .8;
    --easing-effect: cubic-bezier(0, .55, .45, 1)
}

.swiper {
    --swiper-pagination-color: white;
    --swiper-pagination-bottom: 3.6rem;
    --swiper-pagination-bullet-horizontal-gap: 2.5rem;
    --swiper-pagination-bullet-size: 1.6rem;
    --swiper-pagination-bullet-inactive-color: transparent;
    --swiper-pagination-bullet-inactive-opacity: 1
}

@media screen and (max-width: 768px) {
    .swiper {
        --swiper-pagination-bottom: 2rem;
        --swiper-pagination-bullet-horizontal-gap: 1.6rem;
        --swiper-pagination-bullet-size: 1rem
    }
}

.swiper-pagination-bullet {
    border: .1rem solid currentColor
}

html {
    box-sizing: border-box;
    -webkit-text-size-adjust: 100%;
    word-break: normal;
    -moz-tab-size: 4;
    tab-size: 4
}

*,
:before,
:after {
    background-repeat: no-repeat;
    box-sizing: inherit
}

:before,
:after {
    text-decoration: inherit;
    vertical-align: inherit
}

* {
    padding: 0;
    margin: 0
}

hr {
    overflow: visible;
    height: 0;
    color: inherit
}

details,
main {
    display: block
}

summary {
    display: list-item
}

small {
    font-size: 80%
}

[hidden] {
    display: none
}

abbr[title] {
    border-bottom: none;
    text-decoration: underline;
    text-decoration: underline dotted
}

a {
    background-color: transparent
}

a:active,
a:hover {
    outline-width: 0
}

code,
kbd,
pre,
samp {
    font-family: monospace, monospace
}

pre {
    font-size: 1em
}

b,
strong {
    font-weight: bolder
}

sub,
sup {
    font-size: 75%;
    line-height: 0;
    position: relative;
    vertical-align: baseline
}

sub {
    bottom: -.25em
}

sup {
    top: -.5em
}

table {
    border-color: inherit;
    text-indent: 0
}

iframe {
    border-style: none
}

input {
    border-radius: 0
}

[type=number]::-webkit-inner-spin-button,
[type=number]::-webkit-outer-spin-button {
    height: auto
}

[type=search] {
    -webkit-appearance: textfield;
    outline-offset: -2px
}

[type=search]::-webkit-search-decoration {
    -webkit-appearance: none
}

textarea {
    overflow: auto;
    resize: vertical
}

button,
input,
optgroup,
select,
textarea {
    font: inherit
}

optgroup {
    font-weight: 700
}

button {
    overflow: visible
}

button,
select {
    text-transform: none
}

button,
[type=button],
[type=reset],
[type=submit],
[role=button] {
    cursor: pointer
}

button::-moz-focus-inner,
[type=button]::-moz-focus-inner,
[type=reset]::-moz-focus-inner,
[type=submit]::-moz-focus-inner {
    border-style: none;
    padding: 0
}

button:-moz-focusring,
[type=button]::-moz-focus-inner,
[type=reset]::-moz-focus-inner,
[type=submit]::-moz-focus-inner {
    outline: 1px dotted ButtonText
}

button,
html [type=button],
[type=reset],
[type=submit] {
    -webkit-appearance: button
}

button,
input,
select,
textarea {
    background-color: transparent;
    border-style: none
}

a:focus,
button:focus,
input:focus,
select:focus,
textarea:focus {
    outline-width: 0
}

select {
    -moz-appearance: none;
    -webkit-appearance: none
}

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

select::-ms-value {
    color: currentColor
}

legend {
    border: 0;
    color: inherit;
    display: table;
    white-space: normal;
    max-width: 100%
}

::-webkit-file-upload-button {
    -webkit-appearance: button;
    color: inherit;
    font: inherit
}

[disabled] {
    cursor: default
}

img {
    border-style: none
}

progress {
    vertical-align: baseline
}

[aria-busy=true] {
    cursor: progress
}

[aria-controls] {
    cursor: pointer
}

[aria-disabled=true] {
    cursor: default
}

html body {
    font-family: var(--font-base)
}

html {
    font-size: 62.5%;
    line-height: var(--line-height-body);
    scroll-behavior: smooth
}

body {
    -webkit-text-size-adjust: 100%;
    -webkit-print-color-adjust: exact;
    background: rgb(var(--color-bg-body));
    color: rgb(var(--color-text-base));
    font-size: 1.6rem;
    font-weight: var(--font-weight-medium);
    letter-spacing: 0;
    line-break: strict;
    overflow-wrap: anywhere;
    text-box: trim-both text;
    word-break: normal
}

body.is-overflowHidden {
    overflow: hidden
}

:is(h1, h2, h3, h4, p, ul, ol, div, figure):first-child {
    margin-top: 0
}

:is(h1, h2, h3, h4, p, ul, ol, div, figure):last-child {
    margin-bottom: 0
}

:is(h1, h2, h3, h4)+* {
    margin-top: 0 !important
}

ul,
ol {
    list-style: none
}

img,
video,
object {
    max-width: 100%;
    height: auto;
    vertical-align: top
}

a {
    color: inherit;
    text-decoration: none;
    transition: opacity .2s var(--easing-effect) 0ms
}

@media (hover: hover) and (pointer: fine) {
    a:hover {
        opacity: var(--opacity-hover);
        text-decoration: underline
    }
}

button {
    color: inherit;
    background-color: transparent;
    border: none;
    cursor: pointer;
    outline: none;
    padding: 0;
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none
}

em {
    font-style: normal
}

.footer {
    display: flex;
    flex-direction: column;
    row-gap: 6rem;
    padding-block: 9rem 2.5rem;
    background: linear-gradient(90deg, var(--gradient-theme-primary));
    color: #fff
}

@media screen and (max-width: 1100px) {
    .footer {
        padding-top: 5.6rem;
        row-gap: 4.8rem
    }
}

.footer__upper-container {
    display: flex
}

@media screen and (min-width: 1101px) {
    .footer__upper-container {
        --container-max-width: 159rem;
        justify-content: space-between;
        column-gap: 3rem
    }
}

@media screen and (max-width: 1100px) {
    .footer__upper-container {
        flex-direction: column;
        row-gap: 3rem
    }
}

.footer__lower-container {
    display: grid
}

@media screen and (min-width: 1101px) {
    .footer__lower-container {
        --container-max-width: 168.2rem;
        align-items: flex-end;
        justify-content: space-between;
        grid-template-columns: 1fr auto 1fr;
        column-gap: 3rem
    }
}

@media screen and (max-width: 1100px) {
    .footer__lower-container {
        row-gap: 2rem
    }
}

.footer__about {
    display: flex;
    flex-direction: column;
    row-gap: 2.8rem
}

@media screen and (min-width: 1101px) {
    .footer__about {
        flex-shrink: 0
    }
}

@media screen and (max-width: 1100px) {
    .footer__about {
        row-gap: 1.6rem;
        align-items: center;
        font-size: 1.4rem
    }
}

.footer__logo {
    color: #fff
}

@media screen and (max-width: 1100px) {
    .footer__logo {
        width: 14rem;
        margin-inline: auto
    }
}

.footer__sitemap-wrapper {
    display: flex
}

@media screen and (min-width: 1101px) {
    .footer__sitemap-wrapper {
        align-items: flex-start;
        justify-content: space-between;
        column-gap: 8.8rem
    }
}

@media screen and (max-width: 1100px) {
    .footer__sitemap-wrapper {
        row-gap: 3rem;
        flex-direction: column
    }
}

.footer__sitemap {
    display: grid;
    gap: 2.8rem 2.5rem;
    letter-spacing: .05rem;
    line-height: 1.2
}

@media screen and (min-width: 1101px) {
    .footer__sitemap {
        grid-auto-flow: column;
        grid-template-columns: repeat(3, minmax(0, 18.4rem));
        grid-template-rows: repeat(2, auto);
        font-size: 2rem
    }
}

@media screen and (max-width: 1100px) {
    .footer__sitemap {
        display: flex;
        flex-wrap: wrap;
        justify-content: center;
        gap: 1.6rem 4.8rem
    }
}

.footer__sitemap-link {
    display: block;
    width: fit-content;
    background: linear-gradient(currentColor, currentColor) no-repeat 100% 100%/0 .1rem;
    transition-property: background-size, color;
    transition-duration: .2s
}

@media (hover: hover) and (pointer: fine) {
    .footer__sitemap-link[href]:hover {
        opacity: 1;
        text-decoration: none;
        background-position-x: 0;
        background-size: 100% .1rem
    }
}

.footer__groups {
    display: flex;
    flex-direction: column;
    row-gap: 1.7rem
}

.footer__groups-item {
    display: flex;
    justify-content: center
}

.footer__social {
    display: flex
}

@media screen and (min-width: 1101px) {
    .footer__social {
        justify-content: flex-end;
        grid-area: 1/3
    }
}

@media screen and (max-width: 1100px) {
    .footer__social {
        justify-content: center
    }
}

.footer__copyright {
    text-align: center;
    font-size: 1.4rem;
    line-height: 1.4;
    font-weight: var(--font-weight-regular)
}

.footer__copyright small {
    font-size: inherit
}

@media screen and (min-width: 1101px) {
    .footer__copyright {
        grid-area: 1/2
    }
}

@media screen and (max-width: 768px) {
    .footer__copyright {
        font-size: 1.2rem
    }
}

.header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    min-height: 10.4rem;
    padding: 3rem 3.6rem;
    background-color: #fff;
    box-shadow: 0 .7rem 1.1rem #00000026
}

@media screen and (max-width: 1100px) {
    .header {
        min-height: 7.4rem;
        padding: 1.2rem var(--padding-x-base)
    }
}

.header__logo {
    color: #0076be
}

@media screen and (min-width: 1101px) {
    .header__logo {
        padding-inline: 4.4rem
    }
}

@media screen and (max-width: 1100px) {
    .header__logo {
        width: 14rem
    }
}

.main {
    overflow: clip
}

@keyframes animation-scale-in {
    0% {
        opacity: 0;
        scale: 1.04;
        filter: blur(2rem)
    }

    80% {
        opacity: 1
    }

    to {
        opacity: 1;
        scale: 1;
        filter: blur(0)
    }
}

@keyframes animation-clip-path {
    0% {
        clip-path: inset(0 100% 0 0)
    }

    to {
        clip-path: inset(0)
    }
}

@keyframes animation-fade-in {
    0% {
        opacity: 0
    }

    to {
        opacity: 1
    }
}

@keyframes animation-slide-up {
    0% {
        opacity: 0;
        translate: 0 1rem
    }

    to {
        opacity: 1;
        translate: 0 0
    }
}

@keyframes animation-blur-in {
    0% {
        opacity: 0;
        filter: blur(30px)
    }

    to {
        opacity: 1;
        filter: blur(0)
    }
}

.container {
    width: 100%;
    margin-inline: auto;
    padding-inline: var(--padding-x-base)
}

@media screen and (min-width: 769px) {
    .container {
        max-width: calc(var(--container-max-width, var(--width-content-site)) + var(--padding-x-base) * 2)
    }
}

@media screen and (min-width: 769px) {
    .container--large {
      max-width: calc(134rem + var(--padding-x-base) * 2);
    }
}

[data-effect=text-clipping],
[data-effect=fade-in-image-scale],
[data-effect=slide-up],
[data-effect=fade-in] {
    opacity: 0;
    transition: var(--easing-time, .4s) ease-out var(--effect-delay, .2s);
    transition-property: opacity, translate
}

.is-visible[data-effect=text-clipping],
.is-visible[data-effect=fade-in-image-scale],
.is-visible[data-effect=slide-up],
.is-visible[data-effect=fade-in] {
    opacity: 1
}

[data-effect=slide-up] {
    translate: 0 20px
}

[data-effect=slide-up].is-visible {
    translate: none
}

[data-effect=fade-in-image-scale] img {
    scale: 1.05;
    transition: scale .8s ease-out .2s
}

[data-effect=fade-in-image-scale].is-visible img {
    scale: 1
}

[data-effect=text-clipping]>span {
    clip-path: inset(0 100% -500% 0);
    transition: clip-path var(--effect-duration, .8s) var(--easing-effect) var(--effect-delay, .2s)
}

[data-effect=text-clipping].is-visible>span {
    clip-path: inset(0 0 -500% 0)
}

[data-effect-delay="0"] {
    transition-delay: 0ms
}

[data-effect-delay="1"] {
    transition-delay: .1s
}

[data-effect-delay="2"] {
    transition-delay: .2s
}

[data-effect-delay="3"] {
    transition-delay: .3s
}

[data-effect-delay="4"] {
    transition-delay: .4s
}

[data-effect-delay="5"] {
    transition-delay: .5s
}

[data-effect-delay="6"] {
    transition-delay: .6s
}

[data-effect-delay="7"] {
    transition-delay: .7s
}

[data-effect-delay="8"] {
    transition-delay: .8s
}

[data-effect-delay="9"] {
    transition-delay: .9s
}

[data-effect-delay="10"] {
    transition-delay: 1s
}

.loading {
    position: fixed;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    width: 100vw;
    height: 100dvh;
    background: rgb(var(--color-bg));
    display: flex;
    justify-content: center;
    align-items: center;
    flex-direction: column;
    transition: all .5s linear;
    z-index: 99
}

.loading.is-loaded {
    opacity: 0;
    visibility: hidden
}

.loading__spinner {
    display: block;
    width: 4rem;
    height: 4rem;
    color: rgb(var(--color-theme-primary))
}

.pageTop {
    --pagetop-size: 57;
    --pagetop-position: 23;
    position: fixed;
    bottom: calc(var(--pagetop-position) * .1rem);
    right: 3.3rem;
    color: rgb(var(--color-theme-primary));
    z-index: 10;
    transition: .3s ease-in-out;
    transition-property: opacity, visibility, transform
}

.pageTop.is-hide {
    opacity: 0;
    visibility: hidden
}

.pageTop.is-colorChange {
    color: #fff
}

@media screen and (max-width: 768px) {
    .pageTop {
        --pagetop-size: 48;
        --pagetop-position: 10;
        right: 1rem
    }
}

.pageTop__link {
    display: block;
    width: calc(var(--pagetop-size) * .1rem);
    aspect-ratio: 1/1;
    place-content: center;
    border-radius: 50%;
    border: 1px solid currentColor;
    transition: background-color .15s ease-in-out
}

.pageTop__link:after {
    --icon-mask: url(../images/common/icon-pagetop-arrow.svg);
    content: "";
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    margin: auto;
    display: inline-block;
    width: var(--icon-size, 1em);
    height: var(--icon-size, 1em);
    background-color: var(--icon-color, currentColor);
    -webkit-mask-image: var(--icon-mask);
    mask-image: var(--icon-mask);
    -webkit-mask-repeat: no-repeat;
    mask-repeat: no-repeat;
    -webkit-mask-position: center;
    mask-position: center;
    -webkit-mask-size: contain;
    mask-size: contain;
    transition: .25s var(--easing-effect)
}

@media (hover: hover) and (pointer: fine) {
    .pageTop__link:hover {
        opacity: 1;
        background-color: rgb(var(--color-theme-primary));
        border-color: rgb(var(--color-theme-primary));
        color: #fff
    }
}

.table {
    width: 100%;
    border-collapse: collapse
}

.table th,
.table td {
    border: solid rgb(var(--color-table-border));
    border-width: .1rem 0;
    padding: 1.4rem 2rem 1.3rem;
    line-height: 1.6;
    text-align: left
}

.table th {
    width: var(--table-term-width);
    font-size:1.8rem;
    font-weight: var(--font-weight-medium)
}

.table td {
    font-size: 1.6rem;
    font-weight: var(--font-weight-regular)
}

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

    .table th,
    .table td {
        padding-inline: .8rem
    }

    .table th {
        font-size: 1.6rem
    }

    .table td {
        font-size: 1.4rem
    }
}

.boxFeature {
    position: relative;
    display: block;
    text-align: center;
    line-height: 1.6
}

.boxFeature__number {
    position: absolute;
    top: 0;
    left: 0;
    background: linear-gradient(90deg, var(--gradient-theme-primary));
    font-size: 3.2rem;
    font-weight: var(--font-weight-black);
    line-height: 1;
    translate: -.3rem calc(-50% + .3rem);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent
}

.boxFeature__label {
    margin-block: -2.3rem 2.3rem;
    margin-inline: 4.8rem;
    padding: 1rem 1.2rem .8rem;
    background-color: #fff;
    box-shadow: 0 .4rem 1rem #00000014;
    border-radius: 999.9rem;
    color: rgb(var(--color-theme-accent));
    font-size: 1.8rem;
    font-weight: var(--font-weight-bold)
}

.boxFeature__figure {
    display: grid;
    place-content: center;
    padding: 3rem 3rem 4rem;
    min-height: 24.5rem;
    border-radius: 1.3rem;
    background-color: rgb(var(--color-bg))
}

.boxFeature__figure-icon {
    width: 17.1rem;
    aspect-ratio: 171/140
}

.boxFeature__figure-icon img {
    width: 100%;
    height: 100%;
    object-fit: contain
}

.boxGrid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(30rem, 1fr));
    gap: 4.6rem
}

.buttonBlock {
    margin-top: 7.3rem;
    text-align: center
}

@media screen and (max-width: 768px) {
    .buttonBlock {
        margin-top: 4rem
    }
}

.button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    column-gap: 1rem;
    min-height: 4.9rem;
    min-width: 24.5rem;
    padding: 1.2rem 2.4rem 1rem;
    border-radius: 999.9rem;
    border: .1rem solid currentColor;
    color: currentColor;
    font-size: 1.5rem;
    line-height: 1.4;
    text-align: center;
    transition-property: background-color, border-color, color;
    letter-spacing: .05rem
}

.button:after {
    --icon-mask: url(../images/common/icon-button-arrow.svg);
    content: "";
    flex-shrink: 0;
    display: inline-block;
    width: var(--icon-size, 1em);
    height: var(--icon-size, 1em);
    background-color: var(--icon-color, currentColor);
    -webkit-mask-image: var(--icon-mask);
    mask-image: var(--icon-mask);
    -webkit-mask-repeat: no-repeat;
    mask-repeat: no-repeat;
    -webkit-mask-position: center;
    mask-position: center;
    -webkit-mask-size: contain;
    mask-size: contain;
    transition: .25s var(--easing-effect)
}

.button:has(.button__icon):after {
    content: none
}

@media (hover: hover) and (pointer: fine) {
    .button:hover {
        --gradient-deg: -90deg;
        opacity: 1;
        text-decoration: none;
        background-color: rgb(var(--color-theme-primary));
        border-color: rgb(var(--color-theme-primary));
        color: #fff
    }

    .button:hover:after {
        translate: .6rem 0
    }
}

.button__text {
    text-align: center
}

.button__icon {
    line-height: 1;
    flex-shrink: 0
}

.button--primary {
    background: linear-gradient(var(--gradient-deg, 90deg), var(--gradient-theme-primary));
    border: 0;
    color: #fff
}

.button--secondary {
    background-color: #fff;
    border-color: #fff;
    color: rgb(var(--color-theme-accent));
    font-weight: var(--font-weight-semibold)
}

.button--secondary:after {
    --icon-mask: url(../images/common/icon-button-arrow-round.svg);
    --icon-size: 1.3em
}

.hamburger {
    position: relative;
    width: 2.4rem;
    height: 2rem;
    overflow: hidden;
    z-index: 15;
    color: rgb(var(--color-theme-primary))
}

.hamburger[aria-expanded=true] {
    color: #fff
}

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

.hamburger__line {
    position: relative;
    pointer-events: none
}

.hamburger__line,
.hamburger__line:before,
.hamburger__line:after {
    display: block;
    width: 100%;
    height: .2rem;
    background-color: currentColor;
    border-radius: 10rem;
    transition: .15s ease-in-out
}

.hamburger__line:before,
.hamburger__line:after {
    content: "";
    position: absolute;
    left: 0;
    transition-property: transform, top
}

.hamburger__line:before {
    top: -.9rem
}

.hamburger__line:after {
    bottom: -.9rem
}

[aria-expanded=true] .hamburger__line {
    translate: 150% 0
}

[aria-expanded=true] .hamburger__line:before {
    top: 0;
    transform: translate(-150%) rotate(45deg)
}

[aria-expanded=true] .hamburger__line:after {
    top: 0;
    transform: translate(-150%) rotate(-45deg)
}

.cardGrid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(30rem, 1fr));
    gap: 6rem 4.6rem;
    margin-top: 7rem
}

@media screen and (max-width: 768px) {
    .cardGrid {
        margin-top: 5rem
    }
}

.cardGrid__col {
    display: grid;
    grid-template-rows: subgrid;
    grid-row: span 2
}

.card {
    position: relative;
    display: grid;
    grid-template-rows: subgrid;
    grid-row: span 2;
    gap: 0;
    height: 100%;
    padding: 3rem var(--padding-x-base);
    background-color: #fff;
    border-radius: 1.3rem;
    color: rgb(var(--color-text-base));
    text-align: center;
    line-height: 1.6
}

.card:has(.card__label) {
    padding-top: 7rem
}

@media screen and (max-width: 768px) {
    .card:has(.card__label) {
        padding-top: 5rem
    }
}

.card__label {
    position: absolute;
    top: 0;
    inset-inline: 4.8rem;
    padding: .5rem var(--padding-x-base) .4rem;
    background-color: rgb(var(--color-theme-accent));
    border-radius: 999.9rem;
    color: #fff;
    font-size: 2.4rem;
    font-weight: var(--font-weight-bold);
    text-align: center;
    text-transform: uppercase;
    translate: 0 -50%
}

@media screen and (max-width: 768px) {
    .card__label {
        font-size: 1.8rem
    }
}

.card__icon {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 14.8rem;
    margin-inline: auto;
    aspect-ratio: 1/1
}

.card__icon img {
    width: 100%;
    height: 100%;
    object-fit: contain
}

@media screen and (max-width: 768px) {
    .card__icon {
        width: 10rem
    }
}

.card__text {
    display: flex;
    flex-direction: column;
    justify-content: center;
    margin-top: 3.5rem;
    font-size: 1.8rem;
    font-weight: var(--font-weight-regular)
}

@media screen and (max-width: 768px) {
    .card__text {
        margin-top: 2.4rem;
        font-size: 1.6rem
    }
}

[data-typography] {
    position: relative;
    z-index: 0
}

[data-typography]:before {
    content: attr(data-typography);
    display: block;
    font-weight: var(--font-weight-bold);
    line-height: 1;
    text-transform: uppercase;
    z-index: -1;
    white-space: nowrap
}

.headingType01 {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    margin-bottom: 5.5rem;
    font-weight: var(--font-weight-bold)
}

@media screen and (max-width: 768px) {
    .headingType01 {
        margin-bottom: 3rem
    }
}

.headingType01__ja {
    color: rgb(var(--color-text-heading));
    font-size: 1.6rem;
    line-height: 1.4
}

.headingType01__ja--large {
    font-size: clamp(2rem, 3.3854166667vw, 2.6rem);
    font-weight: var(--font-weight-bold);
    line-height: 1.35;
    padding-top: 0.2rem;
}

.headingType01__en {
    background: linear-gradient(90deg, var(--gradient-theme-primary));
    font-size: 3.8rem;
    font-weight: var(--font-weight-black);
    line-height: 1.1;
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent
}

@media screen and (max-width: 768px) {
    .headingType01__en {
        font-size: 2.8rem
    }
}

.headingType01--center {
    align-items: center
}

.headingType01--colorInherit .headingType01__en {
    background: none;
    -webkit-text-fill-color: currentColor
}

.headingType02 {
    margin-bottom: 3rem;
    font-size: 2rem;
    font-weight: var(--font-weight-bold);
    line-height: 1.6;
    color: rgb(var(--color-theme-primary))
}

@media screen and (max-width: 768px) {
    .headingType02 {
        font-size: 1.8rem
    }
}

.headingType02[data-typography]:before {
    font-size: 24rem;
    opacity: .05
}

@media screen and (min-width: 769px) {
    .headingType02[data-typography]:before {
        position: absolute;
        left: -5.8rem;
        top: 50%;
        translate: 0 -50%
    }
}

@media screen and (max-width: 1100px) {
    .headingType02[data-typography]:before {
        left: -4rem;
        top: 0;
        font-size: 18rem
    }
}

@media screen and (max-width: 768px) {
    .headingType02[data-typography]:before {
        margin-bottom: -2.5rem;
        font-size: 6.8rem
    }
}

.image {
    border-radius: 1.3rem;
    overflow: hidden
}

.image img {
    width: 100%
}

@media screen and (max-width: 768px) {
    .image {
        width: 100%
    }
}

.logoList {
    display: grid;
    justify-content: center;
    grid-template-columns: repeat(auto-fit, minmax(0, 37.3rem));
    gap: 4rem 5.3rem
}

@media screen and (max-width: 768px) {
    .logoList {
        row-gap: 2.4rem
    }
}

.logoList__item a {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    height: 100%;
    padding: 2rem;
    min-height: 12.9rem;
    border-radius: 1.3rem;
    background-color: #fff;
    transition-property: scale
}

.logoList__item a img {
    width: 100%
}

@media (hover: hover) and (pointer: fine) {
    .logoList__item a:hover {
        opacity: 1;
        scale: 1.02
    }
}

@media screen and (max-width: 768px) {
    .logoList__item a {
        min-height: 10rem
    }
}

.logo {
    display: block;
    width: fit-content;
    text-align: center;
    color: currentColor;
    line-height: 1
}

.logo svg {
    width: 100%;
    vertical-align: top
}

.logo--shadow {
    box-shadow: 0 .7rem 1.5rem #0000000d
}

.listDisc>li {
    position: relative;
    padding-left: 1em;
    line-height: 1.57;
    letter-spacing: .05rem
}

.listDisc>li:before {
    content: "・";
    position: absolute;
    top: 0;
    left: 0;
    width: 1em
}

@media screen and (min-width: 769px) {
    .listDisc--large {
        font-size: 2.4rem;
        line-height: 1.7;
        font-weight: var(--font-weight-bold);
        letter-spacing: 0
    }
}

.list-table {
    font-size: 1.6rem;
    line-height: 1.4;
}

@media screen and (min-width: 769px) {
    .list-table div {
        display: flex;
        flex-wrap: nowrap;
    }
    .list-table div:last-child dt,
    .list-table div:last-child dd {
        border-bottom: none;
    }
}

.list-table dt {
    text-align: left;
    font-size: 1.125em;
    font-weight: var(--font-weight-medium);
    padding-top: 1.3333333333em;
    padding-bottom: 0;
    color: #0359BE;
}

@media screen and (min-width: 769px) {
    .list-table dt {
        width: 14.4rem;
        margin-right: 5rem;
        padding-top: 1.7777777778em;
        padding-bottom: 1.7777777778em;
        border-bottom: 1px solid #EBEBEB;
    }
}

.list-table dd {
    flex: 1;
    font-weight: var(--font-weight-regular);
    line-height:1.8em;
    padding-top: 0.5em;
    padding-bottom: 1.5em;
    border-bottom: 1px solid #EBEBEB;
}

@media screen and (min-width: 769px) {
    .list-table dd {
        padding-top: 2em;
        padding-bottom: 2em;
    }
}

.social {
    display: flex;
    align-items: center;
    flex-wrap: nowrap;
    gap: 1rem 1.4rem
}

.social__link {
    display: block
}

.gNav {
    display: flex
}

@media screen and (min-width: 1101px) {
    .gNav {
        align-items: center;
        column-gap: 2.2rem
    }
}

@media screen and (max-width: 1100px) {
    .gNav {
        position: fixed;
        top: 0;
        right: 0;
        bottom: 0;
        left: 0;
        flex-direction: column;
        align-items: center;
        justify-content: center;
        row-gap: 3rem;
        height: 100dvh;
        padding: 7.4rem var(--padding-x-base);
        background-color: #000000d9;
        visibility: hidden;
        opacity: 0;
        overflow-y: auto;
        transition: .3s ease-in-out;
        transition-property: opacity, visibility;
        z-index: 10
    }

    .gNav[aria-hidden=false] {
        color: #fff;
        opacity: 1;
        visibility: visible
    }
}

.gNav__menu {
    display: flex
}

@media screen and (min-width: 1101px) {
    .gNav__menu {
        align-items: center;
        column-gap: 5.8rem
    }
}

@media screen and (max-width: 1100px) {
    .gNav__menu {
        flex-direction: column
    }
}

@media screen and (max-width: 768px) {
    .gNav__menu {
        align-self: stretch
    }
}

.gNav__menu-item--button {
    min-width: 19.8rem
}

.gNav__menu-item--button a {
    width: 100%
}

@media screen and (min-width: 1101px) {
    .gNav__menu-item--button a {
        min-height: 4.2rem;
        min-width: 0
    }
}

@media screen and (max-width: 1100px) {
    .gNav__menu-item--button {
        padding-block: 1.6rem
    }
}

.gNav__menu-link {
    display: block;
    background: linear-gradient(rgb(var(--color-theme-primary)), rgb(var(--color-theme-primary))) no-repeat 100% 100%/0 .1rem;
    text-align: center;
    transition-property: background-size, color;
    transition-duration: .2s
}

@media (hover: hover) and (pointer: fine) {
    .gNav__menu-link[href]:hover {
        opacity: 1;
        text-decoration: none;
        background-position-x: 0;
        background-size: 100% .1rem
    }
}

@media screen and (min-width: 1101px) {
    .gNav__menu-link {
        color: rgb(var(--color-text-title));
        letter-spacing:2px;
    }
}

@media screen and (max-width: 1100px) {
    .gNav__menu-link {
        padding: 1.6rem var(--padding-x-base)
    }
}

.gNav__social {
    flex-shrink: 0
}

.heading-page {
    overflow: hidden;
    position: relative;
    z-index: -1;
    height: min(65.3645833333vw, 50.2rem);
}

.heading-page:after {
    content: "";
    display: block;
    position: absolute;
    z-index: 1;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0.3);
}

.heading-page__block {
    position: absolute;
    z-index: 2;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
}

.heading-page__en {
    font-family: "Noto Sans JP", sans-serif;
    font-size: clamp(4.2rem, 7.2916666667vw, 7rem);
    font-weight: var(--font-weight-black);
    line-height: 1.1;
    letter-spacing: 0.0089285714em;
    text-shadow: 0 0.4rem 1rem rgba(0, 0, 0, 0.15);
    color: #FFF;
    letter-spacing:2px;
}

.heading-page__ja {
    font-size: clamp(1.4rem, 2.0833333333vw, 2.2rem);
    font-weight: var(--font-weight-semibold);
    margin-top: 0.625em;
    margin-bottom: 2.6rem;
    letter-spacing: 4px;
    color: #FFF;
    margin-left:5px;
}

.heading-page__copy {
    display: inline-block;
    font-size: clamp(1.6rem, 3.3854166667vw, 1.7rem);
    font-weight: var(--font-weight-semibold);
    line-height: 1.1;
    padding-top: 0.6153846154em;
    padding-bottom: 0.6153846154em;
    padding-left: 0.7em;
    padding-right: 0.7em;
    background: rgba(255, 255, 255, 0.8);
    letter-spacing:0.08rem;
    margin-left:5px;
}

.heading-page__image {
    width: 100%;
    height: 100%;
}

.heading-page__image figure {
    width: 100%;
    height: 100%;
}

.heading-page__image figure img {
    width: 100%;
    height: 102%;
    object-fit: cover;
}

.pankuzu {
    padding-top: clamp(2.4rem, 3.0909090909vw, 3.4rem);
}

.pankuzu__list {
    display: inline-block;
}

.pankuzu__list>li {
    display: inline;
    position: relative;
    z-index: 0;
    font-size: clamp(1.4rem, 2.0833333333vw, 1.6rem);
    font-weight: var(--font-weight-regular);
    line-height: 1.1;
}

.pankuzu__list>li:after {
    content: "/";
    display: inline-block;
    margin-left: 0.5em;
    margin-right: 0.5em;
}

.pankuzu__list>li:last-child {
    color:inherit;
}

.pankuzu__list>li a {
    color:rgb(var(--color-theme-primary));
}

.pankuzu__list>li:last-child:after {
    display: none;
}

.contact {
    position: relative;
    padding-block: 17.3rem 10.2rem;
    color: #fff;
    overflow: hidden;
    z-index: 0
}

.contact:before,
.contact:after {
    content: "";
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    margin: auto;
    z-index: -1;
    pointer-events: none
}

.contact:before {
    background: url(../images/common/contact-bg.jpg) no-repeat 50% 50%/cover;
    scale: 1.05;
    transition: scale .8s ease-out .2s
}

.contact:after {
    background-color: #0006
}

.contact[data-effect].is-visible:before {
    scale: 1
}

.btn-container{
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: center; 
    gap:5rem;
    margin:auto;
}

@media screen and (max-width:940px) {
.btn-container{
    gap:2rem;
}
}

@media screen and (max-width: 768px) {
    .contact {
        padding-block: 10rem 5.6rem
    }
}

.contact__heading {
    margin-bottom: 5.8rem;
    font-size: 4.5rem;
    line-height: 1.6;
    text-align: center;
    text-shadow: 0px 6px 6px rgba(0, 0, 0, .25)
}

.contact__heading[data-typography]:before {
    position: absolute;
    bottom: 50%;
    inset-inline: 0;
    font-family: var(--font-inter);
    font-size: 16.6rem;
    line-height: .8;
    opacity: .36;
    text-shadow: none;
    letter-spacing: .028em
}

@media screen and (max-width: 1100px) {
    .contact__heading[data-typography]:before {
        font-size: 10rem
    }
}

@media screen and (max-width: 768px) {
    .contact__heading[data-typography] {
        margin-bottom: 3rem;
        font-size: 3rem
    }

    .contact__heading[data-typography]:before {
        bottom: 65%;
        font-size: 4.8rem
    }
}

.contact__buttons {
    display: grid;
    justify-content: center;
    grid-template-columns: repeat(auto-fit, minmax(0, 42.1rem));
    gap: 4.1rem
}

.contact__buttons a {
    min-height: 6.1rem;
    width: 100%;
    font-size: 2rem;
    letter-spacing: -.01em
}

@media screen and (min-width: 769px) {
    .contact__buttons a {
        padding-inline: 3.7rem
    }
}

@media screen and (max-width: 768px) {
    .contact__buttons {
        row-gap: 2.4rem
    }

    .contact__buttons a {
        font-size: 1.8rem
    }
}

.section {
    margin-top: var(--section-margin-top, 12rem);
    padding-block: var(--section-padding-block)
}

@media screen and (max-width: 768px) {
    .section {
        --section-margin-top: 5.6rem
    }
}

[class*=section--bg] {
    --section-padding-block: 10rem
}

@media screen and (max-width: 768px) {
    [class*=section--bg] {
        --section-padding-block: 5.6rem
    }
}

.section--bgColor01 {
    background-color: rgb(var(--color-bg))
}

.section--bgColor02 {
    background-color: #F0F2F4;
}

.top-company {
    position: relative
}

.top-company h2{
    margin-bottom:50px !important;;
}

.top-company__block {
    display: grid;
    align-items: start;
}

@media screen and (min-width: 769px) {
    .top-company__block {
        grid-template-columns: 1fr 47.4506578947%;
        column-gap: 7.3rem
    }
}

@media screen and (max-width: 1100px) {
    .top-company__block {
        gap: 4rem
    }
}

.top-company__texts {
    --table-term-width: 17.4rem
}

.top-company__texts table tr:last-child th,.top-company__texts table tr:last-child td{
    border: none;
}

.top-company__texts table a{
    max-width:260px;
    display: inline-block;
    text-decoration: none;
    border:1px solid #f9f9f9;
    box-shadow:5px 5px 12px rgb(0 0 0 / 7%);
    overflow: hidden;
    transition:.25s;
}

.top-company__texts table img{
}
.top-company__texts table a:hover { opacity:.8; box-shadow: 2px 2px 0px rgb(0 0 0 / 10%); opacity:.65; border:1px solid #999}




@media screen and (max-width: 1100px) {
    .top-company__texts {
        --table-term-width: 13rem
    }
}

@media screen and (max-width: 768px) {
    .top-company__texts {
        --table-term-width: 10rem
    }
}

.top-company__image {
    display: flex;
    min-height: 40.5rem
}

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

@media screen and (max-width: 768px) {
    .top-company__image {
        grid-row: 1;
        min-height: 0;
        aspect-ratio: 300/180
    }
}

.top-mainvisual {
    position: relative;
    color: #fff;
    overflow: hidden
}

.top-mainvisual__contents {
    position: absolute;
    bottom: 9.1666666667vw;
    right: 17.8645833333vw;
    z-index: 5;
    opacity: 0;
    animation: animation-blur-in 2s var(--easing-effect) .6s forwards
}

@media screen and (max-width: 1100px) {
    .top-mainvisual__contents {
        bottom: 15rem;
        inset-inline: 0;
        padding-inline: var(--padding-x-base)
    }
}

@media screen and (max-width: 768px) {
    .top-mainvisual__contents {
        bottom: 10rem
    }
}

.top-mainvisual__copy {
    margin-bottom: 1.5rem;
    font-size: 6rem;
    line-height: 1.4;
    letter-spacing: .4rem;
    font-weight: var(--font-weight-medium)
}

@media screen and (max-width: 768px) {
    .top-mainvisual__copy {
        font-size: 3.8rem
    }
}

.top-mainvisual__label {
    font-family: var(--font-inter);
    font-size: 2.6rem;
    font-weight: var(--font-weight-regular);
    line-height: 1.1923076923
}

@media screen and (max-width: 768px) {
    .top-mainvisual__label {
        font-size: 1.6rem
    }
}

.top-mainvisual__images {
    display: flex !important;
    position: relative;
    height: calc(100dvh - 10.4rem);
    overflow: hidden;
    box-sizing: border-box;
    z-index: -1
}

.top-mainvisual__images:before,
.top-mainvisual__images:after {
    content: "";
    position: absolute;
    opacity: .8;
    filter: blur(15rem);
    z-index: 5
}

.top-mainvisual__images:before {
    bottom: min(-6.7708333333vw, -130px);
    right: min(-7.1875vw, -138px);
    width: max(59.8958333333vw, 1150px);
    height: max(33.8541666667vw, 650px);
    background: #21aae0
}

.top-mainvisual__images:after {
    bottom: max(7.8125vw, 150px);
    right: min(-23.6458333333vw, -454px);
    width: max(51.40625vw, 987px);
    height: max(28.125vw, 540px);
    background: #0354bb
}

@media screen and (max-width: 1100px) {
    .top-mainvisual__images:before {
        right: auto;
        left: min(-7.1875vw, -138px)
    }

    .top-mainvisual__images:after {
        right: auto;
        left: min(-23.6458333333vw, -454px)
    }
}

@media screen and (max-width: 768px) {
    .top-mainvisual__images {
        height: calc(100dvh - 7.4rem)
    }

    .top-mainvisual__images:before,
    .top-mainvisual__images:after {
        opacity: 1;
        left: auto
    }

    .top-mainvisual__images:before {
        top: auto;
        bottom: -15.2671755725vw;
        right: 20.6106870229vw;
        width: 139.4402035623vw;
        height: 65.6488549618vw
    }

    .top-mainvisual__images:after {
        bottom: 16.2849872774vw;
        right: 30.0254452926vw;
        width: 119.0839694656vw;
        height: 65.6488549618vw
    }
}

.top-mainvisual__images-wrapper {
    align-self: stretch;
    height: auto !important
}

.top-mainvisual__images-item img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    scale: 1;
    transition: scale 6.5s ease-in-out
}

.top-mainvisual__images-item.swiper-slide-active img {
    scale: 1.06;
    transition-delay: 0ms
}

.top-philosophy {
    margin-bottom: 16rem;
    position: relative;
    background: url(../images/top/philosophy-bg.png) no-repeat 50% 100%/100%
}

@media screen and (max-width: 768px) {
    .top-philosophy {
        background-image: url(../images/top/philosophy-bg-sp.png);
        background-position-y: 50%
    }
}

.top-philosophy__block {
    display: grid
}

@media screen and (min-width: 769px) {
    .top-philosophy__block {
        grid-template-columns: auto 45.6414473684%;
        justify-content: space-between;
        align-items: flex-start;
        column-gap: 4rem
    }
}

@media screen and (max-width: 768px) {
    .top-philosophy__block {
        row-gap: 4rem
    }
}

.top-philosophy__texts {
    font-weight: var(--font-weight-regular);
    line-height: 1.6
}

@media screen and (min-width: 1101px) {
    .top-philosophy__texts {
        max-width: 53.4rem
    }
}

@media screen and (min-width: 769px) {
    .top-philosophy__texts {
        padding-block: 3rem;
        font-size: 1.8rem
    }
}

.top-philosophy__images {
    position: relative
}

.top-philosophy__images-item:nth-child(1) {
    width: 75.8558558559%;
    margin-left: auto
}

.top-philosophy__images-item:nth-child(2) {
    position: absolute;
    left: 0;
    bottom: -8rem;
    width: 40.5405405405%;
    background-color: #fff;
    border: .2rem solid white
}

.top-philosophy__button {
    margin-top: 8.3rem
}

@media screen and (max-width: 768px) {
    .top-philosophy__button {
        margin-top: 4rem
    }
}

.top-recruit {
    position: relative;
    --section-padding-block: 11rem 6rem;
    color: #fff;
    overflow: hidden;
    z-index: 0
}

.top-recruit:before,
.top-recruit:after {
    content: "";
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    margin: auto;
    z-index: -1;
    pointer-events: none
}

.top-recruit:before {
    background: url(../images/top/recruit-bg.jpg) no-repeat 50% 50%/cover;
    scale: 1.05;
    transition: scale .8s ease-out .2s
}

.top-recruit:after {
    background-color: #035bbf80
}

.top-recruit[data-effect].is-visible:before {
    scale: 1
}

@media screen and (max-width: 768px) {
    .top-recruit {
        --section-padding-block: 5.6rem
    }
}

.top-recruit__header {
    display: flex;
    flex-direction: column;
    align-items: center
}

.top-service {
    position: relative
}

.top-service__block {
    display: grid;
    align-items: center
}

@media screen and (min-width: 769px) {
    .top-service__block {
        grid-template-columns: 51.3980263158% 1fr;
        column-gap: 5.8rem
    }
}

@media screen and (max-width: 1100px) {
    .top-service__block {
        gap: 4rem
    }
}

.top-service__texts {
    font-weight: var(--font-weight-regular);
    line-height: 1.6
}

@media screen and (min-width: 769px) {
    .top-service__texts {
        padding-top: 2.8rem;
        font-size: 1.8rem
    }
}

.top-service__image {
    display: flex;
    min-height: 49.8rem
}

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

@media screen and (max-width: 768px) {
    .top-service__image {
        min-height: 0;
        aspect-ratio: 300/180
    }
}

.top-service__button {
    margin-top: 4.5rem
}

@media screen and (min-width: 769px) {
    .company-message {
        margin-top: 0;
        padding-top: 7.3rem;
        padding-bottom: 5.8rem;
    }
}

.company-message__block {
    padding-left: 15.6340057637%;
    padding-right: 15.6340057637%;
}

@media screen and (min-width: 769px) {
    .company-message__block {
        display: grid;
        transform: translateY(-2rem);
        grid-template-columns: 43.3962264151% 42.6624737945%;
        column-gap: 9.748427673%;
    }
}

@media screen and (max-width: 1100px) {
    .company-message__block {
        grid-template-columns: 1fr 42.6624737945%;
        padding-left: 0;
        padding-right: 0;
    }
}

@media screen and (min-width: 769px) {
    .company-message__image {
        order: 2;
    }
}

.company-message__texts {
    font-weight: var(--font-weight-regular);
    margin-top: 2.4rem;
}

@media screen and (min-width: 769px) {
    .company-message__texts {
        order: 1;
        line-height: 2;
        margin-top: 0;
    }
}

.company-message__name {
    text-align: right;
    font-size: 1.8rem;
    font-weight: var(--font-weight-regular);
}

.company-message__name>span {
    display: inline-block;
    font-size: 1.125em;
    font-weight: var(--font-weight-semibold);
    margin-top: clamp(2.4rem, 3.3636363636vw, 3.7rem);
    margin-left: 1em;
}

@media screen and (min-width: 769px) {
    .company-vision {
        margin-top: 0;
        padding-top: 10.7rem;
        padding-bottom: 8.5rem;
    }
}

.company-vision__list {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(30rem, 1fr));
    padding-top: clamp(0.5rem, 1.2727272727vw, 1.4rem);
    gap: 2.4rem;
}

@media screen and (min-width: 769px) {
    .company-vision__list {
        gap: 4.3rem;
    }
}

.company-vision__item {
    display: grid;
    place-items: center;
    text-align: center;
    font-size: clamp(1.8rem, 1.5714285714vw, 2.2rem);
    font-weight: var(--font-weight-semibold);
    line-height: 1.6;
    padding-top: 2em;
    padding-bottom: 2em;
    padding-left: 1em;
    padding-right: 1em;
    border-radius: 1.3rem;
    background: #FFF;
}

@media screen and (min-width: 769px) {
    .company-info {
        padding-top: 10rem;
        padding-bottom: 6rem;
    }
}

.company-info .list-table {
    transform: translateY(-1rem);
}

@media screen and (min-width: 769px) {
    .company-info .list-table {
        transform: translateY(0);
        padding-left: 7.4013157895%;
        padding-right: 7.4013157895%;
    }
}

.company-access {
    padding-bottom: clamp(5rem, 6.9090909091vw, 7.6rem);
}

@media screen and (min-width: 769px) {
    .company-access {
        margin-top: 0;
        padding-top: 10rem;
    }
}

.company-access__map {
    overflow: hidden;
    position: relative;
    z-index: 0;
    height: clamp(24rem, 38.0714285714vw, 53.3rem);
    margin-inline: auto;
}

@media screen and (min-width: 769px) {
    .company-access__map {
        width: 85.7730263158%;
    }
}

.company-access__map>iframe {
    position: absolute;
    z-index: 1;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
}

.company-recruit {
    overflow: hidden;
    position: relative;
    z-index: 0;
    margin-top: 0;
    --section-padding-block: 10rem 7.4rem;
    color: white;
}

.company-recruit::before,
.company-recruit::after {
    content: "";
    position: absolute;
    inset: 0;
    margin: auto;
    z-index: -1;
    pointer-events: none;
}

.company-recruit::before {
    background: url(../images/service/recruit-bg.jpg) no-repeat 50% 50%/cover;
    scale: 1.05;
    transition: scale 800ms ease-out 200ms;
}

.company-recruit::after {
    background-color: rgba(3, 91, 191, 0.5);
}

.company-recruit[data-effect].is-visible::before {
    scale: 1;
}

@media screen and (max-width: 768px) {
    .company-recruit {
        --section-padding-block: 5.6rem;
    }
}

@media screen and (min-width: 769px) {
    .company-recruit__header {
        width: 79.7697368421%;
        margin-inline: auto;
    }
}

.company-recruit__text {
    font-size: clamp(1.7rem, 2.1818181818vw, 2.4rem);
    font-weight: var(--font-weight-semibold);
    line-height: 1.7;
}

.company-related {
    margin-top: 0;
    --section-padding-block: 5.6rem;
}

@media screen and (min-width: 769px) {
    .company-related {
        padding-top: 10rem;
        padding-bottom: 8.5rem;
    }
}

@media screen and (min-width: 769px) {
    .company-related__item {
        display: flex;
        flex-wrap: nowrap;
        justify-content: center;
        align-items: center;
        gap: 4rem;
    }
}

.company-related__item>a {
    display: grid;
    place-items: center;
    width: min(100%, 37.3rem);
    height: 12.9rem;
    padding-left: 2rem;
    padding-right: 2rem;
    background: #FFF;
    border-radius: 1.3rem;
    transition-property: scale;
}

@media screen and (min-width: 769px) {
    .company-related__item>a {
        height: 19.9rem;
    }
}

@media screen and (max-width: 1100px) {
    .company-related__item>a {
        margin-inline: auto;
    }
}

@media (hover: hover) and (pointer: fine) {
    .company-related__item a:hover {
        opacity: 1;
        scale: 1.02;
    }
}

@media screen and (max-width: 768px) {
    .company-related__item a {
        min-height: 10rem;
    }
}

.company-related__item:not(:last-child) {
    margin-bottom: 3.5rem;
}

.company-related__itemDetail {
    width: min(100%, 37.3rem);
    margin-top: 2rem;
}

@media screen and (min-width: 769px) {
    .company-related__itemDetail {
        width: min(100%, 52.2rem);
        margin-top: 0;
    }
}

@media screen and (max-width: 1100px) {
    .company-related__itemDetail {
        margin-inline: auto;
    }
}

.company-related__title {
    font-size: clamp(2rem, 2vw, 2.2rem);
    font-weight: var(--font-weight-semibold);
    line-height: 1.25;
    margin-bottom: 0.6363636364em;
    color: rgb(var(--color-theme-primary));
}

@media screen and (max-width: 1100px) {
    .company-related__title {
        margin-bottom: 0.3636363636em;
    }
}

.company-related__texts {
    font-size: clamp(1.6rem, 1.6363636364vw, 1.8rem);
    font-weight: var(--font-weight-regular);
    line-height: 1.7;
}

.service-security {
    overflow: hidden;
    position: relative;
    z-index: 0;
}

@media screen and (min-width: 769px) {
    .service-security {
        margin-top: 0;
        padding-top: 5rem;
        padding-bottom: 10rem;
    }
}

.service-security__header {
    margin-bottom: clamp(5rem, 8.1818181818vw, 9rem);
}

.service-security__header>p {
    font-size: clamp(1.6rem, 1.6363636364vw, 1.8rem);
    font-weight: var(--font-weight-regular);
}

@media screen and (min-width: 769px) {
    .service-security__header>p {
        line-height: 2.11;
    }
}

@media screen and (max-width: 1100px) {
    .service-security__header .headingType01__ja {
        padding-top: 0.5rem;
    }
}

.service-security__block {
    position: relative;
    z-index: -1;
    display: flex;
    flex-wrap: nowrap;
    align-items: center;
    gap: 8rem;
    margin-top: clamp(5rem, 7.2727272727vw, 8rem);
    max-width: 114.8rem;
    margin-inline: auto;
}

@media screen and (max-width: 768px) {
    .service-security__block {
        flex-direction: column;
        flex-wrap: nowrap;
        gap: 2.4rem;
    }
}

.service-security__block:after {
    content: "";
    display: block;
    position: absolute;
    z-index: -1;
    top: min(10.6770833333vw, 8.2rem);
    right: -4.8rem;
    width: 60.4166666667vw;
    height: min(32.5714285714vw, 45.6rem);
    background: #F1F5F9;
    border-radius: 1.5rem 0 0 1.5rem;
    margin: 0 calc(50% - 50vw);
}

@media screen and (max-width: 768px) {
    .service-security__block:after {
        top: 10.4166666667vw;
        width: 90vw;
        height: 59.375vw;
    }
}

.service-security__block--odd {
    margin-top: min(18.1818181818vw, 20rem);
}

@media screen and (max-width: 768px) {
    .service-security__block--odd {
        margin-top: 7rem;
    }
}

.service-security__block--odd:after {
    left: -4.8rem;
    border-radius: 0 1.5rem 1.5rem 0;
}

.service-security__block--odd .service-security__detail {
    order: 2;
}

.service-security__block--odd .service-security__image {
    order: 1;
}

.service-security__block--odd .service-security__titleNumber:after {
    background: #F1F5F9;
}

.service-security__detail {
    flex: 1;
}

@media screen and (max-width: 768px) {
    .service-security__detail {
        order: 2;
    }
}

.service-security__title {
    display: flex;
    flex-wrap: nowrap;
    align-items: center;
    font-size: clamp(2.2rem, 2vw, 2.8rem);
    margin-bottom: 1.25em;
}

@media screen and (max-width: 768px) {
    .service-security__title {
        margin-bottom: 0.7142857143em;
    }
}

.service-security__titleNumber {
    position: relative;
    z-index: 0;
    font-family: "Noto Sans JP", sans-serif;
    flex: 0 0 7.4rem;
}

.service-security__titleNumber>span {
    display: grid;
    place-items: center;
    width: 7.4rem;
    height: 7.4rem;
    font-size: 1.1428571429em;
    font-weight: var(--font-weight-bold);
    line-height: 1;
    background: url(../images/service/line-circle.svg) no-repeat center;
    background-size: 7.4rem 7.4rem;
}

.service-security__titleLabel {
    font-weight: var(--font-weight-semibold);
    line-height: 1.6;
    color: rgb(var(--color-theme-accent));
    font-size: 1em;
    margin-left: 2.2rem;
}

.service-security__texts {
    letter-spacing: 0.03125em;
    font-weight: var(--font-weight-regular);
}

.service-security__image {
    width: 47.9933110368%;
}

@media screen and (max-width: 768px) {
    .service-security__image {
        order: 1;
        width: 100%;
    }
}

@media screen and (min-width: 769px) {
    .service-points {
        padding-bottom: 8.9rem;
    }
}

.service-points .cardGrid {
    padding-top: clamp(3rem, 5vw, 5.5rem);
}

.service-points .cardGrid__col {
    display: block;
}

@media screen and (min-width: 769px) {
    .service-area {
        margin-top: 0;
        padding-top: 9rem;
        padding-bottom: 6rem;
    }
}

.service-area__header {
    margin-bottom: 3.5rem;
}

.service-area__header>p {
    font-size: clamp(1.6rem, 1.6363636364vw, 1.8rem);
    font-weight: var(--font-weight-regular);
    line-height: 1.6;
}

@media screen and (min-width: 769px) {
    .service-area__block {
        display: grid;
        grid-template-columns: 48.4375% 1fr;
        column-gap: 10.1973684211%;
        align-items: center;
    }
}

.service-area__map {
    margin-bottom: 2.4rem;
}

@media screen and (max-width: 1100px) {
    .service-area__map {
        margin-bottom: 4rem;
    }
}

.service-area__title {
    font-size: clamp(2rem, 3.3854166667vw, 2.6rem);
    color: rgb(var(--color-theme-primary));
    margin-bottom: 1.4230769231em;
}

.service-area__texts {
    font-size: clamp(1.6rem, 1.6363636364vw, 1.8rem);
    font-weight: var(--font-weight-regular);
    line-height: 2;
    margin-top: clamp(3rem, 4.5454545455vw, 5rem);
}

.service-flow {
    padding-bottom: 3rem;
}

@media screen and (min-width: 769px) {
    .service-flow {
        margin-top: 0;
        padding-top: 9rem;
        padding-bottom: 2.5rem;
    }
}

.service-flow__header>p {
    font-size: clamp(1.6rem, 1.6363636364vw, 1.8rem);
    font-weight: var(--font-weight-regular);
    line-height: 1.6;
}

.service-flow__list {
    margin-top: clamp(3rem, 5.4545454545vw, 6rem);
    padding-left: 7.4013157895%;
}

@media screen and (max-width: 1100px) {
    .service-flow__list {
        padding-left: 0;
    }
}

.service-flow__item {
    display: flex;
    flex-wrap: nowrap;
    gap: 1.8rem;
}

.service-flow__item:not(:last-child) .service-flow__icon:after {
    content: "";
    display: block;
    position: absolute;
    z-index: -1;
    top: 0;
    left: 50%;
    width: 1px;
    height: 100%;
    border-left: 2px dotted #0198E5;
}

.service-flow__item .service-flow__icon {
    position: relative;
    z-index: 0;
    flex: 0 0 clamp(7.2rem, 13.4545454545vw, 14.8rem);
}

.service-flow__item .service-flow__icon>img {
    width: 100%;
}

.service-flow__detail {
    padding-bottom: clamp(2.4rem, 5.6363636364vw, 6.2rem);
}

@media screen and (min-width: 769px) {
    .service-flow__detail {
        width: 41.2078152753%;
    }
}

@media screen and (max-width: 1100px) {
    .service-flow__detail {
        flex: 1;
    }
}

.service-flow__number {
    font-size: 1.8rem;
    font-weight: var(--font-weight-bold);
    color: #0356BC;
    margin-bottom: 1rem;
}

.service-flow__title {
    font-size: clamp(1.9rem, 2.1818181818vw, 2.4rem);
    font-weight: var(--font-weight-semibold);
    line-height: 1.4;
    margin-bottom: 0.5em;
}

.service-flow__texts {
    font-weight: var(--font-weight-regular);
    line-height: 1.6;
}

@media screen and (max-width: 1100px) {
    .service-flow__texts {
        font-size: 1.5rem;
    }
}

.recruit-job {
    position: relative;
    z-index: 0;
    padding-bottom: 1rem;
}

@media screen and (min-width: 769px) {
    .recruit-job {
        margin-top: 0;
        padding-top: 7rem;
        padding-bottom: 4.5rem;
    }
}

.recruit-job__header {
    margin-bottom: clamp(3rem, 5vw, 5.5rem);
}

.recruit-job__header>p {
    font-size: clamp(1.6rem, 1.6363636364vw, 1.8rem);
    font-weight: var(--font-weight-regular);
    margin-bottom: clamp(5rem, 6.7272727273vw, 7.4rem);
}

@media screen and (min-width: 769px) {
    .recruit-job__header>p {
        line-height: 2.11;
    }
}

.recruit-job__list {
    width: min(100%, 109.5rem);
    margin-inline: auto;
}

@media screen and (min-width: 769px) {
    .recruit-job__list {
        display: grid;
        grid-template-columns: 1fr 1fr;
        column-gap: 3.7rem;
    }
}

.recruit-job__item {
    margin-bottom: 4rem;
}

.recruit-job__title {
    position: relative;
    z-index: 1;
    text-align: center;
    width: 27.8rem;
    font-size: 2rem;
    font-weight: var(--font-weight-bold);
    line-height: 1.35;
    margin-top: -2.3rem;
    margin-inline: auto;
    margin-bottom: 2.3rem;
    padding-top: 1rem;
    padding-bottom: 1rem;
    padding-left: 2.4rem;
    padding-right: 2.4rem;
    border-radius: 999.9rem;
    color: rgb(var(--color-theme-accent));
    background-color: #fff;
    box-shadow: 0 0.4rem 1rem rgba(0, 0, 0, 0.15);
}

.recruit-job__texts {
    font-size: clamp(1.6rem, 1.6363636364vw, 1.8rem);
    font-weight: var(--font-weight-regular);
}

@media screen and (min-width: 769px) {
    .recruit-points {
        margin-top: 0;
        padding-top: 10.5rem;
        padding-bottom: 8.9rem;
    }
}

.recruit-points .cardGrid {
    padding-top: clamp(3rem, 5vw, 5.5rem);
}

@media screen and (min-width: 1101px) {
    .recruit-points .cardGrid {
        display: flex;
        flex-wrap: wrap;
        justify-content: center;
        align-items: center;
        gap: 7.1rem 4.6rem;
    }
}

@media screen and (max-width: 1100px) {
    .recruit-points .cardGrid {
        gap: 5.5rem 4.6rem;
    }
}

.recruit-points .cardGrid__col {
    display: block;
}

@media screen and (min-width: 1101px) {
    .recruit-points .cardGrid__col {
        width: 37.3rem;
    }
}

@media screen and (max-width: 768px) {
    .recruit-points .cardGrid__col {
        width: 100%;
    }
}

@media screen and (min-width: 769px) {
    .recruit-flow {
        margin-top: 0;
        padding-top: 11.2rem;
        padding-bottom: 5.5rem;
    }
}

.recruit-flow__header>p {
    font-size: clamp(1.6rem, 1.6363636364vw, 1.8rem);
    font-weight: var(--font-weight-regular);
    line-height: 1.6;
}

.recruit-flow__list {
    margin-top: clamp(3rem, 5.4545454545vw, 6rem);
}

@media screen and (min-width: 769px) {
    .recruit-flow__list {
        padding-left: 16.2006578947%;
    }
}

.recruit-flow__item {
    display: flex;
    flex-wrap: nowrap;
    gap: clamp(1.6rem, 0.3636363636vw, 4rem);
}

.recruit-flow__item:not(:last-child) .recruit-flow__circle:after {
    content: "";
    display: block;
    position: absolute;
    z-index: -1;
    top: 1.2rem;
    left: 50%;
    width: 1px;
    height: 100%;
    border-left: 1px solid #BABABA;
}

.recruit-flow__item:last-child .recruit-flow__detail {
    padding-bottom: 0;
}

.recruit-flow__time {
    font-size: 2.2rem;
    line-height: 1.5;
    font-weight: var(--font-weight-bold);
    color: rgb(var(--color-theme-accent));
}

.recruit-flow__circle {
    position: relative;
    z-index: 0;
}

.recruit-flow__circle>i {
    display: block;
    width: 0.7rem;
    height: 0.7rem;
    background-color: rgb(var(--color-theme-accent));
    border-radius: 50%;
    margin-top: 1.2rem;
}

.recruit-flow__detail {
    flex: 1;
    padding-bottom: clamp(2.8rem, 3.0909090909vw, 3.4rem);
}

.recruit-flow__title {
    font-size: clamp(1.9rem, 2.1818181818vw, 2.4rem);
    font-weight: var(--font-weight-semibold);
    line-height: 1.4;
    margin-bottom: 0.5em;
}

.recruit-flow__texts {
    font-size: clamp(1.6rem, 1.6363636364vw, 1.8rem);
    font-weight: var(--font-weight-regular);
    line-height: 1.6;
}

@media screen and (min-width: 769px) {
    .recruit-workability {
        margin-top: 0;
        padding-top: 10rem;
        padding-bottom: 7.5rem;
    }
}

.recruit-workability__list {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(27rem, 1fr));
    gap: 5rem 4.2rem;
    padding-top: clamp(3rem, 5vw, 5.5rem);
    margin-bottom: clamp(4rem, 5.2727272727vw, 5.8rem);
}

.recruit-workability__item {
    position: relative;
    z-index: 0;
    text-align: center;
    background: #FFF;
    padding-top: 3.2rem;
    padding-left: 1.4rem;
    padding-right: 1.4rem;
    padding-bottom: 2.4rem;
    border-radius: 1.3rem;
}

.recruit-workability__number {
    position: absolute;
    z-index: 1;
    top: -1.9rem;
    left: 50%;
    transform: translateX(-50%);
    width: 17.3rem;
    font-size: clamp(1.8rem, 2vw, 2.2rem);
    font-weight: var(--font-weight-medium);
    line-height: 1.35;
    margin-bottom: 1.3rem;
    margin-inline: auto;
    padding-top: 0.5rem;
    padding-bottom: 0.5rem;
    padding-left: 2.4rem;
    padding-right: 2.4rem;
    border-radius: 999.9rem;
    color: #FFF;
    background-color: rgb(var(--color-theme-accent));
}

.recruit-workability__image {
    margin-bottom: 2rem;
}

.recruit-workability__title {
    font-size: clamp(1.6rem, 1.6363636364vw, 1.8rem);
    font-weight: var(--font-weight-regular);
    line-height: 1.35;
}

.recruit-workability__button {
    display: flex;
    justify-content: center;
}

@media screen and (min-width: 769px) {
    .recruit-faq {
        margin-top: 0;
        padding-top: 9rem;
    }
}

.recruit-faq__list {
    width: min(100%, 84rem);
    margin-inline: auto;
    padding-top: 1.6rem;
    padding-bottom: 1.6rem;
    padding-left: clamp(2rem, 3.2727272727vw, 3.6rem);
    padding-right: clamp(2rem, 3.2727272727vw, 3.6rem);
    border-radius: 1.3rem;
    box-shadow: 0 0.4rem 27rem rgba(0, 0, 0, 0.1);
}

.recruit-faq__list>div {
    display: flex;
    flex-wrap: nowrap;
    align-items: center;
    padding-top: 1.3rem;
    padding-bottom: 1.3rem;
}

.recruit-faq__list dt {
    font-size: clamp(2.8rem, 3.4545454545vw, 3.8rem);
    font-weight: var(--font-weight-bold);
    padding-left: 0.2631578947em;
    margin-right: 0.6315789474em;
    line-height: 1;
}

.recruit-faq__list dd {
    font-weight: var(--font-weight-regular);
    line-height: 1.5;
}

.recruit-faq__list:not(:last-child) {
    margin-bottom: 2.4rem;
}

.recruit-faq__question {
    border-bottom: 1px solid #CCC;
}

.recruit-faq__question dt {
    color: #0368C7;
}

.recruit-faq__question dd {
    font-size: clamp(1.6rem, 1.6363636364vw, 1.8rem);
    font-weight: var(--font-weight-semibold);
}

.recruit-faq__answer dt {
    color: #A61C0D;
}

@media screen and (min-width: 769px) {
    .recruit-application {
        padding-bottom: 8.5rem;
    }
}

@media screen and (max-width: 1100px) {
    .recruit-application {
        padding-top: 1rem;
        padding-bottom: 5.5rem;
    }
}

.recruit-application .list-table {
    width: min(100%, 102.4rem);
    margin-inline: auto;
    margin-bottom: 4.2rem;
}

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

    .recruit-application .list-table div:last-child dt,
    .recruit-application .list-table div:last-child dd {
        border-bottom: 1px solid #EBEBEB;
    }
}

@media screen and (min-width: 769px) {
    .recruit-application .list-table dt {
        padding-top: 1.1111111111em;
        padding-bottom: 1.1111111111em;
    }
}

@media screen and (min-width: 769px) {
    .recruit-application .list-table dd {
        padding-top: 1.25em;
        padding-bottom: 1.25em;
    }
}

.recruit-application__button {
    display: flex;
    justify-content: center;
}





#contact .p-01{
    font-size:clamp(1.6rem, 1.6363636364vw, 1.8rem);
    padding-top:7rem;
    line-height:2.3;
    text-align: center;
    margin-bottom:clamp(4rem, 6.7272727273vw, 5rem);
    }

.contact-us {
    margin-top: 0;
    padding-top: 5rem;
    padding-bottom: 10rem;
    }

.contact-us .card{
    background:rgb(var(--color-bg));
    padding: 3rem 0rem;
}

.card__label2{
    position: absolute;
    top: 0;
    inset-inline: 4.8rem;
    padding: .5rem var(--padding-x-base) .4rem;
    background-color:#fff;
    box-shadow: 0 0 1rem #00000014;
    border-radius: 999.9rem;
    color:rgb(var(--color-theme-accent));
    font-size: 1.8rem;
    font-weight: var(--font-weight-bold);
    text-align: center;
    text-transform: uppercase;
    translate: 0 -50%;
}
.card:has(.card__label2) {
    padding-top: 5rem
}


.contact-us .card .tel{
    font-size:1.7em;
    font-weight: bold;
    margin-bottom: 10px;
}

.contact-us .card .tel a{
    text-decoration: none;
    display: inline-block;
    transition:.3s;
}

.contact-us .card .tel a i{
    color: rgb(var(--color-theme-accent));
    margin-right:5px;
    vertical-align: middle;
}

.contact-us .card .tel a span{
    display: inline-block;
    vertical-align: middle;
}

.contact-us .card .tel a:hover{
    opacity: .5;
}

.contact-us .card .p-02{

}

.contact-us .card .p-03{
    font-size:1.4rem;
}

.contact-us .card .mail i{
    color: rgb(var(--color-theme-accent));
    margin-right:5px;
    vertical-align: middle;
}

.contact-us .card .mail span{
    font-size:2rem;
    display: inline-block;
    vertical-align: middle;
}

.contact-us .card .button{
    margin:0 4rem;
}

.contact-us .card .button::after{
    display: none;
}


.mailform{

}
@media screen and (min-width: 769px) {
    .mailform {
        margin-top: 0;
        padding-top: 10.5rem;
        padding-bottom: 8.9rem;
    }
}

@media screen and (max-width: 768px) {
    .card__label2 {
        font-size: 1.8rem
    }
    .card:has(.card__label2) {
        padding-top: 5rem
    }
    .mailform {
        margin-top: 0;
        padding-top:5rem;
        padding-bottom: 5rem;
    }
}




#contact #box-02 .area-01{ margin:0 auto 70px;}
#contact #box-02 .area-01 ul{}
#contact #box-02 .area-01 li{ line-height:2em; letter-spacing:normal; text-indent:-1em; padding-left:1em;}

#contact #box-02 .area-01{ overflow:hidden; margin:auto; text-align:center;}
#contact #box-02 .area-01 p{ font-size:18px; font-weight:bold; margin-bottom:20px;}
#contact #box-02 .area-01 ul{ display:inline-block; margin-bottom:40px;}
#contact #box-02 .area-01 li{ text-align:left; text-indent:-1em; padding-left:1em;}

#contact #box-02 .area-02 .area-mailform{ border-radius:30px; background:#fff; padding:20px 40px;}
#contact #box-02 .area-02 .area-mailform table{ width:100%; margin-bottom:50px; overflow: hidden; border-collapse: collapse;}
#contact #box-02 .area-02 .area-mailform table tr{ border-bottom:1px dashed #ccc;}
#contact #box-02 .area-02 .area-mailform table td{ padding:20px 8px; vertical-align:middle;}
#contact #box-02 .area-02 .area-mailform table td.td-01{ width:30%; font-weight:bold; padding-left:20px;}
#contact #box-02 .area-02 .area-mailform table ul li{ margin-bottom:7px;}
#contact #box-02 .area-02 .area-mailform table ul li:last-of-type{ margin-bottom:0px;}
#contact #box-02 .area-02 .area-mailform table ul.ul-01 li{ margin-bottom:0px;}
#contact #box-02 .area-02 .area-mailform table select{ padding:3px; font-size:15px;}
#contact #box-02 .area-02 .area-mailform table input{ padding:3px; font-size:15px;}
#contact #box-02 .area-02 .area-mailform table label img{ display:block; margin:0 auto 3px;}
#contact #box-02 .area-02 .area-mailform table button{}
#contact #box-02 .area-02 .area-mailform .chui{ font-weight:bold; color:#fff; background:#0277D1; font-size:11px; padding:3px 7px 3px; margin-right:7px; position:relative; bottom:3px; float:right;position:relative; top:0px;}
#contact #box-02 .area-02 .area-mailform .chui-01{ float:left;}
#contact #box-02 .area-02 .area-mailform .p-01{ margin-top:5px;}
#contact #box-02 .area-02 .area-mailform .autotext{ margin-bottom:30px;}
#contact #box-02 .area-02 .area-mailform .p-02{ font-weight:bold;}
#contact #box-02 .area-02 .area-mailform .p-min{ font-size:14px; letter-spacing:normal; padding-top:5px;}
#contact #box-02 .area-02 .area-mailform .w01{width:99%; max-width:97%;}
#contact #box-02 .area-02 .area-mailform .w02{width:47%;}

#contact #box-02 .area-02 .area-mailform .kakunin{ background:#F0F7FC; padding:5px 5px;margin-bottom:20px; text-align:center;}
#contact #box-02 .area-02 .area-mailform .tb-01{}
#contact #box-02 .area-02 .area-mailform .tb-03{ text-align:center;}
#contact #box-02 .area-02 .area-mailform .tb-03 .chui{ float:none;}
#contact #box-02 .area-02 .area-mailform .tb-02{ text-align:center;}
#contact #box-02 .area-02 .area-mailform .tb-04{ height:200px;overflow-y:scroll;padding:20px; border:#999 solid 1px; background:#FFF; margin:auto; margin-bottom:50px; }
#contact #box-02 .area-02 .area-mailform .btn{ background:linear-gradient(var(--gradient-deg, 90deg), var(--gradient-theme-primary)); color:#fff; padding:15px 0; text-decoration:none; display:block; -webkit-border-radius:50px;-moz-border-radius:50px;border-radius:50px; margin:50px auto 30px; width:300px; font-size:18px; font-weight:bold; transition:.3s; box-shadow:none; border:none;}
#contact #box-02 .area-02 .area-mailform .btn:hover{ opacity:1; cursor:pointer; --gradient-deg: -90deg; background-color: rgb(var(--color-theme-primary));}

#contact #box-02 .area-02 .area-mailform .p-03{ font-weight:bold; margin-bottom:10px;}
#contact #box-02 .area-02 .area-mailform .p-04{ font-weight:bold;}
#contact #box-02 .area-02 .area-mailform .p-05{margin-bottom:15px;}
#contact #box-02 .area-02 .area-mailform .ul-01{margin-bottom:15px;}
#contact #box-02 .area-02 .area-mailform h2{ font-size:22px; font-weight:bold; margin-bottom:5px;}




@media screen and (max-width: 768px) {
#contact .p-01{ font-size: 16px; margin:0 20px; padding-top: 5rem; text-align:left; line-height:1.7em;}
.contact-us{ padding-top: 7rem;}
#contact h2.u-mb-90{ margin-bottom: 40px !important;}
#contact #box-02 .area-01 p{ font-size:16px; font-weight:bold; margin-bottom:20px;}
#contact #box-02 .area-01 ul{ display:inline-block; margin-bottom:40px;}
#contact #box-02 .area-01 li{ font-size: 14px; text-align:left; text-indent:-1em; padding-left:1em;}
#contact #box-02 .area-02 .area-mailform{ padding:10px 20px; border-radius:15px;}
#contact #box-02 .area-02 .area-mailform table td{ padding:0px 0px 20px; display: block;}
#contact #box-02 .area-02 .area-mailform table td.td-01{ width: 100%; padding:20px 8px 5px; font-weight:bold;}
#contact #box-02 .area-02 .area-mailform table td.td-01 span{ float: none; vertical-align: middle; padding:5px 10px; margin-left: 10px;}
#contact #box-02 .area-02 .area-mailform .p-05{ font-size: 14px;}
#contact #box-02 .area-02 .area-mailform h2{ font-size:18px;}
#contact #box-02 .area-02 .area-mailform .w03{width:99%; max-width:97%;}
#contact #box-02 .area-02 .area-mailform table select{ padding:3px; font-size:16px;}
#contact #box-02 .area-02 .area-mailform table input{ padding:3px; font-size:16px;}
#contact #box-02 .area-02 .area-mailform table textarea{ padding:3px; font-size:16px;}
}




.recruit #box-02 .area-01{ margin:0 auto 70px;}
.recruit #box-02 .area-01 ul{}
.recruit #box-02 .area-01 li{ line-height:2em; letter-spacing:normal; text-indent:-1em; padding-left:1em;}

.recruit #box-02 .area-01{ overflow:hidden; margin:auto; text-align:center;}
.recruit #box-02 .area-01 p{ font-size:18px; font-weight:bold; margin-bottom:20px;}
.recruit #box-02 .area-01 ul{ display:inline-block; margin-bottom:40px;}
.recruit #box-02 .area-01 li{ text-align:left; text-indent:-1em; padding-left:1em;}

.recruit #box-02 .area-02 .area-mailform{ border-radius:30px; background:#fff; padding:20px 40px;}
.recruit #box-02 .area-02 .area-mailform table{ width:100%; margin-bottom:50px; overflow: hidden; border-collapse: collapse;}
.recruit #box-02 .area-02 .area-mailform table tr{ border-bottom:1px dashed #ccc;}
.recruit #box-02 .area-02 .area-mailform table td{ padding:20px 8px; vertical-align:middle;}
.recruit #box-02 .area-02 .area-mailform table td.td-01{ width:30%; font-weight:bold; padding-left:20px;}
.recruit #box-02 .area-02 .area-mailform table ul li{ margin-bottom:7px;}
.recruit #box-02 .area-02 .area-mailform table ul li:last-of-type{ margin-bottom:0px;}
.recruit #box-02 .area-02 .area-mailform table ul.ul-01 li{ margin-bottom:0px;}
.recruit #box-02 .area-02 .area-mailform table label img{ display:block; margin:0 auto 3px;}
.recruit #box-02 .area-02 .area-mailform table button{}
.recruit #box-02 .area-02 .area-mailform .chui{ font-weight:bold; color:#fff; background:#0277D1; font-size:11px; padding:3px 7px 3px; margin-right:7px; position:relative; bottom:3px; float:right;position:relative; top:0px;}
.recruit #box-02 .area-02 .area-mailform .chui-01{ float:left;}
.recruit #box-02 .area-02 .area-mailform .p-01{ margin-top:5px;}
.recruit #box-02 .area-02 .area-mailform .autotext{ margin-bottom:30px;}
.recruit #box-02 .area-02 .area-mailform .p-02{ font-weight:bold;}
.recruit #box-02 .area-02 .area-mailform .p-min{ font-size:14px; letter-spacing:normal; padding-top:5px;}
.recruit #box-02 .area-02 .area-mailform .w01{width:99%; max-width: 97%;}
.recruit #box-02 .area-02 .area-mailform .w02{width:47%;}

.recruit #box-02 .area-02 .area-mailform .kakunin{ background:#F0F7FC; padding:5px 5px;margin-bottom:20px; text-align:center;}
.recruit #box-02 .area-02 .area-mailform .tb-01{}
.recruit #box-02 .area-02 .area-mailform .tb-03{ text-align:center;}
.recruit #box-02 .area-02 .area-mailform .tb-03 .chui{ float:none;}
.recruit #box-02 .area-02 .area-mailform .tb-02{ text-align:center;}
.recruit #box-02 .area-02 .area-mailform .tb-04{ height:200px;overflow-y:scroll;padding:20px; border:#999 solid 1px; background:#FFF; margin:auto; margin-bottom:50px; }
.recruit #box-02 .area-02 .area-mailform .btn{ background:linear-gradient(var(--gradient-deg, 90deg), var(--gradient-theme-primary)); color:#fff; padding:15px 0; text-decoration:none; display:block; -webkit-border-radius:50px;-moz-border-radius:50px;border-radius:50px; margin:50px auto 30px; width:300px; font-size:18px; font-weight:bold; transition:.3s; box-shadow:none; border:none;}
.recruit #box-02 .area-02 .area-mailform .btn:hover{ opacity:1; cursor:pointer; --gradient-deg: -90deg; background-color: rgb(var(--color-theme-primary));}

.recruit #box-02 .area-02 .area-mailform .p-03{ font-weight:bold; margin-bottom:10px;}
.recruit #box-02 .area-02 .area-mailform .p-04{ font-weight:bold;}
.recruit #box-02 .area-02 .area-mailform .p-05{margin-bottom:15px;}
.recruit #box-02 .area-02 .area-mailform .ul-01{margin-bottom:15px;}
.recruit #box-02 .area-02 .area-mailform h2{ font-size:22px; font-weight:bold; margin-bottom:5px;}




@media screen and (max-width: 768px) {
.contact-us{ padding-top: 7rem;}
.recruit #box-02 .area-01 p{ font-size:16px; font-weight:bold; margin-bottom:20px;}
.recruit #box-02 .area-01 ul{ display:inline-block; margin-bottom:40px;}
.recruit #box-02 .area-01 li{ font-size: 14px; text-align:left; text-indent:-1em; padding-left:1em;}
.recruit #box-02 .area-02 .area-mailform{ padding:10px 20px; border-radius:15px;}
.recruit #box-02 .area-02 .area-mailform table td{ padding:0px 0px 20px; display: block;}
.recruit #box-02 .area-02 .area-mailform table td.td-01{ width: 100%; padding:20px 8px 5px; font-weight:bold;}
.recruit #box-02 .area-02 .area-mailform table td.td-01 span{ float: none; vertical-align: middle; padding:5px 10px; margin-left: 10px;}
.recruit #box-02 .area-02 .area-mailform .p-05{ font-size: 14px;}
.recruit #box-02 .area-02 .area-mailform h2{ font-size:18px;}
.recruit #box-02 .area-02 .area-mailform .w03{width:99%; max-width:97%;}
.recruit #box-02 .area-02 .area-mailform table select{ padding:3px; font-size:16px;}
.recruit #box-02 .area-02 .area-mailform table input{ padding:3px; font-size:16px;}
.recruit #box-02 .area-02 .area-mailform table textarea{ padding:3px; font-size:16px;}
}





/* -------- カテゴリー -------- */
/* -------- カテゴリー -------- */
/* -------- カテゴリー -------- */


/*▼ブログ共通　bl▼*/
#wrper{ width:1148px; margin:auto; overflow:hidden; padding:50px 0 70px;}

/*　左カラム　*/
#mleft{ width:65%; float:left;}
#mleft .box{ padding-top:0;}
#mleft .box h2{ line-height: 1.3em;}


/* news・カテゴリー */
.category #mleft .area-01{}
.category #mleft .area-01 table{ width:100%;}
.category #mleft .area-01 table td{ padding:15px 0px; border-bottom:#999 dotted 1px;}
.category #mleft .area-01 table td.td-01{ width:150px; padding-left:50px; background:url(../images/common/ico-more.png) 0 18px no-repeat; background-size:20px; padding-left:30px;}
.category #mleft .area-01 table td a{ color:rgb(var(--color-theme-primary));}
.category #mleft .tb-01 .p-01 a{ font-weight: bold; color: #0066c0;}


/*　右サイドカラム　*/
#mright{ width:25%; float:right;}
#mright .sbox{ margin-bottom:40px;}

#mright h2{ font-size:19px; font-weight:bold; letter-spacing:normal; padding-bottom:3px; position:relative; margin-bottom:10px;}
#mright h2 span{ font-size:14px; font-weight:bold; color:#cee9f9; display:inline-block; margin-left:10px;}
#mright h2:before{ box-sizing: inherit; display: block; height: 1px; position: absolute; content: ""; bottom:0; left:0; width: 40%; z-index: 1; background:#0f2b94;}
#mright h2:after { content: ""; bottom: 0; left: 0; width: 100%; background:#ddd; box-sizing: inherit; display: block; height: 1px; position: absolute; z-index: 0;}


#mright #sbox-01{}
#mright #sbox-01 ul{}
#mright #sbox-01 ul li{ overflow:hidden; margin-bottom:7px;}
#mright #sbox-01 ul li a{ padding:0px; text-decoration:none; display:block; transition: 0.2s;}
#mright #sbox-01 ul li .img{ width:80px; height:80px; float:left; overflow:hidden; border:1px solid #efefef; box-sizing:border-box;}
#mright #sbox-01 ul li img{ width:80px; height:80px; object-fit:cover; float:left;transition: 0.3s;}
#mright #sbox-01 ul li p{ width:193px; font-size:14px; font-weight:500; color:#333; letter-spacing:normal; display:inline-block; float:right; padding-top:2px;}
#mright #sbox-01 ul li a:hover{ opacity:0.9; transition: 0.2s;}
#mright #sbox-01 ul li a:hover img{ -webkit-transform: scale(1.04); transform: scale(1.04); transition: 0.3s;}


#mright #sbox-02{}
#mright #sbox-02 ul{}
#mright #sbox-02 ul li{ border-bottom:1px solid #ddd;}
#mright #sbox-02 ul li a{ background:url(../images/common/ico-more.png) left 10px top 16px no-repeat; font-size:15px; color:#555; background-size:16px auto; padding:10px 10px 10px 32px; letter-spacing:normal; text-decoration:none; display:block; transition: 0.2s;}
#mright #sbox-02 ul li a span{ transition: 0.2s;}
#mright #sbox-02 ul li a:hover{ background-color:#edf8ff; opacity:1; transition: 0.2s;}
#mright #sbox-02 ul li a:hover span{ padding-left:3px; transition: 0.2s;}



/*▼記事詳細ページ　single▼*/
.single #mleft .date{ font-weight:bold; text-align: right; margin-bottom:10px;}


.postNavi{ overflow:hidden; margin-top:50px;}
.postNavi .prev{ display:inline-block; float: left;}
.postNavi .next{ display:inline-block; float: right; text-align:right;}






.content p {
  margin-bottom: 1.5em;
  line-height: 1.6;
}

.content h2 {
  margin-top: 2em;
  margin-bottom: 1em;
  font-size: 1.5em;
}

.content ul,
.content ol {
  padding-left: 1.5em;
  margin-bottom: 1.5em;
}

.content li {
  margin-bottom: 0.5em;
}

.content img {
  max-width: 100%;
  height: auto;
  display: block;
  margin: 1em 0;
}


.wp-block-paragraph {
  margin-bottom: 1.5em;
}

.wp-block-heading {
  margin-top: 2em;
  margin-bottom: 1em;
}





.post-navigation {
  display: flex;
  justify-content: space-between;
  margin-top: 30px;
}

.post-prev a,
.post-next a {
  padding:4px 8px;
  background: rgb(var(--color-theme-primary));
  font-size:12px;
  color: #fff;
  text-decoration: none;
  letter-spacing: normal;
  border-radius:4px;
}






/* -------- お知らせ -------- */

.news{ margin-top:0;}
.news .area-01{ background:#fff; padding:50px 50px; border-radius:2.4rem; max-width:calc(134rem + var(--padding-x-base) * 2); box-sizing:border-box; margin:0 5%;}
.news .area-01 table{ width:100%;}
.news .area-01 table td{ padding:15px 0px; border-bottom:#999 dotted 1px;}
.news .area-01 table td.td-01{ width:150px; padding-left:50px; background:url(../images/common/ico-more.png) 0 18px no-repeat; background-size:20px; padding-left:30px;}
.news .area-01 table td a{ color:rgb(var(--color-theme-primary));}
@media screen and (max-width:600px) {
.news .area-01{ padding:30px 30px;}
.news .area-01 table td{ display: block; padding:5px 0 15px;}
.news .area-01 table td.td-01{ border: none; padding:15px 0 0 28px;}

}


@media screen and (max-width:900px) {
        #wrper{ width:inherit; padding-top:30px;}
        #mleft{ width:inherit; float: none; padding:0 3rem 50px;}
        #mright{ width:inherit; float: none; padding:0 2.5rem;}

#mright #sbox-01 ul li a{ overflow: hidden;}
#mright #sbox-01 ul li .img{ width:80px; height:80px; float:left; overflow:hidden; border:1px solid #efefef; box-sizing:border-box;}
#mright #sbox-01 ul li img{ width:80px; height:80px; object-fit:cover; float:left;transition: 0.3s;}
#mright #sbox-01 ul li p{ width:inherit; min-width:190px; float: left; margin-left:13px;}
.news .area-01{ margin:0;}
}


.u-color-white {
    color: #fff
}

.u-color-black {
    color: #000
}

.u-color-text {
    color: rgb(var(--color-text-base))
}

.u-color-primary {
    color: rgb(var(--color-theme-primary))
}

.u-color-accent {
    color: rgb(var(--color-accent))
}

.u-color-inherit {
    color: inherit
}

.u-hidden {
    display: none !important
}

@media screen and (min-width: 769px) {
    .u-hidden-pc {
        display: none !important
    }
}

@media screen and (max-width: 768px) {
    .u-hidden-sp {
        display: none !important
    }
}

.u-visible-sp {
    display: block !important;
}

@media screen and (min-width: 769px) {
    .u-visible-sp {
        display: none !important;
    }
}

.u-m-auto {
    margin: 0 auto !important
}

.u-mt-0 {
    margin-top: 0rem !important
}

.u-mb-0 {
    margin-bottom: 0rem !important
}

.u-ml-0 {
    margin-left: 0rem !important
}

.u-mr-0 {
    margin-right: 0rem !important
}

.u-mt-5 {
    margin-top: .5rem !important
}

.u-mb-5 {
    margin-bottom: .5rem !important
}

.u-ml-5 {
    margin-left: .5rem !important
}

.u-mr-5 {
    margin-right: .5rem !important
}

.u-mt-10 {
    margin-top: 1rem !important
}

.u-mb-10 {
    margin-bottom: 1rem !important
}

.u-ml-10 {
    margin-left: 1rem !important
}

.u-mr-10 {
    margin-right: 1rem !important
}

.u-mt-15 {
    margin-top: 1.5rem !important
}

.u-mb-15 {
    margin-bottom: 1.5rem !important
}

.u-ml-15 {
    margin-left: 1.5rem !important
}

.u-mr-15 {
    margin-right: 1.5rem !important
}

.u-mt-20 {
    margin-top: 2rem !important
}

.u-mb-20 {
    margin-bottom: 2rem !important
}

.u-ml-20 {
    margin-left: 2rem !important
}

.u-mr-20 {
    margin-right: 2rem !important
}

.u-mt-25 {
    margin-top: 2.5rem !important
}

.u-mb-25 {
    margin-bottom: 2.5rem !important
}

.u-ml-25 {
    margin-left: 2.5rem !important
}

.u-mr-25 {
    margin-right: 2.5rem !important
}

.u-mt-30 {
    margin-top: 3rem !important
}

.u-mb-30 {
    margin-bottom: 3rem !important
}

.u-ml-30 {
    margin-left: 3rem !important
}

.u-mr-30 {
    margin-right: 3rem !important
}

.u-mt-35 {
    margin-top: 3.5rem !important
}

.u-mb-35 {
    margin-bottom: 3.5rem !important
}

.u-ml-35 {
    margin-left: 3.5rem !important
}

.u-mr-35 {
    margin-right: 3.5rem !important
}

.u-mt-40 {
    margin-top: 4rem !important
}

.u-mb-40 {
    margin-bottom: 4rem !important
}

.u-ml-40 {
    margin-left: 4rem !important
}

.u-mr-40 {
    margin-right: 4rem !important
}

.u-mt-45 {
    margin-top: 4.5rem !important
}

.u-mb-45 {
    margin-bottom: 4.5rem !important
}

.u-ml-45 {
    margin-left: 4.5rem !important
}

.u-mr-45 {
    margin-right: 4.5rem !important
}

.u-mt-50 {
    margin-top: 5rem !important
}

.u-mb-50 {
    margin-bottom: 5rem !important
}

.u-ml-50 {
    margin-left: 5rem !important
}

.u-mr-50 {
    margin-right: 5rem !important
}

.u-mt-55 {
    margin-top: 5.5rem !important
}

.u-mb-55 {
    margin-bottom: 5.5rem !important
}

.u-ml-55 {
    margin-left: 5.5rem !important
}

.u-mr-55 {
    margin-right: 5.5rem !important
}

.u-mt-60 {
    margin-top: 6rem !important
}

.u-mb-60 {
    margin-bottom: 6rem !important
}

.u-ml-60 {
    margin-left: 6rem !important
}

.u-mr-60 {
    margin-right: 6rem !important
}

.u-mt-65 {
    margin-top: 6.5rem !important
}

.u-mb-65 {
    margin-bottom: 6.5rem !important
}

.u-ml-65 {
    margin-left: 6.5rem !important
}

.u-mr-65 {
    margin-right: 6.5rem !important
}

.u-mt-70 {
    margin-top: 7rem !important
}

.u-mb-70 {
    margin-bottom: 7rem !important
}

.u-ml-70 {
    margin-left: 7rem !important
}

.u-mr-70 {
    margin-right: 7rem !important
}

.u-mt-75 {
    margin-top: 7.5rem !important
}

.u-mb-75 {
    margin-bottom: 7.5rem !important
}

.u-ml-75 {
    margin-left: 7.5rem !important
}

.u-mr-75 {
    margin-right: 7.5rem !important
}

.u-mt-80 {
    margin-top: 8rem !important
}

.u-mb-80 {
    margin-bottom: 8rem !important
}

.u-ml-80 {
    margin-left: 8rem !important
}

.u-mr-80 {
    margin-right: 8rem !important
}

.u-mt-85 {
    margin-top: 8.5rem !important
}

.u-mb-85 {
    margin-bottom: 8.5rem !important
}

.u-ml-85 {
    margin-left: 8.5rem !important
}

.u-mr-85 {
    margin-right: 8.5rem !important
}

.u-mt-90 {
    margin-top: 9rem !important
}

.u-mb-90 {
    margin-bottom: 9rem !important
}

.u-ml-90 {
    margin-left: 9rem !important
}

.u-mr-90 {
    margin-right: 9rem !important
}

.u-mt-95 {
    margin-top: 9.5rem !important
}

.u-mb-95 {
    margin-bottom: 9.5rem !important
}

.u-ml-95 {
    margin-left: 9.5rem !important
}

.u-mr-95 {
    margin-right: 9.5rem !important
}

.u-mt-100 {
    margin-top: 10rem !important
}

.u-mb-100 {
    margin-bottom: 10rem !important
}

.u-ml-100 {
    margin-left: 10rem !important
}

.u-mr-100 {
    margin-right: 10rem !important
}

@media screen and (max-width: 768px) {
    .u-m-auto-sp {
        margin: 0 auto !important
    }

    .u-mt-0-sp {
        margin-top: 0rem !important
    }

    .u-mb-0-sp {
        margin-bottom: 0rem !important
    }

    .u-ml-0-sp {
        margin-left: 0rem !important
    }

    .u-mr-0-sp {
        margin-right: 0rem !important
    }

    .u-mt-5-sp {
        margin-top: .5rem !important
    }

    .u-mb-5-sp {
        margin-bottom: .5rem !important
    }

    .u-ml-5-sp {
        margin-left: .5rem !important
    }

    .u-mr-5-sp {
        margin-right: .5rem !important
    }

    .u-mt-10-sp {
        margin-top: 1rem !important
    }

    .u-mb-10-sp {
        margin-bottom: 1rem !important
    }

    .u-ml-10-sp {
        margin-left: 1rem !important
    }

    .u-mr-10-sp {
        margin-right: 1rem !important
    }

    .u-mt-15-sp {
        margin-top: 1.5rem !important
    }

    .u-mb-15-sp {
        margin-bottom: 1.5rem !important
    }

    .u-ml-15-sp {
        margin-left: 1.5rem !important
    }

    .u-mr-15-sp {
        margin-right: 1.5rem !important
    }

    .u-mt-20-sp {
        margin-top: 2rem !important
    }

    .u-mb-20-sp {
        margin-bottom: 2rem !important
    }

    .u-ml-20-sp {
        margin-left: 2rem !important
    }

    .u-mr-20-sp {
        margin-right: 2rem !important
    }

    .u-mt-25-sp {
        margin-top: 2.5rem !important
    }

    .u-mb-25-sp {
        margin-bottom: 2.5rem !important
    }

    .u-ml-25-sp {
        margin-left: 2.5rem !important
    }

    .u-mr-25-sp {
        margin-right: 2.5rem !important
    }

    .u-mt-30-sp {
        margin-top: 3rem !important
    }

    .u-mb-30-sp {
        margin-bottom: 3rem !important
    }

    .u-ml-30-sp {
        margin-left: 3rem !important
    }

    .u-mr-30-sp {
        margin-right: 3rem !important
    }

    .u-mt-35-sp {
        margin-top: 3.5rem !important
    }

    .u-mb-35-sp {
        margin-bottom: 3.5rem !important
    }

    .u-ml-35-sp {
        margin-left: 3.5rem !important
    }

    .u-mr-35-sp {
        margin-right: 3.5rem !important
    }

    .u-mt-40-sp {
        margin-top: 4rem !important
    }

    .u-mb-40-sp {
        margin-bottom: 4rem !important
    }

    .u-ml-40-sp {
        margin-left: 4rem !important
    }

    .u-mr-40-sp {
        margin-right: 4rem !important
    }

    .u-mt-45-sp {
        margin-top: 4.5rem !important
    }

    .u-mb-45-sp {
        margin-bottom: 4.5rem !important
    }

    .u-ml-45-sp {
        margin-left: 4.5rem !important
    }

    .u-mr-45-sp {
        margin-right: 4.5rem !important
    }

    .u-mt-50-sp {
        margin-top: 5rem !important
    }

    .u-mb-50-sp {
        margin-bottom: 5rem !important
    }

    .u-ml-50-sp {
        margin-left: 5rem !important
    }

    .u-mr-50-sp {
        margin-right: 5rem !important
    }

    .u-mt-55-sp {
        margin-top: 5.5rem !important
    }

    .u-mb-55-sp {
        margin-bottom: 5.5rem !important
    }

    .u-ml-55-sp {
        margin-left: 5.5rem !important
    }

    .u-mr-55-sp {
        margin-right: 5.5rem !important
    }

    .u-mt-60-sp {
        margin-top: 6rem !important
    }

    .u-mb-60-sp {
        margin-bottom: 6rem !important
    }

    .u-ml-60-sp {
        margin-left: 6rem !important
    }

    .u-mr-60-sp {
        margin-right: 6rem !important
    }

    .u-mt-65-sp {
        margin-top: 6.5rem !important
    }

    .u-mb-65-sp {
        margin-bottom: 6.5rem !important
    }

    .u-ml-65-sp {
        margin-left: 6.5rem !important
    }

    .u-mr-65-sp {
        margin-right: 6.5rem !important
    }

    .u-mt-70-sp {
        margin-top: 7rem !important
    }

    .u-mb-70-sp {
        margin-bottom: 7rem !important
    }

    .u-ml-70-sp {
        margin-left: 7rem !important
    }

    .u-mr-70-sp {
        margin-right: 7rem !important
    }

    .u-mt-75-sp {
        margin-top: 7.5rem !important
    }

    .u-mb-75-sp {
        margin-bottom: 7.5rem !important
    }

    .u-ml-75-sp {
        margin-left: 7.5rem !important
    }

    .u-mr-75-sp {
        margin-right: 7.5rem !important
    }
}

.u-p-0 {
    padding: 0rem !important
}

.u-pt-0 {
    padding-top: 0rem !important
}

.u-pb-0 {
    padding-bottom: 0rem !important
}

.u-pl-0 {
    padding-left: 0rem !important
}

.u-pr-0 {
    padding-right: 0rem !important
}

.u-p-5 {
    padding: .5rem !important
}

.u-pt-5 {
    padding-top: .5rem !important
}

.u-pb-5 {
    padding-bottom: .5rem !important
}

.u-pl-5 {
    padding-left: .5rem !important
}

.u-pr-5 {
    padding-right: .5rem !important
}

.u-p-10 {
    padding: 1rem !important
}

.u-pt-10 {
    padding-top: 1rem !important
}

.u-pb-10 {
    padding-bottom: 1rem !important
}

.u-pl-10 {
    padding-left: 1rem !important
}

.u-pr-10 {
    padding-right: 1rem !important
}

.u-p-15 {
    padding: 1.5rem !important
}

.u-pt-15 {
    padding-top: 1.5rem !important
}

.u-pb-15 {
    padding-bottom: 1.5rem !important
}

.u-pl-15 {
    padding-left: 1.5rem !important
}

.u-pr-15 {
    padding-right: 1.5rem !important
}

.u-p-20 {
    padding: 2rem !important
}

.u-pt-20 {
    padding-top: 2rem !important
}

.u-pb-20 {
    padding-bottom: 2rem !important
}

.u-pl-20 {
    padding-left: 2rem !important
}

.u-pr-20 {
    padding-right: 2rem !important
}

.u-p-25 {
    padding: 2.5rem !important
}

.u-pt-25 {
    padding-top: 2.5rem !important
}

.u-pb-25 {
    padding-bottom: 2.5rem !important
}

.u-pl-25 {
    padding-left: 2.5rem !important
}

.u-pr-25 {
    padding-right: 2.5rem !important
}

.u-p-30 {
    padding: 3rem !important
}

.u-pt-30 {
    padding-top: 3rem !important
}

.u-pb-30 {
    padding-bottom: 3rem !important
}

.u-pl-30 {
    padding-left: 3rem !important
}

.u-pr-30 {
    padding-right: 3rem !important
}

.u-p-35 {
    padding: 3.5rem !important
}

.u-pt-35 {
    padding-top: 3.5rem !important
}

.u-pb-35 {
    padding-bottom: 3.5rem !important
}

.u-pl-35 {
    padding-left: 3.5rem !important
}

.u-pr-35 {
    padding-right: 3.5rem !important
}

.u-p-40 {
    padding: 4rem !important
}

.u-pt-40 {
    padding-top: 4rem !important
}

.u-pb-40 {
    padding-bottom: 4rem !important
}

.u-pl-40 {
    padding-left: 4rem !important
}

.u-pr-40 {
    padding-right: 4rem !important
}

.u-p-45 {
    padding: 4.5rem !important
}

.u-pt-45 {
    padding-top: 4.5rem !important
}

.u-pb-45 {
    padding-bottom: 4.5rem !important
}

.u-pl-45 {
    padding-left: 4.5rem !important
}

.u-pr-45 {
    padding-right: 4.5rem !important
}

.u-p-50 {
    padding: 5rem !important
}

.u-pt-50 {
    padding-top: 5rem !important
}

.u-pb-50 {
    padding-bottom: 5rem !important
}

.u-pl-50 {
    padding-left: 5rem !important
}

.u-pr-50 {
    padding-right: 5rem !important
}

.u-p-55 {
    padding: 5.5rem !important
}

.u-pt-55 {
    padding-top: 5.5rem !important
}

.u-pb-55 {
    padding-bottom: 5.5rem !important
}

.u-pl-55 {
    padding-left: 5.5rem !important
}

.u-pr-55 {
    padding-right: 5.5rem !important
}

.u-p-60 {
    padding: 6rem !important
}

.u-pt-60 {
    padding-top: 6rem !important
}

.u-pb-60 {
    padding-bottom: 6rem !important
}

.u-pl-60 {
    padding-left: 6rem !important
}

.u-pr-60 {
    padding-right: 6rem !important
}

.u-p-65 {
    padding: 6.5rem !important
}

.u-pt-65 {
    padding-top: 6.5rem !important
}

.u-pb-65 {
    padding-bottom: 6.5rem !important
}

.u-pl-65 {
    padding-left: 6.5rem !important
}

.u-pr-65 {
    padding-right: 6.5rem !important
}

.u-p-70 {
    padding: 7rem !important
}

.u-pt-70 {
    padding-top: 7rem !important
}

.u-pb-70 {
    padding-bottom: 7rem !important
}

.u-pl-70 {
    padding-left: 7rem !important
}

.u-pr-70 {
    padding-right: 7rem !important
}

.u-p-75 {
    padding: 7.5rem !important
}

.u-pt-75 {
    padding-top: 7.5rem !important
}

.u-pb-75 {
    padding-bottom: 7.5rem !important
}

.u-pl-75 {
    padding-left: 7.5rem !important
}

.u-pr-75 {
    padding-right: 7.5rem !important
}

.u-p-80 {
    padding: 8rem !important
}

.u-pt-80 {
    padding-top: 8rem !important
}

.u-pb-80 {
    padding-bottom: 8rem !important
}

.u-pl-80 {
    padding-left: 8rem !important
}

.u-pr-80 {
    padding-right: 8rem !important
}

.u-p-85 {
    padding: 8.5rem !important
}

.u-pt-85 {
    padding-top: 8.5rem !important
}

.u-pb-85 {
    padding-bottom: 8.5rem !important
}

.u-pl-85 {
    padding-left: 8.5rem !important
}

.u-pr-85 {
    padding-right: 8.5rem !important
}

.u-p-90 {
    padding: 9rem !important
}

.u-pt-90 {
    padding-top: 9rem !important
}

.u-pb-90 {
    padding-bottom: 9rem !important
}

.u-pl-90 {
    padding-left: 9rem !important
}

.u-pr-90 {
    padding-right: 9rem !important
}

.u-p-95 {
    padding: 9.5rem !important
}

.u-pt-95 {
    padding-top: 9.5rem !important
}

.u-pb-95 {
    padding-bottom: 9.5rem !important
}

.u-pl-95 {
    padding-left: 9.5rem !important
}

.u-pr-95 {
    padding-right: 9.5rem !important
}

.u-p-100 {
    padding: 10rem !important
}

.u-pt-100 {
    padding-top: 10rem !important
}

.u-pb-100 {
    padding-bottom: 10rem !important
}

.u-pl-100 {
    padding-left: 10rem !important
}

.u-pr-100 {
    padding-right: 10rem !important
}

@media screen and (max-width: 768px) {
    .u-p-0-sp {
        padding: 0rem !important
    }

    .u-pt-0-sp {
        padding-top: 0rem !important
    }

    .u-pb-0-sp {
        padding-bottom: 0rem !important
    }

    .u-pl-0-sp {
        padding-left: 0rem !important
    }

    .u-pr-0-sp {
        padding-right: 0rem !important
    }

    .u-p-5-sp {
        padding: .5rem !important
    }

    .u-pt-5-sp {
        padding-top: .5rem !important
    }

    .u-pb-5-sp {
        padding-bottom: .5rem !important
    }

    .u-pl-5-sp {
        padding-left: .5rem !important
    }

    .u-pr-5-sp {
        padding-right: .5rem !important
    }

    .u-p-10-sp {
        padding: 1rem !important
    }

    .u-pt-10-sp {
        padding-top: 1rem !important
    }

    .u-pb-10-sp {
        padding-bottom: 1rem !important
    }

    .u-pl-10-sp {
        padding-left: 1rem !important
    }

    .u-pr-10-sp {
        padding-right: 1rem !important
    }

    .u-p-15-sp {
        padding: 1.5rem !important
    }

    .u-pt-15-sp {
        padding-top: 1.5rem !important
    }

    .u-pb-15-sp {
        padding-bottom: 1.5rem !important
    }

    .u-pl-15-sp {
        padding-left: 1.5rem !important
    }

    .u-pr-15-sp {
        padding-right: 1.5rem !important
    }

    .u-p-20-sp {
        padding: 2rem !important
    }

    .u-pt-20-sp {
        padding-top: 2rem !important
    }

    .u-pb-20-sp {
        padding-bottom: 2rem !important
    }

    .u-pl-20-sp {
        padding-left: 2rem !important
    }

    .u-pr-20-sp {
        padding-right: 2rem !important
    }

    .u-p-25-sp {
        padding: 2.5rem !important
    }

    .u-pt-25-sp {
        padding-top: 2.5rem !important
    }

    .u-pb-25-sp {
        padding-bottom: 2.5rem !important
    }

    .u-pl-25-sp {
        padding-left: 2.5rem !important
    }

    .u-pr-25-sp {
        padding-right: 2.5rem !important
    }

    .u-p-30-sp {
        padding: 3rem !important
    }

    .u-pt-30-sp {
        padding-top: 3rem !important
    }

    .u-pb-30-sp {
        padding-bottom: 3rem !important
    }

    .u-pl-30-sp {
        padding-left: 3rem !important
    }

    .u-pr-30-sp {
        padding-right: 3rem !important
    }

    .u-p-35-sp {
        padding: 3.5rem !important
    }

    .u-pt-35-sp {
        padding-top: 3.5rem !important
    }

    .u-pb-35-sp {
        padding-bottom: 3.5rem !important
    }

    .u-pl-35-sp {
        padding-left: 3.5rem !important
    }

    .u-pr-35-sp {
        padding-right: 3.5rem !important
    }

    .u-p-40-sp {
        padding: 4rem !important
    }

    .u-pt-40-sp {
        padding-top: 4rem !important
    }

    .u-pb-40-sp {
        padding-bottom: 4rem !important
    }

    .u-pl-40-sp {
        padding-left: 4rem !important
    }

    .u-pr-40-sp {
        padding-right: 4rem !important
    }

    .u-p-45-sp {
        padding: 4.5rem !important
    }

    .u-pt-45-sp {
        padding-top: 4.5rem !important
    }

    .u-pb-45-sp {
        padding-bottom: 4.5rem !important
    }

    .u-pl-45-sp {
        padding-left: 4.5rem !important
    }

    .u-pr-45-sp {
        padding-right: 4.5rem !important
    }

    .u-p-50-sp {
        padding: 5rem !important
    }

    .u-pt-50-sp {
        padding-top: 5rem !important
    }

    .u-pb-50-sp {
        padding-bottom: 5rem !important
    }

    .u-pl-50-sp {
        padding-left: 5rem !important
    }

    .u-pr-50-sp {
        padding-right: 5rem !important
    }

    .u-p-55-sp {
        padding: 5.5rem !important
    }

    .u-pt-55-sp {
        padding-top: 5.5rem !important
    }

    .u-pb-55-sp {
        padding-bottom: 5.5rem !important
    }

    .u-pl-55-sp {
        padding-left: 5.5rem !important
    }

    .u-pr-55-sp {
        padding-right: 5.5rem !important
    }

    .u-p-60-sp {
        padding: 6rem !important
    }

    .u-pt-60-sp {
        padding-top: 6rem !important
    }

    .u-pb-60-sp {
        padding-bottom: 6rem !important
    }

    .u-pl-60-sp {
        padding-left: 6rem !important
    }

    .u-pr-60-sp {
        padding-right: 6rem !important
    }

    .u-p-65-sp {
        padding: 6.5rem !important
    }

    .u-pt-65-sp {
        padding-top: 6.5rem !important
    }

    .u-pb-65-sp {
        padding-bottom: 6.5rem !important
    }

    .u-pl-65-sp {
        padding-left: 6.5rem !important
    }

    .u-pr-65-sp {
        padding-right: 6.5rem !important
    }

    .u-p-70-sp {
        padding: 7rem !important
    }

    .u-pt-70-sp {
        padding-top: 7rem !important
    }

    .u-pb-70-sp {
        padding-bottom: 7rem !important
    }

    .u-pl-70-sp {
        padding-left: 7rem !important
    }

    .u-pr-70-sp {
        padding-right: 7rem !important
    }

    .u-p-75-sp {
        padding: 7.5rem !important
    }

    .u-pt-75-sp {
        padding-top: 7.5rem !important
    }

    .u-pb-75-sp {
        padding-bottom: 7.5rem !important
    }

    .u-pl-75-sp {
        padding-left: 7.5rem !important
    }

    .u-pr-75-sp {
        padding-right: 7.5rem !important
    }

    .u-p-80-sp {
        padding: 8rem !important
    }

    .u-pt-80-sp {
        padding-top: 8rem !important
    }

    .u-pb-80-sp {
        padding-bottom: 8rem !important
    }

    .u-pl-80-sp {
        padding-left: 8rem !important
    }

    .u-pr-80-sp {
        padding-right: 8rem !important
    }

    .u-p-85-sp {
        padding: 8.5rem !important
    }

    .u-pt-85-sp {
        padding-top: 8.5rem !important
    }

    .u-pb-85-sp {
        padding-bottom: 8.5rem !important
    }

    .u-pl-85-sp {
        padding-left: 8.5rem !important
    }

    .u-pr-85-sp {
        padding-right: 8.5rem !important
    }

    .u-p-90-sp {
        padding: 9rem !important
    }

    .u-pt-90-sp {
        padding-top: 9rem !important
    }

    .u-pb-90-sp {
        padding-bottom: 9rem !important
    }

    .u-pl-90-sp {
        padding-left: 9rem !important
    }

    .u-pr-90-sp {
        padding-right: 9rem !important
    }

    .u-p-95-sp {
        padding: 9.5rem !important
    }

    .u-pt-95-sp {
        padding-top: 9.5rem !important
    }

    .u-pb-95-sp {
        padding-bottom: 9.5rem !important
    }

    .u-pl-95-sp {
        padding-left: 9.5rem !important
    }

    .u-pr-95-sp {
        padding-right: 9.5rem !important
    }

    .u-p-100-sp {
        padding: 10rem !important
    }

    .u-pt-100-sp {
        padding-top: 10rem !important
    }

    .u-pb-100-sp {
        padding-bottom: 10rem !important
    }

    .u-pl-100-sp {
        padding-left: 10rem !important
    }

    .u-pr-100-sp {
        padding-right: 10rem !important
    }
}

.u-textCenter {
    text-align: center
}

.u-textRight {
    text-align: right
}

.u-textLeft {
    text-align: left
}

@media screen and (max-width: 768px) {
    .u-textCenter-sp {
        text-align: center
    }

    .u-textRight-sp {
        text-align: right
    }

    .u-textLeft-sp {
        text-align: left
    }
}

.u-visuallyHidden {
    position: absolute !important;
    overflow: hidden;
    width: .1rem;
    height: .1rem;
    margin: -.1rem;
    padding: 0;
    border: 0;
    clip: rect(0 0 0 0);
    word-wrap: normal !important
}





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

@media screen and (max-width: 768px) {
    .spno{ display: none;}
}