<html><head><meta name="color-scheme" content="light dark"></head><body><pre style="word-wrap: break-word; white-space: pre-wrap;">@import url('https://fonts.googleapis.com/css2?family=M+PLUS+2:wght@100..900&amp;display=swap');
@import url("https://fonts.googleapis.com/css2?family=BIZ+UDGothic:wght@400;700&amp;display=swap");
@import url("https://fonts.googleapis.com/css2?family=Inter:ital,opsz,wght@0,14..32,100..900;1,14..32,100..900&amp;display=swap");
@import url("https://fonts.googleapis.com/css2?family=Noto+Serif+JP:wght@300;400;500;600;700;900&amp;display=swap");
@import url("https://fonts.googleapis.com/css2?family=Archivo:ital,wght@0,100..900;1,100..900&amp;display=swap");

:root {
    --color-primary: #d4056c;
    --color-primary-rgb: 212, 5, 108;
    --color-primary-contrast: #fff;
    --color-primary-contrast-rgb: 255, 255, 255;
    --color-secondary: #007199;
    --color-secondary-rgb: 0, 113, 153;
    --color-secondary-contrast: #ffffff;
    --color-secondary-contrast-rgb: 255, 255, 255;
    --color-tertiary: #909090;
    --color-tertiary-rgb: 144, 144, 144;
    --color-tertiary-contrast: #ffffff;
    --color-tertiary-contrast-rgb: 255, 255, 255;
    --color-text-primary: #000;
    --color-text-secondary: #fff;
    --color-text-disabled: #999999;
    --color-link: #0066cc;
    --font-family-base: "M PLUS 2", sans-serif;
    --font-family-english: "Inter", "M PLUS 2", sans-serif;
    --font-size-base: clamp(1rem, 0.708rem + 0.46vw, 1.25rem)
}

html {
    -webkit-text-size-adjust: 100%;
    -ms-text-size-adjust: 100%;
    -webkit-background-size: cover;
    -moz-background-size: cover;
    -o-background-size: cover;
    background-size: cover
}

html {
    box-sizing: border-box
}

*, *:before, *:after {
    box-sizing: inherit
}

:root {
    scroll-padding-top: 100px
}

html, body {
    height: 100%
}

body {
    font-family: var(--font-family-base);
    font-weight: 400;
    font-style: normal;
    font-feature-settings: "palt";
    color: #2f2725;
    background: #fff;
    line-height: 1.85em;
    text-decoration: none;
    text-align: left;
    margin: 0;
    padding: 0
}

.nopc {
    display: none
}

@media only screen and (max-width: 768px) {
    .nopc {
        display: block
    }

    .nosp {
        display: none !important
    }
}

img {
    max-width: 100%;
    margin: 0;
    padding: 0;
    line-height: 0;
    vertical-align: bottom;
    object-fit: contain
}

img.w350 {
    width: 350px !important
}

img.w450 {
    width: 450px !important
}

img.w50per {
    width: 50% !important
}

img.w70per {
    width: 70% !important
}

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

.float-img-left {
    float: left;
    margin: 5px 0.5em 0.5em 0
}

.float-img-right {
    float: right;
    margin: 5px 0 0.5em 0.5em
}

.float-img-left.w50per, .float-img-right.w50per {
    width: 50% !important
}

@media only screen and (max-width: 768px) {
    .float-img-left {
        float: none;
        margin: 0 auto 20px
    }

    .float-img-right {
        float: none;
        margin: 0 auto 20px
    }

    .float-img-left.w50per, .float-img-right.w50per {
        width: 100% !important
    }
}

.nomg {
    margin: 0 !important
}

.mgauto {
    margin: 0 auto !important
}

.mt10 {
    margin-top: 10px !important
}

.mt20 {
    margin-top: 20px !important
}

.mt40 {
    margin-top: 40px !important
}

.mt50 {
    margin-top: 50px !important
}

.mt60 {
    margin-top: 60px !important
}

.mt80 {
    margin-top: 80px !important
}

.mt100 {
    margin-top: 100px !important
}

.mt130 {
    margin-top: 130px !important
}

.mt-65 {
    margin-top: -65px !important
}

.mb10 {
    margin-bottom: 10px !important
}

.mb20 {
    margin-bottom: 20px !important
}

.mb40 {
    margin-bottom: 40px !important
}

.mb60 {
    margin-bottom: 60px !important
}

.mb100 {
    margin-bottom: 100px !important
}

.mb130 {
    margin-bottom: 130px !important
}

@media only screen and (max-width: 768px) {
    .mt0-sp {
        margin-top: 0 !important
    }

    .mb0-sp {
        margin-bottom: 0 !important
    }
}

.nopd {
    padding: 0 !important
}

.pdtb60 {
    padding-top: 60px !important;
    padding-bottom: 60px !important
}

.pdtb70 {
    padding-top: 70px !important;
    padding-bottom: 70px !important
}

.pdtb80 {
    padding-top: 80px !important;
    padding-bottom: 80px !important
}

.pdlr60 {
    padding-left: 60px !important;
    padding-right: 60px !important
}

.pdlr80 {
    padding-left: 80px !important;
    padding-right: 80px !important
}

.pdlr120 {
    padding-left: 120px !important;
    padding-right: 120px !important
}

.pdl100 {
    padding-left: 100px !important
}

@media only screen and (max-width: 768px) {
    .pdlr15-sp {
        padding-left: 15px !important;
        padding-right: 15px !important
    }

    .pdlr40-sp {
        padding-left: 40px !important;
        padding-right: 40px !important
    }

    .pdlr60-sp {
        padding-left: 60px !important;
        padding-right: 60px !important
    }

    .pdl15-sp {
        padding-left: 15px !important;
        padding-right: 0 !important
    }

    .pdl40-sp {
        padding-left: 40px !important;
        padding-right: 0 !important
    }

    .pdl60-sp {
        padding-left: 60px !important;
        padding-right: 0 !important
    }
}

.t-c {
    text-align: center !important
}

.t-l {
    text-align: left !important
}

.t-r {
    text-align: right !important
}

@media only screen and (max-width: 768px) {
    .t-c-sp {
        text-align: center !important
    }

    .t-l-sp {
        text-align: left !important
    }

    .t-r-sp {
        text-align: right !important
    }
}

.d-ib {
    display: inline-block !important
}

.w-fc {
    width: fit-content !important
}

a.trans {
    transition: all .3s
}

a.trans:link {
    text-decoration: none;
    color: #fff;
    display: inline-block;
    filter: alpha(opacity=60);
    -moz-opacity: 1;
    opacity: 1;
    vertical-align: bottom
}

a.trans:visited {
    text-decoration: none;
    color: #fff;
    display: inline-block;
    filter: alpha(opacity=60);
    -moz-opacity: 1;
    opacity: 1;
    vertical-align: bottom
}

a.trans:hover {
    text-decoration: none;
    color: #fff;
    display: inline-block;
    filter: alpha(opacity=100);
    -moz-opacity: 0.60;
    opacity: 0.60;
    vertical-align: bottom
}

a.trans:active {
    text-decoration: none;
    color: #fff;
    display: inline-block;
    filter: alpha(opacity=60);
    -moz-opacity: 1;
    opacity: 1;
    vertical-align: bottom
}

a.line {
    color: var(--color-primary);
    font-weight: 700;
    position: relative;
    display: inline-block;
    transition: .3s
}

a.line::after {
    position: absolute;
    bottom: 0;
    left: 0;
    content: '';
    width: 0;
    height: 1px;
    background-color: #f90000;
    transition: .3s
}

a.line:hover {
    color: #f90000
}

a.line:hover::after {
    width: 100%
}

.arrowScroll {
    width: 40px;
    height: 40px;
    border: 2px solid #07f;
    border-radius: 50%;
    position: relative;
    animation: scroll_r 1.5s infinite;
    -webkit-animation: scroll_r 1.5s infinite;
    margin: 1em auto 0 auto
}

.arrowScroll::before {
    content: '';
    position: absolute;
    top: 9px;
    left: 8px;
    width: 16px;
    height: 16px;
    border-left: 2px solid #07f;
    border-bottom: 2px solid #07f;
    transform: rotate(225deg)
}

@keyframes scroll_r {
    0% {
        transform: translate(0)
    }

    20% {
        transform: translateX(15px)
    }

    40% {
        transform: translate(0)
    }
}

.material-icons {
    vertical-align: middle
}

.clearfix:before, .clearfix:after {
    content: "";
    display: table
}

.clearfix:after {
    clear: both
}

.clearfix {
    *zoom: 1
}

*, *:before, *:after {
    -webkit-box-sizing: border-box;
    box-sizing: border-box
}

.container {
    display: flex;
    padding: 0;
    margin: 0
}

header.headerwrap {
    background: #fff;
    text-align: center;
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    align-items: center;
    height: 110px;
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    padding: 0 0 0 20px;
    margin: 20px 40px 0 40px;
    border-radius: 10px;
    box-shadow: 0 7px 10px rgba(0, 0, 0, 0.05);
    z-index: 9900;
    transition: ease-out 1.2s all
}

header.headerwrap .header-logo {
    margin-right: auto;
    transition: ease-out 1.2s all
}

header.headerwrap .header-logo a {
    display: flex;
    align-items: center
}

header.headerwrap .header-logo a img {
    width: auto;
    height: 80px;
    transition: ease-out 1.2s all
}

header.headerwrap.headerwrap-home {
    background: rgba(255, 255, 255, 0);
    box-shadow: none
}

header.headerwrap.scroll-up {
    background: #fff;
    box-shadow: 0 7px 10px rgba(0, 0, 0, 0.05);
    height: 80px
}

header.headerwrap.scroll-up .header-logo a img {
    height: 60px
}

@media only screen and (max-width: 768px) {
    header.headerwrap {
        height: 100px;
        padding: 0 10px 0 20px;
        margin: 0;
        border-radius: 0
    }
}

.gnav {
    padding: 0;
    margin: 0;
    z-index: 9900
}

.gnav&gt;ul {
    display: flex;
    justify-content: flex-end;
    list-style: none;
    margin: 0;
    padding: 0 0 0 20px
}

.gnav&gt;ul&gt;li {
    width: fit-content;
    padding: 0 20px;
    color: #fff;
    display: flex;
    justify-content: center;
    align-items: center;
    height: 70px
}

.gnav&gt;ul&gt;li&gt;a, .gnav&gt;ul&gt;li .nolink {
    font-size: 1rem;
    font-weight: 400;
    color: #383838;
    background: rgba(255, 255, 255, 0);
    text-align: center;
    display: flex;
    flex-wrap: wrap;
    text-decoration: none;
    align-items: center;
    justify-content: center;
    flex-direction: column;
    align-content: center;
    position: relative;
    transition: all 0.3s
}

.gnav&gt;ul&gt;li&gt;a.btn-box, .gnav&gt;ul&gt;li .nolink.btn-box {
    color: #fff !important;
    background: var(--color-primary);
    padding: 10px 30px;
    border-radius: 10px;
    overflow: hidden;
    position: relative;
    display: flex;
    justify-content: center;
    align-items: center;
    transition: all .3s
}

.gnav&gt;ul&gt;li&gt;a.btn-box:hover:before, .gnav&gt;ul&gt;li .nolink.btn-box:hover:before {
    position: absolute;
    content: '';
    display: inline-block;
    top: 70px;
    left: 0;
    width: 600px;
    height: 100%;
    background-color: #fff;
    animation: kiran 1s ease-in-out infinite
}

@-webkit-keyframes kiran {
    0% {
        transform: scale(0) rotate(45deg);
        opacity: 0
    }

    80% {
        transform: scale(0) rotate(45deg);
        opacity: 0.5
    }

    81% {
        transform: scale(2) rotate(45deg);
        opacity: 1
    }

    100% {
        transform: scale(8) rotate(45deg);
        opacity: 0
    }
}


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

