@charset "UTF-8";
a,
abbr,
address,
article,
aside,
audio,
b,
blockquote,
body,
canvas,
caption,
cite,
code,
dd,
del,
details,
dfn,
div,
dl,
dt,
em,
embed,
fieldset,
figcaption,
figure,
footer,
form,
h1,
h2,
h3,
h4,
h5,
h6,
header,
html,
i,
iframe,
img,
input,
ins,
kbd,
label,
legend,
li,
main,
mark,
menu,
nav,
object,
ol,
output,
p,
pre,
q,
ruby,
s,
samp,
section,
small,
span,
strong,
sub,
summary,
sup,
table,
tbody,
td,
textarea,
tfoot,
th,
thead,
time,
tr,
u,
ul,
var,
video {
    margin: 0;
    padding: 0;
    border: 0;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    font-size: 100%;
    font: inherit;
    vertical-align: baseline;
}
html {
    font-size: 0.625em;
    height: 100%;
    overflow-y: scroll;
}
body {
    color: #363435;
    font-family:
        Roboto, "Noto Sans JP", "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro",
        "メイリオ", Meiryo, sans-serif;
    font-weight: 400;
    font-style: normal;
    line-height: 1;
    text-align: center;
    -webkit-text-size-adjust: 100%;
}
dd,
dt,
ol,
p,
td,
th,
ul {
    font-size: 1.6em;
}
dd dd,
dd dt,
dd li,
dd ol,
dd p,
dd ul,
li dd,
li dt,
li ol,
li p,
li ul,
ol li,
td dl,
td li,
td ol,
td p,
td td,
td th,
td ul,
ul li {
    font-size: 1em;
}
@media screen and (max-width: 767px) {
    dd,
    dt,
    ol,
    p,
    td,
    th,
    ul {
        font-size: 1.4em;
    }
}
@media screen and (max-width: 320px) {
    dd,
    dt,
    ol,
    p,
    td,
    th,
    ul {
        font-size: 1.2em;
    }
}
ol,
ul {
    list-style: none;
}
a {
    color: #4c5cf6;
    text-decoration: none;
}
@media screen and (min-width: 768px) {
    a[href^="tel:"] {
        pointer-events: none;
    }
}
address {
    font-style: normal;
}
button,
input[type="button"],
input[type="file"]::-webkit-file-upload-button,
input[type="reset"],
input[type="submit"] {
    padding: 1px 6px;
}
input[type="checkbox"] {
    margin: 0;
}
img {
    border: 0;
    height: auto;
    max-width: 100%;
    vertical-align: bottom;
}
.img-box {
    font-size: 0;
    line-height: 0;
}
.wrap {
    margin-left: auto;
    margin-right: auto;
    max-width: 1260px;
    padding-left: 30px;
    padding-right: 30px;
    width: 100%;
    position: relative;
}
@media (max-width: 1024px) {
    .wrap {
        padding-left: 15px;
        padding-right: 15px;
    }
}
.wrap.opt-large {
    max-width: 1180px;
}
.wrap.opt-middle {
    max-width: 960px;
}
.wrap.opt-small {
    max-width: 860px;
}
@media screen and (max-width: 767px) {
    .wrap {
        padding-left: 0;
        padding-right: 0;
    }
}
table {
    border-collapse: collapse;
    width: 100%;
}
sup {
    font-size: 10px;
    font-weight: 400;
    vertical-align: top;
}
.text-bold,
strong {
    font-weight: 700;
}
html {
    overflow-x: hidden;
    height: 100%;
}
body {
    height: 100%;
}
body.is-fixed {
    position: fixed;
}
.text-small {
    font-size: 0.8em;
}
.text-large {
    font-size: 2.4em;
}
video {
    outline: 0;
}
.text-left {
    text-align: left !important;
}
.text-center {
    text-align: center !important;
}
@media screen and (max-width: 767px) {
    .text-center.opt-sp-left {
        text-align: left !important;
    }
}
.text-right {
    text-align: right !important;
}
.color-red {
    color: red !important;
}
@media screen and (min-width: 768px) {
    .sp_only,
    br.sp_only,
    img.sp_only,
    span.sp_only {
        display: none !important;
    }
    br.sp_only {
        width: 0 !important;
    }
    .pc_only {
        display: block !important;
    }
    br.pc_only,
    img.pc_only,
    span.pc_only {
        display: inline !important;
    }
    td.pc_only,
    th.pc_only {
        display: table-cell !important;
    }
}
@media screen and (max-width: 767px) {
    .sp_only {
        display: block !important;
    }
    .pc_only,
    br.pc_only,
    img.pc_only,
    span.pc_only,
    td.pc_only,
    th.pc_only {
        display: none !important;
    }
    br.sp_only,
    img.sp_only,
    span.sp_only {
        display: inline !important;
    }
}
.mb0 {
    margin-bottom: 0 !important;
}
.ml0 {
    margin-left: 0 !important;
}
.mr0 {
    margin-right: 0 !important;
}
.mt0 {
    margin-top: 0 !important;
}
.pb0 {
    padding-bottom: 0 !important;
}
.pl0 {
    padding-left: 0 !important;
}
.pr0 {
    padding-right: 0 !important;
}
.pt0 {
    padding-top: 0 !important;
}
.m-btn {
    margin-top: 60px;
    line-height: 1.3 !important;
    text-align: center;
}
@media screen and (max-width: 767px) {
    .m-btn {
        margin-top: 40px;
    }
}
.m-btn > a,
.m-btn > button {
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    background-color: #fff;
    border: 1px solid #363435;
    border-radius: 150px;
    color: #363435;
    cursor: pointer;
    display: inline-block;
    font-weight: 700;
    overflow: hidden;
    max-width: 240px;
    padding-bottom: 20px;
    padding-top: 20px;
    text-align: center;
    text-decoration: none !important;
    width: 100%;
    position: relative;
    -webkit-transition: all 0.3s;
    transition: all 0.3s;
    z-index: 0;
}
.m-btn > a:before,
.m-btn > button:before {
    background-color: #fff;
    content: "";
    height: 100%;
    width: 120%;
    position: absolute;
    left: 0;
    top: 0;
    -webkit-transform: skew(-15deg) translateY(0);
    -ms-transform: skew(-15deg) translateY(0);
    transform: skew(-15deg) translateY(0);
    -webkit-transform-origin: top right;
    -ms-transform-origin: top right;
    transform-origin: top right;
    -webkit-transition: all 0.5s ease;
    transition: all 0.5s ease;
    z-index: -1;
}
.m-btn > a:after,
.m-btn > button:after {
    border-right: 2px solid #363435;
    border-top: 2px solid #363435;
    content: "";
    height: 7px;
    width: 7px;
    position: absolute;
    right: 25px;
    top: 49%;
    -webkit-transform: rotate(45deg) translateY(-50%);
    -ms-transform: rotate(45deg) translateY(-50%);
    transform: rotate(45deg) translateY(-50%);
    -webkit-transition: all 0.3s;
    transition: all 0.3s;
}
@media screen and (min-width: 768px) {
    .m-btn > a:hover,
    .m-btn > button:hover {
        background-color: #363435;
        color: #fff;
    }
    .m-btn > a:hover:before,
    .m-btn > button:hover:before {
        -webkit-transform: skew(-15deg) translateY(0) scaleX(0);
        -ms-transform: skew(-15deg) translateY(0) scaleX(0);
        transform: skew(-15deg) translateY(0) scaleX(0);
        -webkit-transform-origin: top right;
        -ms-transform-origin: top right;
        transform-origin: top right;
    }
    .m-btn > a:hover:after,
    .m-btn > button:hover:after {
        border-right-color: #fff;
        border-top-color: #fff;
    }
}
@media screen and (max-width: 767px) {
    .m-btn > a,
    .m-btn > button {
        font-size: 1.5rem;
        max-width: 270px;
        padding-bottom: 14px;
    }
}
.m-btn > a:disabled,
.m-btn > button:disabled {
    background-color: #e1e1e1;
    border-color: #e1e1e1;
    color: #acacac;
    cursor: not-allowed;
}
.m-btn > a:disabled:before,
.m-btn > button:disabled:before {
    background-color: #acacac;
}
.m-btn > a:disabled:after,
.m-btn > button:disabled:after {
    border-right-color: #e1e1e1;
    border-top-color: #e1e1e1;
}
.m-btn.theme-yellow > a,
.m-btn.theme-yellow > button {
    background-color: #ffd802;
    border: 1px solid #ffd802;
    color: #363435;
}
.m-btn.theme-yellow > a:before,
.m-btn.theme-yellow > button:before {
    background-color: #ffd802;
}
.m-btn.theme-yellow > a:after,
.m-btn.theme-yellow > button:after {
    border-right: 2px solid #363435;
    border-top: 2px solid #363435;
    content: "";
    height: 7px;
    width: 7px;
    position: absolute;
    right: 25px;
    top: 49%;
    -webkit-transform: rotate(45deg) translateY(-50%);
    -ms-transform: rotate(45deg) translateY(-50%);
    transform: rotate(45deg) translateY(-50%);
    -webkit-transition: all 0.3s;
    transition: all 0.3s;
}
@media screen and (min-width: 768px) {
    .m-btn.theme-yellow > a:hover,
    .m-btn.theme-yellow > button:hover {
        background-color: #363435;
        border-color: #363435;
        color: #fff;
    }
    .m-btn.theme-yellow > a:hover:before,
    .m-btn.theme-yellow > button:hover:before {
        -webkit-transform: skew(-15deg) translateY(0) scaleX(0);
        -ms-transform: skew(-15deg) translateY(0) scaleX(0);
        transform: skew(-15deg) translateY(0) scaleX(0);
        -webkit-transform-origin: top right;
        -ms-transform-origin: top right;
        transform-origin: top right;
    }
    .m-btn.theme-yellow > a:hover:after,
    .m-btn.theme-yellow > button:hover:after {
        border-right-color: #fff;
        border-top-color: #fff;
    }
}
@media screen and (max-width: 767px) {
    .m-btn.theme-yellow > a,
    .m-btn.theme-yellow > button {
        font-size: 1.5rem;
        max-width: 270px;
        padding-bottom: 14px;
    }
}
.m-btn.theme-blank > a,
.m-btn.theme-blank > button {
    max-width: 340px;
}
.m-btn.theme-blank > a:after,
.m-btn.theme-blank > button:after {
    background: url(../img/icon-blank_bg.png) no-repeat 0 0;
    border: 0;
    height: 18px;
    width: 18px;
    right: 20px;
    top: 50%;
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
    transform: translateY(-50%);
}
@media screen and (min-width: 768px) {
    .m-btn.theme-blank > a:hover:after,
    .m-btn.theme-blank > button:hover:after {
        background-image: url(../img/icon-blank-white_bg.png);
    }
}
.m-btn.theme-blue > a,
.m-btn.theme-blue > button {
    background-color: #4c5cf6;
    border: 1px solid #4c5cf6;
    color: #fff;
}
.m-btn.theme-blue > a:before,
.m-btn.theme-blue > button:before {
    background-color: #4c5cf6;
}
.m-btn.theme-blue > a:after,
.m-btn.theme-blue > button:after {
    content: none;
}
@media screen and (min-width: 768px) {
    .m-btn.theme-blue > a:hover,
    .m-btn.theme-blue > button:hover {
        background-color: #363435;
        border-color: #363435;
        color: #fff;
    }
    .m-btn.theme-blue > a:hover:before,
    .m-btn.theme-blue > button:hover:before {
        -webkit-transform: skew(-15deg) translateY(0) scaleX(0);
        -ms-transform: skew(-15deg) translateY(0) scaleX(0);
        transform: skew(-15deg) translateY(0) scaleX(0);
        -webkit-transform-origin: top right;
        -ms-transform-origin: top right;
        transform-origin: top right;
    }
}
@media screen and (max-width: 767px) {
    .m-btn.theme-blue > a,
    .m-btn.theme-blue > button {
        font-size: 1.5rem;
        max-width: 270px;
        padding-bottom: 14px;
    }
}
.m-btn.theme-white-blue > a,
.m-btn.theme-white-blue > button {
    background-color: #fff;
    border: 1px solid #4c5cf6;
    color: #363435;
}
.m-btn.theme-white-blue > a:before,
.m-btn.theme-white-blue > button:before {
    background-color: #fff;
}
.m-btn.theme-white-blue > a:after,
.m-btn.theme-white-blue > button:after {
    content: none;
}
@media screen and (min-width: 768px) {
    .m-btn.theme-white-blue > a:hover,
    .m-btn.theme-white-blue > button:hover {
        background-color: #363435;
        border-color: #363435;
        color: #fff;
    }
    .m-btn.theme-white-blue > a:hover:before,
    .m-btn.theme-white-blue > button:hover:before {
        -webkit-transform: skew(-15deg) translateY(0) scaleX(0);
        -ms-transform: skew(-15deg) translateY(0) scaleX(0);
        transform: skew(-15deg) translateY(0) scaleX(0);
        -webkit-transform-origin: top right;
        -ms-transform-origin: top right;
        transform-origin: top right;
    }
}
@media screen and (max-width: 767px) {
    .m-btn.theme-white-blue > a,
    .m-btn.theme-white-blue > button {
        font-size: 1.5rem;
        max-width: 270px;
        padding-bottom: 14px;
    }
}
.m-btn.opt-small > a,
.m-btn.opt-small > button {
    font-size: 1.3rem;
    padding-bottom: 8px;
    padding-top: 10px;
    width: 100px;
}
.m-btn.opt-auto > a,
.m-btn.opt-auto > button {
    max-width: initial;
    padding-left: 10px;
    padding-right: 10px;
    width: auto;
}
.m-btn.opt-middle > a,
.m-btn.opt-middle > button {
    max-width: 450px;
}
.m-btn.opt-left {
    text-align: left;
}
.m-btn-list {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    gap: 30px 30px;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
}
.m-btn-list .m-btn {
    margin-top: 0;
}
.m-btn-list .m-btn > a {
    padding-left: 30px;
    padding-right: 50px;
}
@media screen and (max-width: 767px) {
    .m-btn-list .m-btn > a {
        padding-left: 20px;
        padding-right: 50px;
    }
}
.m-banner.theme-center {
    display: table;
    margin-left: auto;
    margin-right: auto;
}
.m-banner > ul {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    margin-bottom: -20px;
    margin-right: -20px;
}
@media screen and (max-width: 767px) {
    .m-banner > ul {
        margin-right: 0;
    }
}
.m-banner > ul > li {
    height: 100px;
    margin-bottom: 20px;
    margin-right: 20px;
    width: 224px;
}
@media screen and (max-width: 767px) {
    .m-banner > ul > li {
        height: 60px;
        margin-right: 0;
        width: 48%;
    }
    .m-banner > ul > li:nth-child(2n) {
        margin-left: auto;
    }
}
.m-banner > ul > li > a,
.m-banner > ul > li > span {
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    background-color: #fff;
    border-radius: 8px;
    -webkit-box-shadow: 0 0 8px rgba(0, 0, 0, 0.2);
    box-shadow: 0 0 8px rgba(0, 0, 0, 0.2);
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    height: inherit;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    overflow: hidden;
    padding: 30px;
    position: relative;
    -webkit-transition: all 0.3s;
    transition: all 0.3s;
}
.m-banner > ul > li > a img,
.m-banner > ul > li > span img {
    max-height: 100%;
    -webkit-transition: all 0.3s;
    transition: all 0.3s;
}
.m-banner > ul > li > a svg,
.m-banner > ul > li > span svg {
    color: #fff;
    height: 10px;
    width: 10px;
    position: absolute;
    bottom: 5px;
    right: 5px;
    z-index: 1;
    -webkit-transform: rotate(-45deg);
    -ms-transform: rotate(-45deg);
    transform: rotate(-45deg);
}
.m-banner > ul > li > a:after,
.m-banner > ul > li > span:after {
    background-color: #777;
    content: "";
    height: 45px;
    width: 45px;
    position: absolute;
    bottom: 0;
    right: 0;
    -webkit-transform: rotate(45deg) translate(50%, 50%);
    -ms-transform: rotate(45deg) translate(50%, 50%);
    transform: rotate(45deg) translate(50%, 50%);
    -webkit-transform-origin: bottom right;
    -ms-transform-origin: bottom right;
    transform-origin: bottom right;
    z-index: 0;
}
@media screen and (max-width: 767px) {
    .m-banner > ul > li > a,
    .m-banner > ul > li > span {
        padding: 10px;
    }
    .m-banner > ul > li > a svg,
    .m-banner > ul > li > span svg {
        height: 8px;
        width: 8px;
        bottom: 3px;
        right: 3px;
    }
    .m-banner > ul > li > a:after,
    .m-banner > ul > li > span:after {
        height: 30px;
        width: 30px;
    }
}
@media screen and (min-width: 768px) {
    .m-banner > ul > li > a:hover {
        -webkit-box-shadow: 0 0 16px rgba(0, 0, 0, 0.2);
        box-shadow: 0 0 16px rgba(0, 0, 0, 0.2);
        -webkit-transform: scale(1.1);
        -ms-transform: scale(1.1);
        transform: scale(1.1);
        z-index: 2;
    }
    .m-banner > ul > li > a:hover img {
        -webkit-transform: scale(1.1);
        -ms-transform: scale(1.1);
        transform: scale(1.1);
    }
    .m-banner > ul > li > a:hover svg {
        bottom: 3px;
        right: 3px;
    }
}
.m-banner > ul > li.is-coming {
    position: relative;
}
.m-banner > ul > li.is-coming::before {
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    background-color: rgba(0, 0, 0, 0.75);
    content: "COMING SOON";
    color: #fff;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    font-weight: 700;
    height: 100%;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    width: 100%;
    position: absolute;
    left: 0;
    top: 0;
    z-index: 10;
}
.m-lead {
    display: table;
    margin: 0 auto 50px;
    text-align: left;
}
.m-lead:last-child {
    margin-bottom: 0;
}
@media screen and (max-width: 767px) {
    .m-lead {
        margin-bottom: 35px;
        padding-left: 5px;
        padding-right: 5px;
        text-align: left;
    }
}
.m-lead.opt-left {
    text-align: left;
}
.m-lead.opt-inner {
    margin-bottom: 35px;
    text-align: left;
}
.m-lead.opt-inner:last-child {
    margin-bottom: 0;
}
.m-lead figure {
    margin-bottom: 2em;
}
.m-lead figure:last-child {
    margin-bottom: 0;
}
.m-lead p {
    line-height: 1.875;
    margin-bottom: 1.5em;
}
.m-lead p:last-child {
    margin-bottom: 0;
}
.m-ul > li {
    line-height: 1.875;
    padding-left: 1em;
    text-align: left;
    text-indent: -1em;
}
.m-ul > li:before {
    content: "・";
}
.m-ol {
    counter-reset: ol;
}
.m-ol > li {
    counter-increment: ol;
    line-height: 1.875;
    padding-left: 1em;
    text-align: left;
    text-indent: -1em;
}
.m-ol > li:before {
    content: counter(ol) ".";
}
.m-ol.opt-strong > li {
    font-weight: 700;
}
.m-caution {
    margin-top: 15px;
}
.m-caution:first-child {
    margin-top: 0;
}
.m-caution > li {
    font-size: 1.3rem;
    line-height: 1.875;
    padding-left: 1em;
    text-indent: -1em;
}
.m-caution > li:before {
    content: "※";
}
.m-caution > li.is-noicon:before {
    content: none;
}
.m-caution.opt-center {
    text-align: center;
}
@media screen and (max-width: 767px) {
    .m-caution.opt-center.opt-sp-left {
        text-align: left;
    }
}
.m-caution.opt-large > li {
    font-size: 1.6rem;
    font-weight: 700;
}
.m-flow {
    margin-bottom: 80px;
}
@media screen and (max-width: 767px) {
    .m-flow {
        margin-bottom: 40px;
    }
}
.m-flow:last-child {
    margin-bottom: 0;
}
.m-flow > ol {
    counter-reset: ol;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
}
@media screen and (max-width: 767px) {
    .m-flow > ol {
        display: block;
    }
}
.m-flow > ol > li {
    border-radius: 8px;
    counter-increment: ol;
    font-weight: 700;
    line-height: 1.5;
    min-height: 100px;
    margin-right: 20px;
    padding-bottom: 10px;
    padding-top: 45px;
    text-align: center;
    width: 224px;
    position: relative;
}
@media screen and (max-width: 767px) {
    .m-flow > ol > li {
        margin-bottom: 20px;
        margin-right: 0;
        min-height: 0;
        padding: 20px;
        padding-left: 45px;
        text-align: left;
        width: 100%;
    }
}
.m-flow > ol > li a {
    text-decoration: underline;
}
.m-flow > ol > li > span {
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    min-height: 45px;
}
@media screen and (max-width: 767px) {
    .m-flow > ol > li > span {
        display: block;
        min-height: 0;
    }
}
.m-flow > ol > li:nth-child(1) {
    background-color: #ffe868;
}
.m-flow > ol > li:nth-child(2) {
    background-color: #ffe246;
}
.m-flow > ol > li:nth-child(3) {
    background-color: #ffdd24;
}
.m-flow > ol > li:nth-child(4) {
    background-color: #ffd802;
}
.m-flow > ol > li:nth-child(5) {
    background-color: #ffd202;
}
.m-flow > ol > li:last-child {
    margin-right: 0;
}
.m-flow > ol > li:last-child:after {
    content: none;
}
.m-flow > ol > li:before {
    background-color: #363435;
    border-radius: 50%;
    color: #fff;
    content: counter(ol);
    height: 24px;
    line-height: 24px;
    text-align: center;
    width: 24px;
    position: absolute;
    left: 50%;
    top: 15px;
    -webkit-transform: translateX(-50%);
    -ms-transform: translateX(-50%);
    transform: translateX(-50%);
}
@media screen and (max-width: 767px) {
    .m-flow > ol > li:before {
        left: 10px;
        top: 50%;
        -webkit-transform: translateY(-50%);
        -ms-transform: translateY(-50%);
        transform: translateY(-50%);
    }
}
.m-flow > ol > li:after {
    border-color: transparent transparent transparent #363435;
    border-style: solid;
    border-width: 8px 0 8px 8px;
    content: "";
    position: absolute;
    right: -6px;
    top: 50%;
    -webkit-transform: translate(100%, -50%);
    -ms-transform: translate(100%, -50%);
    transform: translate(100%, -50%);
}
@media screen and (max-width: 767px) {
    .m-flow > ol > li:after {
        border-color: #363435 transparent transparent;
        border-width: 8px 8px 0;
        bottom: -6px;
        left: 50%;
        right: auto;
        top: auto;
        -webkit-transform: translate(-50%, 100%);
        -ms-transform: translate(-50%, 100%);
        transform: translate(-50%, 100%);
    }
}
.m-flow.theme-horizontal > ol {
    display: block;
}
.m-flow.theme-horizontal > ol > li {
    background-color: #fff;
    border-bottom: 1px solid #ddd;
    border-radius: 0;
    -webkit-box-sizing: content-box;
    box-sizing: content-box;
    font-weight: 400;
    min-height: 100px;
    margin-bottom: 60px;
    margin-right: 0;
    padding-bottom: 60px;
    padding-left: 140px;
    padding-top: 0;
    text-align: left;
    width: auto;
}
@media screen and (max-width: 767px) {
    .m-flow.theme-horizontal > ol > li {
        min-height: 100px;
        margin-bottom: 30px;
        margin-right: 0;
        padding-bottom: 30px;
        padding-left: 70px;
        padding-top: 0;
    }
}
.m-flow.theme-horizontal > ol > li .m-flow_title {
    font-size: 2.4rem;
    font-weight: 700;
    margin-bottom: 10px;
}
@media screen and (max-width: 767px) {
    .m-flow.theme-horizontal > ol > li .m-flow_title {
        font-size: 1.8rem;
    }
}
.m-flow.theme-horizontal > ol > li ol,
.m-flow.theme-horizontal > ol > li p,
.m-flow.theme-horizontal > ol > li ul {
    margin-bottom: 1em;
}
.m-flow.theme-horizontal > ol > li ol:last-child,
.m-flow.theme-horizontal > ol > li p:last-child,
.m-flow.theme-horizontal > ol > li ul:last-child {
    margin-bottom: 0;
}
.m-flow.theme-horizontal > ol > li:last-child {
    border-bottom: 0;
    margin-bottom: 0;
    padding-bottom: 0;
}
.m-flow.theme-horizontal > ol > li:before {
    background-color: #ffd802;
    color: #fff;
    font-size: 6.4rem;
    font-weight: 700;
    height: 100px;
    line-height: 100px;
    text-align: center;
    width: 100px;
    position: absolute;
    left: 0;
    top: 0;
    -webkit-transform: translateX(0);
    -ms-transform: translateX(0);
    transform: translateX(0);
}
@media screen and (max-width: 767px) {
    .m-flow.theme-horizontal > ol > li:before {
        font-size: 3.2rem;
        height: 50px;
        line-height: 50px;
        width: 50px;
    }
}
.m-flow.theme-horizontal > ol > li:after {
    content: none;
}
.m-flow.theme-horizontal.opt-minisize > ol > li {
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    min-height: 70px;
    margin-bottom: 30px;
    padding-bottom: 30px;
    padding-left: 100px;
}
.m-flow.theme-horizontal.opt-minisize > ol > li:last-child {
    border-bottom: 0;
    margin-bottom: 0;
    padding-bottom: 0;
}
@media screen and (max-width: 767px) {
    .m-flow.theme-horizontal.opt-minisize > ol > li {
        min-height: 70px;
        margin-bottom: 15px;
        padding-bottom: 15px;
        padding-left: 70px;
        padding-top: 0;
    }
}
.m-flow.theme-horizontal.opt-minisize > ol > li:before {
    font-size: 4rem;
    height: 70px;
    line-height: 70px;
    width: 70px;
}
@media screen and (max-width: 767px) {
    .m-flow.theme-horizontal.opt-minisize > ol > li:before {
        font-size: 3.2rem;
        height: 50px;
        line-height: 50px;
        width: 50px;
    }
}
.m-flow.opt-flex > ol > li {
    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;
}
.m-flow.opt-flex > ol > li .m-flow_text {
    -webkit-box-flex: 1;
    -ms-flex: 1;
    flex: 1;
}
.m-flow.opt-flex > ol > li .m-flow_img {
    margin-left: 40px;
    width: 250px;
}
@media screen and (max-width: 767px) {
    .m-flow.opt-flex > ol > li {
        display: block;
    }
    .m-flow.opt-flex > ol > li .m-flow_img {
        margin: 0 auto 20px;
        width: 125px;
    }
}
.m-table {
    overflow: hidden;
    overflow-x: auto;
    text-align: left;
}
.m-table > table {
    border: 0;
    border-top: 1px solid #ddd;
    width: 100%;
}
.m-table > table > tbody > tr > td,
.m-table > table > tbody > tr > th {
    border: 0;
    border-bottom: 1px solid #ddd;
    line-height: 1.875;
    padding: 30px 0;
    text-align: left;
}
@media screen and (max-width: 767px) {
    .m-table > table > tbody > tr > td,
    .m-table > table > tbody > tr > th {
        display: block;
        padding: 0 5px;
    }
}
@media screen and (min-width: 768px) {
    .m-table > table > tbody > tr > td a[href^="tel:"],
    .m-table > table > tbody > tr > th a[href^="tel:"] {
        color: #222;
    }
}
.m-table > table > tbody > tr td:nth-child(1),
.m-table > table > tbody > tr th {
    background-color: #fff;
    font-weight: 700;
    vertical-align: middle;
    width: 200px;
}
.m-table > table > tbody > tr td:nth-child(1).is-vat,
.m-table > table > tbody > tr th.is-vat {
    vertical-align: top;
}
@media screen and (max-width: 767px) {
    .m-table > table > tbody > tr td:nth-child(1),
    .m-table > table > tbody > tr th {
        border-bottom: 0;
        padding-bottom: 0;
        padding-top: 15px;
        width: auto !important;
    }
}
@media screen and (max-width: 767px) {
    .m-table > table > tbody > tr td {
        padding-bottom: 15px;
    }
}
.m-table > table > tbody > tr td.m-table_inner {
    padding: 0;
}
.m-table > table > tbody > tr td.m-table_inner table th {
    font-size: 1em;
    font-weight: 400;
}
.m-table > table > tbody > tr td.m-table_inner table tr:last-child td,
.m-table > table > tbody > tr td.m-table_inner table tr:last-child th {
    border-bottom: 0;
}
@media screen and (max-width: 767px) {
    .m-table > table > tbody > tr td.m-table_inner {
        padding-left: 60px;
    }
    .m-table > table > tbody > tr td.m-table_inner table {
        border-top: 1px solid #d7d7d7;
        margin-top: 15px;
    }
    .m-table > table > tbody > tr td.m-table_inner table th {
        font-size: 1.4rem;
        font-weight: 700;
    }
}
.m-table.theme-yellow > table {
    border-left: 1px solid #bbb;
    border-top: 1px solid #bbb;
}
.m-table.theme-yellow > table > tbody > tr th {
    background-color: #ffd802;
}
.m-table.theme-yellow > table > tbody > tr td,
.m-table.theme-yellow > table > tbody > tr th {
    border-right: 1px solid #bbb;
    border-bottom: 1px solid #bbb;
    padding: 15px;
}
.m-table.opt-auto > table {
    width: auto;
}
@media screen and (max-width: 767px) {
    .m-table.opt-auto > table {
        width: 100%;
    }
}
.m-table.opt-auto > table > tbody > tr td,
.m-table.opt-auto > table > tbody > tr th {
    padding: 15px;
    width: auto;
}
.m-news > ul > li {
    border-bottom: 1px solid #ddd;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    line-height: 1.5;
    padding: 10px 0;
    text-align: left;
}
@media screen and (max-width: 767px) {
    .m-news > ul > li {
        display: block;
        padding: 15px 5px;
    }
}
.m-news > ul > li.is-attention a {
    color: #ea0000;
    font-weight: 700;
}
.m-news > ul > li.is-attention a > span {
    background-image: -webkit-gradient(
        linear,
        left bottom,
        left top,
        from(#ea0000),
        to(#ea0000)
    );
    background-image: -webkit-linear-gradient(bottom, #ea0000, #ea0000);
    background-image: linear-gradient(0deg, #ea0000, #ea0000);
}
.m-news > ul > li > span {
    padding-left: 9px;
    width: 110px;
}
@media screen and (max-width: 767px) {
    .m-news > ul > li > span {
        color: #999;
        display: block;
        margin-bottom: 5px;
        padding-left: 0;
        width: auto;
    }
}
.m-news > ul > li > a {
    color: #363435;
    display: block;
    -webkit-box-flex: 1;
    -ms-flex: 1;
    flex: 1;
    padding-right: 30px;
    width: -webkit-calc(100% - 110px);
    width: calc(100% - 110px);
    position: relative;
}
@media screen and (max-width: 767px) {
    .m-news > ul > li > a {
        margin-right: -5px;
        padding-right: 15px;
        width: auto;
    }
}
.m-news > ul > li > a:after {
    border-right: 2px solid #363435;
    border-top: 2px solid #363435;
    content: "";
    height: 7px;
    width: 7px;
    position: absolute;
    right: 5px;
    top: 49%;
    -webkit-transform: rotate(45deg) translateY(-50%);
    -ms-transform: rotate(45deg) translateY(-50%);
    transform: rotate(45deg) translateY(-50%);
    -webkit-transition: all 0.3s;
    transition: all 0.3s;
}
.m-news > ul > li > a > span {
    background: -webkit-gradient(
            linear,
            left bottom,
            left top,
            from(#363435),
            to(#363435)
        )
        no-repeat 0 100%;
    background: -webkit-linear-gradient(bottom, #363435, #363435) no-repeat 0
        100%;
    background: linear-gradient(0deg, #363435, #363435) no-repeat 0 100%;
    background-size: 0 1px;
    -webkit-transition: all 0.3s ease;
    transition: all 0.3s ease;
}
@media screen and (min-width: 768px) {
    .m-news > ul > li > a:hover:after {
        right: 0;
        -webkit-transform: rotate(45deg) translateY(-50%);
        -ms-transform: rotate(45deg) translateY(-50%);
        transform: rotate(45deg) translateY(-50%);
    }
    .m-news > ul > li > a:hover > span {
        background-size: 100% 1px;
    }
}
.m-news .m-news_item {
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    gap: 0 10px;
    margin-right: 8px;
    min-width: 310px;
}
.m-news .m-news_item time {
    display: inline-block;
    font-weight: 700;
}
.m-news .m-news_item .m-tag[class*="--color"] {
    padding-left: 0;
    padding-right: 0;
    width: 80px;
}
@media screen and (max-width: 767px) {
    .m-news .m-news_item {
        margin-bottom: 8px;
    }
}
.m-tag {
    background-color: #ffd802;
    border-radius: 20px;
    color: #363435;
    display: inline-block;
    line-height: 1;
    font-size: 1.4rem;
    font-weight: 700;
    padding: 5px 18px 4px;
    text-align: center;
}
.m-tag.--color-blue {
    background-color: #4c5cf6;
    color: #fff;
}
.m-tag.--color-gray {
    background-color: #363636;
    color: #fff;
}
@media screen and (max-width: 767px) {
    .m-tag {
        font-size: 1.2rem;
    }
}
.m-news-single .at-below-post {
    display: none !important;
}
.m-pagination {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    margin-top: 50px;
}
@media screen and (max-width: 767px) {
    .m-pagination {
        margin-top: 25px;
    }
}
.m-pagination > a,
.m-pagination > span {
    background-color: #fff;
    border: 1px solid #ffd802;
    border-radius: 8px;
    color: #363435;
    display: inline-block;
    font-size: 1.8rem;
    font-weight: 700;
    height: 40px;
    line-height: 40px;
    margin-right: 10px;
    overflow: hidden;
    text-align: center;
    width: 40px;
    -webkit-transition: all 0.3s;
    transition: all 0.3s;
}
@media screen and (max-width: 767px) {
    .m-pagination > a,
    .m-pagination > span {
        font-size: 1.3rem;
        height: 30px;
        line-height: 30px;
        width: 30px;
    }
}
.m-pagination > a:last-child,
.m-pagination > span:last-child {
    margin-right: 0;
}
.m-pagination > a.m-pagination_next,
.m-pagination > a.m-pagination_prev,
.m-pagination > span.m-pagination_next,
.m-pagination > span.m-pagination_prev {
    text-indent: -200%;
    text-align: left;
    position: relative;
}
.m-pagination > a.m-pagination_next:before,
.m-pagination > a.m-pagination_prev:before,
.m-pagination > span.m-pagination_next:before,
.m-pagination > span.m-pagination_prev:before {
    border-right: 2px solid #363435;
    border-top: 2px solid #363435;
    content: "";
    height: 7px;
    width: 7px;
    position: absolute;
    left: 0;
    top: 15px;
}
@media screen and (max-width: 767px) {
    .m-pagination > a.m-pagination_next:before,
    .m-pagination > a.m-pagination_prev:before,
    .m-pagination > span.m-pagination_next:before,
    .m-pagination > span.m-pagination_prev:before {
        height: 5px;
        width: 5px;
        top: 11px;
    }
}
.m-pagination > a.m-pagination_prev:before,
.m-pagination > span.m-pagination_prev:before {
    left: 16px;
    -webkit-transform: rotate(-135deg);
    -ms-transform: rotate(-135deg);
    transform: rotate(-135deg);
}
@media screen and (max-width: 767px) {
    .m-pagination > a.m-pagination_prev:before,
    .m-pagination > span.m-pagination_prev:before {
        left: 12px;
    }
}
.m-pagination > a.m-pagination_next:before,
.m-pagination > span.m-pagination_next:before {
    left: 12px;
    -webkit-transform: rotate(45deg);
    -ms-transform: rotate(45deg);
    transform: rotate(45deg);
}
@media screen and (max-width: 767px) {
    .m-pagination > a.m-pagination_next:before,
    .m-pagination > span.m-pagination_next:before {
        left: 9px;
    }
}
.m-pagination > a.is-active,
.m-pagination > span.is-active {
    background-color: #ffd802;
}
@media screen and (min-width: 768px) {
    .m-pagination > a:hover,
    .m-pagination > span:hover {
        background-color: #ffd802;
    }
    .m-pagination > a:hover.m-pagination_next:before,
    .m-pagination > a:hover.m-pagination_prev:before,
    .m-pagination > span:hover.m-pagination_next:before,
    .m-pagination > span:hover.m-pagination_prev:before {
        border-color: #363435;
    }
}
input[type="email"],
input[type="password"],
input[type="text"],
select,
textarea {
    border: 1px solid #d7d7d7;
    border-radius: 10px;
    padding: 0 0.5em;
    width: 100%;
}
input[type="email"].opt-mini,
input[type="password"].opt-mini,
input[type="text"].opt-mini,
select.opt-mini,
textarea.opt-mini {
    max-width: 100px;
}
input[type="email"]::-webkit-input-placeholder,
input[type="password"]::-webkit-input-placeholder,
input[type="text"]::-webkit-input-placeholder,
select::-webkit-input-placeholder,
textarea::-webkit-input-placeholder {
    color: #b7b7b7;
}
input[type="email"]::-moz-placeholder,
input[type="password"]::-moz-placeholder,
input[type="text"]::-moz-placeholder,
select::-moz-placeholder,
textarea::-moz-placeholder {
    color: #b7b7b7;
}
input[type="email"]:-ms-input-placeholder,
input[type="password"]:-ms-input-placeholder,
input[type="text"]:-ms-input-placeholder,
select:-ms-input-placeholder,
textarea:-ms-input-placeholder {
    color: #b7b7b7;
}
input[type="email"]::-ms-input-placeholder,
input[type="password"]::-ms-input-placeholder,
input[type="text"]::-ms-input-placeholder,
select::-ms-input-placeholder,
textarea::-ms-input-placeholder {
    color: #b7b7b7;
}
input[type="email"]::placeholder,
input[type="password"]::placeholder,
input[type="text"]::placeholder,
select::placeholder,
textarea::placeholder {
    color: #b7b7b7;
}
input[type="email"],
input[type="password"],
input[type="text"],
select {
    min-height: 46px;
    padding: 0 0.5em;
}
@media screen and (max-width: 767px) {
    input[type="email"],
    input[type="password"],
    input[type="text"],
    select {
        min-height: 35px;
    }
}
textarea {
    height: 226px;
}
@media screen and (max-width: 767px) {
    textarea {
        min-height: 160px;
    }
}
select {
    width: auto;
}
.js-custom-input {
    display: none;
    margin-top: 10px;
}
.m-checkradio label {
    display: inline-block;
    font-size: 1.6rem;
    font-weight: 1.3;
    margin-left: 0.5em;
}
.m-contact-box {
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    background-color: #eee;
    border-radius: 10px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    margin-top: 90px;
    padding: 40px 60px;
    text-align: left;
}
.m-contact-box:first-child {
    margin-top: 0;
}
.m-contact-box.theme-bg.opt-white {
    background-color: #fff;
}
.m-contact-box.theme-padding-none {
    margin-bottom: 40px;
    padding: 0;
}
.m-contact-box .m-contact-box_text {
    line-height: 1.5;
    width: -webkit-calc(100% - 240px);
    width: calc(100% - 240px);
}
.m-contact-box .m-contact-box_btn {
    margin-top: 0;
    width: 240px;
}
@media screen and (max-width: 767px) {
    .m-contact-box {
        display: block;
        margin-top: 45px;
        padding: 20px 15px;
    }
    .m-contact-box .m-contact-box_title {
        text-align: center;
    }
    .m-contact-box .m-contact-box_text {
        width: 100%;
    }
    .m-contact-box .m-contact-box_btn {
        margin: 20px auto 0;
    }
}
.m-media {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    margin-bottom: 40px;
}
.m-media:last-child {
    margin-bottom: 0;
}
.m-media .m-media_box {
    width: 48%;
}
.m-media .m-media_box:nth-child(2n) {
    margin-left: auto;
}
@media screen and (max-width: 767px) {
    .m-media {
        display: block;
    }
    .m-media .m-media_box {
        width: auto;
    }
}
.m-copy .m-copy-textarea {
    border: 0;
    border-radius: 0;
    font-size: 2rem;
    line-height: 1.2;
    margin-bottom: 0.5em !important;
    min-height: 0;
    vertical-align: middle;
    outline: 0;
    padding: 0;
    text-align: center;
}
@media screen and (max-width: 767px) {
    .m-copy .m-copy-textarea {
        font-size: 1.4rem;
        text-align: left;
    }
}
.m-copy .m-copy_text {
    background-color: #363636;
    border-radius: 20px;
    color: #fff;
    padding: 1em;
    position: fixed;
    left: 50%;
    top: 50%;
    -webkit-transform: translate(-50%, -50%);
    -ms-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
    z-index: 1000;
}
.m-index-list {
    background-color: #fff;
    border-radius: 10px;
    padding: 40px;
    margin-bottom: 60px;
}
.m-index-list.theme-gray {
    -webkit-box-shadow: 0 3px 6px rgba(0, 0, 0, 0.08);
    box-shadow: 0 3px 6px rgba(0, 0, 0, 0.08);
    border-radius: 0;
    position: relative;
}
@media screen and (min-width: 768px) {
    .m-index-list.theme-gray {
        width: 70%;
    }
}
.m-index-list.theme-gray::before {
    border-top: 3px solid #ffd802;
    content: "";
    width: 100%;
    position: absolute;
    left: 0;
    top: 0;
}
.m-index-list.theme-gray .m-index-list_title {
    cursor: pointer;
}
.m-index-list.theme-gray .m-index-list_title > h2 {
    -webkit-transition: all 0.3s;
    transition: all 0.3s;
}
.m-index-list.theme-gray .m-index-list_title > h2::after,
.m-index-list.theme-gray .m-index-list_title > h2::before {
    background-color: #000;
    content: "";
    height: 2px;
    width: 20px;
    position: absolute;
    right: 5px;
    top: 14px;
    -webkit-transition: all 0.3s;
    transition: all 0.3s;
}
.m-index-list.theme-gray .m-index-list_title > h2::before {
    -webkit-transform: rotate(45deg);
    -ms-transform: rotate(45deg);
    transform: rotate(45deg);
}
.m-index-list.theme-gray .m-index-list_title > h2::after {
    -webkit-transform: rotate(-45deg);
    -ms-transform: rotate(-45deg);
    transform: rotate(-45deg);
}
.m-index-list.theme-gray .m-index-list_title.is-active {
    margin-bottom: 0;
}
.m-index-list.theme-gray .m-index-list_title.is-active > h2::after {
    background-color: transparent;
    border-bottom: 2px solid #000;
    border-top: 2px solid #000;
    height: 12px;
    top: 7px;
}
.m-index-list.theme-gray .m-index-list_title.is-active > h2::before {
    -webkit-transform: rotate(0);
    -ms-transform: rotate(0);
    transform: rotate(0);
}
.m-index-list.theme-gray .m-index-list_title.is-active > h2::after {
    -webkit-transform: rotate(0);
    -ms-transform: rotate(0);
    transform: rotate(0);
}
.m-index-list.theme-gray > ol {
    counter-reset: ol;
    display: block;
}
.m-index-list.theme-gray > ol > li {
    counter-increment: ol;
    width: 100%;
    position: relative;
}
.m-index-list.theme-gray > ol > li::after {
    background-color: #ffd802;
    content: "";
    height: 1px;
    width: 20%;
    position: absolute;
    bottom: -1px;
    left: 0;
    -webkit-transition: width 0.3s ease;
    transition: width 0.3s ease;
}
.m-index-list.theme-gray > ol > li > a {
    padding-left: 1em;
    text-indent: -1em;
}
.m-index-list.theme-gray > ol > li > a::before {
    content: counter(ol) ".";
    font-size: 1.2em;
    font-weight: 500;
}
@media screen and (min-width: 768px) {
    .m-index-list.theme-gray > ol > li:hover::after {
        height: 2px;
        width: 100%;
    }
}
.m-index-list:last-child {
    margin-bottom: 0;
}
@media screen and (max-width: 767px) {
    .m-index-list {
        padding: 20px;
    }
}
.m-index-list > ol,
.m-index-list > ul {
    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;
}
.m-index-list > ol > li,
.m-index-list > ul > li {
    border-bottom: 1px solid #ddd;
    line-height: 1.5;
    text-align: left;
    width: 47.5%;
}
@media screen and (max-width: 767px) {
    .m-index-list > ol > li,
    .m-index-list > ul > li {
        width: 100%;
    }
}
.m-index-list > ol > li > a,
.m-index-list > ul > li > a {
    color: #363435;
    display: block;
    padding: 10px 0;
    padding-right: 30px;
    position: relative;
}
@media screen and (max-width: 767px) {
    .m-index-list > ol > li > a,
    .m-index-list > ul > li > a {
        margin-right: -5px;
        padding-right: 15px;
        width: auto;
    }
}
.m-index-list > ol > li > a:after,
.m-index-list > ul > li > a:after {
    border-right: 2px solid #363435;
    border-top: 2px solid #363435;
    content: "";
    height: 7px;
    width: 7px;
    position: absolute;
    right: 5px;
    top: 49%;
    -webkit-transform: rotate(45deg) translateY(-50%);
    -ms-transform: rotate(45deg) translateY(-50%);
    transform: rotate(45deg) translateY(-50%);
    -webkit-transition: all 0.3s;
    transition: all 0.3s;
}
@media screen and (max-width: 767px) {
    .m-index-list > ol > li > a:after,
    .m-index-list > ul > li > a:after {
        height: 5px;
        width: 5px;
        right: 10px;
    }
}
.m-index-list > ol > li > a > span,
.m-index-list > ul > li > a > span {
    background: -webkit-gradient(
            linear,
            left bottom,
            left top,
            from(#363435),
            to(#363435)
        )
        no-repeat 0 100%;
    background: -webkit-linear-gradient(bottom, #363435, #363435) no-repeat 0
        100%;
    background: linear-gradient(0deg, #363435, #363435) no-repeat 0 100%;
    background-size: 0 1px;
    -webkit-transition: all 0.3s ease;
    transition: all 0.3s ease;
}
@media screen and (min-width: 768px) {
    .m-index-list > ol > li > a:hover:after,
    .m-index-list > ul > li > a:hover:after {
        right: 0;
        -webkit-transform: rotate(45deg) translateY(-50%);
        -ms-transform: rotate(45deg) translateY(-50%);
        transform: rotate(45deg) translateY(-50%);
    }
    .m-index-list > ol > li > a:hover > span,
    .m-index-list > ul > li > a:hover > span {
        background-size: 100% 1px;
    }
}
.aligncenter {
    display: block;
    margin: 0 auto;
}
.alignright {
    float: right;
    margin-bottom: 30px;
    margin-left: 30px;
}
.alignleft {
    float: left;
    margin-bottom: 30px;
    margin-right: 30px;
}
@media screen and (max-width: 767px) {
    .alignright {
        float: none;
        margin-bottom: 30px;
        margin-left: auto;
    }
    .alignleft {
        float: none;
        margin-bottom: 30px;
        margin-right: auto;
    }
}
.wp-block-embed iframe {
    width: 100%;
}
.wp-embedded-content {
    width: 100% !important;
}
@media screen and (max-width: 767px) {
    .wp-embedded-content {
        height: auto;
    }
}
#toc_container {
    border-top: 7px solid #ffd802;
    -webkit-box-shadow: 0 4px 10px rgba(0, 0, 0, 0.04);
    box-shadow: 0 4px 10px rgba(0, 0, 0, 0.04);
    padding: 20px !important;
    margin-bottom: 40px !important;
    margin-top: 40px;
    width: 100% !important;
    position: relative;
    z-index: 0;
}
@media screen and (max-width: 767px) {
    #toc_container {
        border-top-width: 5px;
        padding: 15px;
    }
}
#toc_container.no_bullets.contracted .toc_title {
    margin-bottom: 0;
}
#toc_container.no_bullets.contracted .toc_title .toc_toggle > a::before {
    line-height: 17px;
    -webkit-transform: rotate(0) translateY(-50%);
    -ms-transform: rotate(0) translateY(-50%);
    transform: rotate(0) translateY(-50%);
}
#toc_container .toc_title {
    background: url(/common/img/icon-logo.svg) no-repeat 0 0;
    background-size: 36px;
    color: #ffd802;
    font-size: 2.4em;
    font-weight: 700;
    line-height: 1.8;
    margin-bottom: 30px;
    min-height: 48px;
    padding-left: 2em !important;
    text-align: left !important;
}
@media screen and (max-width: 767px) {
    #toc_container .toc_title {
        font-size: 2em;
        margin-bottom: 20px;
        background-size: 28px;
        min-height: 0;
    }
}
#toc_container .toc_title .toc_toggle {
    font-size: 0;
    line-height: 0;
    position: absolute;
    bottom: 30px;
    left: 50%;
    -webkit-transform: translateX(-50%);
    -ms-transform: translateX(-50%);
    transform: translateX(-50%);
    z-index: 2;
}
#toc_container .toc_title .toc_toggle a {
    background-color: #fff;
    border: 2px solid #ffd802;
    border-radius: 30px;
    color: #363636;
    display: block;
    font-size: 1.4rem;
    font-weight: 700;
    line-height: 1;
    padding: 12px 0;
    text-align: center;
    text-decoration: none;
    width: 125px;
    position: relative;
    -webkit-transition: padding 0.3s ease;
    transition: padding 0.3s ease;
}
#toc_container .toc_list {
    border-radius: 0;
    counter-reset: toc;
    display: block !important;
    font-size: 1.8em;
    font-weight: 700;
    overflow: hidden;
    width: auto !important;
    position: relative;
    z-index: 0;
    -webkit-transition: height 0.3s;
    transition: height 0.3s;
}
#toc_container .toc_list::before {
    background: -webkit-gradient(
        linear,
        left bottom,
        left top,
        color-stop(25%, #fff),
        to(transparent)
    );
    background: -webkit-linear-gradient(bottom, #fff 25%, transparent);
    background: linear-gradient(0deg, #fff 25%, transparent);
    height: 50%;
    pointer-events: all;
    width: 100%;
    position: absolute;
    bottom: 0;
    left: 0;
    z-index: 1;
}
#toc_container .toc_list.--hide::before {
    content: "";
}
#toc_container .toc_list.--active {
    -webkit-box-sizing: content-box !important;
    box-sizing: content-box !important;
    padding-bottom: 80px!important;
    opacity: 1!important;
}
@media screen and (max-width: 767px) {
    #toc_container .toc_list.--active {
        padding-bottom: 70px;
    }
}
#toc_container .toc_list.--active::before {
    content: none !important;
}
@media screen and (max-width: 767px) {
    #toc_container .toc_list {
        font-size: 1.4em;
    }
}
#toc_container .toc_list > li {
    counter-increment: toc;
    margin-bottom: 1em;
    padding-left: 50px !important;
    text-indent: 0 !important;
    position: relative;
}
#toc_container .toc_list > li::before {
    border-right: 3px solid #ffd802;
    color: #ffd802;
    font-size: 1.5em;
    /*content: counter(toc, decimal-leading-zero) !important;*/
    line-height: 1;
    padding-right: 7px;
    position: absolute;
    top: 0;
    left: 0;
}
.toc_brackets {
    display: none!important;
}
@media screen and (max-width: 767px) {
    #toc_container .toc_list > li {
        padding-left: 40px !important;
    }
    #toc_container .toc_list > li::before {
        border-right-width: 2px;
        padding-right: 7px;
    }
}
#toc_container .toc_list > li:last-child {
    margin-bottom: 0;
}
#toc_container .toc_list > li a {
    -webkit-box-align: start;
    -ms-flex-align: start;
    align-items: flex-start;
    background: -webkit-gradient(
            linear,
            left bottom,
            left top,
            from(#4c5cf6),
            to(#4c5cf6)
        )
        no-repeat 100% 100%;
    background: -webkit-linear-gradient(bottom, #4c5cf6, #4c5cf6) no-repeat 100%
        100%;
    background: linear-gradient(0deg, #4c5cf6, #4c5cf6) no-repeat 100% 100%;
    background-size: 0 1px;
    color: #363435;
    display: inline-block;
    text-decoration: none;
    -webkit-transition: background-size 0.3s ease;
    transition: background-size 0.3s ease;
}
@media screen and (min-width: 768px) {
    #toc_container .toc_list > li a:hover {
        background-position: 0 100%;
        background-size: 100% 1px;
        color: #4c5cf6;
    }
}
#toc_container .toc_list > li .toc_number {
    border-right: 2px solid #ffd802;
    color: #ffd802;
    font-size: 1.5em;
    font-weight: 900;
    line-height: 0.9;
    padding-right: 10px;
    text-align: right;
    position: absolute;
    left: 0;
}
#toc_container .toc_list > li ul {
    border: none;
    margin-left: 0;
    margin-top: 0.5em;
    padding: 0;
}
#toc_container .toc_list > li ul li {
    margin-bottom: 0.5em;
    padding-left: 1em;
    text-indent: 0 !important;
    position: relative;
}
#toc_container .toc_list > li ul li::before {
    background-color: #ffd802;
    border-radius: 50%;
    content: "";
    height: 9px;
    padding: 0 !important;
    width: 9px;
    position: absolute;
    left: 0;
    top: 0.5em;
}
#toc_container .toc_list > li ul li .toc_number {
    display: none;
}
#toc_container .toc_list > li ul li ul {
    padding-left: 0.5em;
}
#toc_container .toc_list > li ul li ul li::before {
    background: #fff;
    border: 3px solid #ffd802;
    height: 6px;
    width: 6px;
    top: 0.4em;
}
.layout-header {
    background-color: #fff;
    height: 80px;
    width: 100%;
    position: fixed;
    left: 0;
    top: 0;
    z-index: 10000;
}
@media screen and (max-width: 767px) {
    .layout-header {
        height: 50px;
    }
}
.layout-header .layout-header_inner {
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    height: inherit;
    max-width: initial;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
}
.layout-header .layout-header_inner .logo {
    width: 206px;
}
@media (max-width: 1400px) {
    .layout-header .layout-header_inner .logo {
        margin-right: 30px;
        width: 150px;
    }
}
@media (max-width: 1280px) {
    .layout-header .layout-header_inner {
        padding-left: 15px;
        padding-right: 15px;
    }
    .layout-header .layout-header_inner .logo {
        margin-right: 20px;
    }
}
@media screen and (max-width: 767px) {
    .layout-header .layout-header_inner {
        text-align: left;
    }
    .layout-header .layout-header_inner .logo {
        -webkit-box-sizing: content-box;
        box-sizing: content-box;
        padding-left: 16px;
        width: 150px;
    }
}
.gnav {
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    text-align: left;
}
@media screen and (max-width: 767px) {
    .gnav {
        background-color: #fff;
        display: block;
        height: -webkit-calc(100vh - 50px);
        height: calc(100vh - 50px);
        overflow-y: auto;
        padding: 30px 10px 120px;
        width: 100%;
        position: fixed;
        right: 0;
        top: 50px;
        -webkit-transform: translateX(100%);
        -ms-transform: translateX(100%);
        transform: translateX(100%);
        z-index: 10000;
        -webkit-transition: -webkit-transform 0.3s ease-out;
        transition: -webkit-transform 0.3s ease-out;
        transition: transform 0.3s ease-out;
        transition:
            transform 0.3s ease-out,
            -webkit-transform 0.3s ease-out;
    }
    .gnav.is-active {
        -webkit-transform: translateX(0);
        -ms-transform: translateX(0);
        transform: translateX(0);
    }
}
.gnav > ul {
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
}
@media screen and (max-width: 767px) {
    .gnav > ul {
        border-top: 1px solid #ddd;
        display: block;
        margin-right: 0;
    }
}
@media (max-width: 1400px) {
    .gnav > ul > li {
        font-size: 1.4rem;
    }
}
@media (max-width: 1280px) {
    .gnav > ul > li {
        font-size: 1.4rem;
    }
}
@media (max-width: 1100px) {
    .gnav > ul > li {
        font-size: 1rem;
    }
}
@media screen and (min-width: 768px) {
    .gnav > ul > li:hover .subnav {
        opacity: 1;
        padding: 40px 0 80px;
        pointer-events: all;
        -webkit-transform: translateY(100%);
        -ms-transform: translateY(100%);
        transform: translateY(100%);
        -webkit-transition:
            opacity 0.3s linear 0.1s,
            -webkit-transform 0.3s;
        transition:
            opacity 0.3s linear 0.1s,
            -webkit-transform 0.3s;
        transition:
            opacity 0.3s linear 0.1s,
            transform 0.3s;
        transition:
            opacity 0.3s linear 0.1s,
            transform 0.3s,
            -webkit-transform 0.3s;
        z-index: 0;
    }
    .gnav > ul > li:hover > a:before,
    .gnav > ul > li:hover > span:before {
        -webkit-transform: scaleX(1);
        -ms-transform: scaleX(1);
        transform: scaleX(1);
        -webkit-transform-origin: top left;
        -ms-transform-origin: top left;
        transform-origin: top left;
    }
}
.gnav > ul > li > a,
.gnav > ul > li > span {
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    color: #363435;
    cursor: pointer;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    font-weight: 500;
    height: 80px;
    padding: 0 20px;
    overflow: hidden;
    position: relative;
    z-index: 0;
}
.gnav > ul > li > a:before,
.gnav > ul > li > span:before {
    background: #363435;
    content: "";
    height: 2px;
    width: 100%;
    position: absolute;
    bottom: 0;
    left: 0;
    -webkit-transform: scaleX(0);
    -ms-transform: scaleX(0);
    transform: scaleX(0);
    -webkit-transform-origin: top right;
    -ms-transform-origin: top right;
    transform-origin: top right;
    -webkit-transition: -webkit-transform 0.3s;
    transition: -webkit-transform 0.3s;
    transition: transform 0.3s;
    transition:
        transform 0.3s,
        -webkit-transform 0.3s;
    z-index: -1;
}
@media (max-width: 1280px) {
    .gnav > ul > li > a,
    .gnav > ul > li > span {
        padding-left: 10px;
        padding-right: 10px;
    }
}
@media screen and (max-width: 767px) {
    .gnav > ul > li > a,
    .gnav > ul > li > span {
        border-bottom: 1px solid #ddd;
        display: block;
        font-size: 1.6rem;
        font-weight: 700;
        height: auto;
        padding: 10px;
    }
    .gnav > ul > li > a:before,
    .gnav > ul > li > span:before {
        content: none;
    }
}
.gnav > ul > li > span {
    padding-right: 38px;
}
.gnav > ul > li > span:after {
    border-right: 2px solid #363435;
    border-bottom: 2px solid #363435;
    content: "";
    height: 5px;
    width: 5px;
    position: absolute;
    right: 13px;
    top: 50%;
    -webkit-transform: rotate(45deg) translate(-50%, -50%);
    -ms-transform: rotate(45deg) translate(-50%, -50%);
    transform: rotate(45deg) translate(-50%, -50%);
}
@media screen and (max-width: 767px) {
    .gnav > ul > li > span {
        border-bottom: 0;
        cursor: default;
        font-size: 1.6rem;
        padding: 15px;
        text-align: center;
    }
    .gnav > ul > li > span:after {
        bottom: 0;
        left: 50%;
        right: auto;
        top: auto;
        -webkit-transform: rotate(45deg) translateX(-50%);
        -ms-transform: rotate(45deg) translateX(-50%);
        transform: rotate(45deg) translateX(-50%);
    }
}
.gnav > ul > li .subnav {
    opacity: 0;
    pointer-events: none;
    width: 100%;
    position: absolute;
    bottom: 0;
    left: 0;
    -webkit-transform: translateY(0);
    -ms-transform: translateY(0);
    transform: translateY(0);
    -webkit-transition:
        opacity 0.3s linear,
        padding 0.3s linear 0.2s,
        -webkit-transform 0s linear 0.3s;
    transition:
        opacity 0.3s linear,
        padding 0.3s linear 0.2s,
        -webkit-transform 0s linear 0.3s;
    transition:
        opacity 0.3s linear,
        transform 0s linear 0.3s,
        padding 0.3s linear 0.2s;
    transition:
        opacity 0.3s linear,
        transform 0s linear 0.3s,
        padding 0.3s linear 0.2s,
        -webkit-transform 0s linear 0.3s;
    z-index: -1;
}
@media screen and (max-width: 767px) {
    .gnav > ul > li .subnav {
        border-bottom: 1px solid #ddd;
        opacity: 1;
        padding: 10px 10px 20px;
        pointer-events: all;
        position: static;
        z-index: 0;
    }
}
.gnav > ul > li .subnav:after {
    background-color: #eee;
    content: "";
    height: 100%;
    margin: 0 -webkit-calc(50% - 50vw);
    margin: 0 calc(50% - 50vw);
    width: 100vw;
    position: fixed;
    left: 0;
    top: 0;
    z-index: -1;
    -webkit-transition: opacity 0.3s linear;
    transition: opacity 0.3s linear;
}
@media screen and (max-width: 767px) {
    .gnav > ul > li .subnav:after {
        content: none;
    }
}
.gnav > ul > li .subnav p {
    font-size: 2rem;
    font-weight: 700;
    margin-bottom: 40px;
}
.gnav > ul > li .subnav p.subnav_title {
    margin-bottom: 1em;
}
.gnav > ul > li .subnav p a {
    color: #363435;
    display: inline-block;
    padding-bottom: 3px;
    position: relative;
}
.gnav > ul > li .subnav p a:before {
    border-right: 2px solid #363435;
    border-top: 2px solid #363435;
    content: none;
    height: 8px;
    width: 8px;
    -webkit-transform: rotate(45deg);
    -ms-transform: rotate(45deg);
    transform: rotate(45deg);
    position: absolute;
    left: 0;
    top: 5px;
}
.gnav > ul > li .subnav p a:after {
    background: #363435;
    content: "";
    height: 2px;
    width: 100%;
    position: absolute;
    bottom: 0;
    left: 0;
    -webkit-transform: scaleX(0);
    -ms-transform: scaleX(0);
    transform: scaleX(0);
    -webkit-transform-origin: top right;
    -ms-transform-origin: top right;
    transform-origin: top right;
    -webkit-transition: -webkit-transform 0.3s;
    transition: -webkit-transform 0.3s;
    transition: transform 0.3s;
    transition:
        transform 0.3s,
        -webkit-transform 0.3s;
    z-index: 1;
}
@media screen and (min-width: 768px) {
    .gnav > ul > li .subnav p a:hover:after {
        -webkit-transform: scaleX(1);
        -ms-transform: scaleX(1);
        transform: scaleX(1);
        -webkit-transform-origin: top left;
        -ms-transform-origin: top left;
        transform-origin: top left;
    }
}
@media screen and (max-width: 767px) {
    .gnav > ul > li .subnav p {
        font-size: 1.6rem;
        margin-bottom: 20px;
    }
    .gnav > ul > li .subnav p a:before {
        height: 4px;
        width: 4px;
    }
}
.gnav .gnav_btn-wrapper {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
}
@media screen and (max-width: 767px) {
    .gnav .gnav_btn-wrapper {
        -webkit-box-pack: justify;
        -ms-flex-pack: justify;
        justify-content: space-between;
        margin: 20px auto 0;
        width: 100%;
    }
}
.gnav .gnav_btn-wrapper .gnav_btn {
    margin-top: 0;
}
.gnav .gnav_btn-wrapper .gnav_btn:nth-child(2) {
    margin-left: 1em;
}
@media (max-width: 1280px) {
    .gnav .gnav_btn-wrapper .gnav_btn:nth-child(2) {
        margin-left: 0.5em;
    }
    .gnav .gnav_btn-wrapper .gnav_btn > a,
    .gnav .gnav_btn-wrapper .gnav_btn > button {
        font-size: 1rem;
        width: 70px;
    }
}
@media screen and (max-width: 767px) {
    .gnav .gnav_btn-wrapper .gnav_btn {
        width: 49%;
    }
    .gnav .gnav_btn-wrapper .gnav_btn:nth-child(2) {
        margin-left: 0;
    }
    .gnav .gnav_btn-wrapper .gnav_btn > a,
    .gnav .gnav_btn-wrapper .gnav_btn > button {
        font-size: 1.2rem;
        width: 100%;
    }
}
.menu {
    display: none;
    height: 11px;
    width: 25px;
    position: fixed;
    right: 16px;
    top: 19px;
    z-index: 100000;
    -webkit-transition: top 0.3s linear 0.3s;
    transition: top 0.3s linear 0.3s;
}
@media screen and (max-width: 767px) {
    .menu {
        display: block;
    }
}
.menu > span {
    background-color: #363435;
    display: block;
    height: 2px;
    width: 25px;
    position: absolute;
    right: 0;
    top: 0;
    -webkit-transition:
        background 0.3s linear 0.2s,
        opacity 0.3s linear,
        -webkit-transform 0.3s linear 0.3s;
    transition:
        background 0.3s linear 0.2s,
        opacity 0.3s linear,
        -webkit-transform 0.3s linear 0.3s;
    transition:
        background 0.3s linear 0.2s,
        transform 0.3s linear 0.3s,
        opacity 0.3s linear;
    transition:
        background 0.3s linear 0.2s,
        transform 0.3s linear 0.3s,
        opacity 0.3s linear,
        -webkit-transform 0.3s linear 0.3s;
}
.menu > span:nth-child(2) {
    top: 5px;
}
.menu > span:nth-child(3) {
    top: 10px;
}
.menu:after,
.menu:before {
    background-color: #000;
    content: "";
    height: 2px;
    opacity: 0;
    width: 25px;
    position: absolute;
    left: 0;
    top: 5px;
    -webkit-transition: all 0.3s ease-in;
    transition: all 0.3s ease-in;
}
.menu:before {
    -webkit-transform: rotate(45deg);
    -ms-transform: rotate(45deg);
    transform: rotate(45deg);
}
.menu:after {
    -webkit-transform: rotate(-45deg);
    -ms-transform: rotate(-45deg);
    transform: rotate(-45deg);
}
.menu.is-active span {
    opacity: 0;
    -webkit-transform: translateX(-10px);
    -ms-transform: translateX(-10px);
    transform: translateX(-10px);
    -webkit-transition-delay: 0s, 0.2s;
    transition-delay: 0s, 0.2s;
}
.menu.is-active span:nth-child(2) {
    -webkit-transform: translateX(-10px);
    -ms-transform: translateX(-10px);
    transform: translateX(-10px);
    -webkit-transition-delay: 0.1s, 0.2s;
    transition-delay: 0.1s, 0.2s;
}
.menu.is-active span:nth-child(3) {
    -webkit-transform: translateX(-10px);
    -ms-transform: translateX(-10px);
    transform: translateX(-10px);
    -webkit-transition-delay: 0.2s, 0.2s;
    transition-delay: 0.2s, 0.2s;
}
.menu.is-active:after,
.menu.is-active:before {
    opacity: 1;
}
.layout-container {
    overflow: hidden;
    padding-top: 135px;
}
@media screen and (max-width: 767px) {
    .layout-container {
        padding-top: 50px;
    }
}
.page-title {
    background: url(../img/page-title_bg.png) 50% 0;
    padding: 40px 0;
}
@media screen and (max-width: 767px) {
    .page-title {
        padding: 20px 0;
    }
}
.page-title h1,
.page-title p {
    font-size: 3.2em;
    font-weight: 700;
    line-height: 1.5;
    text-align: left;
}
.page-title h1 span,
.page-title p span {
    display: block;
    font-size: 2rem;
}
@media screen and (max-width: 767px) {
    .page-title h1,
    .page-title p {
        font-size: 2.8em;
        text-align: center;
    }
    .page-title h1 span,
    .page-title p span {
        font-size: 1.6rem;
    }
}
.page-title.--type02 {
    background: 0 0;
    padding: 120px 0;
    position: relative;
}
.page-title.--type02 h1 {
    font-size: 48px;
    padding-bottom: 0.6em;
    text-align: center;
    position: relative;
}
.page-title.--type02 h1::after {
    background: -webkit-linear-gradient(85deg, #f26462, #ffc656);
    background: linear-gradient(5deg, #f26462, #ffc656);
    content: "";
    height: 7px;
    width: 85px;
    position: absolute;
    bottom: 0;
    left: 50%;
    -webkit-transform: translateX(-50%);
    -ms-transform: translateX(-50%);
    transform: translateX(-50%);
}
@media screen and (max-width: 767px) {
    .page-title.--type02 {
        padding: 60px 0 40px;
    }
    .page-title.--type02 h1 {
        font-size: 32px;
    }
    .page-title.--type02 h1::after {
        height: 6px;
        width: 60px;
    }
}
.section {
    padding-bottom: 100px;
    padding-top: 120px;
}
.section + .section {
    padding-top: 0;
}
.section + .section.theme-bg {
    padding-top: 120px;
}
@media screen and (max-width: 767px) {
    .section + .section.theme-bg {
        padding-top: 60px;
    }
}
@media screen and (max-width: 767px) {
    .section {
        padding: 60px 15px;
    }
}
.section.theme-bg + .section {
    padding-top: 120px;
}
@media screen and (max-width: 767px) {
    .section.theme-bg + .section {
        padding-top: 60px;
    }
}
.section.theme-bg.is-gray {
    background-color: #eee;
}
.section.theme-bg.is-yellow {
    background-color: #ffd802;
}
.section-title {
    margin-bottom: 60px;
}
@media screen and (max-width: 767px) {
    .section-title {
        margin-bottom: 40px;
    }
}
.section-title h2 {
    font-size: 3.2em;
    font-weight: 700;
    line-height: 1.25;
    padding-bottom: 20px;
    text-align: center;
    position: relative;
}
.section-title h2 > span {
    font-size: 0.8em;
}
.section-title h2:before {
    background-color: #ffd802;
    content: "";
    height: 4px;
    width: 40px;
    position: absolute;
    bottom: 0;
    left: 50%;
    -webkit-transform: translateX(-50%);
    -ms-transform: translateX(-50%);
    transform: translateX(-50%);
}
@media screen and (max-width: 767px) {
    .section-title h2 {
        font-size: 2.4em;
        padding-bottom: 15px;
    }
    .section-title h2:before {
        height: 2px;
        width: 25px;
    }
}
.section-title.theme-white h2:before {
    background-color: #fff;
}
.content-title {
    border-bottom: 6px solid #eee;
    margin-bottom: 40px;
    padding-bottom: 20px;
    text-align: left;
    position: relative;
}
@media screen and (max-width: 767px) {
    .content-title {
        border-bottom-width: 4px;
        padding-bottom: 10px;
        margin-bottom: 20px;
    }
}
.content-title:before {
    background-color: #ffd802;
    content: "";
    height: 6px;
    width: 200px;
    position: absolute;
    bottom: 0;
    left: 0;
    -webkit-transform: translateY(100%);
    -ms-transform: translateY(100%);
    transform: translateY(100%);
}
@media screen and (max-width: 767px) {
    .content-title:before {
        height: 4px;
        width: 120px;
    }
}
.content-title.opt-small {
    border-bottom-width: 4px;
    margin-bottom: 20px;
    padding-bottom: 10px;
}
.content-title.opt-small:before {
    height: 4px;
    width: 120px;
}
.content-title.opt-small h2,
.content-title.opt-small h3,
.content-title.opt-small h4,
.content-title.opt-small h5 {
    font-size: 2em;
}
@media screen and (max-width: 767px) {
    .content-title.opt-small {
        border-bottom-width: 3px;
    }
    .content-title.opt-small:before {
        height: 3px;
        width: 80px;
    }
    .content-title.opt-small h3,
    .content-title.opt-small h4,
    .content-title.opt-small h5 {
        font-size: 1.8em;
    }
}
.content-title h2,
.content-title h3 {
    font-size: 3.2em;
    font-weight: 700;
    line-height: 1.2;
}
@media screen and (max-width: 767px) {
    .content-title h2,
    .content-title h3 {
        font-size: 2.4em;
    }
}
.content-title p {
    line-height: 1.2;
    margin: 10px 0;
}
.content-title p:first-child {
    margin-top: 0;
}
.content-title p:last-child {
    margin-bottom: 0;
}
.local-title {
    font-size: 2.4rem;
    font-weight: 700;
    line-height: 1.2;
    margin-bottom: 0.7em;
}
.local-title.theme-border {
    font-size: 1.8rem;
    padding-left: 1.5em;
    text-align: left;
    position: relative;
}
.local-title.theme-border:before {
    background-color: #ffd802;
    content: "";
    height: 6px;
    width: 20px;
    position: absolute;
    left: 0;
    top: 50%;
    -webkit-transform: translateY(-50%);
    -ms-transform: translateY(-50%);
    transform: translateY(-50%);
}
.layout-breadcrumbs {
    background-color: #efefef;
    padding: 20px;
}
.layout-breadcrumbs .breadcrumbs {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
}
.layout-breadcrumbs .breadcrumbs li a {
    color: inherit;
    text-decoration: underline;
}
@media screen and (min-width: 768px) {
    .layout-breadcrumbs .breadcrumbs li a:hover {
        text-decoration: none;
    }
}
.layout-breadcrumbs .breadcrumbs li:not(:last-child) {
    margin-right: 1em;
    padding-right: 1.2em;
    position: relative;
}
.layout-breadcrumbs .breadcrumbs li:not(:last-child)::after {
    border-right: 1px solid #000;
    border-top: 1px solid #000;
    content: "";
    height: 6px;
    width: 6px;
    position: absolute;
    right: 0;
    top: 50%;
    -webkit-transform: rotate(45deg) translateY(-50%);
    -ms-transform: rotate(45deg) translateY(-50%);
    transform: rotate(45deg) translateY(-50%);
}
@media screen and (max-width: 767px) {
    .layout-breadcrumbs {
        padding: 12px 10px 10px;
    }
    .layout-breadcrumbs .breadcrumbs {
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    }
    .layout-breadcrumbs .breadcrumbs li:not(:last-child)::after {
        height: 4px;
        width: 4px;
        top: -webkit-calc(50% - 1px);
        top: calc(50% - 1px);
    }
}
.pagetop {
    display: none;
    pointer-events: none;
    width: 100%;
    position: fixed;
    bottom: 100px;
    right: 30px;
    z-index: 1000;
}
@media screen and (max-width: 767px) {
    .pagetop {
        bottom: 70px;
        right: 15px;
    }
}
.pagetop a {
    background: #ffd802;
    border: 2px solid #ffd802;
    border-radius: 50%;
    display: block;
    height: 50px;
    margin-left: auto;
    overflow: hidden;
    pointer-events: auto;
    text-align: left;
    text-indent: -200%;
    width: 50px;
    position: relative;
    -webkit-transition: all 0.5s;
    transition: all 0.5s;
    z-index: 0;
}
.pagetop a::before {
    border-right: 2px solid #000;
    border-top: 2px solid #000;
    content: "";
    height: 11px;
    width: 11px;
    position: absolute;
    left: 17px;
    top: 19px;
    -webkit-transform: rotate(-45deg);
    -ms-transform: rotate(-45deg);
    transform: rotate(-45deg);
}
@media screen and (max-width: 767px) {
    .pagetop a {
        height: 40px;
        width: 40px;
    }
    .pagetop a::before {
        height: 8px;
        width: 8px;
        left: 13px;
        top: 15px;
    }
}
@media screen and (min-width: 768px) {
    .pagetop a:hover {
        background-image: url(../img/icon-arrow-top-blue_img.svg);
        background-color: #fff;
    }
}
.footer-link {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    margin: 2em 0;
}
.footer-link > li {
    margin-right: 2em;
}
.footer-link > li:last-child {
    margin-right: 0;
}
.footer-link > li > a {
    color: #000;
}
@media screen and (min-width: 768px) {
    .footer-link > li > a:hover {
        text-decoration: underline;
    }
}
.layout-footer {
    background-color: #ffd802;
    padding: 20px 0;
    text-align: center;
}
.layout-footer .copyright {
    font-size: 1.2rem;
    font-weight: 500;
    letter-spacing: 0.08em;
    line-height: 1.1;
}
body.no-banner .layout-container {
    padding: 0;
}
body.no-banner #fixed-banner {
    display: none;
}
.mc_lp {
    background-color: #020617;
    background-image: linear-gradient(to right, rgba(255, 255, 255, 0.05) 1px, transparent 1px),
          linear-gradient(to bottom, rgba(255, 255, 255, 0.05) 1px, transparent 1px);
    background-size: 40px 40px;
}