@charset "UTF-8";

/* base.css上書き */
html {
    color: #666464;
    background-color: white;
    font-family: 'メイリオ',
        Meiryo,
        'ヒラギノ角ゴ Pro W3',
        'Hiragino Kaku Gothic Pro',
        sans-serif;
    font-size: 14px;
    letter-spacing: 1px;
}

/* common */
table {
    width: 100%;
    border-collapse: collapse;
}

.scrollable {
    min-width: 768px;
}

.table-nowrap {
  white-space: nowrap;
}

.scroll-hint-icon {
    -webkit-transform: translate(0, -50%);
    transform: translate(0, -50%);
    top: 50% !important;
    z-index: 1;
}

.no-opacity a:hover {
    opacity: 1;
}

.color-01-text {
    color: rgb(40, 40, 149);
}

.color-01-bgc {
    background-color: #54b04e;
}

.color-02-text {
    color: rgb(40, 40, 149);
}

.color-02-bgc {
    background-color: #fe8a00;
}

.border-01 {
    border: 1px solid rgb(40, 40, 149);
}

.border-01-top {
    border-top: 1px solid rgb(40, 40, 149);
}

.border-01-bottom {
    border-bottom: 1px solid rgb(40, 40, 149);
}

.border-01-left {
    border-left: 1px solid rgb(40, 40, 149);
}

.border-01-right {
    border-right: 1px solid rgb(40, 40, 149);
}

.border-01-radius {
    border: 1px solid rgb(40, 40, 149);
    border-radius: 1000px;
}

.border-02 {
    border: 1px solid #fe8a00;
}

.border-02-top {
    border-top: 1px solid #fe8a00;
}

.border-02-bottom {
    border-bottom: 1px solid #fe8a00;
}

.border-02-left {
    border-left: 1px solid #fe8a00;
}

.border-02-right {
    border-right: 1px solid #fe8a00;
}

.border-gray {
    border: 1px solid #ccc;
}

.border-gray-top {
    border-top: 1px solid #ccc;
}

.border-gray-bottom {
    border-bottom: 1px solid #ccc;
}

.border-gray-left {
    border-left: 1px solid #ccc;
}

.border-gray-right {
    border-right: 1px solid #ccc;
}

.tel,
.fax {
    font-size: 16px;
    letter-spacing: 2px;
}

.tel-item .tel {
    font-family: 'PT Serif',
        serif;
    font-size: 30px;
    color: rgb(40, 40, 149);
    ;
}

.tel-item .tel a {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    align-items: center;
    -ms-flex-align: center;
}

.tel-item .tel a::before {
    content: "\f879";
    display: inline-block;
    margin-right: 10px;
    font-family: "Font Awesome 5 Free";
    font-weight: 900;
    font-size: 80%;
    line-height: 100%;
}

.logo {
    width: 250px;
    max-width: 80%;
    -ms-flex-negative: 0;
    flex-shrink: 0;
}

.shop-name {
    font-size: 20px;
}

.map::after {
    padding-top: 60%;
}

.underline-link {
    color: #54b04e;
}

.underline-link a {
    text-decoration: underline;
}

.underline-link.-arrow::before {
    content: "\f054";
    display: inline-block;
    margin-right: 5px;
    font-family: "Font Awesome 5 Free";
    font-weight: 900;
    font-size: 80%;
    color: inherit;
    line-height: 100%;
}

.default_ul {
    list-style-type: disc;
    margin-left: 30px;
}

.default_ol {
    list-style-type: decimal;
    margin-left: 30px;
}

@media (max-width: 1024px) {
    .logo {
        width: 200px;
    }

    .tel-item .tel {
        font-size: 28px;
    }
}

@media (max-width: 599px) {
    .logo {
        width: 170px;
    }

    .tel-item .tel {
        font-size: 26px;
    }
}

/* icon */
.icon {
    width: 55px;
    height: 55px;
    display: block;
}

.icon img {
    width: 100%;
    height: auto;
}

.icon-mail::before {
    content: "\f0e0";
    display: inline-block;
    font-family: "Font Awesome 5 Free";
    font-weight: 900;
    font-size: inherit;
    line-height: 100%;
}

.icon-nav {
    width: 45px;
    height: 45px;
    display: block;
    margin: auto;
}

.icon-header {
    width: 40px;
    height: 40px;
}

.icon-title {
    width: 100px;
    display: block;
    margin: 0 auto 10px auto;
}

.icon-circle {
    width: 100px;
    height: 100px;
}

.icon-bnr {
    width: 25px;
    height: 25px;
    display: block;
}

footer .icon-bnr {
    color: #fff;
    font-size: 18px;
}

footer .icon-bnr:hover {
    color: rgb(40, 40, 149);
}

.icon-cal::before {
    content: "\f133";
    display: inline-block;
    margin-right: 10px;
    font-family: "Font Awesome 5 Free";
    font-weight: 900;
    font-size: inherit;
    color: rgb(40, 40, 149);
    ;
    line-height: 100%;
}

.icon-tag::before {
    content: "\f02b";
    display: inline-block;
    margin-right: 10px;
    font-family: "Font Awesome 5 Free";
    font-weight: 900;
    font-size: inherit;
    color: rgb(40, 40, 149);
    line-height: 100%;
}

@media (max-width: 1024px) {
    .icon {
        width: 44px;
        height: 44px;
    }

    .icon-nav {
        width: 36px;
        height: 36px;
    }

    .icon-header {
        width: 32px;
        height: 32px;
    }

    .icon-title {
        width: 80px;
    }

    .icon-circle {
        width: 80px;
        height: 80px;
    }
}

@media (max-width: 1024px) {
    .icon {
        width: 33px;
        height: 33px;
    }

    .icon-nav {
        width: 27px;
        height: 27px;
    }

    .icon-header {
        width: 24px;
        height: 24px;
    }

    .icon-title {
        width: 60px;
    }

    .icon-circle {
        width: 60px;
        height: 60px;
    }
}

/* title */
.title-01 {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    -webkit-box-align: center;
    align-items: center;
    -ms-flex-align: center;
    margin-bottom: 50px;
    padding-top: 30px;
    font-size: 36px;
}

.title-01 .en::before {
    content: "";
    display: block;
    width: 200px;
    height: 1px;
    margin: 0.5em auto 0.75em;
    border-bottom: 1px solid #27110a;
}

.title-01-sub {
    font-size: 24px;
}

.title-02 {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    -webkit-box-align: center;
    align-items: center;
    -ms-flex-align: center;
    font-size: 24px;
    letter-spacing: 1px;
    text-align: center;
    padding: 10px 0;
}

.title-03 {
    font-size: 20px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    -webkit-box-align: center;
    align-items: center;
    -ms-flex-align: center;
    letter-spacing: 1px;
    text-align: center;
}

.title-04 {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    margin-bottom: 50px;
    font-family: "游明朝", YuMincho, "Hiragino Mincho ProN W3", "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
    font-size: 40px;
    letter-spacing: 2px;
}

.title-05 {
    margin-bottom: 30px;
    font-size: 34px;
}

.title-06 {
    margin-bottom: 30px;
    padding-left: 10px;
    font-size: 24px;
    border-left: 10px solid rgb(40, 40, 149);
    color: rgb(40, 40, 149);
}

.title-07 {
    margin-bottom: 30px;
    padding-left: 10px;
    font-size: 28px;
    border-left: 10px solid rgb(40, 40, 149);
    color: rgb(40, 40, 149);
}

.title-08 {
    margin-bottom: 50px;
    padding: 5px 10px;
    font-size: 24px;
    color: rgb(40, 40, 149);
    border-bottom: 1px solid rgb(40, 40, 149);
}

.title-09 {
    margin-bottom: 30px;
    padding-left: 10px;
    font-size: 30px;
    border-left: 10px solid rgb(40, 40, 149);
    color: rgb(40, 40, 149);
}

.title-10 {
    margin-bottom: 30px;
    padding: 5px 10px;
    font-size: 24px;
    color: #7CD2FF;
    border-bottom: 1px solid #7CD2FF;
}

.title-inner-02 {
    font-weight: normal;
    font-size: 14px;
    color: #949393;
}

.title-inner-03 {
    font-size: 50%;
}

.title-inner-28 {
    font-size: 28px;
}

[class*="title"].-bottom-large {
    margin-bottom: 80px;
}

[class*="title"].-bottom-medium {
    margin-bottom: 50px;
}

[class*="title"].-bottom-small {
    margin-bottom: 30px;
}

[class*="title"].-bottom-0 {
    margin-bottom: 0;
}

@media (max-width: 1024px) {
    .title-01 {
        margin-bottom: 40px;
        font-size: 32px;
    }

    .title-02 {
        font-size: 22px;
    }

    .title-03 {
        font-size: 16px;
    }

    .title-04 {
        margin-bottom: 40px;
        font-size: 32px;
        letter-spacing: 1px;
    }

    .title-05 {
        font-size: 27.2px;
    }

    .title-06 {
        padding-left: 8px;
        font-size: 19.2px;
        border-left: 8px solid rgb(40, 40, 149);
    }

    .title-07 {
        margin-bottom: 24px;
        padding: 10px 5px;
        font-size: 22.4px;
    }

    .title-08 {
        font-size: 19.2px;
    }

    .title-inner-28 {
        font-size: 25px;
    }

    .title-inner-02 {
        font-weight: normal;
        font-size: 12px;
        color: #949393;
    }

    [class*="title"].-bottom-large {
        margin-bottom: 64px;
    }

    [class*="title"].-bottom-medium {
        margin-bottom: 40px;
    }

    [class*="title"].-bottom-small {
        margin-bottom: 24px;
    }
}

@media (max-width: 599px) {
    .title-01 {
        margin-bottom: 30px;
        font-size: 24px;
    }

    .title-02 {
        font-size: 20px;
    }

    .title-04 {
        margin-bottom: 30px;
        font-size: 24px;
    }

    .title-05 {
        font-size: 20.4px;
    }

    .title-10 {
        margin-bottom: 15px;
        padding: 5px 10px;
        font-size: 20px;
        color: #7CD2FF;
        border-bottom: 1px solid #7CD2FF;
    }

    [class*="title"].-bottom-large {
        margin-bottom: 48px;
    }

    [class*="title"].-bottom-medium {
        margin-bottom: 30px;
    }

    [class*="title"].-bottom-small {
        margin-bottom: 18px;
    }

    .title-inner-28 {
        font-size: 22px;
    }

}

/* list */
.list-check li {
    padding-left: 30px;
    font-weight: 500;
    position: relative;
}

.list-check li+li {
    margin-top: 30px;
}