@media screen and (max-width: 768px) {
    .pc-only {
        display: none !important;
    }
}


.gnav&gt;ul&gt;li:hover&gt;a, .gnav&gt;ul&gt;li:hover .nolink {
    color: var(--color-primary)
}

.headerwrap-home .gnav&gt;ul {
    background: rgba(255, 255, 255, 0.5);
    backdrop-filter: blur(5px);
    border-radius: 10px
}

.headerwrap-home .gnav&gt;ul&gt;li&gt;a, .headerwrap-home .gnav&gt;ul&gt;li .nolink {
    color: #fff
}

.headerwrap-home .gnav&gt;ul&gt;li:hover&gt;a, .headerwrap-home .gnav&gt;ul&gt;li:hover .nolink {
    color: #f4a053
}

.headerwrap-home.scroll-up .gnav&gt;ul {
    background: none
}

.headerwrap-home.scroll-up .gnav&gt;ul&gt;li&gt;a, .headerwrap-home.scroll-up .gnav&gt;ul&gt;li .nolink {
    color: #383838
}

.headerwrap-home.scroll-up .gnav&gt;ul&gt;li:hover&gt;a, .headerwrap-home.scroll-up .gnav&gt;ul&gt;li:hover .nolink {
    color: #f4a053
}

@media screen and (min-width: 1024px) {
    .gnav&gt;ul .sub, .header-wrap.scroll-up .gnav&gt;ul .sub {
        opacity: 0;
        position: absolute;
        transition: all 0.3s;
        visibility: hidden;
        padding: 20px 0
    }

    .gnav&gt;ul .sub&gt;ul, .header-wrap.scroll-up .gnav&gt;ul .sub&gt;ul {
        margin: 0 auto;
        background-color: rgba(135, 95, 71, 0.85)
    }

    .gnav&gt;ul .sub&gt;ul&gt;li, .header-wrap.scroll-up .gnav&gt;ul .sub&gt;ul&gt;li {
        color: #fff;
        padding: 0.5em 0.85em 0.5em 1em;
        transition: all 0.3s;
        text-align: left;
        display: none;
        transition: all 0.3s
    }

    .gnav&gt;ul .sub&gt;ul&gt;li:first-child, .header-wrap.scroll-up .gnav&gt;ul .sub&gt;ul&gt;li:first-child {
        padding: 1.25em 0.85em 0.5em 1em
    }

    .gnav&gt;ul .sub&gt;ul&gt;li:last-child, .header-wrap.scroll-up .gnav&gt;ul .sub&gt;ul&gt;li:last-child {
        padding: 0.5em 0.85em 1.25em 1em
    }

    .gnav&gt;ul .sub&gt;ul&gt;li a, .header-wrap.scroll-up .gnav&gt;ul .sub&gt;ul&gt;li a {
        color: #fff;
        border-bottom: none;
        height: inherit;
        padding-left: 1em;
        border-bottom: none;
        text-align: left;
        position: relative;
        transition: all 0.3s
    }

    .gnav&gt;ul .sub&gt;ul&gt;li a::before, .header-wrap.scroll-up .gnav&gt;ul .sub&gt;ul&gt;li a::before {
        font-family: "Material Icons";
        content: "\e5cc";
        position: absolute;
        top: 50%;
        left: 0;
        margin-top: -0.7em
    }

    .gnav&gt;ul .sub&gt;ul&gt;li:hover a, .header-wrap.scroll-up .gnav&gt;ul .sub&gt;ul&gt;li:hover a {
        color: #f4d5c3
    }

    .gnav&gt;ul .sub&gt;ul&gt;li img, .header-wrap.scroll-up .gnav&gt;ul .sub&gt;ul&gt;li img {
        width: 160px;
        margin: 0 auto 1em auto
    }

    .gnav&gt;ul .sub a, .header-wrap.scroll-up .gnav&gt;ul .sub a {
        color: #fff;
        text-align: center;
        display: block
    }
}

.gnav-icon {
    display: none
}

@media screen and (max-width: 1024px) {
    .gnav-header {
        background: rgba(255, 255, 255, 0.85);
        width: 15%;
        z-index: 9999
    }

    .gnav&gt;ul {
        background: rgba(255, 255, 255, 0.85);
        background-size: initial;
        background-attachment: scroll !important;
        display: none;
        backdrop-filter: blur(6px);
        padding: 110px 10px 10px 10px !important;
        border-radius: 0;
        left: 50%;
        position: absolute;
        transform: translate(-50%, 0%);
        width: 100%
    }

    .gnav&gt;ul li {
        width: 100%;
        margin-bottom: 20px;
        display: block
    }

    .gnav&gt;ul li a, .gnav&gt;ul li div.nav-sub {
        font-size: 21px;
        border-bottom: 1px solid #707070;
        border-right: none;
        color: #000;
        font-weight: 700;
        padding: 0 1em 20px 1em;
        text-align: left;
        display: flex;
        flex-wrap: wrap;
        text-decoration: none;
        justify-content: center;
        flex-direction: column;
        align-content: flex-start;
        align-items: flex-start;
        height: inherit
    }

    .gnav&gt;ul li a span, .gnav&gt;ul li div.nav-sub span {
        font-size: 1.4rem
    }

    .gnav&gt;ul li a:last-child a, .gnav&gt;ul li div.nav-sub:last-child a {
        border-bottom: none
    }

    .gnav&gt;ul li a.nav-sub, .gnav&gt;ul li div.nav-sub {
        position: relative
    }

    .gnav&gt;ul li a.nav-sub::after, .gnav&gt;ul li div.nav-sub::after {
        content: '';
        display: block;
        height: 11px;
        width: 8px;
        position: absolute;
        top: 50%;
        right: 15px;
        background: url("/official2024/wp-content/themes/conlabo/img/arrow.svg") no-repeat;
        -webkit-transform: translateY(-50%) rotate(90deg);
        -ms-transform: translateY(-50%) rotate(90deg);
        transform: translateY(-50%) rotate(90deg);
        transition: transform 0.2s
    }

    .gnav&gt;ul li .sub&gt;ul {
        background: rgba(5, 63, 106, 0.3)
    }

    .gnav&gt;ul li .sub&gt;ul&gt;li img {
        display: none
    }

    .gnav&gt;ul li a.sub_open, .gnav&gt;ul li div.sub_open {
        background: rgba(5, 63, 106, 0.6)
    }

    .gnav&gt;ul li a.sub_open::after, .gnav&gt;ul li div.sub_open::after {
        -webkit-transform: translateY(-50%) rotate(-90deg);
        -ms-transform: translateY(-50%) rotate(-90deg);
        transform: translateY(-50%) rotate(-90deg)
    }

    .gnav-icon {
        color: #999;
        cursor: pointer;
        display: inline-block;
        font-size: 28px;
        position: absolute;
        right: 5px;
        top: 15px;
        z-index: 2
    }

    .headerwrap-home .gnav&gt;ul {
        background: rgba(255, 255, 255, 0.85);
        backdrop-filter: blur(6px);
        padding: 110px 0 0 0 !important;
        border-radius: 0
    }

    .headerwrap-home .gnav&gt;ul li a {
        color: #707070
    }
}

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

    .gnav {
        left: 0;
        position: fixed;
        top: 0;
        width: 100%;
        z-index: -1
    }

    .nav {
        height: 100vh;
        overflow: auto;
        -webkit-overflow-scrolling: touch
    }

    .gnav-icon {
        display: none
    }

    .menu-icon {
        display: flex;
        justify-content: center;
        align-items: center;
        right: 0;
        top: 0;
        cursor: pointer;
        padding: 24px 14px;
        -webkit-tap-highlight-color: transparent;
        height: 100%
    }

    .navicon {
        background: #707070;
        display: block;
        height: 3px;
        width: 26px;
        position: relative;
        transition: 0.3192s cubic-bezier(0.04, 0.04, 0.12, 0.96) 0.1008s
    }

    .navicon:before, .navicon:after {
        content: "";
        display: block;
        height: 100%;
        width: 100%;
        position: absolute;
        background: #707070;
        transition: 0.3192s cubic-bezier(0.04, 0.04, 0.12, 0.96) 0.1008s
    }

    .navicon:before {
        top: 9px
    }

    .navicon:after {
        bottom: 9px
    }

    .tel-btn a i {
        color: #174dfd;
        font-size: 3rem
    }

    .gnav-icon:checked~.menu-icon .navicon:before {
        transform: rotate(-45deg)
    }

    .gnav-icon:checked~.menu-icon .navicon:after {
        transform: rotate(45deg)
    }

    .gnav-icon:checked~.menu-icon:not(.steps) .navicon:before {
        top: 0
    }

    .gnav-icon:checked~.menu-icon:not(.steps) .navicon:after {
        bottom: 0
    }

    .gnav-icon:checked~.menu-icon .navicon {
        background: transparent;
        transition: 0.2192s cubic-bezier(0.04, 0.04, 0.12, 0.96) 0.1008s
    }
}

#js-nav.subnav {
    background: #7ecef6;
    width: 100%;
    position: fixed;
    bottom: 0;
    z-index: 1000
}

#js-nav.subnav ul {
    width: 100%;
    max-width: 1200px;
    margin: 0 auto;
    display: flex
}

#js-nav.subnav ul li {
    flex: 1
}

#js-nav.subnav ul li a {
    color: #000;
    background: #7ecef6;
    padding: 20px 40px;
    display: block;
    text-align: center;
    border-right: 1px solid #fff;
    border-left: 1px solid #fff;
    transition: all 0.3s
}

#js-nav.subnav ul li a.active {
    color: #fff;
    background: var(--color-secondary)
}

#js-nav.subnav ul li a:hover {
    color: #fff;
    background: var(--color-secondary)
}

@media only screen and (max-width: 768px) {
    #js-nav.subnav ul li a {
        padding: 15px 5px;
        font-size: 14px
    }
}

.splide .splide__track .splide__slide img {
    width: 100%;
    height: auto;
    object-fit: cover;
    border-radius: 20px
}

.splide .splide__track .splide__slide figure figcaption {
    font-size: var(--font-size-base);
    margin-top: 0.35em
}

.splide .splide__arrows .splide__arrow {
    position: absolute;
    top: calc(50% - 15px);
    transform: translateY(-50%);
    width: 40px;
    height: 40px;
    border: none;
    display: flex;
    justify-content: center;
    align-items: center;
    cursor: pointer;
    transition: all 0.3s
}

.splide .splide__arrows .splide__arrow--prev {
    left: 40px;
    transform: translateY(-50%) scale(-1, 1)
}

.splide .splide__arrows .splide__arrow--next {
    right: 40px
}

.splide .splide__arrows .splide__arrow--prev, .splide .splide__arrows .splide__arrow--next {
    z-index: 100
}

.splide .splide__arrows .arrow_btn {
    background-color: transparent;
    transition: .2s
}

.splide .splide__arrows .arrow_btn::before {
    content: "";
    display: inline-block;
    vertical-align: middle;
    color: #fff;
    line-height: 1;
    width: 40px;
    height: 40px;
    border: 5px solid #fff;
    border-left: 0;
    border-bottom: 0;
    box-sizing: border-box;
    transform: translateX(-25%) rotate(45deg)
}

.splide .splide__arrows .arrow_btn:hover::before {
    opacity: 0.65
}

.splide .splide__arrows .arrow_btn:disabled::before {
    border-color: #ccc
}

.splide .splide__arrows.gr .arrow_btn::before {
    color: #707070;
    border-color: #707070
}

.splide .splide__pagination {
    margin-top: 30px
}

