@charset "UTF-8";
/* ==========================================================
Name:
    base.css

Description:
    サイト全体に共通する設定を記述する

Contents:
    base settings
    javascript style hooks
    base blocks
========================================================== */
/* ==========================================================
*
*   base settings
*
========================================================== */
/* ---------------------------------------------
*   Rounded Mplus 1c
--------------------------------------------- */
@import url(https://fonts.googleapis.com/earlyaccess/roundedmplus1c.css);
/* ---------------------------------------------
*   html, body
--------------------------------------------- */
html,
body {
    color: #222;
    font-weight: 500;
    font-size: 18px;
    font-family: "Rounded Mplus 1c", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", sans-serif;

    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    -webkit-text-size-adjust: 100%;
}

@media screen and (max-width: 738px) {
    html,
    body {
        font-size: 4.375vw;
    }
}

body {
    position: relative;
    min-width: 1160px;
    line-height: 1.5;
}

@media screen and (max-width: 738px) {
    body {
        min-width: 320px;
        line-height: 1.5;
    }
}

body.fixing {
    overflow: hidden;
}

/* ---------------------------------------------
*   <a> tag
--------------------------------------------- */
a {
    color: inherit;
    text-decoration: none;
}

/* ---------------------------------------------
*   <img> tag
--------------------------------------------- */
img {
    max-width: 100%;
    width: auto;
    height: auto;
    vertical-align: bottom;
}

/* ==========================================================
*
*   javascript style hooks
*
========================================================== */
/* ==========================================================
*
*   base blocks
*
========================================================== */
/* ---------------------------------------------
*   header
--------------------------------------------- */
.header {
    position: relative;
    background: url(/img/common/bg_head.png) 50% 0 no-repeat;
}

@media screen and (max-width: 738px) {
    .header {
        background: url(/img/sp/common/bg_head.png) 50% 0 no-repeat;
        background-size: 100% auto;
    }
}

.header--top .header-container {
    height: auto;
}

/*  header-container
--------------------------------------------- */
.header-container {
    position: relative;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    margin-right: auto;
    margin-left: auto;
    width: 1140px;
    height: 250px;
}

@media screen and (max-width: 738px) {
    .header-container {
        margin-right: 3.125vw;
        margin-left: 3.125vw;
        width: auto;
    }
}

@media screen and (max-width: 738px) {
    .header-container {
        margin-right: 0;
        margin-left: 0;
        height: 56.25vw;
    }
}

/*  header-logo
--------------------------------------------- */
.header-logo__link {
    position: absolute;
    top: 18px;
    left: 50%;
    z-index: 30;
    display: block;
    overflow: hidden;
    margin-left: -50px;
    padding-top: 112px;
    width: 372px;
    height: 0;
    background-image: url(/img/common/logo_head.png);
    background-position: 0 0;
    background-size: cover;
    background-repeat: no-repeat;
    -webkit-transform: translateX(-50%);
    transform: translateX(-50%);
}

@media screen and (max-width: 738px) {
    .header-logo__link {
        top: 1.40625vw;
        left: 47%;
        z-index: 100;
        margin-left: 0;
        padding-top: 18.125vw;
        width: 60vw;
        background-image: url(/img/sp/common/logo_head.png);
    }
}

/*  header-frame-hide
--------------------------------------------- */
.header-frame-hide {
    position: relative;
    overflow: hidden;
    max-width: 1140px;
    height: 250px;
}

@media screen and (max-width: 738px) {
    .header-frame-hide {
        max-width: none;
        height: 56.25vw;
    }
}

/*  header-bonnon
--------------------------------------------- */
.header-bonnon {
    position: absolute;
    bottom: -101px;
    left: 73px;
    width: 200px;
    height: 331px;
}

@media screen and (max-width: 738px) {
    .header-bonnon {
        bottom: -18.75vw;
        left: -3.90625vw;
        z-index: 40;
        width: 37.96875vw;
        height: 69.21875vw;
    }
}

.header-bonnon img {
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
}

@media screen and (max-width: 738px) {
    .header-bonnon img {
        width: 100%;
    }
}

.js-bonnon1 {
    -webkit-transform: translate(0, 12%);
    transform: translate(0, 12%);
}

.js-bonnon1--jump {
    -webkit-transform: translate(0, 0);
    transform: translate(0, 0);
    -webkit-animation: bonnonAnime1 1s ease;
    animation: bonnonAnime1 1s ease;

    -webkit-animation-fill-mode: forwards;
    animation-fill-mode: forwards;
}

@-webkit-keyframes bonnonAnime1 {
    0% {
        -webkit-transform: translate(0, 12%);
        transform: translate(0, 12%);
    }
    30% {
        -webkit-transform: translate(0, -6%);
        transform: translate(0, -6%);
    }
    100% {
        -webkit-transform: translate(0, 0);
        transform: translate(0, 0);
    }
}

@keyframes bonnonAnime1 {
    0% {
        -webkit-transform: translate(0, 12%);
        transform: translate(0, 12%);
    }
    30% {
        -webkit-transform: translate(0, -6%);
        transform: translate(0, -6%);
    }
    100% {
        -webkit-transform: translate(0, 0);
        transform: translate(0, 0);
    }
}

.js-bonnon2--smile .js-bonnon-smile-off {
    -webkit-animation: bonnonAnime2Off 3 5s ease;
    animation: bonnonAnime2Off 3 5s ease;

    -webkit-animation-fill-mode: forwards;
    animation-fill-mode: forwards;
}

.js-bonnon-smile-off {
    z-index: 2;
}

.js-bonnon-smile-on {
    z-index: 1;
}

@-webkit-keyframes bonnonAnime2Off {
    0% {
        opacity: 1;
    }
    14% {
        opacity: 1;
    }
    15% {
        opacity: 0;
    }
    50% {
        opacity: 0;
    }
    64% {
        opacity: 0;
    }
    65% {
        opacity: 1;
    }
    100% {
        opacity: 1;
    }
}

@keyframes bonnonAnime2Off {
    0% {
        opacity: 1;
    }
    14% {
        opacity: 1;
    }
    15% {
        opacity: 0;
    }
    50% {
        opacity: 0;
    }
    64% {
        opacity: 0;
    }
    65% {
        opacity: 1;
    }
    100% {
        opacity: 1;
    }
}

.js-bonnon3--last .js-bonnon-smile-off {
    z-index: 0;
    opacity: 0;
}

.js-bonnon3--last .js-bonnon-smile-on {
    z-index: 0;
    opacity: 0;
}

.js-bonnon3--last .js-bonnon-last {
    opacity: 0;
    -webkit-animation: bonnonAnimeLast 1s ease;
    animation: bonnonAnimeLast 1s ease;

    -webkit-animation-fill-mode: forwards;
    animation-fill-mode: forwards;
}

@-webkit-keyframes bonnonAnimeLast {
    0% {
        opacity: 0;
    }
    100% {
        z-index: 1;
        opacity: 1;
    }
}

@keyframes bonnonAnimeLast {
    0% {
        opacity: 0;
    }
    100% {
        z-index: 1;
        opacity: 1;
    }
}

.js-bonnon-hand {
    position: absolute;
    bottom: -10px;
    left: 135px;
    opacity: 1;
}

@media screen and (max-width: 738px) {
    .js-bonnon-hand {
        bottom: -2.1875vw;
        left: 7.5vw;
        z-index: 41;
        width: 19.53125vw;
        height: 6.5625vw;
    }
}

@media screen and (max-width: 738px) {
    .js-bonnon-hand img {
        width: 100%;
    }
}

/*  header-owl
--------------------------------------------- */
.header-owl {
    position: absolute;
    bottom: -61px;
    left: 50%;
    margin-left: -124px;
    width: 153px;
    height: 179px;
    -webkit-transform: translateX(-50%);
    transform: translateX(-50%);
}

@media screen and (max-width: 738px) {
    .header-owl {
        bottom: -9.6875vw;
        z-index: 42;
        margin-left: -8.4375vw;
        width: 28.125vw;
        height: 30.78125vw;
    }
}

.header-owl img {
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
}

@media screen and (max-width: 738px) {
    .header-owl img {
        width: 100%;
    }
}

.js-owl1--smile .js-owl-smile-off {
    -webkit-animation: owlAnime2Off .5s ease;
    animation: owlAnime2Off .5s ease;

    -webkit-animation-fill-mode: forwards;
    animation-fill-mode: forwards;
}

.js-owl-smile-off {
    z-index: 1;
}

@-webkit-keyframes owlAnime2Off {
    0% {
        opacity: 1;
    }
    100% {
        opacity: 0;
    }
}

@keyframes owlAnime2Off {
    0% {
        opacity: 1;
    }
    100% {
        opacity: 0;
    }
}

.js-owl-hand {
    position: absolute;
    bottom: -17px;
    left: 50%;
    margin-left: -168px;
    -webkit-transform: translateX(-50%);
    transform: translateX(-50%);
}

@media screen and (max-width: 738px) {
    .js-owl-hand {
        bottom: -1.71875vw;
        z-index: 42;
        margin-left: -16.875vw;
        width: 6.875vw;
        height: 6.5625vw;
    }
}

@media screen and (max-width: 738px) {
    .js-owl-hand img {
        width: 100%;
    }
}

/*  header-boy
--------------------------------------------- */
.header-boy {
    position: absolute;
    bottom: -63px;
    left: 49%;
    width: 113px;
    height: 157px;
    -webkit-transform: translateX(-50%);
    transform: translateX(-50%);
}

@media screen and (max-width: 738px) {
    .header-boy {
        bottom: -14.53125vw;
        left: -0.15625vw;
        z-index: 40;
        width: 29.53125vw;
    }
}

.header-boy img {
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
}

.js-boy1--smile .js-boy-smile-off {
    -webkit-animation: boyAnime2Off 5s ease;
    animation: boyAnime2Off 5s ease;
    -webkit-animation-iteration-count: infinite;
    animation-iteration-count: infinite;

    -webkit-animation-fill-mode: forwards;
    animation-fill-mode: forwards;
}

.js-boy-smile-off {
    z-index: 1;
}

@-webkit-keyframes boyAnime2Off {
    0% {
        opacity: 1;
    }
    4% {
        opacity: 1;
    }
    5% {
        opacity: 0;
    }
    9% {
        opacity: 0;
    }
    10% {
        opacity: 1;
    }
    14% {
        opacity: 1;
    }
    15% {
        opacity: 0;
    }
    99% {
        opacity: 0;
    }
    100% {
        opacity: 1;
    }
}

@keyframes boyAnime2Off {
    0% {
        opacity: 1;
    }
    4% {
        opacity: 1;
    }
    5% {
        opacity: 0;
    }
    9% {
        opacity: 0;
    }
    10% {
        opacity: 1;
    }
    14% {
        opacity: 1;
    }
    15% {
        opacity: 0;
    }
    99% {
        opacity: 0;
    }
    100% {
        opacity: 1;
    }
}

.js-boy-hand {
    position: absolute;
    bottom: -20px;
    left: 50%;
    width: 98px;
    height: 51px;
    -webkit-transform: translateX(-50%);
    transform: translateX(-50%);
}

.js-boy-hand img {
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: -10%;
}

/*  header-fox
--------------------------------------------- */
.header-fox {
    position: absolute;
    right: 50%;
    bottom: -95px;
    margin-right: -155px;
    width: 140px;
    height: 184px;
    -webkit-transform: translate(50%);
    transform: translate(50%);
}

@media screen and (max-width: 738px) {
    .header-fox {
        bottom: -17.1875vw;
        z-index: 41;
        margin-right: -8.90625vw;
        width: 25.9375vw;
        height: 33.90625vw;
    }
}

.header-fox img {
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
}

@media screen and (max-width: 738px) {
    .header-fox img {
        width: 100%;
    }
}

.js-fox1--smile .js-fox-smile-off {
    -webkit-animation: foxAnime2Off 1.2s ease;
    animation: foxAnime2Off 1.2s ease;

    -webkit-animation-fill-mode: forwards;
    animation-fill-mode: forwards;
}

.js-fox-smile-off {
    z-index: 1;
}

@-webkit-keyframes foxAnime2Off {
    0% {
        opacity: 1;
    }
    100% {
        opacity: 0;
    }
}

@keyframes foxAnime2Off {
    0% {
        opacity: 1;
    }
    100% {
        opacity: 0;
    }
}

.js-fox-hand {
    position: absolute;
    right: 50%;
    bottom: -8px;
    margin-right: -163px;
    -webkit-transform: translateX(50%);
    transform: translateX(50%);
}

@media screen and (max-width: 738px) {
    .js-fox-hand {
        bottom: 1.09375vw;
        z-index: 41;
        margin-right: -10.46875vw;
        width: 10vw;
        height: 3.4375vw;
    }
}

@media screen and (max-width: 738px) {
    .js-fox-hand img {
        width: 100%;
    }
}

/*  header-niko
--------------------------------------------- */
.header-niko {
    position: absolute;
    right: 161px;
    bottom: -105px;
    width: 198px;
    height: 284px;
}

@media screen and (max-width: 738px) {
    .header-niko {
        right: -1.5625vw;
        bottom: -19.21875vw;
        z-index: 40;
        width: 38.4375vw;
        height: 55.3125vw;
    }
}

.header-niko img {
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
}

@media screen and (max-width: 738px) {
    .header-niko img {
        width: 100%;
    }
}

.js-niko1 {
    -webkit-transform: translate(0, 12%);
    transform: translate(0, 12%);
}

.js-niko1--jump {
    -webkit-transform: translate(0, 0);
    transform: translate(0, 0);
    -webkit-animation: nikoAnime1 1s ease;
    animation: nikoAnime1 1s ease;

    -webkit-animation-fill-mode: forwards;
    animation-fill-mode: forwards;
}

@-webkit-keyframes nikoAnime1 {
    0% {
        -webkit-transform: translate(0, 12%);
        transform: translate(0, 12%);
    }
    30% {
        -webkit-transform: translate(0, -6%);
        transform: translate(0, -6%);
    }
    100% {
        -webkit-transform: translate(0, 0);
        transform: translate(0, 0);
    }
}

@keyframes nikoAnime1 {
    0% {
        -webkit-transform: translate(0, 12%);
        transform: translate(0, 12%);
    }
    30% {
        -webkit-transform: translate(0, -6%);
        transform: translate(0, -6%);
    }
    100% {
        -webkit-transform: translate(0, 0);
        transform: translate(0, 0);
    }
}

.js-niko2--smile .js-niko-smile-off {
    -webkit-animation: nikoAnime2Off 3 5s ease;
    animation: nikoAnime2Off 3 5s ease;

    -webkit-animation-fill-mode: forwards;
    animation-fill-mode: forwards;
}

.js-niko-smile-off {
    z-index: 1;
}

@-webkit-keyframes nikoAnime2Off {
    0% {
        opacity: 1;
    }
    14% {
        opacity: 1;
    }
    15% {
        opacity: 0;
    }
    50% {
        opacity: 0;
    }
    64% {
        opacity: 0;
    }
    65% {
        opacity: 1;
    }
    100% {
        opacity: 1;
    }
}

@keyframes nikoAnime2Off {
    0% {
        opacity: 1;
    }
    14% {
        opacity: 1;
    }
    15% {
        opacity: 0;
    }
    50% {
        opacity: 0;
    }
    64% {
        opacity: 0;
    }
    65% {
        opacity: 1;
    }
    100% {
        opacity: 1;
    }
}

.js-niko-hand {
    position: absolute;
    right: 206px;
    bottom: -8px;
    opacity: 1;
}

@media screen and (max-width: 738px) {
    .js-niko-hand {
        right: 7.5vw;
        bottom: -1.875vw;
        z-index: 41;
        width: 21.875vw;
        height: 6.5625vw;
    }
}

@media screen and (max-width: 738px) {
    .js-niko-hand img {
        width: 100%;
    }
}

/*  header-trigger-frame
--------------------------------------------- */
.header-trigger-frame {
    position: fixed;
    top: 30px;
    right: 24px;
    z-index: 999;
    width: 88px;
    height: 90px;
    background-image: url(/img/common/bg_nav_close.png);
    background-position: 0 0;
    background-repeat: no-repeat;
    cursor: pointer;
}

@media screen and (max-width: 738px) {
    .header-trigger-frame {
        top: 7.8125vw;
        right: 4.21875vw;
        width: 14.53125vw;
        height: 15vw;
        background: url(/img/sp/common/bg_nav_close.png) 0 0 no-repeat;
        background-size: 100% 100%;
    }
}

.header-trigger-frame.active {
    top: 34px;
    width: 86px;
    height: 86px;
    background-image: url(/img/common/bg_nav_open.png);
}

@media screen and (max-width: 738px) {
    .header-trigger-frame.active {
        top: 8.125vw;
        right: 4.21875vw;
        width: 14.6875vw;
        height: 14.6875vw;
        background: url(/img/sp/common/bg_nav_open.png) 0 0 no-repeat;
        background-size: 100% 100%;
    }
}

.header-trigger-frame.active span:nth-of-type(1) {
    top: -4px;
    -webkit-transform: translateY(20px) rotate(-45deg);
    transform: translateY(20px) rotate(-45deg);
}

@media screen and (max-width: 738px) {
    .header-trigger-frame.active span:nth-of-type(1) {
        top: -0.625vw;
        -webkit-transform: translateY(3.125vw) rotate(-45deg);
        transform: translateY(3.125vw) rotate(-45deg);
    }
}

.header-trigger-frame.active span:nth-of-type(2) {
    opacity: 0;
}

.header-trigger-frame.active span:nth-of-type(3) {
    bottom: -6px;
    -webkit-transform: translateY(-20px) rotate(45deg);
    transform: translateY(-20px) rotate(45deg);
}

@media screen and (max-width: 738px) {
    .header-trigger-frame.active span:nth-of-type(3) {
        bottom: -0.9375vw;
        -webkit-transform: translateY(-3.125vw) rotate(45deg);
        transform: translateY(-3.125vw) rotate(45deg);
    }
}

/*  header-trigger
--------------------------------------------- */
.header-trigger {
    position: absolute;
    top: 48%;
    left: 48%;
    display: inline-block;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    width: 50px;
    height: 36px;
    -webkit-transition: all .4s;
    transition: all .4s;
    -webkit-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
}

@media screen and (max-width: 738px) {
    .header-trigger {
        width: 7.8125vw;
        height: 5.625vw;
    }
}

.header-trigger span {
    position: absolute;
    left: 0;
    display: inline-block;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    width: 100%;
    height: 6px;
    border-radius: 4px;
    background-color: #fff;
    -webkit-transition: all .4s;
    transition: all .4s;
}

@media screen and (max-width: 738px) {
    .header-trigger span {
        height: 0.9375vw;
        border-radius: 0.625vw;
    }
}

.header-trigger span:nth-of-type(1) {
    top: 0;
}

.header-trigger span:nth-of-type(2) {
    top: 16px;
}

@media screen and (max-width: 738px) {
    .header-trigger span:nth-of-type(2) {
        top: 2.5vw;
    }
}

.header-trigger span:nth-of-type(3) {
    bottom: 0;
}

/* ---------------------------------------------
*   wrapper
--------------------------------------------- */
.wrapper--green .breadcrumb,
.wrapper--green .page-title-frame {
    background-color: #89b92a;
}

.wrapper--green .page-heading {
    background-image: url(/img/common/bg_darkgreen02.png);
}

@media screen and (max-width: 738px) {
    .wrapper--green .page-heading {
        padding-top: 9.375vw;
        padding-bottom: 11.875vw;
        background-image: url(/img/sp/common/bg_green.png);
        background-size: 31.25vw 25.625vw;
    }
}

.wrapper--green .page-heading:before {
    background-image: url(/img/common/bg_triangle_green.png);
}

@media screen and (max-width: 738px) {
    .wrapper--green .page-heading:before {
        background-size: 6.5625vw 2.5vw;
    }
}

.wrapper--green .page-heading:after {
    background-image: url(/img/common/bg_green_gradation.png);
}

@media screen and (max-width: 738px) {
    .wrapper--green .page-heading__icon {
        margin-right: auto;
        margin-bottom: 5.15625vw;
        margin-left: auto;
        width: 12.34375vw;
    }
}

.wrapper--green .page-heading--none:before {
    bottom: -15px;
    background-image: url(/img/common/bg_triangle_green-w.png);
}

@media screen and (max-width: 738px) {
    .wrapper--green .page-heading--none:before {
        bottom: -2vw;
    }
}

.wrapper--green .page-heading--none:after {
    content: none;
}

.wrapper--green .menu-links__list-item-target:hover {
    background: #e9f3d4;
}

.wrapper--green .menu-links__list-item-target--current, .wrapper--green .menu-links__list-item-target--current:hover {
    background: #89b92a;
    color: #fff;
}

.wrapper--green .line-title {
    color: #89b92a;
}

.wrapper--green .line-title:before, .wrapper--green .line-title:after {
    background-image: url(/img/common/icon_circle_green.png);
}

@media screen and (max-width: 738px) {
    .wrapper--green .line-title:before, .wrapper--green .line-title:after {
        background-image: url(/img/sp/common/icon_circle_green.png);
    }
}

.wrapper--red .breadcrumb,
.wrapper--red .page-title-frame {
    background-color: #ed4949;
}

.wrapper--red .page-heading {
    background-image: url(/img/common/bg_red.png);
}

.wrapper--red .page-heading:before {
    background-image: url(/img/common/bg_triangle_white.png);
}

.wrapper--red .page-heading:after {
    background: #fff;
}

@media screen and (max-width: 738px) {
    .wrapper--red .page-heading__icon {
        margin-right: auto;
        margin-bottom: 5.15625vw;
        margin-left: auto;
        width: 8.75vw;
    }
}

.wrapper--red .menu-links__list-item-target:hover {
    background: #e9f3d4;
}

.wrapper--red .menu-links__list-item-target--current, .wrapper--red .menu-links__list-item-target--current:hover {
    background: #ed4949;
    color: #fff;
}

.wrapper--red .line-title {
    color: #ed4949;
}

.wrapper--red .line-title:before, .wrapper--red .line-title:after {
    background-image: url(/img/common/icon_circle_red.png);
}

@media screen and (max-width: 738px) {
    .wrapper--red .line-title:before, .wrapper--red .line-title:after {
        background-image: url(/img/sp/common/icon_circle_red.png);
    }
}

.wrapper--orange .breadcrumb,
.wrapper--orange .page-title-frame {
    background-color: #f29838;
}

.wrapper--orange .page-heading {
    background-image: url(/img/common/bg_orange_main.png);
}

.wrapper--orange .page-heading:before {
    background-image: url(/img/common/bg_triangle_white.png);
}

.wrapper--orange .page-heading:after {
    background: #fff;
}

@media screen and (max-width: 738px) {
    .wrapper--orange .page-heading__icon {
        margin-right: auto;
        margin-bottom: 5.15625vw;
        margin-left: auto;
        width: 9.84375vw;
    }
}

@media screen and (max-width: 738px) {
    .wrapper--orange .page-heading__icon--mail {
        width: 10.3125vw;
    }
}

.wrapper--redorange .breadcrumb,
.wrapper--redorange .page-title-frame {
    background-color: #ed6f49;
}

.wrapper--redorange .page-heading {
    background-image: url(/img/common/bg_redorange.png);
}

.wrapper--redorange .page-heading:before {
    background-image: url(/img/common/bg_triangle_white.png);
}

.wrapper--redorange .page-heading:after {
    background: #fff;
}

@media screen and (max-width: 738px) {
    .wrapper--redorange .page-heading__icon {
        margin-right: auto;
        margin-bottom: 5.15625vw;
        margin-left: auto;
        width: 8.75vw;
    }
}

.wrapper--redorange .line-title {
    color: #ed6f49;
}

.wrapper--redorange .line-title:before, .wrapper--redorange .line-title:after {
    background-image: url(/img/common/icon_circle_redorange.png);
}

@media screen and (max-width: 738px) {
    .wrapper--redorange .line-title:before, .wrapper--redorange .line-title:after {
        background-image: url(/img/sp/common/icon_circle_redorange.png);
    }
}

.wrapper--darkgreen .breadcrumb,
.wrapper--darkgreen .page-title-frame {
    background-color: #00a28e;
}

.wrapper--darkgreen .page-heading {
    background-image: url(/img/common/bg_darkgreen.png);
}

@media screen and (max-width: 738px) {
    .wrapper--darkgreen .page-heading {
        padding-top: 9.375vw;
        padding-bottom: 11.875vw;
        background-size: 31.25vw 25.625vw;
    }
}

.wrapper--darkgreen .page-heading:before {
    background-image: url(/img/common/bg_triangle_green.png);
}

@media screen and (max-width: 738px) {
    .wrapper--darkgreen .page-heading:before {
        background-size: 6.5625vw 2.5vw;
    }
}

.wrapper--darkgreen .page-heading:after {
    background-image: url(/img/common/bg_green_gradation.png);
}

@media screen and (max-width: 738px) {
    .wrapper--darkgreen .page-heading__icon {
        margin-right: auto;
        margin-bottom: 5.15625vw;
        margin-left: auto;
        width: 9.375vw;
    }
}

.wrapper--darkgreen .page-heading--none:before {
    bottom: -15px;
    background-image: url(/img/common/bg_triangle_darkgreen-w.png);
}

@media screen and (max-width: 738px) {
    .wrapper--darkgreen .page-heading--none:before {
        bottom: -2vw;
    }
}

.wrapper--darkgreen .page-heading--none:after {
    content: none;
}

.wrapper--darkgreen .line-title {
    color: #00a28e;
}

.wrapper--darkgreen .line-title:before, .wrapper--darkgreen .line-title:after {
    background-image: url(/img/common/icon_circle_darkgreen.png);
}

@media screen and (max-width: 738px) {
    .wrapper--darkgreen .line-title:before, .wrapper--darkgreen .line-title:after {
        background-image: url(/img/sp/common/icon_circle_darkgreen.png);
    }
}

.wrapper--purple .breadcrumb,
.wrapper--purple .page-title-frame {
    background-color: #db52b9;
}

.wrapper--purple .page-heading {
    background-image: url(/img/common/bg_purple.png);
}

.wrapper--purple .page-heading:before {
    background-image: url(/img/common/bg_triangle_white.png);
}

.wrapper--purple .page-heading:after {
    background: #fff;
}

@media screen and (max-width: 738px) {
    .wrapper--purple .page-heading__icon {
        margin-right: auto;
        margin-bottom: 5.15625vw;
        margin-left: auto;
        width: 8.75vw;
    }
}

.wrapper--blue .breadcrumb,
.wrapper--blue .page-title-frame {
    background-color: #00a7db;
}

.wrapper--blue .page-heading {
    background-image: url(/img/common/bg_blue_main.png);
}

.wrapper--blue .page-heading:before {
    background-image: url(/img/common/bg_triangle_white.png);
}

.wrapper--blue .page-heading:after {
    background: #fff;
}

@media screen and (max-width: 738px) {
    .wrapper--blue .page-heading__icon {
        margin-right: auto;
        margin-bottom: 5.15625vw;
        margin-left: auto;
        width: 8.4375vw;
    }
}

/*20220325 追加分*/


.wrapper--deepblue .breadcrumb,
.wrapper--deepblue .page-title-frame {
    background-color: #006dad;
}

.wrapper--deepblue .page-heading {
    background-image: url(/img/common/bg_blue_main.png);
}

.wrapper--deepblue .page-heading:before {
    background-image: url(/img/common/bg_triangle_white.png);
}

.wrapper--deepblue .page-heading:after {
    background: #fff;
}

@media screen and (max-width: 738px) {
    .wrapper--deepblue .page-heading__icon {
        margin-right: auto;
        margin-bottom: 5.15625vw;
        margin-left: auto;
        width: 8.4375vw;
    }
}

/*20220325 追加分ここまで*/



@media screen and (max-width: 738px) {
    .wrapper--report .page-title {}
    .wrapper--report .page-title__item {
        font-size: 7.8125vw;
    }
}

/* ---------------------------------------------
*   global-nav
--------------------------------------------- */
.global-nav {
    position: fixed;
    top: 0;
    right: 0;
    left: 0;
    z-index: 101;
    display: none;
    width: 100%;
    background-color: #ffd564;
}

@media screen and (max-width: 1024px) {
    .global-nav {
        bottom: 0;
        height: 100%;
    }
}

/*  global-nav-logo
--------------------------------------------- */
.global-nav-logo__text {
    position: absolute;
    top: 30px;
    left: 50%;
    z-index: 2;
    display: block;
    overflow: hidden;
    padding-top: 63.827957px;
    width: 212px;
    height: 0;
    background: url(/img/common/logo_head.png) 0 0 no-repeat;
    background-size: cover;
    background-repeat: no-repeat;
    -webkit-transition: opacity 300ms;
    transition: opacity 300ms;
    -webkit-transform: translateX(-50%);
    transform: translateX(-50%);
}

@media screen and (min-width: 739px) {
    .global-nav-logo__text:hover {
        opacity: 0.7;
    }
}

@media screen and (max-width: 1024px) {
    .global-nav-logo__text {
        top: 4.375vw;
        margin-left: -2.34375vw;
        padding-top: 17.5vw;
        width: 58.125vw;
        background-size: 100% auto;
    }
}

@media screen and (max-width: 500px) {
    .global-nav-logo__text {
        max-width: 250px;
    }
}

/*  global-nav-menu-scroll
--------------------------------------------- */
.global-nav-menu-scroll {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-pack: justify;

    -webkit-box-pack: justify;
    justify-content: space-between;
}

@media screen and (min-width: 1025px) {
    .global-nav-menu-scroll {
        margin-right: auto;
        margin-left: auto;
        width: 1140px;
    }
}

@media screen and (max-width: 1024px) {
    .global-nav-menu-scroll {
        display: block;
        overflow-y: scroll;
        padding-right: 3.125vw;
        padding-left: 3.125vw;
        height: calc(100vh - 30vw);
    }
}

/* -- scroll bar -- */
.global-nav-menu-scroll {
    overflow: -moz-scrollbars-none;

    -ms-overflow-style: none;
}

.global-nav-menu-scroll::-webkit-scrollbar {
    display: none;
}

/* -- windows firefox -- */
.windows.firefox .global-nav-menu-scroll {
    width: 1157px;
}

/*  global-nav-menu
--------------------------------------------- */
.global-nav-menu {
    position: relative;
    margin-top: 103px;
}

@media screen and (min-width: 1025px) {
    .global-nav-menu {
        overflow: auto;
    }
}

@media screen and (max-width: 1024px) {
    .global-nav-menu {
        margin-top: 30vw;
    }
}

@media screen and (max-width: 500px) {
    .global-nav-menu {
        margin-top: 130px;
    }
}

@media screen and (max-width: 400px) {
    .global-nav-menu {
        margin-top: 100px;
    }
}

.global-nav-menu__break {
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    width: 562px;
}

@media screen and (max-width: 1024px) {
    .global-nav-menu__break {
        width: 100%;
    }
}

.global-nav-menu__frame {
    margin-bottom: 10px;
    padding: 14px 20px 10px 20px;
    border-radius: 5px;
    background-color: #fef1d1;
}

@media screen and (max-width: 1024px) {
    .global-nav-menu__frame {
        margin-bottom: 4.6875vw;
        padding: 0;
        border-radius: 0.78125vw;
    }
}

.global-nav-menu__frame--blue .global-nav-menu__list-title-item {
    color: #00a7db;
}

.global-nav-menu__frame--blue .global-nav-menu__link-item-text:before {
    background-color: #00a7db;
}

.global-nav-menu__frame--blue .global-nav-menu__list-title-item:before {
    background-image: url(/img/common/img_event_blue.png);
}

/*20220325 追加分*/

.global-nav-menu__frame--deepblue .global-nav-menu__list-title-item {
    color: #006dad;
}

.global-nav-menu__frame--deepblue .global-nav-menu__image-item-link-text:before {
    background-color: #006dad;
}

.global-nav-menu__frame--deepblue .global-nav-menu__list-title-item:before {
    background-image: url(/img/common/img_odekake_deepblue.png);
}



/*20220325 追加分ここまで*/

.global-nav-menu__frame--green .global-nav-menu__list-title-item {
    color: #89b82a;
}

.global-nav-menu__frame--green .global-nav-menu__link-item-text:before {
    background-color: #89b82a;
}

.global-nav-menu__frame--green .global-nav-menu__list-title-item:before {
    background-image: url(/img/common/img_work_green.png);
}

.global-nav-menu__frame--green .global-nav-menu__image-item-link-text:before {
    background-color: #89b82a;
}

.global-nav-menu__frame--red .global-nav-menu__list-title-item {
    color: #ed4949;
}

.global-nav-menu__frame--red .global-nav-menu__link-item-text:before {
    background-color: #ed4949;
}

.global-nav-menu__frame--red .global-nav-menu__list-title-item:before {
    background-image: url(/img/common/img_train_red.png);
}

.global-nav-menu__frame--red .global-nav-menu__image-item-link-text:before {
    background-color: #ed4949;
}

.global-nav-menu__frame--purple .global-nav-menu__list-title-item {
    color: #db52b9;
}

.global-nav-menu__frame--purple .global-nav-menu__link-item-text:before {
    background-color: #db52b9;
}

.global-nav-menu__frame--purple .global-nav-menu__list-title-item:before {
    background-image: url(/img/common/img_juggle_purple.png);
}

.global-nav-menu__frame--purple .global-nav-menu__image {
    margin-bottom: 3px;
}

.global-nav-menu__frame--purple .global-nav-menu__image-item-link-text:before {
    background-color: #db52b9;
}

.global-nav-menu__frame--orange {
    padding-top: 16px;
    padding-bottom: 15px;
}

@media screen and (max-width: 1024px) {
    .global-nav-menu__frame--orange {
        padding-top: 0;
        padding-bottom: 0;
    }
}

.global-nav-menu__frame--orange .global-nav-menu__list-title-item {
    color: #e89338;
}

.global-nav-menu__frame--orange .global-nav-menu__list-title-item:before {
    background-image: url(/img/common/img_news_yellow.png);
}

.global-nav-menu__frame--orange .global-nav-menu__list {
    margin-bottom: 3px;
}

.global-nav-menu__frame--orange .global-nav-menu__list-title:after {
    display: none;
}

.global-nav-menu__frame--darkgreen .global-nav-menu__list-title-item {
    color: #00a28e;
}

.global-nav-menu__frame--darkgreen .global-nav-menu__link-item-text:before {
    background-color: #00a28e;
}
/*20220325 追加分*/
.global-nav-menu__frame--darkgreen .global-nav-menu__image-item-link-text:before {
    background-color: #00a28e;
}
/*20220325 追加分 ここまで*/

.global-nav-menu__frame--darkgreen .global-nav-menu__list-title-item:before {
    background-image: url(/img/common/img_tobu_green.png);
}

.global-nav-menu__frame--friend .global-nav-menu__link-item-text:before {
    background-color: #ffad42;
}

@media screen and (max-width: 1024px) {
    .global-nav-menu__frame--friend .global-nav-menu__list-contents {
        padding: 3.4375vw 3.125vw;
    }
}

.global-nav-menu__list-title {
    position: relative;
    font-weight: 700;
}

@media screen and (max-width: 1024px) {
    .global-nav-menu__list-title {
        display: block;
        padding: 5.15625vw 3.125vw 5.46875vw 3.125vw;
        font-size: 5vw;
    }
}

@media screen and (max-width: 1024px) {
    .global-nav-menu__list-title:after {
        position: absolute;
        top: 50%;
        right: 4.6875vw;
        display: block;
        width: 7.8125vw;
        height: 7.8125vw;
        background-image: url(/img/sp/common/icon_gnav_plus.png);
        background-position: 0 0;
        background-size: 100% 100%;
        background-repeat: no-repeat;
        content: "";
        -webkit-transform: translateY(-50%);
        transform: translateY(-50%);
    }
}

@media screen and (max-width: 1024px) {
    .global-nav-menu__list-title.js-open:after {
        background-image: url(/img/sp/common/icon_gnav_minus.png);
    }
}

.global-nav-menu__list-title-item {
    position: relative;
    padding-left: 47px;
}

@media screen and (min-width: 739px) {
    .global-nav-menu__list-title-item:hover {
        color: #ea6f0c;
        text-decoration: underline;
    }
}

@media screen and (max-width: 1024px) {
    .global-nav-menu__list-title-item {
        padding-left: 10.46875vw;
    }
}

.global-nav-menu__list-title-item:before {
    position: absolute;
    top: 50%;
    left: 0;
    display: block;
    width: 36px;
    height: 36px;
    background-position: 0 0;
    background-size: 100% 100%;
    background-repeat: no-repeat;
    content: "";
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
}

@media screen and (max-width: 1024px) {
    .global-nav-menu__list-title-item:before {
        width: 7.8125vw;
        height: 7.8125vw;
    }
}

@media screen and (max-width: 1024px) {
    .global-nav-menu__list-button {
        position: absolute;
        top: 0;
        right: 0;
        bottom: 0;
        z-index: 11;
        width: 17.1875vw;
        height: 100%;
    }
}

.global-nav-menu__list-contents {
    margin-top: 8px;
    padding-left: 6px;
}

@media screen and (min-width: 1025px) {
    .global-nav-menu__list-contents {
        display: block !important;
    }
}

@media screen and (max-width: 1024px) {
    .global-nav-menu__list-contents {
        margin-top: 2.34375vw;
        padding-top: 0;
        padding-right: 3.125vw;
        padding-bottom: 5.46875vw;
        padding-left: 3.125vw;
    }
}

.global-nav-menu__link {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    margin-bottom: 3px;
    margin-left: 5px;

    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
}

@media screen and (max-width: 1024px) {
    .global-nav-menu__link {
        display: block;
        margin-bottom: 9.6875vw;
        padding-left: 1.5625vw;
    }
}

.global-nav-menu__link-item {
    margin-right: 38px;
}

@media screen and (max-width: 1024px) {
    .global-nav-menu__link-item {
        margin-right: 0;
        margin-bottom: 6.71875vw;
    }
}

.global-nav-menu__link-item-text {
    position: relative;
    padding-left: 14px;
}

.global-nav-menu__link-item-text:before {
    position: absolute;
    top: 50%;
    left: 0;
    display: block;
    width: 8px;
    height: 8px;
    border-radius: 50%;
    content: "";
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
}

@media screen and (max-width: 738px) {
    .global-nav-menu__link-item-text:before {
        width: 2.1875vw;
        height: 2.1875vw;
    }
}

@media screen and (min-width: 739px) {
    .global-nav-menu__link-item-text:hover {
        color: #ea6f0c;
        text-decoration: underline;
    }
}

@media screen and (max-width: 1024px) {
    .global-nav-menu__link-item-text {
        display: block;
        padding-left: 3.59375vw;
        font-size: 4.375vw;
    }
}

.global-nav-menu__button {
    display: block;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    margin-left: auto;
    padding: 0 15px;
    width: 142px;
    border-radius: 5px;
    background-color: #f6ab4a;
    color: #fff;
    font-size: 16px;
}

@media screen and (min-width: 739px) {
    .global-nav-menu__button:hover {
        background-color: #ea6f0c;
    }
}

@media screen and (max-width: 1024px) {
    .global-nav-menu__button {
        margin-right: auto;
        padding-top: 2.1875vw;
        padding-right: 0;
        padding-bottom: 2.1875vw;
        padding-left: 0;
        width: 50vw;
        border-radius: 1.25vw;
        text-align: center;
        font-size: 4.375vw;
    }
}

.global-nav-menu__image {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-pack: justify;
    margin-top: 15px;
    margin-bottom: 8px;

    -webkit-box-pack: justify;
    justify-content: space-between;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
}

@media screen and (max-width: 1024px) {
    .global-nav-menu__image {
        display: block;
        margin-top: 0;
        margin-bottom: 11.25vw;
    }
}

/*20220325 追加分*/

.global-nav-menu__frame--deepblue .global-nav-menu__image,
.global-nav-menu__frame--purple .global-nav-menu__image{
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-pack: justify;
    margin-top: 15px;
    margin-bottom: 8px;

    -webkit-box-pack: justify;
    justify-content: normal;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
}

@media screen and (max-width: 1024px) {
    .global-nav-menu__frame--deepblue .global-nav-menu__image,
    .global-nav-menu__frame--purple .global-nav-menu__image {
        display: block;
        margin-top: 0;
        margin-bottom: 11.25vw;
    }
}

.global-nav-menu__frame--deepblue .global-nav-menu__image-item:first-child,
.global-nav-menu__frame--purple .global-nav-menu__image-item:first-child{
    margin-right: 10px;
}


/*20220325 追加分 ここまで*/

.global-nav-menu__image-item {
    width: 164px;
}

@media screen and (max-width: 1024px) {
    .global-nav-menu__image-item {
        margin-bottom: 4.6875vw;
        width: 100%;
    }
}
/*20220325 追加分*/
.global-nav-menu__image-item__kidsER {
    width: 396px;
}

@media screen and (max-width: 1024px) {
    .global-nav-menu__image-item__kidsER {
        margin-bottom: 4.6875vw;
        width: 100%;
    }
}

/*20220325 追加分 ここまで*/

.global-nav-menu__image-item:nth-child(n + 4) {
    margin-top: 10px;
}

@media screen and (max-width: 1024px) {
    .global-nav-menu__image-item:nth-child(n + 4) {
        margin-top: 0;
    }
}

.global-nav-menu__image-item-link {
    display: block;
    -webkit-transition: opacity 300ms;
    transition: opacity 300ms;
}

@media screen and (min-width: 739px) {
    .global-nav-menu__image-item-link:hover {
        opacity: 0.7;
    }
}

@media screen and (min-width: 739px) {
    .global-nav-menu__image-item-link:hover {
        color: #ea6f0c;
        text-decoration: underline;
    }
}

@media screen and (max-width: 1024px) {
    .global-nav-menu__image-item-link-target {
        margin-bottom: 0.9375vw;
    }
}

@media screen and (max-width: 1024px) {
    .global-nav-menu__image-item-link-target img {
        width: 100%;
    }
}

.global-nav-menu__image-item-link-text {
    position: relative;
    margin-left: 6px;
    padding-left: 14px;
}

.global-nav-menu__image-item-link-text:before {
    position: absolute;
    top: 50%;
    left: 0;
    display: block;
    width: 8px;
    height: 8px;
    border-radius: 50%;
    content: "";
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
}

@media screen and (max-width: 738px) {
    .global-nav-menu__image-item-link-text:before {
        width: 2.1875vw;
        height: 2.1875vw;
    }
}

@media screen and (max-width: 1024px) {
    .global-nav-menu__image-item-link-text {
        margin-left: 1.5625vw;
        padding-left: 3.59375vw;
        font-size: 4.375vw;
    }
}

.global-nav-menu__registration {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-pack: justify;

    -webkit-box-pack: justify;
    justify-content: space-between;
}

@media screen and (max-width: 1024px) {
    .global-nav-menu__registration {
        display: block;
        padding-bottom: 15.625vw;
    }
}

.global-nav-menu__registration-link {
    display: block;
    padding: 12px 0;
    width: 100%;
    border-radius: 5px;
    background-color: #f6ab4a;
    color: #fff;
    text-align: center;
}
.global-nav-menu__registration-link:nth-child(1) {
      margin-right:8px;
}


@media screen and (min-width: 739px) {
    .global-nav-menu__registration-link:hover {
        background-color: #ea6f0c;
    }
}

@media screen and (max-width: 1024px) {
    .global-nav-menu__registration-link {
        margin-bottom: 1.5625vw;
        padding: 3.4375vw 0;
        width: 100%;
        font-size: 4.375vw;
    }
}

@media screen and (max-width: 1024px) {
    .global-nav-menu__registration-link:last-child {
        margin-bottom: 0;
    }
}

/* -- windows firefox -- */
.windows.firefox .global-nav-menu {
    overflow: auto;
}

@media screen and (max-width: 1024px) {
    .iphone .global-nav-menu-scroll {
        -webkit-box-sizing: border-box;
        box-sizing: border-box;
        padding-bottom: 15.625vw;
    }
}

.tb-hide {
    display: block;
}

@media screen and (min-width: 1025px) {
    .tb-hide {
        display: none !important;
    }
}

/* ---------------------------------------------
*   contents
--------------------------------------------- */
/* ---------------------------------------------
*   main
--------------------------------------------- */
.main--top {
    overflow: hidden;
}

/* ---------------------------------------------
*   breadcrumb
--------------------------------------------- */
.breadcrumb {
    border-bottom: 1px solid #fff;
}

@media screen and (max-width: 738px) {
    .breadcrumb {
        display: none;
    }
}

.breadcrumb__list {
    padding: 12px 0;
}

.breadcrumb__list-item {
    display: inline-block;
    margin-right: 38px;
    color: #fff;
    letter-spacing: normal;
    font-size: 14px;
}

.breadcrumb__list-item a {
    text-decoration: none;
}

.breadcrumb__list-item a:hover {
    text-decoration: underline;
}

.breadcrumb__list-item + .breadcrumb__list-item {
    position: relative;
}

.breadcrumb__list-item + .breadcrumb__list-item:after {
    position: absolute;
    top: 50%;
    left: -25px;
    display: block;
    width: 10px;
    height: 10px;
    background-image: url(/img/common/icon_breadcrumb.png);
    background-position: 50% 0;
    background-size: 100% auto;
    background-repeat: no-repeat;
    content: "";
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
}

/* ---------------------------------------------
*   footer
--------------------------------------------- */
.footer {
    position: relative;
    z-index: 1;
}

@media screen and (max-width: 738px) {
    .footer {
        overflow: hidden;
    }
}

/*  footer-line
--------------------------------------------- */
.footer-line__link {
    display: block;
    padding-top: 30px;
    padding-bottom: 30px;
    padding-left: 10px;
    background-color: #00b900;
    -webkit-transition: opacity 300ms;
    transition: opacity 300ms;
}

@media screen and (min-width: 739px) {
    .footer-line__link:hover {
        opacity: 0.7;
    }
}

@media screen and (max-width: 738px) {
    .footer-line__link {
        padding-top: 6.25vw;
        padding-right: 3.125vw;
        padding-bottom: 6.25vw;
        padding-left: 3.125vw;
    }
}

.footer-line__link-content {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-pack: center;
    -ms-flex-align: center;

    -webkit-box-align: center;
    align-items: center;
    -webkit-box-pack: center;
    justify-content: center;
}

.footer-line__link-content-logo {
    margin-right: 60px;
}

@media screen and (max-width: 738px) {
    .footer-line__link-content-logo {
        margin-right: 4.6875vw;
        width: 40%;
    }
}

.footer-line__link-content-text {
    color: #fff;
    font-weight: 700;
    font-size: 28px;
    line-height: 1.4;
}

@media screen and (max-width: 738px) {
    .footer-line__link-content-text {
        width: calc(100% - 40% - 4.6875vw);
        font-size: 4.375vw;
    }
}

/*  footer-mail
--------------------------------------------- */
.footer-mail {
    overflow-y: hidden;
}

.footer-mail__link {
    display: block;
    padding: 18px 0;
    background-color: #ea5c31;
    text-align: center;
    -webkit-transition: opacity 300ms;
    transition: opacity 300ms;
}

@media screen and (min-width: 739px) {
    .footer-mail__link:hover {
        opacity: 0.7;
    }
}

@media screen and (max-width: 738px) {
    .footer-mail__link {
        padding-top: 3.4375vw;
        padding-right: 3.125vw;
        padding-bottom: 3.4375vw;
        padding-left: 3.125vw;
        text-align: left;
    }
}

.footer-mail__link-content {
    padding-left: 115px;
    letter-spacing: -.4em;
}

@media screen and (max-width: 738px) {
    .footer-mail__link-content {
        padding-left: 0;
    }
}

.footer-mail__link-content-title {
    position: relative;
    display: inline-block;
    margin-right: 58px;
    color: #fff;
    vertical-align: middle;
    letter-spacing: normal;
    font-weight: 700;
    font-size: 30px;
}

@media screen and (max-width: 738px) {
    .footer-mail__link-content-title {
        -webkit-box-sizing: border-box;
        box-sizing: border-box;
        margin-right: auto;
        margin-right: 3.125vw;
        padding-left: 7.03125vw;
        width: 41.66667%;
        font-size: 4.375vw;
    }
}

.footer-mail__link-content-title:before {
    position: absolute;
    top: 50%;
    left: -60px;
    display: block;
    width: 36px;
    height: 26px;
    background-image: url(/img/common/footer_icon_mail.png);
    background-position: 50% 0;
    background-size: 100% auto;
    background-repeat: no-repeat;
    content: "";
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
}

@media screen and (max-width: 738px) {
    .footer-mail__link-content-title:before {
        left: 0;
        width: 5.9375vw;
        height: 4.21875vw;
    }
}

.footer-mail__link-content-text {
    display: inline-block;
    color: #fff;
    vertical-align: middle;
    letter-spacing: normal;
}

@media screen and (max-width: 738px) {
    .footer-mail__link-content-text {
        margin-right: auto;
        width: calc(100% - 41.66667% - 3.125vw);
        letter-spacing: -.03em;
        font-size: 3.75vw;
        line-height: 1.2;
    }
}

/*  footer-guardian
--------------------------------------------- */
.footer-guardian {
    overflow-y: hidden;
    margin-bottom: 30px;
}

@media screen and (max-width: 738px) {
    .footer-guardian {
        margin-bottom: 4.6875vw;
    }
}

.footer-guardian__link {
    display: block;
    padding: 18px 0;
    background-color: #42c3df;
    text-align: center;
    -webkit-transition: opacity 300ms;
    transition: opacity 300ms;
}

@media screen and (min-width: 739px) {
    .footer-guardian__link:hover {
        opacity: 0.7;
    }
}

@media screen and (max-width: 738px) {
    .footer-guardian__link {
        padding-top: 3.4375vw;
        padding-right: 3.125vw;
        padding-bottom: 3.4375vw;
        padding-left: 3.125vw;
        text-align: left;
    }
}

.footer-guardian__link-content {
    letter-spacing: -.4em;
}

.footer-guardian__link-content-title {
    position: relative;
    display: inline-block;
    color: #fff;
    vertical-align: middle;
    letter-spacing: normal;
    font-weight: 700;
    font-size: 30px;
}

@media screen and (max-width: 738px) {
    .footer-guardian__link-content-title {
        -webkit-box-sizing: border-box;
        box-sizing: border-box;
        margin-right: auto;
        padding-left: 7.03125vw;
        font-size: 4.375vw;
    }
}

.footer-guardian__link-content-title:before {
    position: absolute;
    top: 50%;
    left: -50px;
    display: block;
    width: 30px;
    height: 43px;
    background-image: url(/img/common/icon_people.png);
    background-position: 50% 0;
    background-size: 100% auto;
    background-repeat: no-repeat;
    content: "";
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
}

@media screen and (max-width: 738px) {
    .footer-guardian__link-content-title:before {
        left: 0;
        width: 5vw;
        height: 7.1875vw;
    }
}

.footer-guardian__link-content-text {
    display: inline-block;
    color: #fff;
    vertical-align: middle;
    letter-spacing: normal;
}

@media screen and (max-width: 738px) {
    .footer-guardian__link-content-text {
        margin-right: auto;
        width: calc(100% - 45% - 3.125vw);
        letter-spacing: -.03em;
        font-size: 3.75vw;
        line-height: 1.2;
    }
}

/*  footer-calendar
--------------------------------------------- */
.footer-calendar {
    position: relative;
    margin-right: auto;
    margin-left: auto;
    width: 1038px;
}

@media screen and (max-width: 738px) {
    .footer-calendar {
        width: 93.75%;
    }
}

.footer-calendar__link {
    display: block;
    padding-top: 50px;
    padding-bottom: 30px;
    border-radius: 10px;
    text-align: center;
    -webkit-transition: opacity 300ms;
    transition: opacity 300ms;
}

@media screen and (min-width: 739px) {
    .footer-calendar__link:hover {
        opacity: 0.7;
    }
}

@media screen and (max-width: 738px) {
    .footer-calendar__link {
        padding-top: 10.15625vw;
        padding-bottom: 6.71875vw;
        border-radius: 1.5625vw;
    }
}

.footer-calendar__link-title {
    position: relative;
    display: inline-block;
    padding-right: 60px;
}

@media screen and (max-width: 738px) {
    .footer-calendar__link-title {
        padding-right: 5vw;
    }
}

.footer-calendar__link-title:before {
    position: absolute;
    top: -24px;
    left: -216px;
    display: block;
    width: 192px;
    height: 90px;
    background-image: url(/img/common/icon_calender1.png);
    background-position: 50% 0;
    background-size: 100% auto;
    background-repeat: no-repeat;
    content: "";
}

@media screen and (max-width: 738px) {
    .footer-calendar__link-title:before {
        top: -1.75vw;
        left: -17.78125vw;
        width: 16vw;
        height: 14.78125vw;
    }
}

.footer-calendar__link-title:after {
    position: absolute;
    top: -40px;
    right: -225px;
    display: block;
    width: 243px;
    height: 117px;
    background-image: url(/img/common/icon_calender2.png);
    background-position: 50% 0;
    background-size: 100% auto;
    background-repeat: no-repeat;
    content: "";
}

@media screen and (max-width: 738px) {
    .footer-calendar__link-title:after {
        top: -4.15625vw;
        right: -17.25vw;
        width: 21.5625vw;
        height: 13.75vw;
    }
}

.footer-calendar__link-title-item {
    display: inline-block;
    overflow: hidden;
    margin-right: auto;
    margin-left: auto;
    padding-top: 50px;
    width: 494px;
    height: 0;
    background-image: url(/img/common/title_calendar_white.png);
    background-position: 0 0;
    background-size: cover;
    background-repeat: no-repeat;
}

@media screen and (max-width: 738px) {
    .footer-calendar__link-title-item {
        padding-top: 6vw;
        width: 53vw;
        background-size: 100%;
        background-image: url(/img/sp/common/title_calendar_white.png);
    }
}

/*  footer-timetable
--------------------------------------------- */
.footer-timetable{
    position: relative;
    margin-right: auto;
    margin-left: auto;
    width: 1038px;
    margin-top: 30px;
}
.footer-timetable .bg-blue{
    background-color:#33c5e5;
}

.footer-timetable__link {
    display: block;
    padding-top: 20px;
    padding-bottom: 20px;
    border-radius: 10px;
    text-align: center;
    -webkit-transition: opacity 300ms;
    transition: opacity 300ms;
}

@media screen and (min-width: 739px) {
    .footer-timetable__link:hover {
        opacity: 0.7;
    }
}

@media screen and (max-width: 738px) {
    .footer-timetable__link {
        padding-top: 10px;
        padding-bottom: 10px;
        border-radius: 1.5625vw;
    }
    .footer-timetable__link img{
        width: 100%;
    }
}
@media screen and (max-width: 738px) {
    .footer-timetable{
        margin-top: 4.6875vw;
        width: 93.75%;
    }
}
/*  footer-slide-area
--------------------------------------------- */
.footer-slide-area {
    position: relative;
    margin-top: 30px;
    margin-right: auto;
    margin-bottom: 20px;
    margin-left: auto;
    width: 1038px;
}

@media screen and (max-width: 738px) {
    .footer-slide-area {
        margin-top: 4.6875vw;
        margin-bottom: 7.8125vw;
        width: 75%;
    }
}

/*  footer-slide
--------------------------------------------- */
.footer-slide {
    position: relative;
    overflow: hidden;
    width: 100%;
    height: 100px;
}

@media screen and (max-width: 738px) {
    .footer-slide {
        height: 22.8125vw;
    }
}

.footer-slide__list-item-link {
    display: block;
    -webkit-transition: opacity 300ms;
    transition: opacity 300ms;
}

@media screen and (min-width: 739px) {
    .footer-slide__list-item-link:hover {
        opacity: 0.7;
    }
}

/*  footer-logo
--------------------------------------------- */
.footer-logo {
    padding-bottom: 20px;
    border-bottom: 1px solid #888;
}

@media screen and (max-width: 738px) {
    .footer-logo {
        padding-bottom: 7.8125vw;
        border-bottom-width: 0.3125vw;
    }
}

.footer-logo__list {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-pack: center;
    -ms-flex-align: center;

    -webkit-box-pack: center;
    justify-content: center;
    -webkit-box-align: center;
    align-items: center;
}

.footer-logo__list-item {
    margin-right: 80px;
}

@media screen and (max-width: 738px) {
    .footer-logo__list-item {
        margin-right: 9.6875vw;
    }
}

.footer-logo__list-item:last-child {
    margin-right: 0;
}

.footer-logo__list-item--1 .footer-logo__list-item-title {
    padding-top: 53px;
    width: 193px;
    background-image: url(/img/common/footer_logo_bombokids.png);
}

@media screen and (max-width: 738px) {
    .footer-logo__list-item--1 .footer-logo__list-item-title {
        padding-top: 8.28125vw;
        width: 30.15625vw;
    }
}

.footer-logo__list-item--2 .footer-logo__list-item-title {
    padding-top: 87px;
    width: 150px;
    background-image: url(/img/common/footer_logo_tobu.png);
}

@media screen and (max-width: 738px) {
    .footer-logo__list-item--2 .footer-logo__list-item-title {
        padding-top: 16.40625vw;
        width: 28.125vw;
    }
}

.footer-logo__list-item-title {
    display: block;
    overflow: hidden;
    height: 0;
    background-position: 0 0;
    background-size: cover;
    background-repeat: no-repeat;
    -webkit-transition: opacity 300ms;
    transition: opacity 300ms;
}

@media screen and (min-width: 739px) {
    .footer-logo__list-item-title:hover {
        opacity: 0.7;
    }
}

/*  footer-nav
--------------------------------------------- */
.footer-nav {
    margin-top: 23px;
}

@media screen and (max-width: 738px) {
    .footer-nav {
        margin-top: 5.78125vw;
    }
}

.footer-nav__list {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-pack: center;

    -webkit-box-pack: center;
    justify-content: center;
}

@media screen and (max-width: 738px) {
    .footer-nav__list {
        display: block;
    }
}

.footer-nav__list-item {
    margin-right: 60px;
}

@media screen and (max-width: 738px) {
    .footer-nav__list-item {
        margin-right: 0;
        margin-bottom: 1.09375vw;
        text-align: center;
    }
}

.footer-nav__list-item:last-child {
    margin-right: 0;
}

@media screen and (max-width: 738px) {
    .footer-nav__list-item:last-child {
        margin-bottom: 0;
    }
}

.footer-nav__list-item--blank .footer-nav__link {
    position: relative;
}

.footer-nav__list-item--blank .footer-nav__link:before {
    position: absolute;
    top: 50%;
    right: -23px;
    display: block;
    width: 16px;
    height: 14px;
    background-image: url(/img/common/icon_open_orange.png);
    background-position: 50% 0;
    background-size: 100% auto;
    background-repeat: no-repeat;
    content: "";
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
}

@media screen and (max-width: 738px) {
    .footer-nav__list-item--blank .footer-nav__link:before {
        right: -6.25vw;
        width: 3.90625vw;
        height: 3.59375vw;
        background-image: url(/img/sp/common/icon_open_orange.png);
    }
}

.footer-nav__link {
    display: block;
    font-size: 14px;
}

@media screen and (min-width: 739px) {
    .footer-nav__link:hover {
        color: #ea6f0c;
        text-decoration: underline;
    }
}

@media screen and (max-width: 738px) {
    .footer-nav__link {
        display: inline-block;
        font-size: 3.75vw;
    }
}

/*  footer-copyright
--------------------------------------------- */
.footer-copyright {
    padding: 40px 0;
    text-align: center;
}

@media screen and (max-width: 738px) {
    .footer-copyright {
        padding: 4.6875vw 3.125vw 9.375vw;
        line-height: 1.1;
    }
}

.footer-copyright__text {
    font-size: 14px;
}

@media screen and (max-width: 738px) {
    .footer-copyright__text {
        font-size: 3.4375vw;
    }
}

/*  swiper-button-outer
--------------------------------------------- */
/*  swiper-button-prev
--------------------------------------------- */
.footer-slide-area .swiper-button-prev {
    top: 50%;
    left: -50px;
    margin-top: 0;
    width: 36px;
    height: 36px;
    border-radius: 50%;
    background-color: #ff9018;
    background-image: url(/img/common/icon_slide_prev.png);
    background-position: 50% 50%;
    background-size: auto auto;
    background-repeat: no-repeat;
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
}

@media screen and (max-width: 738px) {
    .footer-slide-area .swiper-button-prev {
        left: -9.375vw;
        width: 7.8125vw;
        height: 7.8125vw;
        background-image: url(/img/sp/common/icon_slide_prev.png);
        background-size: 3.125vw 4.21875vw;
    }
}

.footer-slide-area .swiper-button-prev:hover {
    background-color: #ea6f0c;
}

.footer-slide-area .swiper-button-prev:focus {
    outline: none;
}

/*  swiper-button-next
--------------------------------------------- */
.footer-slide-area .swiper-button-next {
    top: 50%;
    right: -50px;
    margin-top: 0;
    width: 36px;
    height: 36px;
    border-radius: 50%;
    background-color: #ff9018;
    background-image: url(/img/common/icon_slide_next.png);
    background-position: 50% 50%;
    background-size: auto auto;
    background-repeat: no-repeat;
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
}

@media screen and (max-width: 738px) {
    .footer-slide-area .swiper-button-next {
        right: -9.375vw;
        width: 7.8125vw;
        height: 7.8125vw;
        background-image: url(/img/sp/common/icon_slide_next.png);
        background-size: 3.125vw 4.21875vw;
    }
}

.footer-slide-area .swiper-button-next:hover {
    background-color: #ea6f0c;
}

.footer-slide-area .swiper-button-next:focus {
    outline: none;
}