.list-check li::before {
    content: "\f14a";
    display: inline-block;
    font-family: "Font Awesome 5 Free";
    font-weight: 900;
    font-size: 20px;
    color: #54b04e;
    line-height: 1;
    line-height: 100%;
    position: absolute;
    top: 2px;
    left: 0;
}

.list-flat {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
}

.list-flat dt {
    -ms-flex-negative: 0;
    flex-shrink: 0;
}

.list-flat dd {
    width: 10%;
    -webkit-box-flex: 1;
    -ms-flex-positive: 1;
    flex-grow: 1;
}



.list-reverse dd {
    margin-left: 0;
}


.list-flat.-border+.list-flat.-border {
    border-top: 1px solid #ccc;
}

.list-faq dt,
.list-faq dd {
    padding: 10px 10px 10px 60px;
    position: relative;
}

.list-faq dt::before,
.list-faq dd::before {
    width: 50px;
    height: 50px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    -webkit-box-align: center;
    align-items: center;
    -ms-flex-align: center;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    font-family: "游明朝", YuMincho, "Hiragino Mincho ProN W3", "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
    font-size: 42px;
    line-height: 1;
    position: absolute;
    top: -5px;
    left: 0;
}

.list-faq dt {
    padding-right: 70px;
    font-weight: bold;
    font-size: 20px;
    color: rgb(40, 40, 149);
    position: relative;
}

.list-faq dt .element-arrow {
    margin: auto;
    -webkit-transform: translate(0, -50%);
    transform: translate(0, -50%);
    position: absolute;
    top: 50%;
    right: 10px;
    z-index: 1;
}

.list-faq dt:hover {
    cursor: pointer;
}

.list-faq dt::before {
    content: "Q";
    color: rgb(40, 40, 149);
}

.list-faq dd {
    padding-top: 40px;
}

.list-faq dd::before {
    content: "A";
    color: white;
    color: #7CD2FF
}

.list-faq.action dt .element-arrow-inner::after {
    -webkit-transform: rotate(0);
    transform: rotate(0);
}

.list-square dt {
    margin-bottom: 15px;
    padding: 10px;
    color: #54b04e;
    border: 1px solid #54b04e;
    border-radius: 5px;
}

.list-square dd {
    padding: 0 15px;
}

.list-pipe {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
}

.list-pipe dt {
    -ms-flex-negative: 0;
    flex-shrink: 0;
    padding-right: 20px;
    position: relative;
}

.list-pipe dt::after {
    content: "";
    width: 1px;
    height: 100%;
    display: inline-block;
    margin: 0 10px;
    background-color: black;
    position: absolute;
    top: 0;
    right: 0;
}

.list-pipe dd {
    width: 10%;
    -webkit-box-flex: 1;
    -ms-flex-positive: 1;
    flex-grow: 1;
}

.list-pile li a {
    height: 100%;
}

.list-interview dt {
    padding-left: 40px;
    font-size: 28px;
    color: #54b04e;
    position: relative;
}

.list-interview dt::before {
    content: "Q";
    display: inline-block;
    font-family: "游明朝", YuMincho, "Hiragino Mincho ProN W3", "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
    font-size: 120%;
    color: #fe8a00;
    line-height: 1;
    position: absolute;
    top: 0;
    left: 0;
}

.list-interview dd {
    margin-top: 10px;
}

.list-dot li {
    padding-left: 20px;
    position: relative;
}

.list-dot li::before {
    content: "●";
    display: inline-block;
    position: absolute;
    top: 0;
    left: 0;
}

.list-dot-02 li::before {
    color: #fe8a00;
}

.list-flow li .box-border-01 {
    padding-left: 100px;
    position: relative;
}

.list-flow li .box-border-01 .number {
    -webkit-transform: translate(-25%, -25%);
    transform: translate(-25%, -25%);
    position: absolute !important;
    top: 0;
    left: 0;
}

.list-flow li+li {
    margin-top: 80px;
}

.-li-short li {
    width: 85%;
}

.-li-short li:nth-of-type(even) {
    margin-left: auto;
}

@media (max-width: 1024px) {
    .list-check li {
        padding-left: 34px;
    }

    .list-check li+li {
        margin-top: 20px;
    }

    .list-check li::before {
        font-size: 24px;
        top: -1px;
    }

    .list-flat dd {
        margin-left: 24px;
    }

    .list-faq dt,
    .list-faq dd {
        padding-left: 48px;
    }

    .list-faq dt::before,
    .list-faq dd::before {
        width: 40px;
        height: 40px;
        font-size: 33.6px;
        top: 0;
    }

    .list-faq dd {
        margin-top: 32px;
    }

    .list-interview dt {
        padding-left: 32px;
        font-size: 22.4px;
    }

    .list-interview dd {
        margin-top: 5px;
    }

    .list-flow li .box-border-01 {
        padding-left: 80px;
    }

    .list-flow li .box-border-01 .number {
        -webkit-transform: translate(-20%, -20%);
        transform: translate(-20%, -20%);
    }

    .-li-short li {
        width: 90%;
    }
}

@media (max-width: 599px) {
    .list-flat dt {
        width: 100%;
    }

    .list-flat dd {
        width: 100%;
        margin-left: 0;
    }

    .list-faq dt,
    .list-faq dd {
        padding-left: 36px;
    }

    .list-faq dt::before,
    .list-faq dd::before {
        width: 30px;
        height: 30px;
        font-size: 25.2px;
        top: 5px;
    }

    .list-faq dd {
        margin-top: 24px;
    }

    .list-sonar.-flat\@sp li .list-inner {
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-align: center;
        align-items: center;
        -ms-flex-align: center;
        -webkit-box-pack: justify;
        -ms-flex-pack: justify;
        justify-content: space-between;
    }

    .list-sonar.-flat\@sp li .list-inner .effect-sonar {
        width: 35%;
    }

    .list-sonar.-flat\@sp li .list-inner .item {
        width: 60%;
        text-align: left;
    }



    .list-interview dt {
        padding-left: 28px;
        font-size: 19.6px;
    }

    .list-flow li .box-border-01 {
        padding-left: 60px;
    }

    .list-flow li .box-border-01 .number {
        -webkit-transform: translate(-15%, -15%);
        transform: translate(-15%, -15%);
    }

    .-li-short li {
        width: 100%;
    }
}

/* button */
.btn {
    width: 220px;
    max-width: 80%;
    height: 45px;
    display: block;
    margin-top: 50px;
    margin-left: auto;
    margin-right: auto;
}

.btn-inner {
    position: relative;
    z-index: 1;
    font-size: 16px;
}

.btn.-center {
    margin-left: auto;
    margin-right: auto;
}

.btn.-left {
    margin-left: 0;
}

.btn.-right {
    margin-right: 0;
}

.btn.-mt-large {
    margin-top: 80px;
}

.btn.-mt-medium {
    margin-top: 50px;
}

.btn.-mt-small {
    margin-top: 30px;
}

.btn.-mt-0 {
    margin-top: 0;
}

.btn.-w100 {
    width: 100%;
    min-width: 200px;
    max-width: 100%;
}

.btn a,
.btn button {
    width: 220px;
    height: 100%;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    -webkit-box-align: center;
    align-items: center;
    -ms-flex-align: center;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    overflow: hidden;
    padding: 0.75em 1em;
    color: #54b04e;
    letter-spacing: 1px;
    text-align: center;
    border-radius: 5px;
    background-color: white;
    cursor: pointer;
    position: relative;
}

.btn a::before,
.btn button::before {
    content: "";
    width: 100%;
    height: 0;
    margin: auto;
    background-color: #54b04e;
    -webkit-transition: 0.3s linear;
    transition: 0.3s linear;
    -webkit-transform: translate(0, -50%);
    transform: translate(0, -50%);
    position: absolute;
    top: 50%;
    left: 0;
    right: 0;
    z-index: 1;
}

.btn a::after,
.btn button::after {
    content: "\f054";
    display: inline-block;
    margin: auto;
    font-family: "Font Awesome 5 Free";
    font-weight: 900;
    font-size: inherit;
    line-height: 100%;
    -webkit-transform: translate(0, -50%);
    transform: translate(0, -50%);
    position: absolute;
    top: 50%;
    right: 10px;
    z-index: 1;
}

.btn a:hover,
.btn button:hover {
    color: white;
    opacity: 1;
}

.btn a:hover::before,
.btn button:hover::before {
    height: 105%;
}

.btn-01 a,
.btn-01 button {
    color: #7CD2FF;
    border: solid 1px #7CD2FF;
}

.btn-01 a::before,
.btn-01 button::before {
    background-color: #7CD2FF;
}

.btn-01 {
    font-size: 16px;
}

.btn-02 a,
.btn-02 button {
    color: #fe8a00;
}

.btn-02 a::before,
.btn-02 button::before {
    background-color: #fe8a00;
}

.btn-large {
    width: 400px;
    height: 65px;
}

.btn-large a,
.btn-large button {
    font-size: 18px;
}

.btn.-alternate.btn-01 a,
.btn.-alternate.btn-01 button {
    color: white;
    border: 1px solid rgba(40, 40, 149, 0.8);
    background-color: rgba(40, 40, 149, 0.8);
}

.btn.-alternate.btn-01 a::before,
.btn.-alternate.btn-01 button::before {
    background-color: white;
}

.btn.-alternate.btn-01 a:hover,
.btn.-alternate.btn-01 button:hover {
    color: rgb(40, 40, 149);
    border: 1px solid rgb(40, 40, 149);

}

.btn.-alternate.btn-02 a,
.btn.-alternate.btn-02 button {
    color: white;
    border: 1px solid #7CD2FF;
    background-color: #7CD2FF;
}

.btn.-alternate.btn-02 a::before,
.btn.-alternate.btn-02 button::before {
    background-color: white;
}

.btn.-alternate.btn-02 a:hover,
.btn.-alternate.btn-02 button:hover {
    color: #7CD2FF;
    border: 1px solid #7CD2FF;
}

.btn.-border-01 a {
    border: 1px solid #7CD2FF;
}

.btn.-border-02 a {
    border: 1px solid #fe8a00;
}

.btn-text {
    width: auto;
    height: auto;
}

.btn-text a {
    width: auto;
    height: auto;
    display: inline-block;
    padding: 0 30px 0 0;
}

.btn-text a::before {
    display: none;
}

.btn-text a:hover {
    color: #54b04e;
    opacity: 0.6;
}

.btn-toggle:hover {
    cursor: pointer;
}

.btn-toggle-inner {
    width: 100%;
    height: 100%;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    -webkit-box-align: center;
    align-items: center;
    -ms-flex-align: center;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    padding: 10px 30px 10px 10px;
    font-size: 18px;
    color: white;
    letter-spacing: 1px;
    text-align: center;
    border-radius: 5px;
    background-color: #fe8a00;
    position: relative;
}