.splide .splide__pagination .splide__pagination__page {
    width: 5px;
    height: 5px;
    margin: 0 20px;
    background: #fff;
    border-radius: 50%;
    transition: all 0.3s
}

.splide .splide__pagination .splide__pagination__page.is-active {
    background: #000
}

.splide .my-carousel-progress {
    background-color: #fff;
    margin-top: 70px
}

.splide .my-carousel-progress .my-carousel-progress-bar {
    background: var(--color-primary);
    height: 5px;
    transition: width 1000ms ease;
    width: 0
}

.splide.wh .splide__track .splide__slide figure figcaption {
    color: #fff
}

.splide.splide_loop .splide__track {
    position: relative
}

.splide.splide_loop .splide__track .splide__slide {
    display: flex;
    align-items: center;
    height: 100%
}

.splide.splide_loop .splide__track .splide__slide img {
    width: 280px;
    height: 206px;
    object-fit: cover;
    border-radius: 0
}

.splide.single {
    width: 1480px;
    margin: 0 auto
}

.splide.single .splide__track {
    position: relative
}

.splide.single .splide__track .splide__slide {
    width: 1160px;
    height: 660px
}

.splide.single .splide__track .splide__slide img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    border-radius: 0
}

.splide.single .splide__arrows .splide__arrow--prev {
    left: -100px
}

.splide.single .splide__arrows .splide__arrow--next {
    right: -100px
}

.splide.history .splide__track .splide__slide .slide_item {
    position: relative;
    background: #fff;
    padding: 135px 50px 40px 50px;
    border-radius: 30px
}

.splide.history .splide__track .splide__slide .slide_item .year {
    position: absolute;
    top: 0;
    right: -15px;
    color: var(--color-primary);
    font-family: var(--font-family-english);
    font-size: 110px;
    font-weight: 400;
    font-style: italic;
    line-height: 0.75em
}

.splide.history .splide__track .splide__slide .slide_item img {
    width: 100%;
    aspect-ratio: 9 / 6;
    object-fit: cover;
    border-radius: 20px
}

.splide.history .splide__track .splide__slide .slide_item .text-area p {
    font-size: 18px
}

.splide.history .splide__track .splide__slide .slide_item .text-area p strong {
    color: #000;
    font-size: 24px
}

.splide.history .splide__track .splide__slide .slide_item .text-area p+p {
    margin-top: 0.5em
}

.splide.history .splide__track.photo .splide__slide .slide_item {
    background: none;
    padding: 0
}

.splide.history .splide__track.photo .splide__slide .slide_item .text-area {
    padding: 10px 15px
}

.splide.history .splide__pagination {
    margin-top: 30px
}

.splide.history .splide__pagination .splide__pagination__page {
    width: 40px;
    height: 5px;
    margin: 0;
    background: #fff;
    border-radius: 0;
    transition: all 0.3s
}

.splide.history .splide__pagination .splide__pagination__page.is-active {
    background: var(--color-primary)
}

.splide.history .splide__arrows {
    margin-bottom: 30px
}

.splide.history .splide__arrows .splide__arrow {
    position: absolute;
    top: initial;
    transform: initial;
    bottom: 20px;
    width: 40px;
    height: 40px;
    display: flex;
    justify-content: center;
    align-items: center;
    border: 1px solid #666;
    border-radius: 100px;
    cursor: pointer;
    opacity: 1;
    transition: all 0.3s
}

.splide.history .splide__arrows .splide__arrow:hover {
    opacity: 0.45
}

.splide.history .splide__arrows .splide__arrow svg {
    margin: 5px
}

.splide.history .splide__arrows .splide__arrow svg path {
    fill: #666
}

.splide.history .splide__arrows .splide__arrow--prev {
    left: 20px;
    transform: scale(-1, 1)
}

.splide.history .splide__arrows .splide__arrow--next {
    left: 70px;
    right: initial
}

.splide.history .splide__arrows .splide__arrow--prev, .splide.history .splide__arrows .splide__arrow--next {
    z-index: 100
}

@media only screen and (max-width: 768px) {
    .splide .splide__track .splide__slide img {
        width: 100%;
        height: auto;
        object-fit: cover;
        border-radius: 20px
    }

    .splide .splide__track .splide__slide figure figcaption {
        font-size: var(--font-size-base);
        margin-top: 0.35em
    }

    .splide .splide__arrows .splide__arrow {
        position: absolute;
        top: 50%;
        transform: translateY(-50%);
        width: 20px;
        height: 20px;
        border: none;
        display: flex;
        justify-content: center;
        align-items: center;
        cursor: pointer;
        transition: all 0.3s
    }

    .splide .splide__arrows .splide__arrow--prev {
        left: 10px;
        transform: translateY(-50%) scale(-1, 1)
    }

    .splide .splide__arrows .splide__arrow--next {
        right: 10px
    }

    .splide .splide__arrows .splide__arrow--prev, .splide .splide__arrows .splide__arrow--next {
        z-index: 100
    }

    .splide .splide__arrows .arrow_btn {
        background-color: transparent;
        transition: .2s
    }

    .splide .splide__arrows .arrow_btn::before {
        content: "";
        display: inline-block;
        vertical-align: middle;
        color: #fff;
        line-height: 1;
        width: 20px;
        height: 20px;
        border: 5px solid #fff;
        border-left: 0;
        border-bottom: 0;
        box-sizing: border-box;
        transform: translateX(-25%) rotate(45deg)
    }

    .splide .splide__pagination {
        margin-top: 10px
    }

    .splide .splide__pagination .splide__pagination__page {
        width: 5px;
        height: 5px;
        margin: 0 20px;
        background: #fff;
        border-radius: 50%;
        transition: all 0.3s
    }

    .splide .splide__pagination .splide__pagination__page.is-active {
        background: #000
    }

    .splide .my-carousel-progress {
        margin-top: 70px
    }

    .splide .my-carousel-progress .my-carousel-progress-bar {
        background: var(--color-primary);
        height: 5px;
        transition: width 1000ms ease;
        width: 0
    }

    .splide.wh .splide__track .splide__slide figure figcaption {
        color: #fff
    }

    .splide.splide_loop .splide__track {
        position: relative
    }

    .splide.splide_loop .splide__track .splide__slide {
        display: flex;
        align-items: center;
        height: 100%
    }

    .splide.splide_loop .splide__track .splide__slide img {
        width: 280px;
        height: 206px;
        object-fit: cover;
        border-radius: 0
    }

    .splide.single {
        width: 1480px;
        margin: 0 auto
    }

    .splide.single .splide__track {
        position: relative
    }

    .splide.single .splide__track .splide__slide {
        width: 1160px;
        height: 660px
    }

    .splide.single .splide__track .splide__slide img {
        width: 100%;
        height: 100%;
        object-fit: cover;
        border-radius: 0
    }

    .splide.single .splide__arrows .splide__arrow--prev {
        left: -30px;
        top: calc(50% - 20px)
    }

    .splide.single .splide__arrows .splide__arrow--next {
        right: -30px;
        top: calc(50% - 20px)
    }

    .splide.history .splide__track .splide__slide .slide_item {
        position: relative;
        background: #fff;
        padding: 135px 50px 40px 50px;
        border-radius: 30px
    }

    .splide.history .splide__track .splide__slide .slide_item .year {
        position: absolute;
        top: 0;
        right: -15px;
        color: var(--color-primary);
        font-family: var(--font-family-english);
        font-size: 110px;
        font-weight: 400;
        font-style: italic;
        line-height: 0.75em
    }

    .splide.history .splide__track .splide__slide .slide_item img {
        width: 100%;
        aspect-ratio: 9 / 6;
        object-fit: cover;
        border-radius: 20px
    }

    .splide.history .splide__track .splide__slide .slide_item .text-area p {
        font-size: 18px
    }

    .splide.history .splide__track .splide__slide .slide_item .text-area p strong {
        color: #000;
        font-size: 24px
    }

    .splide.history .splide__track .splide__slide .slide_item .text-area p+p {
        margin-top: 0.5em
    }

    .splide.history .splide__track.photo .splide__slide .slide_item {
        background: none;
        padding: 0
    }

    .splide.history .splide__track.photo .splide__slide .slide_item .text-area {
        padding: 10px 15px
    }

    .splide.history .splide__pagination {
        margin-top: 30px
    }

    .splide.history .splide__pagination .splide__pagination__page {
        width: 40px;
        height: 5px;
        margin: 0;
        background: #fff;
        border-radius: 0;
        transition: all 0.3s
    }

    .splide.history .splide__pagination .splide__pagination__page.is-active {
        background: var(--color-primary)
    }

    .splide.history .splide__arrows {
        margin-bottom: 30px
    }

    .splide.history .splide__arrows .splide__arrow {
        position: absolute;
        top: initial;
        transform: initial;
        bottom: 20px;
        width: 40px;
        height: 40px;
        display: flex;
        justify-content: center;
        align-items: center;
        border: 1px solid #666;
        border-radius: 100px;
        cursor: pointer;
        opacity: 1;
        transition: all 0.3s
    }

    .splide.history .splide__arrows .splide__arrow:hover {
        opacity: 0.45
    }

    .splide.history .splide__arrows .splide__arrow svg {
        margin: 5px
    }

    .splide.history .splide__arrows .splide__arrow svg path {
        fill: #666
    }

    .splide.history .splide__arrows .splide__arrow--prev {
        left: 20px;
        transform: scale(-1, 1)
    }

    .splide.history .splide__arrows .splide__arrow--next {
        left: 70px;
        right: initial
    }

    .splide.history .splide__arrows .splide__arrow--prev, .splide.history .splide__arrows .splide__arrow--next {
        z-index: 100
    }
}

#main.splide .splide__track .splide__slide {
    opacity: 0.6
}

#main.splide .splide__track .splide__slide.is-active {
    opacity: 1
}

#main.splide .splide__track .splide__slide img {
    width: 100%;
    height: initial;
    aspect-ratio: 96 / 83;
    object-fit: cover;
    border-radius: 20px
}

#thumbnail.splide {
    margin: 0
}

#thumbnail.splide .splide__track .splide__list {
    display: grid;
    grid-template-columns: repeat(1, 1fr);
    gap: 20px
}

#thumbnail.splide .splide__track .splide__list .splide__slide {
    width: 100% !important;
    background: #000;
    border-radius: 10px
}

#thumbnail.splide .splide__track .splide__list .splide__slide img {
    width: 100%;
    height: initial;
    aspect-ratio: 5 / 4;
    object-fit: cover;
    border-radius: 10px;
    opacity: 1;
    transition: all 0.35s
}

#thumbnail.splide .splide__track .splide__list .splide__slide.is-active {
    width: 100% !important
}

#thumbnail.splide .splide__track .splide__list .splide__slide.is-active img {
    opacity: 0.6
}

@media only screen and (max-width: 768px) {
    #main.splide .splide__track .splide__slide img {
        aspect-ratio: 96 / 83;
        border-radius: 10px
    }

    #thumbnail.splide .splide__track .splide__list {
        grid-template-columns: repeat(3, 1fr)
    }

    #thumbnail.splide .splide__track .splide__list .splide__slide {
        border-radius: 5px
    }

    #thumbnail.splide .splide__track .splide__list .splide__slide img {
        aspect-ratio: 5 / 4;
        border-radius: 5px
    }
}

.lum-lightbox.lum-open {
    display: block;
    z-index: 9999
}

.lum-lightbox-inner img.lum-img {
    max-width: 100%;
    transition: opacity .62s ease-out
}

footer {
    color: #fff;
    background: #383838;
    width: 100%;
    padding: 75px 80px 100px 160px;
    margin: 0 auto;
    border-top: 1px solid #000
}

footer .footer-main {
    display: flex;
    width: 100%;
    margin: 0 auto 10px
}