.btn-toggle-inner .balloon {
    width: 250px;
    display: none;
    margin: auto;
    padding: 10px;
    font-weight: bold;
    font-size: 18px;
    color: #fe8a00;
    text-align: center;
    border: 1px solid #fe8a00;
    background-color: white;
    -webkit-transform: translate(0, calc(-100% - 20px));
    transform: translate(0, calc(-100% - 20px));
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    z-index: 1;
}

.btn-toggle-inner .balloon a {
    display: inline;
    color: #fe8a00 !important;
    border: none !important;
    background-color: transparent !important;
}

.btn-toggle-inner .balloon a::after,
.btn-toggle-inner .balloon a::before {
    display: none !important;
}

.btn-toggle-inner .balloon::before {
    content: "";
    margin-left: -15px;
    border: 12px solid transparent;
    border-top: 12px solid white;
    position: absolute;
    bottom: -24px;
    left: 50%;
    z-index: 2;
}

.btn-toggle-inner .balloon::after {
    content: "";
    margin-left: -17px;
    border: 14px solid transparent;
    border-top: 14px solid #fe8a00;
    position: absolute;
    bottom: -28px;
    left: 50%;
    z-index: 1;
}

.btn.-back a,
.btn.-back button {
    padding: 10px 10px 10px 30px;
}

.btn.-back a::after,
.btn.-back button::after {
    content: "\f053";
    left: 10px;
    right: auto;
}

.chart-btn>a {
  margin: 15px auto 0;
}

@media (max-width: 1024px) {
    .btn {
        margin-top: 40px;
    }

    .btn a,
    .btn button {
        font-size: 14px;
    }

    .btn.-center\@tb {
        margin-left: auto;
        margin-right: auto;
    }

    .btn.-left\@tb {
        margin-left: 0;
    }

    .btn.-right\@tb {
        margin-right: 0;
    }

    .btn-large {
        height: 60px;
    }

    .btn-large a,
    .btn-large button {
        font-size: 16px;
    }

    .btn.-mt-large {
        margin-top: 64px;
    }

    .btn.-mt-medium {
        margin-top: 40px;
    }

    .btn.-mt-small {
        margin-top: 24px;
    }

    .btn.-mt-0\@tb {
        margin-top: 0;
    }

    .btn-toggle-inner {
        font-size: 16px;
    }
}

@media (max-width: 599px) {
    .btn.-center\@sp {
        margin-left: auto;
        margin-right: auto;
    }

    .btn.-left\@sp {
        margin-left: 0;
    }

    .btn.-right\@sp {
        margin-right: 0;
    }

    .btn.-mt-large {
        margin-top: 48px;
    }

    .btn.-mt-medium {
        margin-top: 30px;
    }

    .btn.-mt-0\@sp {
        margin-top: 0;
    }
}

/* table */
.area_01 .table01 th {
    background-color: transparent;
    color: #666464;
}

.area_01 .table01,
.area_01 .table01 th,
.area_01 .table01 td {
    border: none;
}

.area_01 .table01 tr+tr {
    border-top: 1px solid #AAA;
}

.timetable tr+tr {
    border: none;
}

.area_01 .table01 {
    width: 100%;
}

.table01 {
    width: auto;
}

.table01 th,
.table01 td {
    font-size: 16px;
    padding: 0.4em;
}

.table-note {
    font-size: 16px;
}

.table01,
.table01 th,
.table01 td {
    border: 1px solid #AAA;
    padding: 4px 5px;
}


.kenpo-table {
    margin: 50px 0;
}

.table01 th {
    background-color: rgba(40, 40, 149, 0.8);
    color: #fff;
    border: solid 1px #fff;
}

/* header */
header {
    width: 100%;
    background-color: white;
    -webkit-transition: 0.3s linear;
    transition: 0.3s linear;
    top: 0;
    left: 0;
    z-index: 5;
}

header .header-inner {
    width: 100%;
    max-width: 1200px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    align-items: center;
    -ms-flex-align: center;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
    margin: auto;
}

header .header-box {
    -webkit-box-flex: 1;
    -ms-flex-positive: 1;
    flex-grow: 1;
    padding: 20px 10px;
    background-color: white;
    -webkit-transition: 0.3s linear;
    transition: 0.3s linear;
    position: relative;
    z-index: 5;
}

header .header-box .list-header {
    display: none;
}

header.fixed {
    position: fixed;
}

.scrolled header {
    -webkit-box-shadow: 0px 0px 10px 5px rgba(0, 0, 0, 0.1);
    box-shadow: 0px 0px 10px 5px rgba(0, 0, 0, 0.1);
}

.scrolled .header-box {
    padding: 10px;
}

.header-nav .nav-list>li+li {
    margin-left: 0;
}

header .nav-tb {
      display: none;
    }

@media (max-width: 1024px) {
    header .header-inner {
        -webkit-box-align: unset;
        align-items: unset;
        -ms-flex-align: unset;
    }

    header .header-box {
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-align: center;
        align-items: center;
        -ms-flex-align: center;
        -webkit-box-pack: justify;
        -ms-flex-pack: justify;
        justify-content: space-between;
        padding: 0;
    }

    header .header-box .logo {
        margin: 10px;
    }

    header .header-box .list-header {
        height: 100%;
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
    }

    header .header-box .list-header li a {
        width: 100%;
        height: 100%;
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-orient: vertical;
        -webkit-box-direction: normal;
        -ms-flex-direction: column;
        flex-direction: column;
        -webkit-box-align: center;
        align-items: center;
        -ms-flex-align: center;
        -webkit-box-pack: center;
        -ms-flex-pack: center;
        justify-content: center;
        padding: 5px 10px;
    }

    header .header-box .list-header li a span {
        display: block;
        margin: auto;
        text-align: center;
    }

    header .header-box .list-header li a .text {
        margin-top: 5px;
        font-size: 12px;
        color: white;
    }

    header .header-box .list-header li:nth-of-type(1) a {
        background-color: rgba(40, 40, 149, 0.7);
    }

    header .header-box .list-header li:nth-of-type(2) a {
        background-color: #7CD2FF;
    }

    header .header-nav {
        width: 80px;
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-orient: vertical;
        -webkit-box-direction: normal;
        -ms-flex-direction: column;
        flex-direction: column;
        -webkit-box-align: center;
        align-items: center;
        -ms-flex-align: center;
        -webkit-box-pack: center;
        -ms-flex-pack: center;
        justify-content: center;
        background-color: #54b04e;
    }

    .scrolled .header-box {
        padding: 0;
    }
    
    header .nav-tb {
      display: block;
    }
}

@media (max-width: 599px) {
    header .header-box .logo {
        margin: 5px;
    }

    header .header-box .list-header li a {
        padding: 5px 10px;
    }

    header .header-box .list-header li a .text {
        display: none;
    }

    header .header-nav {
        width: 50px;
    }
}

/* nav */
nav {
    -ms-flex-negative: 0;
    flex-shrink: 0;
    padding: 0 10px;
}

.nav-list {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
}

header .nav-list {
    -ms-flex-pack: distribute;
    justify-content: space-around;
    max-width: 1250px;
    width: 96%;
    margin: auto;
}

.nav-list .icon-nav {
    margin-bottom: 5px;
    -webkit-transition: 0.3s linear;
    transition: 0.3s linear;
}

.nav-list>li {
    position: relative;
}

.nav-list>li::before {
    content: "";
    width: 30px;
    height: 5px;
    display: block;
    margin: auto;
    margin: auto;
    opacity: 0;
    -webkit-transition: 0.15s linear;
    transition: 0.15s linear;
    -webkit-transform: translate(0, -50%);
    transform: translate(0, -50%);
    position: absolute;
    bottom: -20px;
    left: 0;
    right: 0;
    z-index: 1;
}

.nav-list>li:hover::before {
    opacity: 1;
    bottom: -10px;
}

.nav-list>li a {
    display: block;
    font-size: 16px;
    text-align: center;
}

.nav-list>li+li {
    margin-left: 15px;
}

.dropdown {
    overflow: hidden;
    position: relative;
}

.dropdown::after {
    content: "";
    width: 200px;
    height: 35px;
    border: 0;
    -webkit-transform: translate(-50%, 0);
    transform: translate(-50%, 0);
    position: absolute;
    left: 50%;
    right: 50%;
    z-index: 2;
}

.dropdown-btn {
    display: block;
    font-size: 14px;
    text-align: center;
    -webkit-transition: 0.3s linear;
    transition: 0.3s linear;
}

.dropdown-btn:hover {
    opacity: 0.6;
    cursor: pointer;
}

.dropdown-box {
    width: 200px;
    height: auto;
    margin: 35px auto 0 auto;
    padding: 30px 20px;
    border-radius: 3px;
    background-color: white;
    -webkit-box-shadow: 0 -2px 16px rgba(0, 0, 0, 0.1);
    box-shadow: 0 -2px 16px rgba(0, 0, 0, 0.1);
    opacity: 0;
    -webkit-transition: all 0.3s linear;
    transition: all 0.3s linear;
    -webkit-transform: translate(0, -15px);
    transform: translate(0, -15px);
    position: absolute;
    top: 100%;
    left: -100px;
    right: -100px;
    z-index: 2;
}

.dropdown-box::before {
    content: "";
    width: 0;
    height: 0;
    display: inline-block;
    margin: auto;
    border-width: 0 7px 7px 7px;
    border-style: solid;
    border-color: transparent transparent white transparent;
    position: absolute;
    top: -7px;
    left: 0;
    right: 0;
}

.dropdown-title {
    margin-bottom: 5px;
    font-weight: bold;
    color: #54b04e;
}

.dropdown-list {
    margin-left: 20px;
}

.dropdown-list li {
    width: 100%;
    height: auto;
    overflow: hidden;
    margin-left: 0;
}

.dropdown-list li+li {
    margin-top: 5px;
}

.dropdown-list li a {
    display: block;
    padding: 5px 5px 5px 20px;
    font-size: 14px;
    color: #54b04e;
    text-align: left;
    position: relative;
}

.dropdown-list li a::before {
    content: "\f054";
    display: inline-block;
    font-family: "Font Awesome 5 Free";
    font-weight: 900;
    font-size: 14px;
    font-size: inherit;
    line-height: 100%;
    position: absolute;
    top: 8px;
    left: 5px;
}

.dropdown:hover {
    overflow: visible;
}

.dropdown:hover .dropdown-box {
    opacity: 1;
    -webkit-transform: translate(0, 0);
    transform: translate(0, 0);
}

.mega::after {
    width: 800px;
}

.mega-menu {
    width: 800px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    left: -400px;
    right: -400px;
}

.mega-menu-inner {
    width: calc(94% / 3);
    margin: 15px 1% 15px 1%;
}

.scrolled .nav-list .icon-nav {
    margin-bottom: 0;
    -webkit-transform: scale(0.8);
    transform: scale(0.8);
}

@media (max-width: 1024px) {
    header .nav-list {
        width: 100%;
    }

    nav {
        padding: 0;
    }

    .nav-list {
        width: 100%;
        height: 100vh;
        height: 100%;
        display: block;
        overflow-y: auto;
        -webkit-overflow-scrolling: touch;
        margin-left: 0;
        padding: 120px 20px 100px;
        background-color: rgb(40, 40, 149);
        -webkit-transition: all ease 0.3s;
        transition: all ease 0.3s;
        position: fixed;
        bottom: 100%;
        left: 0;
        z-index: 4;
    }

    .nav-list>li {
        padding: 10px 30px 10px 10px;
    }

    .nav-list>li::after {
        content: "\f054";
        width: 14px;
        height: auto;
        display: inline-block;
        margin: 0;
        font-family: "Font Awesome 5 Free";
        font-weight: 900;
        font-size: inherit;
        color: white;
        line-height: 100%;
        -webkit-transition: 0.3s linear;
        transition: 0.3s linear;
        -webkit-transform: translate(0, 0);
        transform: translate(0, 0);
        position: absolute;
        top: 25px;
        left: auto;
        right: 10px;
        z-index: 1;
    }

    .nav-list>li::before {
        display: none;
    }

    .nav-list>li a {
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-align: center;
        align-items: center;
        -ms-flex-align: center;
        -webkit-box-pack: start;
        -ms-flex-pack: start;
        justify-content: flex-start;
        color: white;
    }

    .nav-list>li .icon-nav {
        margin-left: 0;
        margin-right: 10px;
    }

    .nav-list>li .icon-nav img {
        -webkit-filter: brightness(100);
        filter: brightness(100);
    }

    .nav-list>li+li {
        margin-left: 0;
        border-top: 1px solid white;
    }

    .nav-list>li.action::after {
        -webkit-transform: rotate(-454deg);
        transform: rotate(-454deg);
    }

    .dropdown-btn {
        width: 100%;
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-align: center;
        align-items: center;
        -ms-flex-align: center;
        -webkit-box-pack: start;
        -ms-flex-pack: start;
        justify-content: flex-start;
        color: white;
    }

    .dropdown-box {
        width: 100%;
        display: block;
        margin-top: 0;
        padding: 10px 0 10px 50px;
        background-color: inherit;
        -webkit-box-shadow: none;
        box-shadow: none;
        opacity: 1;
        -webkit-transition: none;
        transition: none;
        -webkit-transform: translate(0, 0);
        transform: translate(0, 0);
        position: static;
    }

    .dropdown-box::before {
        display: none;
    }

    .dropdown-title {
        color: white;
    }

    .dropdown-title.acc-btn::before {
        content: "\f054";
        display: inline-block;
        margin-right: 10px;
        font-family: "Font Awesome 5 Free";
        font-weight: 900;
        font-size: inherit;
        line-height: 100%;
        -webkit-transition: 0.3s linear;
        transition: 0.3s linear;
        -webkit-transform: rotate(90deg);
        transform: rotate(90deg);
    }

    .dropdown-list li {
        padding: 5px;
    }

    .dropdown-list li+li {
        margin-top: 0;
        border-top: 1px solid rgba(255, 255, 255, 0.5);
    }

    .mega-menu-inner {
        width: calc(100% - 30px);
        margin: 15px;
    }

    .mega-menu-inner.action .acc-btn::before {
        -webkit-transform: rotate(-90deg);
        transform: rotate(-90deg);
    }

    .scrolled .nav-list .icon-nav {
        margin-bottom: 5px;
        -webkit-transform: scale(1);
        transform: scale(1);
    }

    .active .nav-list {
        bottom: 0;
    }
}

@media (max-width: 599px) {
    .nav-list {
        padding: 80px 10px;
    }

    .nav-list li::after {
        top: 18px;
    }

    .dropdown-box {
        padding: 10px 0 10px 20px;
    }

    .mega-menu-inner {
        margin: 10px;
    }
}

/* footer */
footer {
    padding-top: 80px;
    padding-bottom: 60px;
}

footer .logo {
    margin: 0 auto 50px;
}

footer .copy {
    padding: 20px;
    font-size: 14px;
    text-align: center;
}

footer .text-bnr {
    font-size: 18px;
}

/* .vertical {
    -webkit-writing-mode: vertical-rl;
    -ms-writing-mode: tb-rl;
    writing-mode: Sideways-rl;
} */

.totop {
    width: 80px;
    height: 80px;
    position: fixed;
    bottom: 10px;
    right: 10px;
    z-index: 2;
}


.totop a {
    width: 100%;
    height: 100%;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    -webkit-box-align: center;
    align-items: center;
    -ms-flex-align: center;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    color: white;
    letter-spacing: 1px;
    border: 1px solid rgba(40, 40, 149, 0.8);
    border-radius: 100%;
    background-color: rgba(40, 40, 149, 0.8);
    -webkit-box-shadow: 0 0 3px rgba(0, 0, 0, 0.5);
    box-shadow: 0 0 3px rgba(0, 0, 0, 0.5);
}

.totop a::before {
    content: "\f062";
    display: inline-block;
    font-family: "Font Awesome 5 Free";
    font-weight: 900;
    font-size: inherit;
    line-height: 100%;
}

.totop a:hover {
    color: rgb(40, 40, 149);
    background-color: white;
    opacity: 1;
}

.fixed-box-title {
    display: none;
}

.fixed-bnr {
    -webkit-transform: translate(0, -50%);
    transform: translate(0, -50%);
    position: fixed;
    top: 35%;
    right: -1px;
    z-index: 2;
}

.fixed-bnr li {
    max-width: 50px;
}

.fixed-bnr li a {
    display: block;
    padding: 20px 10px;
    text-align: center;
    border-radius: 5px 0 0 5px;
    -webkit-box-shadow: 0 0 3px rgba(0, 0, 0, 0.5);
    box-shadow: 0 0 3px rgba(0, 0, 0, 0.5);
}

.fixed-bnr li a [class*="icon"] {
    margin-left: auto;
    margin-right: auto;
}

.fixed-bnr li a:hover {
    opacity: 1;
}

.fixed-bnr li a .text-bnr {
    margin-top: 10px;
    color: white;
    letter-spacing: 4px;
}

.fixed-bnr li+li {
    margin-top: 10px;
}

/* ab text typeA */

.fixed-bnr .type-a li:nth-of-type(1) a {
    border: 1px solid #7CD2FF;
    background-color: #7CD2FF;
}

.fixed-bnr .type-a li:nth-of-type(1) a:hover {
    background-color: white;
    border: 1px solid #7CD2FF;
}

.fixed-bnr li:nth-of-type(1) a:hover .icon-bnr img {
    -webkit-filter: invert(47%) sepia(100%) saturate(695%) hue-rotate(359deg) brightness(101%) contrast(108%);
    filter: invert(47%) sepia(100%) saturate(695%) hue-rotate(359deg) brightness(101%) contrast(108%);
}

.fixed-bnr .type-a li:nth-of-type(1) a:hover .text-bnr {
    color: #7CD2FF;
}

.fixed-bnr .type-a li:nth-of-type(1) a:hover .icon-bnr {
    color: #7CD2FF;
}

.fixed-bnr .type-a li:nth-of-type(2) a {
    border: 1px solid rgba(40, 40, 149, 0.8);
    background-color: rgba(40, 40, 149, 0.8);
}

.fixed-bnr .type-a li:nth-of-type(2) a:hover {
    background-color: white;
    border: 1px solid rgb(40, 40, 149);
}

.fixed-bnr li:nth-of-type(2) a:hover .icon-bnr img {
    -webkit-filter: invert(48%) sepia(5%) saturate(3249%) hue-rotate(69deg) brightness(115%) contrast(133%);
    filter: invert(48%) sepia(5%) saturate(3249%) hue-rotate(69deg) brightness(115%) contrast(133%);
}

.fixed-bnr .type-a li:nth-of-type(2) a:hover .text-bnr {
    color: rgb(40, 40, 149);
}

.fixed-bnr .type-a li:nth-of-type(2) a:hover .icon-bnr {
    color: rgb(40, 40, 149);
}

/* ab text typeB */
.fixed-bnr .type-b li:nth-of-type(2) a {
    border: 1px solid #7CD2FF;
    background-color: #7CD2FF;
}

.fixed-bnr .type-b li:nth-of-type(2) a:hover {
    background-color: white;
    border: 1px solid #7CD2FF;
}

.fixed-bnr .type-b li:nth-of-type(2) a:hover .text-bnr {
    color: #7CD2FF;
}

.fixed-bnr .type-b li:nth-of-type(2) a:hover .icon-bnr {
    color: #7CD2FF;
}

.fixed-bnr .type-b li:nth-of-type(1) a {
    border: 1px solid rgba(40, 40, 149, 0.8);
    background-color: rgba(40, 40, 149, 0.8);
}

.fixed-bnr .type-b li:nth-of-type(1) a:hover {
    background-color: white;
    border: 1px solid rgb(40, 40, 149);
}

.fixed-bnr .type-b li:nth-of-type(1) a:hover .text-bnr {
    color: rgb(40, 40, 149);
}

.fixed-bnr .type-b li:nth-of-type(1) a:hover .icon-bnr {
    color: rgb(40, 40, 149);
}


.fixed-number {
    display: none;
}

.footer-nav {
    margin: 50px auto;
    -webkit-column-count: 3;
    -moz-column-count: 3;
    column-count: 3;
    -webkit-column-gap: 20px;
    -moz-column-gap: 20px;
    column-gap: 20px;
}

.footer-nav li {
    -webkit-column-break-inside: avoid;
    -moz-column-break-inside: avoid;
    break-inside: avoid;
}

.footer-nav li+li {
    margin-top: 20px;
}