footer .footer-main .info {
    width: 30%
}

footer .footer-main .info p {
    font-size: var(--font-size-base);
    line-height: 1.6em;
    margin-bottom: 20px
}

footer .footer-main .info p span {
    font-size: 2.2rem;
    line-height: 1
}

footer .footer-main .fnav {
    width: 40%;
    display: flex;
    justify-content: space-around
}

footer .footer-main .fnav ul {
    width: fit-content;
    list-style: none;
    padding: 0
}

footer .footer-main .fnav ul li {
    color: #fff;
    font-size: var(--font-size-base);
    line-height: 1;
    margin-bottom: 25px;
    text-align: left
}

footer .footer-main .fnav ul li span {
    font-size: 1.6rem
}

footer .footer-main .fnav ul li a {
    text-decoration: none;
    color: #fff;
    transition: all 0.5s
}

footer .footer-main .fnav ul li a:hover {
    text-decoration: none;
    color: #0077b6
}

footer .footer-main .fnav ul li ul {
    margin-top: 25px
}

footer .footer-main .fnav ul li ul li {
    padding: 0 0 0 20px;
    position: relative
}

footer .footer-main .fnav ul li ul li::before {
    content: "-";
    position: absolute;
    top: 50%;
    left: 0;
    transform: translateY(-50%)
}

footer .footer-main .contact {
    width: 30%;
    text-align: right
}

footer .footer-main .contact a.btn-box {
    color: #fff !important;
    background: #d4056c;
    padding: 20px 30px;
    border-radius: 10px;
    display: inline-block;
    width: 70%;
    text-align: center
}

footer .footer-sub {
    width: 100%;
    display: flex;
    justify-content: center;
    margin: 0 auto;
    position: relative
}

footer .footer-sub .copyright {
    color: #fff;
    font-size: var(--font-size-base)
}

footer .footer-sub .plivacy {
    font-size: 16px;
    position: absolute;
    right: 0
}

@media only screen and (max-width: 768px) {
    footer {
        padding: 30px 10px 80px 10px
    }

    footer .footer-main {
        flex-direction: column
    }

    footer .footer-main .info {
        width: 100%
    }

    footer .footer-main .info p {
        font-size: 21px;
        text-align: center
    }

    footer .footer-main .info p span {
        font-size: 1.8rem
    }

    footer .footer-main .fnav {
        width: 100%;
        margin-top: 20px
    }

    footer .footer-main .fnav ul li {
        font-size: 20px;
        line-height: 1;
        margin-bottom: 25px
    }

    footer .footer-main .fnav ul li span {
        font-size: 1.6rem
    }

    footer .footer-main .contact {
        width: 100%;
        text-align: center
    }

    footer .footer-main .contact a.btn-box {
        padding: 15px 20px;
        border-radius: 10px;
        width: 70%
    }

    footer .footer-sub {
        flex-direction: column-reverse;
        margin: 0 auto;
        position: relative
    }

    footer .footer-sub .copyright {
        text-align: center
    }

    footer .footer-sub .plivacy {
        text-align: center;
        position: relative;
        right: initial;
        margin: 15px auto
    }

    footer .footer-main {
        display: flex;
        flex-direction: column;
    }

    footer .footer-main .fnav {
        order: 2 !;
    }

    footer .footer-main .info {
        order: 1;
        margin: 30px 0;
    }

    footer .footer-main .contact {
        order: 3;
        margin-top: 20px
    }
}

.scroll_up {
    transition: 0.8s ease-in-out;
    transform: translateY(30px);
    opacity: 0
}

.scroll_up.on {
    transform: translateY(0);
    opacity: 1.0
}

.scroll_down {
    transition: 0.8s ease-in-out;
    transform: translateY(-30px);
    opacity: 0
}

.scroll_up.on {
    transform: translateY(0);
    opacity: 1.0
}

.scroll_left {
    transition: 0.8s ease-in-out;
    transform: translateX(-30px);
    opacity: 0;
    filter: alpha(opacity=0);
    -moz-opacity: 0
}

.scroll_left.on {
    opacity: 1.0;
    filter: alpha(opacity=100);
    -moz-opacity: 1.0;
    transform: translateX(0)
}

.scroll_right {
    transition: 0.8s ease-in-out;
    transform: translateX(30px);
    opacity: 0;
    filter: alpha(opacity=0);
    -moz-opacity: 0
}

.scroll_right.on {
    opacity: 1.0;
    filter: alpha(opacity=100);
    -moz-opacity: 1.0;
    transform: translateX(0)
}

.zoom_in {
    transition: 0.8s ease-in-out;
    transform: scale(0.75);
    opacity: 0
}

.zoom_in.on {
    transform: scale(1);
    opacity: 1.0
}

.rotate_3d {
    transition: 1.5s ease-in-out;
    perspective-origin: 365px center;
    perspective: 1000px;
    transform-origin: center top;
    transform: translate3d(0, 0, -300px) rotateZ(-3deg) rotateY(30deg) rotateX(-15deg);
    opacity: 0
}

.rotate_3d.on {
    transform: translate3d(0, 0, 0) rotateZ(0deg) rotateY(0deg) rotateX(0deg);
    transition: transform 1s cubic-bezier(0.23, 1, 0.32, 1) 0.2s, opacity 0.6s ease 0.2s;
    opacity: 1
}

.fade_in {
    transition: 1.0s ease-in-out;
    opacity: 0;
    filter: alpha(opacity=0);
    -moz-opacity: 0
}

.fade_in.on {
    opacity: 1.0;
    filter: alpha(opacity=100);
    -moz-opacity: 1.0
}

.img_wrap_left {
    opacity: 0
}

.img_wrap_left.on {
    animation: img-opacity 1s cubic-bezier(0.4, 0, 0.2, 1) forwards;
    overflow: hidden;
    position: relative
}

.img_wrap_left.on::before {
    animation: img-animation 1s cubic-bezier(0.4, 0, 0.2, 1) forwards;
    background: #fff;
    content: '';
    inset: 0;
    pointer-events: none;
    position: absolute;
    z-index: 1
}

.img_wrap_right {
    opacity: 0
}

.img_wrap_right.on {
    animation: img-opacity 1s cubic-bezier(0.4, 0, 0.2, 1) forwards;
    overflow: hidden;
    position: relative
}

.img_wrap_right.on::before {
    animation: img-animation-r 1s cubic-bezier(0.4, 0, 0.2, 1) forwards;
    background: #fff;
    content: '';
    inset: 0;
    pointer-events: none;
    position: absolute;
    z-index: 1
}

@keyframes img-opacity {
    100% {
        opacity: 1
    }
}

@keyframes img-animation {
    100% {
        transform: translateX(100%)
    }
}

@keyframes img-animation-r {
    100% {
        transform: translateX(-100%)
    }
}

.timing02 {
    transition-delay: .2s
}

.timing03 {
    transition-delay: .4s
}

.timing04 {
    transition-delay: .6s
}

.timing05 {
    transition-delay: .8s
}

#contents {
    width: 100%;
    margin: 0 auto
}

.mov-area {
    text-align: left;
    width: 100%;
    height: 560px;
    margin: 0 auto;
    overflow: hidden;
    position: relative
}

.mov-area.top {
    height: 100vh
}

.mov-area video {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 100%;
    height: 100%;
    object-fit: cover
}

.mov-area .text-area {
    position: absolute;
    top: 50%;
    left: 160px;
    transform: translate(0, -50%)
}

.mov-area .text-area p {
    font-family: 'Noto Serif JP', serif;
    color: #fff;
    font-size: clamp(1.125rem, -0.125rem + 2vw, 2.25rem);
    line-height: 1.6em;
    text-shadow: 0 0 5px #000
}

.mov-area .text-area p span {
    font-size: clamp(2.125rem, -0.514rem + 4.22vw, 4.5rem);
    line-height: 1.4em;
    display: block;
    margin-bottom: 40px
}

@media only screen and (max-width: 768px) {
    .mov-area.top {
        height: 60vh
    }

    .mov-area .text-area {
        left: 20px
    }

    .mov-area .text-area p {
        font-size: clamp(1.125rem, -0.125rem + 2vw, 2.25rem)
    }

    .mov-area .text-area p span {
        font-size: clamp(2.000rem, -0.514rem + 4.22vw, 4.5rem);
        margin-bottom: 40px
    }
}

.title-wrap {
    padding: 110px 215px 115px 215px
}

.title-wrap.bggr {
    background: #efefef
}

.title-wrap .title-area {
    display: flex
}

.title-wrap .title-area h1 {
    width: 35%
}

.title-wrap .title-area h1.full {
    width: 100%
}

.title-wrap .title-area p {
    width: 65%;
    font-size: var(--font-size-base);
    line-height: 1.6em
}

.title-wrap.image {
    text-align: left;
    width: 100%;
    height: 500px;
    margin: 0 auto;
    overflow: hidden;
    position: relative
}

.title-wrap.image img {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 100%;
    height: 100%;
    object-fit: cover;
    z-index: -1
}

.title-wrap.image .title-area h1 {
    color: #fff;
    margin: 100px 0 0 0
}

.title-wrap.image .title-area p {
    color: #fff
}

.title-wrap.mov {
    text-align: left;
    width: 100%;
    height: 80vh;
    margin: 0 auto;
    overflow: hidden;
    position: relative
}

.title-wrap.mov video {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 100%;
    height: 100%;
    object-fit: cover;
    z-index: -1
}

.title-wrap.mov .title-area h1 {
    color: #fff;
    margin: 100px 0 0 0
}

.title-wrap.mov .title-area p {
    color: #fff
}

@media only screen and (max-width: 768px) {
    .title-wrap {
        padding: 130px 20px 40px 20px
    }

    .title-wrap .title-area {
        flex-direction: column
    }

    .title-wrap .title-area h1 {
        width: 100%
    }

    .title-wrap .title-area p {
        width: 100%;
        font-size: var(--font-size-base);
        line-height: 1.6em
    }

    .title-wrap.image {
        height: 500px
    }

    .title-wrap.image .title-area h1 {
        margin: 100px 0 0 0
    }

    .title-wrap.mov {
        height: 50vh
    }

    .title-wrap.mov .title-area h1 {
        margin: 50px 0 0 0
    }
}

section {
    width: 100%;
    position: relative;
    padding: 90px 0;
    margin: 0 auto
}

section.no-space {
    padding: 0
}

section.no-pdt {
    padding: 0 0 90px 0
}

section.bggr {
    background: #e6e6e6
}

section.bggr2 {
    background: #909090
}

section.bgbl {
    background: var(--color-secondary)
}

section.bgpk {
    background: #f1e7ec
}

section.bgpk.inset {
    width: calc(100% - 80px);
    margin: 95px 40px;
    border-radius: 20px
}

@media only screen and (max-width: 768px) {
    section.bgpk.inset {
        width: calc(100% - 20px);
        margin: 65px 10px;
        border-radius: 10px
    }
}

.inner {
    text-align: center;
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    justify-content: space-between;
    align-items: stretch;
    align-content: stretch;
    width: 100%;
    padding: 0 80px;
    margin: 0 auto;
    position: relative
}

.inner.full {
    max-width: inherit;
    margin: 0 auto
}

.inner.rr {
    flex-direction: row-reverse
}

.inner.h-center {
    justify-content: center
}

.inner.v-center {
    align-items: center;
    align-content: center
}

.inner.no-space {
    padding: 0;
    margin: 0 auto
}

.inner.type1 {
    padding: 0 135px
}

.inner.type2 {
    padding: 0 20px
}

.inner.type3 {
    padding: 0 0 0 135px
}

.inner.type4 {
    padding: 0 215px
}

.inner .side-title {
    position: absolute;
    top: 0;
    left: 80px;
    writing-mode: vertical-rl;
    font-family: "Archivo", sans-serif;
    font-size: 48px;
    font-weight: 400
}

.inner .side-title.rd {
    color: var(--color-primary)
}

.inner .side-title.bl {
    color: var(--color-secondary)
}

.inner .side-title.gw {
    color: var(--color-tertiary)
}

.inner .side-title.inside {
    left: 40px
}

.inner-area100 {
    text-align: left;
    width: 100%;
    padding: 0;
    align-self: auto
}

.inner-area75 {
    text-align: left;
    width: 75%;
    padding: 0 2%;
    align-self: auto
}

.inner-area70 {
    text-align: left;
    width: 70%;
    padding: 0 2%;
    align-self: auto
}

.inner-area60 {
    text-align: left;
    width: 60%;
    padding: 0 2%;
    align-self: auto
}

.inner-area50 {
    text-align: left;
    width: 50%;
    padding: 0 2%;
    align-self: auto
}

.inner-area40 {
    text-align: left;
    width: 40%;
    padding: 0 2%;
    align-self: auto
}

.inner-area33 {
    text-align: left;
    width: 33.3%;
    padding: 0 2%;
    align-self: auto
}

.inner-area30 {
    text-align: left;
    width: 30%;
    padding: 0 2%;
    align-self: auto
}

.inner-area25 {
    text-align: left;
    width: 25%;
    padding: 0 2%;
    align-self: auto
}

.inner-areaMenu {
    text-align: left;
    width: 25%;
    padding: 0 2%;
    align-self: auto
}

.inner-area100.t-c, .inner-area75.t-c, .inner-area70.t-c, .inner-area60.t-c, .inner-area50.t-c, .inner-area40.t-c, .inner-area33.t-c, .inner-area30.t-c, .inner-area25.t-c, .inner-areaMenu.t-c {
    text-align: center
}

.inner-area100.t-l, .inner-area75.t-l, .inner-area70.t-l, .inner-area60.t-l, .inner-area50.t-l, .inner-area40.t-l, .inner-area33.t-l, .inner-area30.t-l, .inner-area25.t-l, .inner-areaMenu.t-l {
    text-align: left
}

.inner-area100.t-r, .inner-area75.t-r, .inner-area70.t-r, .inner-area60.t-r, .inner-area50.t-r, .inner-area40.t-r, .inner-area33.t-r, .inner-area30.t-r, .inner-area25.t-r, .inner-areaMenu.t-r {
    text-align: right
}

.inner-area100.no-space, .inner-area75.no-space, .inner-area70.no-space, .inner-area60.no-space, .inner-area50.no-space, .inner-area40.no-space, .inner-area33.no-space, .inner-area30.no-space, .inner-area25.no-space, .inner-areaMenu.no-space {
    padding: 0;
    margin: 0 auto
}

.inner-area100.v-c, .inner-area75.v-c, .inner-area70.v-c, .inner-area60.v-c, .inner-area50.v-c, .inner-area40.v-c, .inner-area33.v-c, .inner-area30.v-c, .inner-area25.v-c, .inner-areaMenu.v-c {
    display: flex;
    flex-direction: column;
    justify-content: center;
    height: 50vh
}

@media only screen and (max-width: 768px) {
    .inner {
        line-height: 1.4em;
        flex-direction: column;
        padding: 0 10px;
        max-width: 768px
    }

    .inner.full {
        padding: 0
    }

    .inner.reverse {
        flex-direction: row-reverse
    }

    .inner.menu {
        flex-direction: row;
        flex-wrap: wrap;
        margin: 0 auto
    }

    .inner.type1 {
        padding: 0 20px
    }

    .inner.type2 {
        padding: 0 20px
    }

    .inner.type3 {
        padding: 0 0 0 20px
    }

    .inner.type4 {
        padding: 0 20px
    }

    .inner .side-title {
        top: 30px;
        left: 10px;
        font-size: 40px
    }

    .inner .side-title.inside {
        left: 10px
    }

    section.event .inner {
        margin: 0 auto
    }

    .inner-area100, .inner-area75, .inner-area70, .inner-area60, .inner-area50, .inner-area40, .inner-area33, .inner-area30, .inner-area25 {
        width: 100%;
        margin: 0 auto
    }

    .inner-area100.no-space, .inner-area75.no-space, .inner-area70.no-space, .inner-area60.no-space, .inner-area50.no-space, .inner-area40.no-space, .inner-area33.no-space, .inner-area30.no-space, .inner-area25.no-space {
        width: 100%;
        padding: 0 1em;
        margin: 0 auto
    }

    div[class*="inner-area"]+div[class*="inner-area"] {
        margin-top: 30px
    }
}

.inner p {
    font-size: var(--font-size-base);
    font-feature-settings: "palt";
    color: #000;
    line-height: 1.85em
}

.inner p strong {
    color: #0077b6;
    font-weight: 500;
    font-size: 2rem
}

.inner p.lead {
    color: #000;
    font-weight: 600;
    font-size: 4rem;
    line-height: 1.6em;
    margin: 0 auto 45px auto
}

.inner p.catch {
    font-size: 2.1rem;
    font-weight: 400
}

.inner p.catch.warning {
    color: #c00;
    line-height: 1.5em;
    margin: 0.6em auto 0 auto
}

.inner p.box {
    color: #000;
    font-size: 1.8rem;
    font-weight: 500;
    background: #fff;
    display: inline-block;
    padding: 0.25em 0.75em
}

.inner p.caution {
    color: #d00;
    text-indent: -1em;
    margin: 0 0 0 1em
}

.inner p.caution:before {
    content: "※"
}

.inner p.t-c {
    text-align: center
}

.inner p.t-r {
    text-align: right
}

.inner p.wh {
    color: #fff
}

.inner p+p, .inner ul+p, .inner ol+p, .inner p+ul, .inner p+ol, .inner p+dl {
    margin-top: 1em
}

@media only screen and (max-width: 768px) {
    .inner p {
        line-height: 1.65em;
        text-align: left
    }

    .inner p.lead {
        font-size: 2.2rem;
        line-height: 28px;
        text-align: left
    }

    .inner p.lead.fs-l-sp {
        font-size: 2.5rem;
        line-height: 1.4em
    }

    .inner p.lead span {
        font-size: 2.6rem
    }

    .inner p.catch {
        font-size: 1.8rem;
        text-align: center
    }

    .inner p.sp_center {
        text-align: center
    }
}

.inner-area2Vc {
    width: 42%;
    position: absolute;
    top: 50%;
    transform: translate(0, -50%)
}

@media only screen and (max-width: 768px) {
    .inner-area2Vc {
        display: block;
        width: 100%;
        position: relative;
        top: 0;
        transform: translate(0, 0)
    }
}

.top-logo {
    margin-top: 30px
}

.top-logo img {
    width: 180px
}

@media only screen and (max-width: 768px) {
    .top-logo {
        display: flex;
        flex-direction: column;
        justify-content: center;
        align-items: center;
        height: 50vh
    }
}

.titlebg1 {
    font-size: clamp(3rem, 1.247rem + 2.74vw, 4.5rem);
    font-family: var(--font-family-base);
    color: #000;
    font-weight: 400;
    text-align: left;
    margin-bottom: 50px
}

.titlebg1.wh {
    color: #fff
}

@media only screen and (max-width: 768px) {
    .titlebg1 {
        font-size: 3rem;
        padding-bottom: 10px;
        margin: 40px auto 20px
    }
}

.titlebg2 {
    font-size: clamp(2.25rem, -0.25rem + 4vw, 4.5rem);
    font-family: var(--font-family-base);
    color: #000;
    font-weight: 400;
    line-height: 1;
    text-align: left;
    margin-bottom: 50px
}

.titlebg2 span {
    font-size: var(--font-size-base);
    font-family: var(--font-family-english);
    display: block;
    margin: 15px 0 0 5px
}

@media only screen and (max-width: 768px) {
    .titlebg2 {
        line-height: 1.1em
    }

    .titlebg2 span {
        margin: 0 0 0 5px
    }
}

.titlebg3 {
    font-size: clamp(1.5rem, 0.955rem + 2.73vw, 3rem);
    font-family: var(--font-family-base);
    color: #000;
    font-weight: 400;
    text-align: center;
    margin: 30px auto 85px;
    position: relative;
    z-index: 300
}

.titlebg3 span {
    font-size: clamp(2.5rem, -0.833rem + 5.33vw, 5.5rem);
    font-family: var(--font-family-english);
    color: #e6e6e6;
    display: block;
    text-align: left;
    position: absolute;
    bottom: 10px;
    left: 50%;
    z-index: -1
}

.titlebg3.wh {
    color: #fff
}

.titlebg3.wh span {
    color: #383838
}

.titlebg3.wh2 span {
    color: #fff
}

@media only screen and (max-width: 768px) {
    .titlebg3 {
        font-size: 30px;
        margin: 30px auto 65px
    }

    .titlebg3 span {
        font-size: 48px;
        line-height: 1em;
        bottom: 20px;
        left: 38%
    }

    .titlebg3 span.sp-small {
        font-size: 40px;
        left: 33%
    }
}

.cont-wrap1 {
    display: flex;
    padding-left: 180px;
    position: relative
}

.cont-wrap1 .text-area {
    display: flex;
    flex-direction: column;
    justify-content: space-around;
    height: clamp(400px, 60vh, 575px);
    z-index: 20;
    position: absolute
}

.cont-wrap1 .text-area p strong {
    color: #fff;
    font-size: clamp(1.875rem, -1.042rem + 4.67vw, 4.5rem);
    font-weight: 400;
    line-height: 1.6em;
    text-shadow: 2px 2px 3px rgba(0, 0, 0, 0.65)
}

.cont-wrap1 .img-area {
    margin-left: auto;
    width: 70%;
    display: flex;
    justify-content: space-between;
    align-items: center
}

.cont-wrap1 .img-area li {
    width: 48%;
    height: 600px;
    overflow: hidden
}

.cont-wrap1 .img-area li img {
    width: 100%;
    height: 100%;
    object-fit: cover
}

@media only screen and (max-width: 768px) {
    .cont-wrap1 {
        padding: 0 0 90px 60px
    }

    .cont-wrap1 .text-area {
        flex-direction: column;
        justify-content: flex-start;
        height: clamp(400px, 100vh, 630px)
    }

    .cont-wrap1 .text-area .titlebg1 {
        margin: 40px 0 20px
    }

    .cont-wrap1 .text-area div {
        margin-top: auto
    }

    .cont-wrap1 .img-area {
        margin: 220px 0 0 0;
        width: 100%
    }

    .cont-wrap1 .img-area li {
        width: 48%;
        height: 300px;
        overflow: hidden
    }
}

.cont-wrap2 {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    width: 100%
}

.cont-wrap2 .cont-box {
    background: #fff;
    width: 46%;
    padding: 40px 100px;
    border-radius: 30px
}

.cont-wrap2 .cont-box.full {
    width: 100%;
    padding: 120px clamp(80px, 16%, 200px) 40px
}

.cont-wrap2 .cont-box .img-area {
    display: flex;
    justify-content: center;
    margin: 0 auto 30px
}

.cont-wrap2 .cont-box .img-area img {
    width: 305px;
    height: auto
}

.cont-wrap2 .cont-box .img-area figure figcaption {
    font-size: 24px;
    font-weight: 400;
    text-align: left;
}

.cont-wrap2 .cont-box .img-area.jc-sb {
    justify-content: space-between
}

.cont-wrap2 .cont-box .text-area p {
    font-size: 16px;
    text-align: left
}

.cont-wrap2 .cont-box .text-area p strong {
    color: #000;
    font-size: 20px;
    font-weight: 400
}