@media (max-width: 1024px) {
    footer {
        padding-top: 50px;
    }

    .fixed-box {
        width: 60%;
        position: fixed;
        top: auto;
        bottom: 0;
        left: 0;
        right: auto;
        -webkit-transform: translate(0, 0);
        transform: translate(0, 0);
        z-index: 5;
    }
    
    .fixed-bnr {
        position: static;
        transform: translate(0,0);
    }

    .fixed-bnr li {
        width: 48%;
        margin: 1%;
        max-width: inherit;
    }
    
    .fixed-bnr li + li {
        margin-top: 1%;
    }

    .fixed-bnr li a {
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-align: center;
        align-items: center;
        -ms-flex-align: center;
        -webkit-box-pack: center;
        -ms-flex-pack: center;
        justify-content: center;
        padding: 10px;
        font-size: 14px;
        letter-spacing: 1px;
        border-radius: 5px;
        -webkit-box-shadow: none;
        box-shadow: none;
    }

    .fixed-bnr li a .icon-bnr {
        margin-left: 0;
        margin-right: 5px;
    }

    .fixed-bnr li a .text-bnr {
        margin-top: 0;
        -ms-writing-mode: lr-tb;
        -webkit-writing-mode: horizontal-tb;
        writing-mode: horizontal-tb;
    }
    
    footer .text-bnr {
        font-size: 15px;
    }

    .footer-nav {
        margin: 30px auto;
        -webkit-column-count: 2;
        -moz-column-count: 2;
        column-count: 2;
        -webkit-column-gap: 10px;
        -moz-column-gap: 10px;
        column-gap: 10px;
    }
    
    .list-fixed-bnr {
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-pack: center;
        -ms-flex-pack: center;
        justify-content: center;
    }
}

@media (max-width: 599px) {
    footer .copy {
        padding-bottom: 70px;
    }

    .totop {
        width: 48px;
        height: 48px;
        font-size: 12px;
    }
    
    .fixed-box {
        width: 100%;
    }
    
    .fixed-bnr li a {
        padding: 10px 2px;
    }
    
    footer .text-bnr {
        font-size: 14px;
    }
}

/* main visual */
.first-view {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: reverse;
    -ms-flex-direction: row-reverse;
    flex-direction: row-reverse;
}

.main-img {
    -o-object-fit: scale-down;
    object-fit: scale-down;
}

.first-view-cont {
    width: 45%;
}

.first-view-cont-inner {
    height: 100%;
    position: relative;
}

.first-view-cont-box {
    height: 100%;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    padding: 30px 30px 30px calc(50vw - 600px);
    position: relative;
    z-index: 1;
    background-color: rgba(40, 40, 149, 0.6);
}

.first-view-cont-box>* {
    color: white;
}

.first-view-cont-box .first-view-cont-title {
    margin-bottom: 30px;
    font-weight: bold;
    font-size: 32px;
    letter-spacing: 10px;
}

.first-view-cont-box .text {
    font-weight: bold;
    letter-spacing: 5px;
    font-size: 14px;
    line-height: 200%;
}

.first-view-cont-bgimg {
    width: 100%;
    height: 100%;
    position: absolute;
    top: 0;
    left: 0;
}

.first-view-cont-bgimg img {
    width: 100%;
    height: 100% !important;
    -o-object-fit: cover;
    object-fit: cover;
    -o-object-position: center right;
    object-position: center right;
    font-family: "object-fit: cover; object-position: center right;";
}

.first-view.lower .first-view-img {
    width: 100%;
    display: block;
    position: relative;
}

.first-view.lower .first-view-img img {
    width: 100%;
    height: 100% !important;
    -o-object-fit: cover;
    object-fit: cover;
    -o-object-position: 50% 50%;
    object-position: 50% 50%;
    font-family: "object-fit: cover; object-position: 50% 50%;";
    position: absolute;
    top: 0;
    left: 0;
}

.first-view.lower .first-view-img::after {
    content: "";
    display: block;
    padding-top: 35%;
}

.first-view.lower .first-view-cont-title {
    font-weight: 500;
    letter-spacing: 4px;
}

.first-view.lower .first-view-cont-title span {
    display: block;
}

.first-view.lower .first-view-cont-title .en {
    font-size: 50%;
}

@media (max-width: 1024px) {
    .first-view-cont {
        width: 50%;
    }

    .first-view-cont-box {
        padding: 20px;
    }

    .first-view-cont-box .first-view-cont-title {
        margin-bottom: 24px;
        font-size: 25.6px;
        letter-spacing: 8px;
    }

    .first-view.lower .first-view-img::after {
        padding-top: 40%;
    }
}

@media (max-width: 599px) {
    .first-view-cont {
        width: 55%;
    }

    .first-view-cont-box {
        padding: 20px 10px;
    }

    .first-view-cont-box .first-view-cont-title {
        margin-bottom: 18px;
        font-size: 19.2px;
        letter-spacing: 6px;
    }

    .first-view.lower .first-view-img::after {
        padding-top: 55%;
    }
}

/* parts */
.wing-01 {
    padding: 0 175px;
    position: relative;
}

.wing-01::before,
.wing-01::after {
    content: "";
    width: 350px;
    height: 370px;
    display: block;
    background-size: 100% auto;
    background-repeat: no-repeat;
    background-position: center center;
    position: absolute;
    top: 0;
}

.wing-01::before {
    background-image: url(/import/tenant_1/160.16.229.138/html/images/common/parts_001.png);
    -webkit-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
    left: 0;
}

.wing-01::after {
    background-image: url(/import/tenant_1/160.16.229.138/html/images/common/parts_002.png);
    -webkit-transform: translate(50%, -50%);
    transform: translate(50%, -50%);
    right: 0;
}

.wing-02 {
    padding: 0 160px;
    position: relative;
}

.wing-02::before,
.wing-02::after {
    content: "";
    width: 294px;
    height: 251px;
    display: block;
    background-size: 100% auto;
    background-repeat: no-repeat;
    background-position: center center;
    position: absolute;
    bottom: 0;
}

.wing-02::before {
    background-image: url(/import/tenant_1/160.16.229.138/html/images/common/parts_008.png);
    -webkit-transform: translate(-50%, 0);
    transform: translate(-50%, 0);
    left: 0;
}

.wing-02::after {
    background-image: url(/import/tenant_1/160.16.229.138/html/images/common/parts_009.png);
    -webkit-transform: translate(50%, 0);
    transform: translate(50%, 0);
    right: 0;
}

.effect-sonar .circle {
    width: 80%;
    margin: 0 auto;
    border-radius: 100%;
    background-color: white;
    -webkit-transition: background 0.2s, -webkit-transform ease-out 0.1s;
    transition: background 0.2s, -webkit-transform ease-out 0.1s;
    transition: transform ease-out 0.1s, background 0.2s;
    transition: transform ease-out 0.1s, background 0.2s, -webkit-transform ease-out 0.1s;
    position: relative;
}

.effect-sonar .circle .square-inner {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    -webkit-box-align: center;
    align-items: center;
    -ms-flex-align: center;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
}

.effect-sonar .circle::after {
    content: "";
    width: 100%;
    height: 100%;
    -webkit-box-sizing: content-box;
    box-sizing: content-box;
    border-radius: 50%;
    pointer-events: none;
    position: absolute;
    top: 0;
    left: 0;
}

.effect-sonar a {
    display: block;
}

.effect-sonar a:hover .circle {
    background: rgba(255, 255, 255, 0.6);
    -webkit-transform: scale(0.96);
    transform: scale(0.96);
}

.effect-sonar a:hover .circle::after {
    padding: 0;
    -webkit-box-shadow: 0 0 0 2px rgba(255, 255, 255, 0.1);
    box-shadow: 0 0 0 2px rgba(255, 255, 255, 0.1);
    opacity: 0;
    -webkit-transform: scale(0.9);
    transform: scale(0.9);
    -webkit-animation: sonarEffect 1.3s ease-out 75ms;
    animation: sonarEffect 1.3s ease-out 75ms;
    z-index: -1;
}

.effect-pile {
    position: relative;
}