.cont-wrap2 .cont-box .text-area p+ol {
    margin-top: 0
}

.cont-wrap2 .cont-box .text-area li {
    margin-bottom: 0
}

.cont-wrap2 .cont-box .text-area li dl {
    display: flex
}

.cont-wrap2 .cont-box .text-area li dl dt {
    width: 60%;
    font-weight: 400
}

@media only screen and (max-width: 768px) {
    .cont-wrap2 {
        flex-direction: column
    }

    .cont-wrap2 .cont-box {
        width: 100%;
        padding: 20px 25px;
        margin-bottom: 20px;
        border-radius: 15px
    }

    .cont-wrap2 .cont-box.full {
        padding: 20px 25px
    }

    .cont-wrap2 .cont-box .img-area {
        flex-direction: column;
        margin: 0 auto 15px
    }

    .cont-wrap2 .cont-box .img-area img {
        width: 100%;
        height: auto
    }

    .cont-wrap2 .cont-box .img-area figure figcaption {
        font-size: 20px
    }

    .cont-wrap2 .cont-box .img-area.jc-sb {
        justify-content: center
    }

    .cont-wrap2 .cont-box .text-area p {
        text-align: left
    }

    .cont-wrap2 .cont-box .text-area p strong {
        color: #000;
        font-size: 20px;
        font-weight: 400
    }

    .cont-wrap2 .cont-box .text-area p+ol {
        margin-top: 0
    }

    .cont-wrap2 .cont-box .text-area li {
        margin-bottom: 0
    }

    .cont-wrap2 .cont-box .text-area li dl {
        display: flex
    }

    .cont-wrap2 .cont-box .text-area li dl dt {
        width: 60%;
        font-weight: 400
    }
}

ul.newslist li a {
    display: flex;
    align-items: center;
    margin-bottom: 1em;
    transition: all 0.3s
}

ul.newslist li a time {
    color: #000;
    font-size: var(--font-size-base);
    line-height: 1.85em;
    width: 7em;
    transition: all 0.3s
}

ul.newslist li a .newstitle {
    color: #000;
    font-size: var(--font-size-base);
    text-decoration: underline;
    line-height: 1.85em;
    transition: all 0.3s
}

ul.newslist li a:hover time {
    color: var(--color-primary)
}

ul.newslist li a:hover .newstitle {
    color: var(--color-primary)
}

@media only screen and (max-width: 768px) {
    ul.newslist li a {
        align-items: flex-start;
        flex-direction: column
    }
}

.news-wrap {
    width: 100%;
    max-width: 1500px;
    padding: 0 135px;
    margin: 0 auto
}

.news-wrap .news-box {
    padding: 60px 110px;
    margin: 0 auto;
    border: 1px solid #707070
}

.news-wrap .news-box ul.newslist li a time {
    width: 12em
}

@media only screen and (max-width: 768px) {
    .news-wrap {
        max-width: 768px;
        padding: 0 10px
    }

    .news-wrap .news-box {
        padding: 25px 20px
    }
}

.news-cont .news-title {
    font-size: 1.8rem;
    margin-bottom: 45px
}

.news-cont time {
    font-size: 1.35rem;
    display: block;
    margin-bottom: 75px
}

.news-cont .news-area {
    font-size: 1.5rem
}

.news-cont .news-area p {
    font-size: 1.5rem
}

@media only screen and (max-width: 768px) {
    .news-cont .news-title {
        font-size: 23px;
        line-height: 1.5em;
        margin-bottom: 30px
    }

    .news-cont time {
        font-size: 15px;
        margin-bottom: 50px
    }

    .news-cont .news-area {
        font-size: 18px
    }

    .news-cont .news-area p {
        font-size: 18px
    }
}

.works-list {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 50px 4%;
    padding: 0 80px
}

.works-list li a {
    text-align: center;
    opacity: 1;
    transition: all 0.4s
}

.works-list li a img {
    width: 100%;
    height: 260px;
    object-fit: cover;
    border-radius: 20px
}

.works-list li a .text-area {
    font-size: 1.6rem;
    line-height: 1.5em;
    margin: 0.75em auto 2em
}

.works-list li a:hover {
    opacity: 0.65
}

@media only screen and (max-width: 768px) {
    .works-list {
        grid-template-columns: repeat(2, 1fr);
        padding: 0 10px
    }

    .works-list li a img {
        height: 150px
    }
}

.works-wrap {
    width: 100%;
    max-width: 1500px;
    padding: 0 135px;
    margin: 0 auto
}

.works-wrap .works-box {
    padding: 60px 70px;
    margin: 0 auto;
    border: 1px solid #707070
}

.works-wrap .works-box .works-cont .title {
    font-size: 24px;
    margin-bottom: 50px
}

.works-wrap .works-box .works-cont .img-area {
    display: flex;
    justify-content: space-between;
    align-items: center
}

.works-wrap .works-box .works-cont .img-area .main-img {
    width: 70%
}

.works-wrap .works-box .works-cont .img-area .thum-img {
    width: 23%
}

@media only screen and (max-width: 768px) {
    .works-wrap {
        max-width: 768px;
        padding: 0 10px
    }

    .works-wrap .works-box {
        padding: 25px 20px
    }

    .works-wrap .works-box .works-cont .title {
        font-size: 20px;
        margin-bottom: 30px
    }

    .works-wrap .works-box .works-cont .img-area {
        flex-direction: column
    }

    .works-wrap .works-box .works-cont .img-area .main-img {
        width: 100%
    }

    .works-wrap .works-box .works-cont .img-area .thum-img {
        margin-top: 30px;
        width: 100%
    }
}

ul.page-numbers {
    margin: 130px auto 0;
    display: flex;
    align-items: center;
    justify-content: center
}

ul.page-numbers li {
    display: flex;
    justify-content: center;
    align-items: center;
    flex-wrap: wrap;
    overflow: hidden;
    font-size: 1.5rem;
    color: #000;
    font-weight: 400;
    margin: 0 1em
}

ul.page-numbers li a {
    display: block;
    padding: 0 10px;
    color: #000;
    transition: all 0.3s
}

ul.page-numbers li a:hover {
    color: #0077b6
}

ul.page-numbers li .current {
    font-weight: 900;
    display: block;
    pointer-events: none;
    position: relative;
    padding: 0 10px
}

@media only screen and (max-width: 768px) {
    ul.page-numbers li {
        font-size: 20px;
        margin: 0 6px
    }

    ul.page-numbers li a {
        padding: 0 10px
    }

    ul.page-numbers li .current {
        padding: 0 10px
    }
}

.works-page ul.page-numbers {
    margin: 50px auto 80px;
    display: flex;
    align-items: center;
    justify-content: center
}

.works-page ul.page-numbers li {
    margin: 0
}

.works-page ul.page-numbers li a {
    font-size: 14px;
    line-height: 1;
    font-weight: 300;
    color: #000;
    display: flex;
    justify-content: center;
    align-items: center;
    height: 30px;
    margin: 0 10px;
    border: 1px solid #707070
}

.works-page ul.page-numbers li a:hover {
    color: #0077b6;
    background: #ccc
}

.works-page ul.page-numbers li .current {
    font-size: 14px;
    line-height: 1;
    background: #efefef;
    color: #000;
    display: flex;
    justify-content: center;
    align-items: center;
    height: 30px;
    margin: 0 10px;
    border: 1px solid #707070
}

.page-numbers2 {
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin: 300px auto 0
}

.page-numbers2 .prev a, .page-numbers2 .next a {
    font-size: 1.6rem;
    display: block;
    height: 100%;
    transition: transform 0.3s;
    text-align: center
}

.page-numbers2 .prev a .arrow, .page-numbers2 .next a .arrow {
    color: #383838;
    font-size: 1.6rem;
    display: flex;
    align-items: center
}

.page-numbers2 .prev a .arrow span, .page-numbers2 .next a .arrow span {
    color: #000
}

.page-numbers2 .prev a:hover .arrow, .page-numbers2 .next a:hover .arrow {
    color: #0077b6
}

@media only screen and (max-width: 768px) {
    .page-numbers2 {
        margin: 100px auto 0
    }

    .page-numbers2 .prev, .page-numbers2 .next {
        margin: 0 20px
    }

    .page-numbers2 .prev a, .page-numbers2 .next a {
        font-size: 18px
    }

    .page-numbers2 .prev a .arrow, .page-numbers2 .next a .arrow {
        font-size: 18px
    }

    .page-numbers2 .prev a .arrow span, .page-numbers2 .next a .arrow span {
        font-size: 19px
    }
}

ul.imglist {
    margin: 20px auto;
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    align-items: center
}

ul.imglist li {
    width: 30%
}

ul.imglist li img {
    width: 100%;
    height: 470px;
    object-fit: cover;
    border-radius: 5%
}

ul.imglist.w50 li {
    width: 45%
}

ul.imglist.w50 li img {
    aspect-ratio: 465 / 500;
    width: 100%;
    height: auto
}

@media only screen and (max-width: 768px) {
    ul.imglist {
        padding: 0 15px
    }

    ul.imglist li {
        width: 33.3%;
        padding: 0 2%;
        margin: 0 0 10px 0
    }

    ul.imglist.w14 li {
        width: 33.3%;
        padding: 0 2%
    }

    ul.imglist.w25 li {
        width: 25%
    }

    ul.imglist.w33 li {
        width: 100%
    }

    ul.imglist.w50 li {
        width: 100%
    }

    ul.imglist.spw50 li {
        width: 50%;
        padding: 0 2%
    }

    ul.imglist .imglist-btn .btn3 {
        font-size: 1.3rem
    }
}

.btn1 {
    display: flex;
    justify-content: center;
    align-items: center;
    width: fit-content;
    min-width: 270px;
    min-height: 38px;
    text-align: center;
    color: #fff;
    background: #383838;
    cursor: pointer;
    position: relative;
    text-decoration: none;
    font-size: 18px;
    line-height: 1;
    border-radius: 8px
}

.btn1.w420 {
    min-width: 420px
}

.btn1::after {
    content: "";
    position: absolute;
    top: 50%;
    right: 25px;
    transform: translateY(-50%);
    width: 15px;
    height: 20px;
    clip-path: polygon(0 0, 0 100%, 100% 50%);
    background-color: #fff;
    transition: all .3s
}

.btn1:hover {
    background: rgba(56, 56, 56, 0.65)
}

.btn1:hover::after {
    right: 10px
}

.btn1.left::after {
    right: initial;
    left: 25px;
    clip-path: polygon(0 50%, 100% 0, 100% 100%)
}

.btn1.left:hover::after {
    right: initial;
    left: 10px
}

.btn1.rd {
    background: rgba(var(--color-primary-rgb), 1)
}

.btn1.rd:hover {
    background: rgba(var(--color-primary-rgb), 0.65)
}

.btn1.bl {
    background: rgba(var(--color-secondary-rgb), 1)
}

.btn1.bl:hover {
    background: rgba(var(--color-secondary-rgb), 0.65)
}

.btn1.gr {
    background: rgba(var(--color-tertiary-rgb), 1)
}

.btn1.gr:hover {
    background: rgba(var(--color-tertiary-rgb), 0.65)
}

.btn1.wh {
    color: #383838;
    background: #fff
}

.btn1.wh::after {
    background-color: #383838
}

.btn1.wh:hover {
    background: rgba(255, 255, 255, 0.65)
}

@media only screen and (max-width: 768px) {
    .btn1.w420 {
        min-width: 320px
    }
}

dl.access-info {
    text-align: left
}

dl.access-info div {
    padding: 0.25em 0.5em 0.75em;
    margin-bottom: 0.75em;
    border-bottom: 1px #999 solid
}