.effect-pile::before {
    content: "";
    width: 0;
    height: 0;
    background: white;
    background: linear-gradient(315deg, white 45%, #aaa 50%, #ccc 56%, white 80%);
    -webkit-box-shadow: -1px -1px 1px rgba(0, 0, 0, 0.4);
    box-shadow: -1px -1px 1px rgba(0, 0, 0, 0.4);
    -webkit-transition-duration: 0.3s;
    transition-duration: 0.3s;
    -webkit-transition-property: width, height;
    transition-property: width, height;
    position: absolute;
    bottom: 0;
    right: 0;
    z-index: 1;
}

.effect-pile::after {
    content: "";
    width: 1.5em;
    height: 1.5em;
    background: -webkit-gradient(linear, left top, right bottom, color-stop(50%, rgba(255, 255, 255, 0)), color-stop(50.5%, #cee8cc)) no-repeat top left/100% 100%;
    background: linear-gradient(to bottom right, rgba(255, 255, 255, 0) 50%, #cee8cc 50.5%) no-repeat top left/100% 100%;
    position: absolute;
    bottom: 0;
    right: 0;
}

.effect-pile:hover::before {
    width: 1.5em;
    height: 1.5em;
}

@-webkit-keyframes sonarEffect {
    0% {
        opacity: 0.3;
    }

    40% {
        -webkit-box-shadow: 0 0 0 2px rgba(255, 255, 255, 0.1), 0 0 10px 10px #ccc, 0 0 0 10px rgba(255, 255, 255, 0.5);
        box-shadow: 0 0 0 2px rgba(255, 255, 255, 0.1), 0 0 10px 10px #ccc, 0 0 0 10px rgba(255, 255, 255, 0.5);
        opacity: 0.5;
    }

    100% {
        -webkit-box-shadow: 0 0 0 2px rgba(255, 255, 255, 0.1), 0 0 10px 10px #ccc, 0 0 0 10px rgba(255, 255, 255, 0.5);
        box-shadow: 0 0 0 2px rgba(255, 255, 255, 0.1), 0 0 10px 10px #ccc, 0 0 0 10px rgba(255, 255, 255, 0.5);
        opacity: 0;
        -webkit-transform: scale(1.5);
        transform: scale(1.5);
    }
}

@keyframes sonarEffect {
    0% {
        opacity: 0.3;
    }

    40% {
        -webkit-box-shadow: 0 0 0 2px rgba(255, 255, 255, 0.1), 0 0 10px 10px #fff, 0 0 0 10px rgba(255, 255, 255, 0.5);
        box-shadow: 0 0 0 2px rgba(255, 255, 255, 0.1), 0 0 10px 10px #fff, 0 0 0 10px rgba(255, 255, 255, 0.5);
        opacity: 0.5;
    }

    100% {
        -webkit-box-shadow: 0 0 0 2px rgba(255, 255, 255, 0.1), 0 0 10px 10px #fff, 0 0 0 10px rgba(255, 255, 255, 0.5);
        box-shadow: 0 0 0 2px rgba(255, 255, 255, 0.1), 0 0 10px 10px #fff, 0 0 0 10px rgba(255, 255, 255, 0.5);
        opacity: 0;
        -webkit-transform: scale(1.5);
        transform: scale(1.5);
    }
}

.num-case {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    -webkit-box-align: center;
    align-items: center;
    -ms-flex-align: center;
    font-family: "游明朝", YuMincho, "Hiragino Mincho ProN W3", "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
    color: #54b04e;
    line-height: 1;
    -webkit-transform: translate(0, 50%);
    transform: translate(0, 50%);
    position: relative;
    z-index: 1;
}

.num-case .num {
    font-size: 250%;
}

.wide {
    width: 100%;
}

.sideline {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    align-items: center;
    -ms-flex-align: center;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
}

.grid-box {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
}

.grid-box>* {
    overflow: hidden;
    margin: 1%;
    border-radius: 10px;
}

.grid-100 {
    width: 98%;
}

.grid-square {
    width: 40%;
}

.grid-grow {
    width: 10%;
    -webkit-box-flex: 1;
    -ms-flex-positive: 1;
    flex-grow: 1;
}

.onbox {
    width: 40%;
    margin: auto;
    padding: 50px 30px;
    background-color: white;
    -webkit-transform: translate(0, -50%);
    transform: translate(0, -50%);
    position: absolute;
    top: 50%;
    right: 5%;
    z-index: 1;
}

.onbox-parent {
    position: relative;
}

.deco {
    position: relative;
}

.deco-01::after {
    content: "";
    width: 155px;
    height: 165px;
    display: inline-block;
    background-image: url(/import/tenant_1/160.16.229.138/html/images/common/parts_003.png);
    background-size: 100% auto;
    background-repeat: no-repeat;
    background-position: center center;
    -webkit-transform: translate(75%, 30px);
    transform: translate(75%, 30px);
    position: absolute;
    bottom: 0;
    right: 0;
    z-index: -1;
}

.deco-02::before {
    content: "";
    width: 294px;
    height: 251px;
    display: inline-block;
    background-image: url(/import/tenant_1/160.16.229.138/html/images/common/parts_004.png);
    background-size: 100% auto;
    background-repeat: no-repeat;
    background-position: center center;
    -webkit-transform: translate(-50%, 25%);
    transform: translate(-50%, 25%);
    position: absolute;
    bottom: 0;
    left: 0;
    z-index: -1;
}

.deco-02::after {
    content: "";
    width: 256px;
    height: 341px;
    display: inline-block;
    background-image: url(/import/tenant_1/160.16.229.138/html/images/common/parts_005.png);
    background-size: 100% auto;
    background-repeat: no-repeat;
    background-position: center center;
    -webkit-transform: translate(50%, 25%);
    transform: translate(50%, 25%);
    position: absolute;
    bottom: 0;
    right: 0;
    z-index: -1;
}

.deco-03::before {
    content: "";
    width: 405px;
    height: 674px;
    display: inline-block;
    background-image: url(/import/tenant_1/160.16.229.138/html/images/common/parts_006.png);
    background-size: 100% auto;
    background-repeat: no-repeat;
    background-position: center center;
    position: absolute;
    bottom: 0;
    left: 0;
    z-index: 1;
}

.deco-03::after {
    content: "";
    width: 252px;
    height: 349px;
    display: inline-block;
    background-image: url(/import/tenant_1/160.16.229.138/html/images/common/parts_007.png);
    background-size: 100% auto;
    background-repeat: no-repeat;
    background-position: center center;
    position: absolute;
    bottom: 0;
    right: 0;
    z-index: 1;
}

.filter-01::before {
    content: "";
    width: 100%;
    height: 100%;
    display: block;
    background-color: rgba(84, 176, 78, 0.5);
    position: absolute;
    top: 0;
    left: 0;
}

.filter-02::before {
    content: "";
    width: 100%;
    height: 100%;
    display: block;
    background-color: rgba(40, 40, 149, 0.5);
    position: absolute;
    top: 0;
    left: 0;
}

.filter-03::before {
    content: "";
    width: 100%;
    height: 100%;
    display: block;
    background-color: rgba(214, 214, 243, 0.452);
    position: absolute;
    top: 0;
    left: 0;
}

.filter-04::before {
    content: "";
    width: 100%;
    height: 100%;
    display: block;
    background-color: rgba(124, 210, 255, 0.5);
    position: absolute;
    top: 0;
    left: 0;
}

.filter-05::before {
    content: "";
    width: 100%;
    height: 100%;
    display: block;
    background-color: rgba(255, 255, 255, 0.2);
    position: absolute;
    top: 0;
    left: 0;
}

.label {
    display: inline-block;
    padding: 5px 20px;
    font-size: 20px;
    color: white;
    position: absolute;
    bottom: 10px;
    left: -5px;
    z-index: 1;
}

.label-wrap {
    position: relative;
}

.box-white {
    padding: 50px 30px;
    background-color: white;
}

.box-border-01 {
    padding: 30px 15px;
    border: 1px solid rgb(40, 40, 149);
    border-radius: 10px;
    background-color: white;
}

.box-overlap-item {
    width: 80%;
    margin: -5% auto 0;
    padding: 50px 30px;
    background-color: white;
    position: relative;
    z-index: 1;
}

.band {
    padding: 150px 0;
    position: relative;
}

.band-title {
    font-weight: bold;
    font-size: 28px;
    color: #fe8a00;
    position: relative;
    z-index: 1;
}

.band-bg {
    width: 100%;
    height: 100%;
    position: absolute;
    top: 0;
    left: 0;
}

.band-bg img {
    width: 100%;
    height: 100% !important;
    -o-object-fit: cover;
    object-fit: cover;
    -o-object-position: center center;
    object-position: center center;
    font-family: "object-fit: cover; object-position: center center;";
}

.band-bg::before {
    content: "";
    width: 100%;
    height: 100%;
    display: block;
    background-color: rgba(255, 255, 255, 0.6);
    position: absolute;
    top: 0;
    left: 0;
}

.triangle {
    position: relative;
}

.triangle::after {
    content: "";
    width: 25px;
    height: 25px;
    background: -webkit-gradient(linear, left top, right bottom, color-stop(50%, rgba(255, 255, 255, 0)), color-stop(50.5%, rgba(40, 40, 149, 0.5))) no-repeat top left/100% 100%;
    background: linear-gradient(to bottom right, rgba(255, 255, 255, 0) 50%, rgba(40, 40, 149, 0.5) 50.5%) no-repeat top left/100% 100%;
    position: absolute;
    bottom: 0;
    right: 0;
}

.number {
    width: 110px;
    height: 110px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    -webkit-box-align: center;
    align-items: center;
    -ms-flex-align: center;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    font-family: "游明朝", YuMincho, "Hiragino Mincho ProN W3", "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
    font-size: 24px;
    color: white;
    line-height: 1.2;
    border-radius: 100%;
    background-color: #54b04e;
}

.number-count {
    font-size: 150%;
    letter-spacing: 2px;
}

.number-01 {
    font-family: "游明朝", YuMincho, "Hiragino Mincho ProN W3", "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
    font-size: 42px;
    color: #54b04e;
    text-align: center;
    -webkit-transform: translate(0, 50%);
    transform: translate(0, 50%);
    position: relative;
    z-index: 1;
}

.element-arrow {
    width: 45px;
    height: 45px;
    display: inline-block;
    border: 1px solid rgb(40, 40, 149);
    ;
    border-radius: 5px;
}

.element-arrow-inner {
    width: 100%;
    height: 100%;
    display: block;
    position: relative;
}

.element-arrow-inner::before,
.element-arrow-inner::after {
    content: "";
    width: 10px;
    height: 1px;
    display: inline-block;
    margin: auto;
    background-color: rgb(40, 40, 149);
    -webkit-transition: 0.3s linear;
    transition: 0.3s linear;
    -webkit-transform: translate(0, -50%);
    transform: translate(0, -50%);
    position: absolute;
    top: 50%;
    left: 0;
    right: 0;
    z-index: 1;
}

.element-arrow-inner::after {
    -webkit-transform: rotate(90deg);
    transform: rotate(90deg);
}

@media (max-width: 1024px) {
    .wing-01 {
        padding: 0 140px;
    }

    .wing-01::before,
    .wing-01::after {
        width: 280px;
        height: 296px;
    }

    .wing-02 {
        padding: 0 96px;
    }

    .wing-02::before,
    .wing-02::after {
        content: "";
        width: 176.4px;
        height: 150.6px;
    }

    .effect-sonar .circle {
        width: 90%;
    }

    .num-case .num {
        font-size: 200%;
    }

    .onbox {
        width: 50%;
        padding: 30px 15px;
    }

    .deco-01::after {
        width: 124px;
        height: 132px;
    }

    .deco-02::before {
        width: 235.2px;
        height: 200.8px;
    }

    .deco-02::after {
        width: 204.8px;
        height: 272.8px;
    }

    .deco-03::before {
        width: 202.5px;
        height: 337px;
    }

    .deco-03::after {
        width: 126px;
        height: 174.5px;
    }

    .label {
        padding: 5px 16px;
        font-size: 16px;
    }

    .box-white {
        padding: 30px 20px;
    }

    .box-overlap-item {
        width: 90%;
    }

    .band {
        padding: 80px 0;
    }

    .band-title {
        font-size: 22.4px;
    }

    .number {
        width: 80px;
        height: 80px;
        font-size: 19.2px;
    }

    .element-arrow {
        width: 36px;
        height: 36px;
        border-radius: 3px;
    }
}

@media (max-width: 599px) {
    .wing-01 {
        padding: 0;
    }

    .wing-01::before,
    .wing-01::after {
        width: 105px;
        height: 111px;
    }

    .wing-01::before {
        -webkit-transform: translate(-50%, 50%);
        transform: translate(-50%, 50%);
    }

    .wing-01::after {
        -webkit-transform: translate(50%, 50%);
        transform: translate(50%, 50%);
    }

    .wing-02 {
        padding: 0 48px;
    }

    .wing-02::before,
    .wing-02::after {
        content: "";
        width: 88.2px;
        height: 75.3px;
    }

    .onbox {
        width: 90%;
        margin-top: 15px;
        -webkit-transform: translate(0, 0);
        transform: translate(0, 0);
        position: relative;
        right: 0;
    }

    .deco-01::after {
        width: 93px;
        height: 99px;
    }

    .deco-02::before {
        width: 88.2px;
        height: 75.3px;
    }

    .deco-02::after {
        width: 102.4px;
        height: 136.4px;
    }

    .deco-03::before {
        width: 162px;
        height: 269.6px;
    }

    .deco-03::after {
        width: 100.8px;
        height: 139.6px;
    }

    .box-overlap-item {
        width: 95%;
    }

    .band {
        padding: 50px 0;
    }

    .number {
        width: 60px;
        height: 60px;
        font-size: 14.4px;
    }
}

/* custom contents */
.custom-info {
    margin-top: 10px;
}

.custom-title {
    font-size: 20px;
}

.custom-box .custom-title {
    padding: 5px 10px;
    color: rgb(40, 40, 149);
    border-bottom: 1px solid #ccc;
}

.custom-side-title {
    margin-bottom: 20px;
    padding: 5px 5px 5px 1.2em;
    font-size: 22px;
    color: rgb(40, 40, 149);
    border-bottom: 2px solid rgb(40, 40, 149);
    position: relative;
}

.custom-side-title::before {
    position: absolute;
    top: 10px;
    left: 0;
}

.custom-side-list li a {
    padding: 5px 5px 5px 1.4em;
    letter-spacing: 1px;
    position: relative;
}

.custom-side-list li a::before {
    content: "●";
    display: inline-block;
    color: rgb(40, 40, 149);
    position: absolute;
    top: 1px;
    left: 0;
}

.custom-side-list li+li {
    margin-top: 10px;
}

.list-custom-02 li+li {
    margin-top: 30px;
}

.date,
.category {
    padding-left: 1.6em;
    position: relative;
}

.date::before,
.category::before {
    font-size: 120%;
    position: absolute;
    top: 2px;
    left: 0;
}

.category span {
    display: inline-block;
    padding: 3px 10px;
    font-size: 12px;
    color: white;
    line-height: 1.2;
    border-radius: 3px;
    background-color: rgb(40, 40, 149);
}

.category span+span {
    margin-left: 5px;
}

.detail-content {
    padding: 30px 20px;
    border: 1px solid rgb(40, 40, 149);
    border-radius: 10px;
}

.detail-content-title {
    margin-bottom: 20px;
    padding: 10px 5px;
    font-weight: 500;
    font-size: 18px;
    color: rgb(40, 40, 149);
    border-bottom: 1px solid #ccc;
}

.detail-content-info .date,
.detail-content-info .category {
    margin: 5px;
    font-size: 14px;
}

.detail-content-box {
    margin-top: 20px;
}

.detail-backlink {
    margin: 50px 0;
}

.detail-backlink-list {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
}

.detail-backlink-list li {
    margin: 10px;
}

@media (max-width: 1024px) {
    .date {
        font-size: 14px;
    }

    .custom-title {
        font-size: 16px;
    }

    .detail-backlink-list li .btn {
        max-width: 100%;
    }

    .detail-backlink-list li:nth-of-type(1) {
        -webkit-box-ordinal-group: 2;
        -ms-flex-order: 1;
        order: 1;
    }

    .detail-backlink-list li:nth-of-type(2) {
        -webkit-box-ordinal-group: 4;
        -ms-flex-order: 3;
        order: 3;
    }

    .detail-backlink-list li:nth-of-type(3) {
        -webkit-box-ordinal-group: 3;
        -ms-flex-order: 2;
        order: 2;
    }
}

@media (max-width: 599px) {

    .custom-thumb {
        width: 35%;
    }

    .custom-info {
        width: 60%;
        margin-top: 0;
    }
}

/* form */
.must {
    display: block;
    margin-top: 5px;
    margin-left: 0;
    padding: 0;
    font-size: inherit;
    color: #54b04e;
    text-align: left;
    background-color: transparent;
}

/* common */

.title-01 {
    color: rgb(40, 40, 149);
}

.hamburger {
    background-color: rgb(40, 40, 149);
}


/* other */

.up-fz-16 {
    font-size: 16px;
}

.text16 {
    font-size: 16px;
}

/* top */
.first-view-slide {
    width: 55%;
    margin-left: auto;
}

.first-view .uk-slideshow::after {
    content: "";
    display: block;
    padding-top: 90%;
}

.pbox {
    position: absolute;
    bottom: 15%;
    left: 40%;
}

.parallel-inner .list-flat dd {
    width: auto;
    -webkit-box-flex: 0;
    -ms-flex-positive: 0;
    flex-grow: 0;
}

.list-img {
    width: 100%;
    height: 100%;
}

.list-message {
    overflow: hidden;
    position: relative;
}

.message {
    position: relative;
    z-index: 1;
    padding: 10px;
    text-align: center;
    -webkit-transform: translate(0, -50%);
    transform: translate(0, -50%);
    position: absolute !important;
    top: 50%;
    left: 0;
    right: 0;
}

.message .text {
    color: #fff;
    text-shadow: rgb(40 40 149) 1px 1px 1px,
        rgb(40 40 149) 1px -1px 1px,
        rgb(40 40 149) -1px 1px 1px,
        rgb(40 40 149) -1px -1px 1px,
        rgb(40 40 149) 1px 1px 1px,
        rgb(40 40 149) 1px -1px 1px,
        rgb(40 40 149) -1px 1px 1px,
        rgb(40 40 149) -1px -1px 1px,
        rgb(40 40 149) 1px 1px 1px,
        rgb(40 40 149) 1px -1px 1px,
        rgb(40 40 149) -1px 1px 1px,
        rgb(40 40 149) -1px -1px 1px,
        rgb(40 40 149) 1px 1px 1px,
        rgb(40 40 149) 1px -1px 1px,
        rgb(40 40 149) -1px 1px 1px,
        rgb(40 40 149) -1px -1px 1px;
}

.bnr-effect .bnr-img::before {
    content: "";
    width: 100%;
    height: 100%;
    display: block;
    background-color: rgba(40, 40, 149, 0.5);
    position: absolute;
    top: 0;
    left: 0;
    border: 1px solid rgba(255, 255, 255, 0.9);
    z-index: 1;
    -webkit-transition: .3s linear;
    transition: .3s linear;
}

.bg-none .up-ofi-50::after {
    content: "";
    width: 100%;
    height: 100%;
    display: block;
    background-color: transparent;
    position: absolute;
    top: 0;
    left: 0;
    border: 1px solid rgba(255, 255, 255, 0.9);
}

.list-custom-01 li .bnr-effect a:hover {
    opacity: 1;
}

.list-custom-01 li a:hover .bnr-img::before {
    background-color: transparent;
}

.area-06_list .border-01 {
    border-radius: 10%;
    background-color: #fff;
}

.circle {
    width: 90%;
}

.circle-in {
    width: 100%;
    padding-top: 100%;
    border-radius: 50%;
    background-color: rgba(40, 40, 149, 0.7);
    position: relative;
}

.circle-in-font {
    position: absolute;
    top: 50%;
    left: 50%;
    -webkit-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
    font-size: 17px;
    color: #fff;
    text-align: center;
    width: 100%;
}

.list-sonar li:nth-of-type(even) .circle-in {
    background: #7CD2FF;
}

.list-sonar {
    max-width: 750px;
    margin: 40px auto;
}

.greeting .btn a {
    text-align: left;
}

/* .name-y {
    -webkit-writing-mode: vertical-rl;
    -ms-writing-mode: tb-rl;
    writing-mode: vertical-rl;
    font-size: 26px;
    position: absolute;
    right: 0;
}
 */
 
 .name-y {
    -webkit-writing-mode: vertical-rl;
    writing-mode: vertical-rl;
    font-size: 26px;
    position: absolute;
}


.area-07 .list-inner {
    border: solid 1px #666464;
}

.area-08 .text {
    font-size: 16px;
    line-height: 200%;
    padding: 16px 0;
}

/* area-04 */

.area-04 ul {
    margin: 0 auto;
}

/* news-blog */

.news-blog .inner {
    border: 1px solid #b5b5b5;
    border-radius: 7px;
    background-color: #fff;
    max-width: 1000px;
    margin: 0 auto;
    padding: 2% 4%;
}

.news-blog_item01 {
    padding-right: 3%;
    border-right: 1px solid #474747;
}

.news-blog_item02 {
    padding-left: 3%;
}

.google_map {
    position: relative;
    width: 100%;
    height: 0;
    padding-top: 35%;

}

.google_map iframe {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
}

.bottom-menu01 {
    display: none;
}

.bottom-menu02 {
    display: none;
}

.section-large {
    padding-top: 50px;
    padding-bottom: 50px;
}

@media (max-width: 1024px) {
    .first-view {
        -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    }

    .first-view-slide,
    .first-view-cont {
        width: 100%;
    }

    .first-view .uk-slideshow::after {
        padding-top: 50%;
    }

    .director img {
        position: absolute;
        top: 75%;
        left: 0%;
        transform: translateY(-50%);
        -webkit-transform: translateY(-50%);
        -ms-transform: translateY(-50%);
    }

    .title-inner-28 {
        font-size: 25px;
    }

    .area-05 .inner {
        padding: 80px 0;
    }

    .bottom-menu01 {
        display: block;
        position: fixed;
        bottom: 10px;
        left: 15%;
        z-index: 2;
        color: #fff;
    }

    .bottom-menu02 {
        display: block;
        position: fixed;
        bottom: 10px;
        left: 50%;
        z-index: 2;
        color: #fff;
    }
}

@media (max-width: 599px) {

    .section-large {
        padding-top: 30px;
        padding-bottom: 30px;
    }

    .area-05 .inner {
        padding: 30px 0;
    }

    .first-view .uk-slideshow::after {
        padding-top: 125%;
    }

    .director img {
        position: absolute;
        top: 50%;
        left: 0%;
        transform: translateY(-50%);
        -webkit-transform: translateY(-50%);
        -ms-transform: translateY(-50%);
    }

    .title-inner-28 {
        font-size: 22px;
    }

    .first-view-cont-box .first-view-cont-title {
        margin-bottom: 18px;
        font-size: 17px;
        letter-spacing: 5px;
    }

    .first-view-cont-box .text {
        font-weight: normal;
        letter-spacing: 5px;
        font-size: 11px;
        line-height: 170%;
    }

    .circle {
        margin: 0 auto;
    }

    .list-sonar li:nth-of-type(4n) .circle-in {
        background: rgba(40, 40, 149, 0.8);
    }

    .list-sonar li:nth-of-type(4n-1) .circle-in {
        background: #7CD2FF;
    }

    .area-06 .title-01 {
        margin-bottom: 0;
    }

    .area-06 .parallel,
    .area-08 .parallel {
        -webkit-box-orient: vertical;
        -webkit-box-direction: reverse;
        -ms-flex-direction: column-reverse;
        flex-direction: column-reverse;
    }

    .area-06 .pic,
    .area-08 .pic {
        padding-bottom: 30px;
    }

    .news-blog_item01 {
        padding-right: 0;
        border-right: none;
    }

    .news-blog_item02 {
        padding-left: 0%;
    }

    .google_map {
        padding-top: 100%;
    }

    .bottom-menu01 {
        display: block;
        position: fixed;
        bottom: 10px;
        left: 5%;
        z-index: 2;
        color: #fff;
    }

    .bottom-menu .btn a,
    .bottom-menu .btn button {
        width: 150px;
    }

    .totop {
        position: fixed;
        bottom: 75px;
        right: 10px;
        z-index: 2;
    }


    .block-section {
        margin-top: 50px;
        margin-top: 50px;

    }

    .block-section ul li+li {
        margin-top: 10px;
    }


    .pbox {
        position: absolute;
        bottom: 10%;
        left: 40%;
        z-index: 2;
    }

    .name-y {
        -webkit-writing-mode: horizontal-tb;
        -ms-writing-mode: lr-tb;
        writing-mode: horizontal-tb;
        font-size: 26px;
        position: static;
        padding-top: 30px;
    }

}

/* under */
.breadcrumbs-list li.breadcrumbs-home {
    font-weight: bold;
    color: rgb(40, 40, 149);
}

.first-view .uk-slideshow::after {
    padding-top: 60%;
}

.under .first-view-cont-box .first-view-cont-title {
    margin-bottom: 0;
}

.under .en {
    font-size: 16px;
    font-weight: normal;
    letter-spacing: 2;

}

/* under　clinic */
.under-clinic .list-sonar li:nth-of-type(4n) .circle-in {
    background: rgba(40, 40, 149, 0.8);
}

.under-clinic .list-sonar li:nth-of-type(4n-1) .circle-in {
    background: #7CD2FF;
}


/* under-menu */
.under .first-view-cont-title {
    text-align: center;
}

.under .pbox {
    position: absolute;
    bottom: 20%;
    left: 30%;
}

.under .first-view-cont-title {
    text-align: center;
}


/* under kenpo */

.under-kenpo .text {
    font-size: 16px;
    line-height: 160%;
}

.under .inner-second {
    padding-top: 50px;
    padding-bottom: 50px;
}

.kenpo-title {
    border-bottom: solid 1px rgb(40, 40, 149);
}


.text-kenpoHP a:link {
    color: #0000EE;
    text-decoration: underline;
}

.text-kenpoHP a:visited {
    color: #551A8B;
    text-decoration: underline;
}

.text-kenpoHP a:active {
    color: #FF0000;
    text-decoration: underline;
}

.kenpo-table tr td:nth-of-type(3n),
.kenpo-table tr td:nth-of-type(4n) {
    text-align: center;
}



@media (max-width: 1024px) {

    .under .first-view-cont-title {
        margin-bottom: 0;
        text-align: left;
        padding-bottom: 20px;
    }
}



@media (max-width: 599px) {

    .first-view-cont-box .first-view-cont-title .en {
        font-size: 14px;
    }
}


/* under kenshin */
.price {
    text-decoration: underline;
}

.under .text {
    font-size: 16px;
}

.under-kenshin .table01 {
    margin: 30px 0;
}

.under-kenshin .btn a,
.under-kenshin .btn button,
.under-kenshin .btn {
    width: 300px;
    margin: 50px 0 0 0;
}

/* under news */

.pager ul li a:hover {
    color: white;
    border: 1px solid rgb(40, 40, 149);
    background-color: rgb(40, 40, 149);
    opacity: 1;
}

.pager ul li .now {
    border: 1px solid rgb(40, 40, 149);
    background-color: rgb(40, 40, 149);
}

/* under content */
.contact_tel {
    font-size: 18px;
}

.contact_tel .tel {
    font-size: 26px;
    color: #7CD2FF;
}

.under form,
.form_text {
    width: 95%;
    margin: auto;
}

.form_text {
    margin: 0 auto 80px;
}

.flex {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
}

.flex dt {
    width: 30%;
    font-weight: bold;
    color: rgb(40, 40, 149);
    font-size: 18px;
}

.flex dd {
    width: 67%;
    font-weight: bold;

}

.row-10 {
    height: calc(1.3em * 10);
    line-height: 1.3;
    width: 100%;
}


form>dl {
    margin: 0 0 5%;
}

.flex .inputtext {
    width: 100%;
    height: calc(1.3em * 1.5);
    line-height: 1.3;
}

.radio {
  width: 100%;
}

.radio input {
  margin-left: 3%
}

/* under reserve */

.font_color {
    color: #FF0000;
}

.form dt,
.form dd {
    padding: 0 15px;
}

.form select {
    width: 30%;
}

.form select+select {
    margin-left: 10px;
}

@media (max-width: 599px) {

    .contact_tel {
        font-size: 14px;
    }

    .under_contact .title-07 {
        font-size: 20px;
        padding: 5px 5px;
    }

    .flex dt {
        font-size: 14px;
    }

    .form dt,
    .form dd {
        width: 100%;
    }

    .under form,
    .form_text {
        width: 100%;
    }

    .flex .inputtext {
        width: 100%;
    }

    .form_text {
        margin: 0 auto 50px;
    }

    .form dt {
        padding-bottom: 10px;
    }


}

/* under recruit */

.btn .-alternate .recruit-btn a {
    color: rgb(40, 40, 149);
    border: 1px solid rgba(40, 40, 149, 0.8);
    background-color: white;
}

.btn .-alternate .recruit-btn a::before {
    background-color: rgba(40, 40, 149, 0.8);
}

.btn .-alternate .recruit-btn a:hover {
    color: white;
    border: 1px solid rgb(40, 40, 149);
}

.recruit .btn {
    width: 330px;
}

.recruit .btn a,
.recruit .btn button {
    width: 100%;
    padding: 2em 1em;
}

.recruit .btn-inner {
    font-size: 22px;
}

.recruit .table01 {
    width: 90%;
    margin: 0 auto;
}

.recruit .table01 dt {
    padding: 1em 2em;
    border: 1px solid #fff;
}

.recruit .table01 dd {
    padding: 1em 2em;
    border: 1px solid #AAA;
    border-left: none;
}

.recruit .table01 {
    margin-top: 80px;
    border: none
}

.recruit-table dt {
    width: 20%;
    text-align: center;
    background-color: rgba(40, 40, 149, 0.8);
    color: #fff;

}

.recruit-table dd {
    width: 80%;
}

.recruit-table .recruit-flow {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
}


.flow-item {
    font-size: 22px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    border: 1px solid rgb(40, 40, 149);
    border-radius: 10px;
    padding: 3em 1em;
    color: rgb(40, 40, 149);
    margin-right: 40px;
    background-color: #fff;
}

.recruit-flow li {
    position: relative;
}

.recruit-flow li:not(:last-child)::after {
    content: "\f054";
    display: inline-block;
    margin: auto;
    font-family: "Font Awesome 5 Free";
    font-weight: 900;
    font-size: inherit;
    line-height: 100%;
    -webkit-transform: translate(0, -50%);
    transform: translate(0, -50%);
    position: absolute;
    top: 50%;
    right: 10px;
    z-index: 1;
}

.job-text .job-title {
    background-color: rgb(40, 40, 149);
    color: #fff;
    border-radius: 30px;
    overflow: hidden;
    text-align: center;
    padding: 5px 10px;
}

.job-text dl+dl {
    margin-top: 20px;
}

.job-text dd {
    padding: 0 10px;
    font-size: 18px;
}

.bg-job {
    background-color: #fff;
    border-radius: 20px;
}

.bg-job+.bg-job {
    margin-top: 50px;
}

.first-view .uk-slideshow::after {
    content: "";
    display: block;
    padding-top: 30%;
}

    .under .first-view .uk-slideshow::after {
    content: "";
    display: block;
    padding-top: 0%;
    }

  .under .first-view-cont {
    width: 70%;
  }
  
 .under.first-view.lower .first-view-img::after {
    content: "";
    display: block;
    padding-top: 40%;
}


@media (max-width: 1024px) {
    .recruit-flow li {
        margin: 1% 0;
    }
    .under .under-visual .first-view-cont {
        width: 100%;
    }

}


@media (max-width: 599px) {

    .recruit-table dt,
    .recruit-table dd {
        width: 100%;
    }

    .recruit .table01 dt {
        padding: 0.5em 2em;
        text-align: left;
    }

    .recruit-table dd {
        text-align: left;
    }

    .recruit .table01 dt {
        border: 1px solid rgb(40, 40, 149);
    }

    .recruit .table01 dd {
        border: 1px solid #AAA;
    }

    .flow-item {
        margin-right: 0;
        margin-bottom: 40px;
    }

    .recruit-flow li:not(:last-child)::after {
        width: 20px;
        height: 20px;
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-orient: vertical;
        -webkit-box-direction: normal;
        -ms-flex-direction: column;
        flex-direction: column;
        -webkit-box-align: center;
        -ms-flex-align: center;
        align-items: center;
        -webkit-box-pack: center;
        -ms-flex-pack: center;
        justify-content: center;
        content: "\f107";
        bottom: -110px;
        left: 50%;
        right: 50%;
        -webkit-transform: translate(-50%, -100%);
        transform: translate(-50%, -100%);
    }
}

/* under contact verification */

.verification .btn.-alternate.btn-01 button {
    color: white;
    border: 1px solid #7CD2FF;
    background-color: #7CD2FF;
}

.verification .btn.-alternate.btn-01 button:hover {
    color: #fff;
    border: 1px solid rgb(40, 40, 149);
    background-color: rgb(40, 40, 149);
    }

.verification .btn-01 button {
    color: #fff;
    border: solid 1px rgb(40, 40, 149);
    background-color: rgb(40, 40, 149);
}

.verification .btn.-alternate.btn-01 button:hover {
    color: #7CD2FF;
    border: 1px solid #7CD2FF;
}

.verification .btn-01 button:hover {
    color: rgb(40, 40, 149);
    border: solid 1px rgb(40, 40, 149);
    background-color: #fff;
}

.verification .btn-01 a::before, 
.verification .btn-01 button::before {
    background-color: #FFF;
}

/* under reserve */

.form .select-w100 {
  width: 100%;
}

.form .select-w70 {
  width: 70%;
}

.form .select-w40 {
  width: 40%;
}

.form .radio-mx5 input {
  margin: 0 5px
}

.contact-item dd select [value=""] {
    display: none;
    color: #818181;
}

@media (max-width: 1024px) {
.form .select-w70 {
  width: 40%;
}

.form-birthday > * + * {
  margin-top: 15px;
}

}

.name-y{
  right: 0px;
}

@media all and (-ms-high-contrast: none){
  .name-y{
  right: auto;
}
}