dl.access-info div dt {
    color: #c00;
    font-size: 2rem;
    font-weight: 500;
    line-height: 1.75em;
    width: 9em
}

dl.access-info div dt span {
    margin-right: 0.5em;
    vertical-align: sub
}

dl.access-info div dd {
    font-size: 1.8rem;
    line-height: 1.75em
}

dl.access-info div strong {
    color: #ff0;
    font-weight: 900
}

dl.access-info div.noborder {
    border: none
}

ul.disc {
    list-style-position: outside;
    margin: 0 0 0 24px
}

ul.disc li {
    list-style-type: disc;
    margin: 0 0 0.5em 0
}

ul.disc li:last-child {
    margin: 0
}

ul.disc2 {
    list-style-position: outside;
    margin: 0 0 2em 24px
}

ul.disc2 li {
    list-style-type: disc;
    margin: 0 0 1em 0
}

ul.disc2 li:last-child {
    margin: 0
}

ul.check {
    list-style-position: inside
}

ul.check li {
    list-style: none;
    padding-left: 1.5em;
    text-indent: -1.5em;
    margin: 0 0 1em 0;
    font-size: 2.4rem
}

ul.check li:before {
    font-family: 'Material Icons';
    color: #08f;
    content: '\e834';
    margin: 0 0.5em 0 0;
    position: relative;
    top: 0.15em
}

ul.arrow {
    list-style-position: inside
}

ul.arrow li {
    list-style: none;
    padding-left: 1.5em;
    text-indent: -1.5em
}

ul.arrow li:before {
    font-family: "Font Awesome 5 Free";
    content: "\f152";
    font-weight: 900;
    margin: 0 0.5em 0 0
}

ul li.caution:before {
    content: "※";
    font-weight: bold
}

ul.icon {
    padding: 0
}

ul.icon li {
    color: #000;
    position: relative;
    background: #ddd;
    line-height: 1.5em;
    padding: 0.5em;
    margin-bottom: 4px;
    border-left: solid 35px #555;
    list-style-type: none !important
}

ul.icon li:before {
    font-family: "Font Awesome 5 Free";
    content: "\f030";
    font-weight: 900;
    position: absolute;
    display: block;
    padding: 0.5em;
    width: 1.2em;
    color: white;
    font-weight: normal;
    text-align: center;
    left: -37px;
    top: 50%;
    -moz-transform: translateY(-50%);
    -webkit-transform: translateY(-50%);
    -o-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
    transform: translateY(-50%)
}

ul.icon li img {
    width: 300px;
    float: left;
    margin: 0 10px 0 0
}

@media only screen and (max-width: 768px) {
    ul.icon li img {
        width: 100%;
        float: none;
        margin: 0 0 10px 0
    }
}

ul.icon.plug li:before {
    content: "\f1e6"
}

ul.navlist {
    display: flex;
    justify-content: space-around;
    align-items: center;
    margin: 50px auto
}

ul.navlist li {
    width: 18.5%;
    position: relative
}

ul.navlist li img {
    width: 100%;
    height: auto;
    border-radius: 50%;
    opacity: 0.4
}

ul.navlist li p {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    font-size: 1.8rem;
    line-height: 1.4em;
    text-align: center;
    width: 100%
}

ul.navlist li p span {
    display: block;
    font-size: 4rem;
    margin-bottom: 35px
}

ol.num-title-list {
    list-style: none;
    width: 80%;
    min-width: 500px;
    margin: 0 auto
}

ol.num-title-list li {
    background: #fff;
    padding: 60px 30px 30px 30px;
    margin: 0 0 1em 0
}

ol.num-title-list li p {
    font-size: 2.4rem
}

@media only screen and (max-width: 768px) {
    ol.num-title-list {
        width: 100%;
        min-width: initial;
        margin: 0 auto
    }

    ol.num-title-list li {
        background: #fff;
        padding: 50px 15px 30px 15px;
        margin: 0 0 1em 0
    }

    ol.num-title-list li p {
        font-size: 2rem
    }
}

ol.type1 {
    list-style: decimal;
    list-style-position: outside;
    margin: 0 0 0 1.75em
}

ol.type1 li {
    text-align: left;
    margin-bottom: 1em
}

ol.type1 li:last-child {
    margin: 0
}

ol.type1 li ol {
    list-style: decimal;
    list-style-position: outside;
    margin: 0 0 0 1.75em
}

ol.type1 li ol li {
    text-align: left
}

ol.type1.frame {
    padding: 20px 40px 20px 100px;
    border: 1px solid #707070
}

@media only screen and (max-width: 768px) {
    ol.type1.frame {
        padding: 15px 30px 15px 50px
    }
}

ol.type2 {
    list-style: none;
    counter-reset: list-counter;
    padding: 0;
    margin: 0
}

ol.type2 li {
    font-size: 1.8rem;
    line-height: 1.5em;
    text-align: left;
    margin: 0.5em 0;
    padding-left: 1.8em;
    position: relative;
    text-align: left
}

ol.type2 li::before {
    content: counter(list-counter);
    counter-increment: list-counter;
    border: 1px solid;
    box-sizing: border-box;
    border-radius: 50%;
    height: 1.6em;
    width: 1.6em;
    display: flex;
    justify-content: center;
    align-items: center;
    position: absolute;
    top: 1px;
    left: 0;
    font-size: 90%
}

dl.type1 div {
    display: flex;
    padding: 0 3em 1.5em;
    margin-bottom: 1.5em;
    border-bottom: 1px solid #909090
}

dl.type1 div dt {
    font-size: var(--font-size-base);
    font-weight: 400;
    width: 9em
}

dl.type1 div dd {
    font-size: var(--font-size-base);
    font-weight: 400;
    width: calc(100% - 9em)
}

dl.type1.frame {
    background: #fff;
    padding: 100px 45px
}

@media only screen and (max-width: 768px) {
    dl.type1 div {
        flex-direction: column;
        padding: 0 1em 0.65em;
        margin-bottom: 1.5em
    }

    dl.type1 div dt {
        width: 100%;
        margin-bottom: 0.45em;
        font-size: 18px
    }

    dl.type1 div dd {
        width: 100%
    }

    dl.type1.frame {
        padding: 50px 25px
    }
}

dl.type2 div {
    margin-bottom: 1.5em
}

dl.type2 div dt {
    font-size: 1.4rem;
    color: #8fc31f;
    margin: 0 0 0.5em 0
}

dl.type2 div dd {
    font-size: 1.65rem;
    font-weight: 500
}

#faq {
    text-align: left;
    width: 100%
}

#faq dt {
    border-bottom: solid 1px #8dc21f;
    background: #8dc21f;
    color: #fff;
    cursor: pointer;
    font-weight: 900;
    display: flex;
    align-items: center;
    text-align: left;
    padding: 0.5em 1em;
    margin: 0.3em 0 0 0;
    position: relative
}

#faq dt:hover {
    background-color: #b2d668
}

#faq dt p {
    font-size: 2rem;
    line-height: 1.8em;
    font-weight: 700;
    padding: 0 0.5em;
    margin: 0
}

#faq dt i {
    font-size: 2.6rem
}

#faq dt i.btn {
    margin-left: auto;
    transition: 0.2s
}

#faq dt.selected i.btn {
    transform: rotate(180deg);
    transition: 0.2s
}

#faq dd {
    color: #000;
    font-size: 1.8rem;
    font-weight: 700;
    background: #ffe100;
    border: solid 1px #ffe100;
    margin: 0px;
    padding: 10px
}

@media only screen and (max-width: 768px) {
    #faq dt {
        padding: 0.5em
    }

    #faq dt p {
        font-size: 1.4rem;
        line-height: 1.5em
    }

    #faq dt i {
        font-size: 2rem
    }

    #faq dd {
        font-size: 1.4rem
    }
}

.wp-block-table {
    position: relative;
    overflow-x: auto;
    white-space: nowrap;
    padding: 40px 0 0 0
}

.wp-block-table .scroll-hint {
    display: none
}

.wp-block-table .scroll-hint--show {
    display: none
}

@media only screen and (max-width: 1056px) {
    .wp-block-table .scroll-hint {
        position: absolute;
        top: 300px;
        left: 50%;
        transform: translate(-50%, 0);
        padding: 10px;
        background: rgba(0, 0, 0, 0.5);
        color: #fff;
        font-weight: 700;
        line-height: 1.4;
        display: none;
        animation: scroll-hint-animation 2s infinite ease
    }

    @keyframes scroll-hint-animation {
        0% {
            transform: translate(-50%, -50%)
        }

        50% {
            transform: translate(-40%, -50%)
        }

        100% {
            transform: translate(-50%, -50%)
        }
    }

    .wp-block-table .scroll-hint--show {
        display: block
    }
}

table.has-fixed-layout {
    width: 100%;
    text-align: center;
    border-spacing: 1px;
    margin: 0 auto;
    table-layout: auto !important
}

table.has-fixed-layout thead {
    border-bottom: none
}

table.has-fixed-layout thead tr th {
    color: #000;
    background: #e9e9e9;
    font-size: 18px;
    font-weight: 400;
    padding: 0.35em 1em;
    text-align: left;
    border: 1px solid #d3d3d3
}

table.has-fixed-layout tbody tr td {
    color: #000;
    font-size: 18px;
    font-weight: 400;
    background: #fff;
    padding: 0.35em 1em;
    text-align: left;
    border: 1px solid #d3d3d3
}

table.type1 {
    width: calc(100% + 30px);
    text-align: center;
    border-collapse: separate;
    border-spacing: 30px;
    margin-left: -30px
}

table.type1 thead tr th {
    color: #fff;
    background: #f00;
    font-size: 2rem;
    font-weight: 700;
    padding: 0.75em 1em;
    text-align: center
}

table.type1 tbody tr th {
    color: #fff;
    font-size: 1.7rem;
    font-weight: 700;
    background: #8fc31f;
    padding: 0.35em 1em;
    text-align: center;
    white-space: nowrap;
    display: block
}

table.type1 tbody tr td {
    color: #333;
    font-size: 1.7rem;
    font-weight: 500;
    padding: 0.35em 1em;
    text-align: left
}

@media only screen and (max-width: 768px) {
    table.type1 thead tr th {
        font-size: 1.6rem;
        padding: 0.35em 0.25em
    }

    table.type1 tbody tr th {
        font-size: 1.4rem;
        padding: 0.35em 0.25em
    }

    table.type1 tbody tr td {
        font-size: 1.4rem;
        padding: 0.35em 0.25em
    }
}

.wpcf7-form {
    width: 100%;
    max-width: 800px;
    margin: 0 auto;
    padding: 80px 0 50px 0
}

.wpcf7-form p .mark {
    color: #762d28
}

.wpcf7-form .form-dl {
    text-align: left;
    margin: 0 auto
}

.wpcf7-form .form-dl div {
    display: flex;
    flex-wrap: wrap;
    flex-direction: column;
    margin-bottom: 20px
}

.wpcf7-form .form-dl div dt {
    display: flex;
    align-items: center;
    color: #707070;
    font-size: var(--font-size-base);
    font-weight: 400
}

.wpcf7-form .form-dl div dt .mark {
    text-align: center;
    font-size: var(--font-size-base);
    display: inline-block;
    margin: 0 0 0 0.35em;
    white-space: nowrap
}

.wpcf7-form .form-dl div dt .mark.req {
    color: #f00
}

.wpcf7-form .form-dl div dt.full {
    width: 100%;
    padding: 0
}

.wpcf7-form .form-dl div dd {
    margin-top: 10px
}

.wpcf7-form .form-dl div dd p {
    font-size: 1.5rem;
    margin-top: 10px
}

.wpcf7-form .form-dl div dd.full {
    width: 100%
}

.wpcf7-form select, .wpcf7-form textarea, .wpcf7-form input:not([type="checkbox"]) {
    background: #fff;
    padding: 0.75em 0.5em;
    font-size: var(--font-size-base);
    border: 1px solid #707070
}

.wpcf7-form select:not([type="radio"]), .wpcf7-form textarea:not([type="radio"]), .wpcf7-form input:not([type="checkbox"]):not([type="radio"]) {
    width: 100%
}

.wpcf7-form select::placeholder, .wpcf7-form textarea::placeholder, .wpcf7-form input:not([type="checkbox"])::placeholder {
    font-size: var(--font-size-base);
    color: #aaa
}

.wpcf7-form input[type="checkbox"] {
    appearance: checkbox;
    width: 20px;
    height: 20px;
    margin: 0 10px
}

.wpcf7-form input[type="radio"] {
    margin-right: 10px
}

.wpcf7-form textarea {
    height: 300px
}

.wpcf7-form .select_wrap {
    position: relative
}

.wpcf7-form .select_wrap::after {
    font: var(--fa-font-solid);
    content: "\f107";
    position: absolute;
    right: 16px;
    top: 50%;
    width: 16px;
    height: 14px;
    pointer-events: none;
    color: #949494;
    font-size: var(--font-size-base);
    transform: translateY(-50%)
}

.wpcf7-form .select_wrap select {
    width: 100%;
    line-height: 1.5em;
    outline: 0;
    -webkit-appearance: none;
    appearance: none
}

.wpcf7-form .select_wrap select::-ms-expand {
    display: none
}

.wpcf7-form .select_wrap select:focus {
    border: 1px solid #0072bc
}

.wpcf7-form .select_wrap select option {
    background: #fff;
    color: #2e404d
}

.wpcf7-form .select_wrap select option:nth-child(odd) {
    background: #efefef
}

.wpcf7-form .wpcf7-form-control-wrap {
    width: 100%
}

.wpcf7-form .wpcf7-form-control-wrap .wpcf7-list-item {
    display: block;
    margin: 0 auto 20px
}

.wpcf7-form .wpcf7-form-control-wrap .wpcf7-list-item.last {
    margin: 0
}

.wpcf7-form .wpcf7-form-control-wrap .wpcf7-list-item label {
    display: flex;
    align-items: center
}

.wpcf7-form .submit-area {
    text-align: left
}

.wpcf7-form .form-privacy {
    font-size: var(--font-size-base);
    text-align: left
}

.wpcf7-form .form-privacy .wpcf7-list-item {
    display: block
}

.wpcf7-form .form-privacy .wpcf7-list-item.last {
    margin: 0
}

.wpcf7-form .form-privacy .wpcf7-list-item label {
    display: flex;
    align-items: center
}

.wpcf7-form .submit {
    margin: 30px auto 0
}

.wpcf7-form .submit&gt;input[type="submit"], .wpcf7-form .submit&gt;input[type="button"] {
    display: flex;
    justify-content: center;
    align-items: center;
    width: fit-content;
    min-width: 270px;
    min-height: 38px;
    text-align: center;
    color: #fff;
    background: rgba(var(--color-primary-rgb), 1);
    cursor: pointer;
    position: relative;
    text-decoration: none;
    font-size: 18px;
    line-height: 1;
    border: none;
    border-radius: 8px;
    margin: 0 auto;
    transition: all 0.3s
}

.wpcf7-form .submit&gt;input[type="submit"]:hover, .wpcf7-form .submit&gt;input[type="button"]:hover {
    background: rgba(var(--color-primary-rgb), 0.65)
}

.wpcf7-form .wpcf7-spinner {
    display: block
}

.wpcf7-form .wpcf7-response-output {
    margin: 0 !important;
    padding: 0.2em .35em !important;
    border: 2px solid #00a0d2 !important;
    background: #fff !important;
    text-align: center !important;
    font-size: 2rem;
    font-weight: 700;
    letter-spacing: -0.15em
}

.wpcf7-form span[data-name="hcap-cf7"] .h-captcha {
    margin: 0 auto
}

@media only screen and (max-width: 768px) {
    .wpcf7-form .form-dl {
        padding: 0 10px
    }

    .wpcf7-form .form-dl div {
        flex-direction: column;
        margin-bottom: 40px
    }

    .wpcf7-form .form-dl div:last-of-type {
        border-bottom: none
    }

    .wpcf7-form .form-dl div dt {
        width: 100%;
        padding: 0
    }

    .wpcf7-form .form-dl div dd {
        width: 100%;
        margin-top: 15px
    }

    .wpcf7-form select, .wpcf7-form textarea, .wpcf7-form input:not([type="checkbox"]) {
        padding: 0.75em 0.5em
    }

    .wpcf7-form input[type="checkbox"] {
        width: 35px;
        height: 35px;
        margin-right: 10px
    }

    .wpcf7-form textarea {
        height: 280px
    }

    .wpcf7-form .submit-area {
        padding: 0
    }

    .wpcf7-form .form-privacy {
        font-size: 15px;
        margin: 30px auto 0 auto
    }

    .wpcf7-form .form-privacy p {
        padding: 0
    }

    .wpcf7-form .form-privacy .wpcf7-list-item {
        margin: 20px auto
    }

    .wpcf7-form .form-privacy .wpcf7-list-item label input[type="checkbox"] {
        width: 35px;
        height: 35px
    }

    .wpcf7-form .submit&gt;input[type="submit"], .wpcf7-form .submit&gt;input[type="button"] {
        width: 100%;
        min-height: 75px
    }
}

.privacypolicy {
    padding: 0 80px
}

.privacypolicy li {
    list-style-type: decimal;
    font-size: 16px;
    line-height: 1.5em;
    margin: 0 0 2em 1.7em
}

.privacypolicy li .title {
    font-size: 16px;
    font-weight: 700;
    margin: 0 0 0.75em 0
}

.privacypolicy li p {
    font-family: var(--font-family-base);
    font-weight: 400;
    font-size: 16px;
    line-height: 1.5em
}

.privacypolicy li ul {
    list-style-position: outside;
    margin-left: 1.6em
}

.privacypolicy li ul li {
    list-style-type: disc;
    margin: 0 0 0.5em 0
}

.privacypolicy li ul li:last-child {
    margin: 0
}

@media only screen and (max-width: 768px) {
    .privacypolicy {
        padding: 0 10px
    }
}

.form-search {
    display: flex;
    justify-content: center;
    height: 50px
}

.form-search input {
    width: 250px;
    padding: 0 15px;
    border-radius: 4px 0 0 4px;
    background: transparent;
    border: 2px solid #7fbfff;
    border-right: none;
    outline: 0
}

.form-search button {
    border-radius: 0 4px 4px 0;
    background: #7fbfff;
    border: none;
    color: #fff;
    font-size: 18px;
    cursor: pointer;
    padding: 0 1.25em;
    transition: all 0.3s
}

.form-search button:hover {
    background: #92dbff
}

.cal_wrapper {
    max-width: 960px;
    min-width: 300px;
    margin: 0 auto
}

.googlecal {
    position: relative;
    padding-bottom: 100%;
    height: 0
}

.googlecal iframe {
    position: absolute;
    top: 0;
    left: 0;
    width: 100% !important;
    height: 400px !important
}

@media only screen and (min-width: 1024px) {
    .googlecal {
        padding-bottom: 75%
    }

    .googlecal iframe {
        height: 100% !important
    }
}

.ggmap {
    position: relative;
    padding-bottom: 50%;
    height: 0;
    overflow: hidden
}

.ggmap iframe, .ggmap object, .ggmap embed {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%
}

.ggmap iframe {
    opacity: 0.9
}

.ggmap-footer {
    position: relative;
    padding-bottom: 30%;
    height: 0;
    overflow: hidden
}

.ggmap-footer iframe, .ggmap-footer object, .ggmap-footer embed {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%
}

@media only screen and (max-device-width: 767px) {
    .ggmap-footer {
        padding-bottom: 50%
    }
}

.youtube {
    position: relative;
    padding-bottom: 56.25%;
    height: 0;
    overflow: hidden;
    margin: 0 auto 10px auto
}

.youtube iframe {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%
}

.youtube_short {
    position: relative;
    padding-bottom: 177.77%;
    padding-top: 30px;
    height: 0;
    overflow: hidden;
    margin: 10px auto
}

.youtube_short iframe {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%
}

.breadcrumbs {
    width: 100%;
    margin: 50px auto 100px;
    font-size: 16px;
    font-weight: 400;
    color: #8b8b8b;
    position: relative;
    z-index: 100
}

.breadcrumbs.lower {
    padding: 0 215px;
    margin: 15px auto 50px
}

.breadcrumbs a {
    color: #8b8b8b;
    transition: all .3s
}

.breadcrumbs a:hover {
    color: #0077b6
}

.breadcrumbs .home {
    margin: 0 1em 0 0
}

.breadcrumbs .archive, .breadcrumbs .taxonomy, .breadcrumbs .current-item {
    margin: 0 1em
}

@media only screen and (max-width: 768px) {
    .breadcrumbs {
        display: none
    }
}

#backtotop {
    width: 50px;
    height: 50px;
    position: fixed;
    right: 15px;
    bottom: 0;
    z-index: 1500
}

#backtotop a {
    display: flex;
    justify-content: center;
    align-items: center;
    height: 100%;
    width: 100%;
    text-decoration: none;
    background: rgba(180, 180, 180, 0.4)
}

#backtotop a i {
    font-size: 3.4rem
}

@media only screen and (max-width: 768px) {
    #backtotop {
        width: 40px;
        height: 40px;
        right: 0
    }

    #backtotop a i {
        font-size: 2.8rem
    }
}

.flt-bnr {
    position: fixed;
    top: 125px;
    right: 0;
    z-index: 8000
}

.flt-bnr a {
    background: linear-gradient(#007fd3, #0041c9);
    display: flex;
    align-items: center;
    width: 300px;
    padding: 6px;
    border-radius: 10px 0 0 10px;
    box-shadow: 3px 3px 3px #000;
    opacity: 1;
    transition: all .3s
}

.flt-bnr a figure {
    width: 35%;
    height: auto
}

.flt-bnr a figure img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    border-radius: 5px 0 0 5px
}

.flt-bnr a .flt-bnr-text {
    text-align: center;
    width: 65%;
    padding: 5px 0
}

.flt-bnr a .flt-bnr-text p.title {
    font-size: 2.1rem;
    color: #fff;
    margin: 0 auto 0.35em auto
}

.flt-bnr a .flt-bnr-text p.btn {
    font-size: 1.6rem;
    color: #0041c9;
    background: #fff;
    display: inline-block;
    padding: 3px 10px;
    border-radius: 5px
}

.flt-bnr a:hover {
    opacity: 0.65
}

@media screen and (max-width: 960px) {
    .flt-bnr {
        top: initial;
        bottom: 0;
        left: 0;
        right: 0
    }

    .flt-bnr a {
        display: flex;
        width: 100%;
        padding: 6px;
        border-radius: 0;
        box-shadow: none
    }

    .flt-bnr a figure {
        width: 35%
    }

    .flt-bnr a figure img {
        border-radius: 0
    }

    .flt-bnr a .flt-bnr-text {
        width: 65%
    }

    .flt-bnr a .flt-bnr-text p.title {
        font-size: 2.4rem;
        margin: 0 auto 0.6em auto
    }

    .flt-bnr a .flt-bnr-text p.btn {
        font-size: 1.85rem
    }
}


.bottom__btn {
    margin-top: 30px;
    display: flex;
    justify-content: center;
}

@media only screen and (max-width: 768px) {
    .inner-area33 {
        width: 70vw;
    }
}

/*# sourceMappingURL=common.css.map */</pre></body></html>