@charset "UTF-8";@font-face {
    font-family: "Noto Sans JP";
    font-weight: 400;
    font-style: normal;
    font-display: swap;
    src: url("../fonts/SnellRoundhandLTStd-Scr.woff2") format("woff2"),url("../fonts/SnellRoundhandLTStd-Scr.woff") format("woff")
}

:root {
    --headerHeight: 64px;
    --fixedButtonHeight: 55px
}

@media screen and (min-width: 64em) {
    :root {
        --fixedButtonHeight:0px
    }
}

@media screen and (min-width: 64em) {
    :root {
        --headerHeight:131px
    }
}

@media screen and (min-width: 80em) {
    :root {
        --headerHeight:135px
    }
}

:root .page-template-template-lp {
    --headerHeight: 56px
}

@media screen and (min-width: 48em) {
    :root .page-template-template-lp {
        --headerHeight:63px
    }
}

@media screen and (min-width: 108em) {
    :root .page-template-template-lp {
        --headerHeight:0
    }
}

html {
    overflow-y: scroll;
    font-size: 62.5%;
    line-height: 1;
    -webkit-text-size-adjust: 100%
}

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

article,aside,details,figcaption,figure,footer,header,main,menu,nav,section {
    display: block
}

a {
    background: transparent;
    color: currentColor;
    -webkit-text-decoration-skip: objects
}

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

img {
    border-style: none
}

li {
    list-style: none
}

summary {
    display: list-item
}

hr {
    overflow: visible;
    height: 0
}

[hidden],template {
    display: none
}

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

table {
    border-spacing: 0;
    border-collapse: collapse
}

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

b,strong {
    font-weight: bolder
}

dfn {
    font-style: italic
}

mark {
    background-color: #ff0;
    color: #333
}

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

sub {
    bottom: -0.25em
}

sup {
    top: -0.5em
}

button,input,select,textarea {
    border-radius: 0;
    border: none;
    background: none;
    color: inherit;
    font-family: inherit;
    font-size: inherit;
    outline: none;
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none
}

textarea {
    overflow: auto
}

button {
    overflow: visible
}

[role=button],[type=button],[type=reset],[type=submit],button {
    cursor: pointer;
    -webkit-appearance: none
}

[disabled] {
    cursor: default
}

[type=number] {
    width: auto
}

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

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

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

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

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

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

input::-ms-clear {
    visibility: hidden
}

input::-ms-reveal {
    visibility: hidden
}

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

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

progress {
    vertical-align: baseline
}

svg:not(:root) {
    overflow: hidden
}

audio,canvas,progress,video {
    display: inline-block
}

@-webkit-keyframes fadeOutPageCover {
    0% {
        opacity: 1
    }

    to {
        opacity: 0
    }
}

@keyframes fadeOutPageCover {
    0% {
        opacity: 1
    }

    to {
        opacity: 0
    }
}

@-webkit-keyframes fadeIn {
    0% {
        opacity: 0
    }

    to {
        opacity: 1
    }
}

@keyframes fadeIn {
    0% {
        opacity: 0
    }

    to {
        opacity: 1
    }
}

@-webkit-keyframes fadeInUp {
    0% {
        opacity: 0;
        -webkit-transform: translate3d(0,10px,0);
        transform: translate3d(0,10px,0)
    }

    to {
        opacity: 1;
        -webkit-transform: translate3d(0,0,0);
        transform: translate3d(0,0,0)
    }
}

@keyframes fadeInUp {
    0% {
        opacity: 0;
        -webkit-transform: translate3d(0,10px,0);
        transform: translate3d(0,10px,0)
    }

    to {
        opacity: 1;
        -webkit-transform: translate3d(0,0,0);
        transform: translate3d(0,0,0)
    }
}

picture {
    display: block
}

img,svg {
    width: 100%;
    max-width: 100%;
    height: auto;
    line-height: 1;
    vertical-align: top;
    -webkit-transition: color 0.5s ease,opacity 0.5s ease,background 0.5s ease,border 0.5s ease;
    transition: color 0.5s ease,opacity 0.5s ease,background 0.5s ease,border 0.5s ease
}

.el_ofi img {
    width: 100%;
    height: 100%;
    font-family: "object-fit: cover;";
    -o-object-fit: cover;
    object-fit: cover
}

.el_ofi .el_ofi__centerTop img {
    font-family: "object-fit: cover;object-position: center top;";
    -o-object-position: center top;
    object-position: center top
}

.el_mediaQueryImage_inner {
    background: no-repeat;
    background-size: cover
}

.el_logo_link {
    display: block
}

.el_logo_link:hover {
    opacity: 0.7
}

.el_logo_link:focus-visible {
    opacity: 0.7
}

:root .el_logo_link:focus,_:-ms-fullscreen {
    opacity: 0.7
}

.el_logo_logo {
    display: block
}

.el_postImage {
    overflow: hidden;
    position: relative
}

.el_postImage:before {
    display: block;
    content: "";
    width: 100%;
    padding-top: 52.5%
}

.el_postImage img {
    position: absolute;
    top: 0;
    left: 0
}

.el_postImage__works:before {
    padding-top: 60.28%
}

.el_postDate {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center
}

.el_postDate_icon {
    display: inline-block;
    width: 18px;
    margin-left: 3px
}

.el_postDate_date {
    display: inline-block;
    margin-left: 3px
}

.el_worksImage {
    background: #fff
}

.el_imageSkew {
    position: relative
}

.el_imageSkew:after,.el_imageSkew:before {
    position: absolute;
    top: 0;
    z-index: 2;
    width: 100%;
    height: 100%;
    background: url('data:image/svg+xml;utf-8,<svg xmlns="http://www.w3.org/2000/svg" width="115" height="410" viewBox="0 0 115 410"><path d="M0,0H115L0,410Z" fill="%23fff"/></svg>') no-repeat left center;
    background-size: auto 100%;
    pointer-events: none
}

@media screen and (min-width: 48em) {
    .el_imageSkew:after,.el_imageSkew:before {
        content:""
    }
}

.el_imageSkew:before {
    left: -1px
}

.el_imageSkew:after {
    right: -1px;
    -webkit-transform: scale(-1,-1);
    transform: scale(-1,-1)
}

.el_fadeInUp {
    -webkit-animation: fadeInUp 0.7s cubic-bezier(0.75,0,0.45,1) 0.1s both;
    animation: fadeInUp 0.7s cubic-bezier(0.75,0,0.45,1) 0.1s both
}

@-webkit-keyframes frameInImg_bg {
    0% {
        -webkit-transform: translate3d(-100%,0,0);
        transform: translate3d(-100%,0,0)
    }

    to {
        -webkit-transform: translate3d(101%,0,0);
        transform: translate3d(101%,0,0)
    }
}

@keyframes frameInImg_bg {
    0% {
        -webkit-transform: translate3d(-100%,0,0);
        transform: translate3d(-100%,0,0)
    }

    to {
        -webkit-transform: translate3d(101%,0,0);
        transform: translate3d(101%,0,0)
    }
}

@-webkit-keyframes frameInImg_img {
    0% {
        opacity: 0
    }

    50% {
        opacity: 0
    }

    75% {
        opacity: 1
    }

    to {
        opacity: 1
    }
}

@keyframes frameInImg_img {
    0% {
        opacity: 0
    }

    50% {
        opacity: 0
    }

    75% {
        opacity: 1
    }

    to {
        opacity: 1
    }
}

.js_animationImage {
    overflow: hidden;
    position: relative
}

.js_animationImage:not(.js_enable) .js_animationImage_shape {
    display: none
}

.js_animationImage:not(.js_animationImage__hasShape):before {
    position: absolute;
    top: 0;
    left: 0;
    z-index: 1;
    content: "";
    width: 100%;
    height: 100%;
    background: #ff9955
}

.js_animationImage_shape {
    position: absolute;
    top: 0;
    left: 0;
    z-index: 1;
    width: 100%;
    height: 100%;
    background: #ff9955
}

.js_animationImage.is_active .js_animationImage_shape {
    -webkit-animation: frameInImg_bg cubic-bezier(0.645,0.045,0.355,1) 1.2s;
    animation: frameInImg_bg cubic-bezier(0.645,0.045,0.355,1) 1.2s;
    -webkit-animation-fill-mode: both;
    animation-fill-mode: both
}

.js_animationImage.is_active:not(.js_animationImage__hasShape):before {
    -webkit-animation: frameInImg_bg cubic-bezier(0.645,0.045,0.355,1) 1.2s;
    animation: frameInImg_bg cubic-bezier(0.645,0.045,0.355,1) 1.2s;
    -webkit-animation-fill-mode: both;
    animation-fill-mode: both
}

.is_active .js_animationImage_image {
    -webkit-animation: frameInImg_img cubic-bezier(0.645,0.045,0.355,1) 1.2s;
    animation: frameInImg_img cubic-bezier(0.645,0.045,0.355,1) 1.2s;
    -webkit-animation-fill-mode: both;
    animation-fill-mode: both
}

.el_textNote {
    padding-left: 1em
}

.el_textNote:before {
    content: "※";
    margin-left: -1em
}

.el_textNote__small {
    font-size: 1.5rem
}

.el_textEmphasis {
    font-weight: 500
}

.el_textUnderLine_inner {
    padding-bottom: 5px;
    border-bottom: 1px dashed #333
}

.el_textHighlight {
    padding: 2px 8px;
    background: -webkit-gradient(linear,left top,left bottom,color-stop(0,transparent),color-stop(50%,transparent),color-stop(50%,#f8f891),to(#f8f891));
    background: linear-gradient(180deg,transparent 0,transparent 50%,#f8f891 50%,#f8f891 100%);
    font-weight: 500;
    -webkit-box-decoration-break: clone;
    box-decoration-break: clone
}

a {
    text-decoration: none;
    -webkit-transition: color 0.5s ease,opacity 0.5s ease,background 0.5s ease,border 0.5s ease;
    transition: color 0.5s ease,opacity 0.5s ease,background 0.5s ease,border 0.5s ease
}

@media screen and (min-width: 48em) {
    a[href*="tel:"] {
        cursor:default;
        pointer-events: none
    }
}

.el_textLink {
    text-decoration: underline
}

.el_textLink:hover {
    color: #55798a
}

.el_textLink:focus-visible {
    color: #55798a
}

:root .el_textLink:focus,_:-ms-fullscreen {
    color: #55798a
}

.hp_screenReaderText {
    overflow: hidden;
    clip: rect(1px,1px,1px,1px);
    position: absolute;
    width: 1px;
    height: 1px
}

.el_linkHasIcon {
    display: inline-block;
    position: relative;
    padding-left: 20px;
    color: #ff9955
}

.el_linkHasIcon:hover {
    text-decoration: underline
}

.el_linkHasIcon:focus-visible {
    text-decoration: underline
}

:root .el_linkHasIcon:focus,_:-ms-fullscreen {
    text-decoration: underline
}

.el_linkHasIcon:before {
    position: absolute;
    top: 0.9375em;
    left: 0;
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
    content: "";
    width: 12px;
    height: 12px;
    background: url(../img/common/icon_blank.svg) no-repeat
}

@media screen and (min-width: 23.4375em) {
    .sps_only {
        display:none
    }
}

.sps_none {
    display: none
}

@media screen and (min-width: 23.4375em) {
    .sps_none {
        display:block
    }
}

.sp_none {
    display: none
}

@media screen and (min-width: 48em) {
    .sp_none {
        display:inline-block
    }
}

@media screen and (min-width: 48em) {
    .tab_none {
        display:none
    }
}

.tab_only {
    display: none
}

@media screen and (min-width: 48em) {
    .tab_only {
        display:inline-block
    }
}

@media screen and (min-width: 64em) {
    .tab_only {
        display:none
    }
}

@media screen and (min-width: 48em) {
    .tab_only_none {
        display:none
    }
}

@media screen and (min-width: 64em) {
    .tab_only_none {
        display:inline-block
    }
}

@media screen and (min-width: 64em) {
    .pc_none {
        display:none
    }
}

@media screen and (min-width: 64em) {
    .pc_none__pcm {
        display:block
    }
}

@media screen and (min-width: 80em) {
    .pc_none__pcm {
        display:none
    }
}

.pc_only {
    display: none
}

@media screen and (min-width: 64em) {
    .pc_only {
        display:inline-block
    }
}

@media screen and (min-width: 64em) {
    .pc_only__pcm {
        display:none
    }
}

@media screen and (min-width: 80em) {
    .pc_only__pcm {
        display:inline-block
    }
}

@media screen and (min-width: 64em) {
    .pc_only__pcl {
        display:none
    }
}

@media screen and (min-width: 90em) {
    .pc_only__pcl {
        display:inline-block
    }
}

.pcs_only {
    display: none
}

@media screen and (min-width: 64em) {
    .pcs_only {
        display:inline-block
    }
}

@media screen and (min-width: 80em) {
    .pcs_only {
        display:none
    }
}

@media screen and (min-width: 64em) {
    .pcs_only_none {
        display:none
    }
}

@media screen and (min-width: 80em) {
    .pcs_only_none {
        display:inline-block
    }
}

@media screen and (min-width: 80em) {
    .pcm_none {
        display:none
    }
}

.pcm_only {
    display: none
}

@media screen and (min-width: 80em) {
    .pcm_only {
        display:inline-block
    }
}

@media screen and (min-width: 90em) {
    .pcm_only {
        display:none
    }
}

@media screen and (min-width: 90em) {
    .pcl_none {
        display:none
    }
}

.pcl_only {
    display: none
}

@media screen and (min-width: 90em) {
    .pcl_only {
        display:inline-block
    }
}

@media screen and (min-width: 100em) {
    .pcl_only {
        display:none
    }
}

@media screen and (min-width: 64em) {
    .ham_only {
        display:none
    }
}

.firefox_pc_only {
    display: none
}

@-moz-document url-prefix() {
    @media screen and (min-width: 48em) {
        .firefox_pc_only {
            display:block
        }
    }
}

.js_IEalert {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    position: fixed;
    bottom: 5%;
    left: 5%;
    z-index: 1000;
    width: 90vw;
    height: 90vh;
    padding: 3em 0;
    background: rgb(196,52,52);
    background: rgba(196,52,52,0.95);
    text-align: center;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center
}

.js_IEalert a,.js_IEalert p,.js_IEalert span {
    color: #fff
}

.js_IEalert span {
    display: block;
    font-size: 3rem
}

.js_IEalert p {
    font-size: 2rem
}

.js_IEalert a {
    display: inline-block;
    margin-top: 20px;
    padding: 8px 80px;
    border: solid 1px #fff;
    font-size: 16px
}

.js_IEalert a:hover {
    background: rgba(255,255,255,0.1)
}

.bl_worksPickup_link {
    display: block;
    overflow: hidden;
    position: relative
}

.bl_worksPickup_link:hover .bl_worksPickup_content {
    -webkit-transform: translate3d(0,0,0);
    transform: translate3d(0,0,0)
}

.bl_worksPickup_link:focus-visible .bl_worksPickup_content {
    -webkit-transform: translate3d(0,0,0);
    transform: translate3d(0,0,0)
}

:root .bl_worksPickup_link:focus .bl_worksPickup_content,_:-ms-fullscreen .bl_worksPickup_content {
    transform: translate3d(0,0,0)
}

.bl_worksPickup_content {
    overflow: auto;
    position: absolute;
    bottom: 0;
    left: 0;
    -webkit-transform: translate3d(0,100%,0);
    transform: translate3d(0,100%,0);
    z-index: 2;
    width: 100%;
    max-height: 100%;
    padding: 6px 23px 8px;
    background: rgba(51,51,51,0.9);
    color: #fff;
    -webkit-transition: -webkit-transform 0.5s ease;
    transition: -webkit-transform 0.5s ease;
    transition: transform 0.5s ease;
    transition: transform 0.5s ease,-webkit-transform 0.5s ease
}

@media screen and (min-width: 48em) {
    .bl_worksPickup__wide .bl_worksPickup_content {
        padding:7px 32px 8px
    }
}

.bl_worksPickup_image {
    padding: 8px;
    border: 1px solid #e4e1e1
}

.bl_worksPickup_title {
    font-size: inherit;
    font-weight: inherit
}

.bl_worksFeature_inner {
    max-width: 1000px;
    margin: 0 auto
}

.bl_worksFeature_body {
    margin-top: 50px
}

.bl_worksFeature_label {
    display: inline-block;
    padding: 2px 16px;
    background: #ff9955;
    color: #fff;
    font-size: 1.6rem;
    font-weight: 500;
    line-height: 1.5
}

.bl_worksFeature_title {
    display: block;
    margin-top: 4px;
    color: #ff9955;
    font-size: 1.8rem;
    font-weight: 500
}

@media screen and (min-width: 48em) {
    .bl_worksFeature_title {
        display:inline-block;
        margin: 0 0 0 25px;
        font-size: 2rem
    }
}

.bl_worksFeature_point {
    margin-top: 20px;
    font-size: 2rem;
    font-weight: 500
}

@media screen and (min-width: 48em) {
    .bl_worksFeature_point {
        font-size:2.2rem
    }
}

@media screen and (min-width: 64em) {
    .bl_worksFeature_point {
        font-size:2.6rem
    }
}

.bl_worksFeature_content {
    margin-top: 20px
}

.bl_worksFeature_text:not(:first-child) {
    margin-top: 16px
}

.bl_worksFeature_information {
    margin-top: 30px
}

.bl_worksFeature_footer {
    margin-top: 50px;
    text-align: center
}

.bl_inPageLink {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap
}

.bl_inPageLink_item {
    width: 50%;
    border-right: 1px solid #e4e1e1
}

@media screen and (min-width: 48em) {
    .bl_inPageLink_item {
        width:33.3333333333%
    }
}

.bl_inPageLink_item:nth-child(odd) {
    border-left: 1px solid #e4e1e1
}

@media screen and (min-width: 48em) {
    .bl_inPageLink_item:nth-child(odd) {
        border-left:none
    }
}

.bl_inPageLink_item:nth-child(2)~.bl_inPageLink_item {
    margin-top: 20px
}

@media screen and (min-width: 48em) {
    .bl_inPageLink_item:nth-child(2)~.bl_inPageLink_item {
        margin-top:0
    }
}

@media screen and (min-width: 48em) {
    .bl_inPageLink_item:nth-child(3n+1) {
        border-left:1px solid #e4e1e1
    }
}

@media screen and (min-width: 48em) {
    .bl_inPageLink_item:nth-child(3)~.bl_inPageLink_item {
        margin-top:45px
    }
}

.bl_inPageLink_link {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    height: 100%;
    padding: 4px 8px;
    font-size: 1.4rem;
    line-height: 1.5;
    text-align: center;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center
}

.bl_inPageLink_link:hover {
    background: #fff4ed
}

.bl_inPageLink_link:focus-visible {
    background: #fff4ed
}

:root .bl_inPageLink_link:focus,_:-ms-fullscreen {
    background: #fff4ed
}

@media screen and (min-width: 48em) {
    .bl_inPageLink_link {
        font-size:1.6rem
    }
}

@media screen and (min-width: 64em) {
    .bl_inPageLink_link {
        font-size:1.7rem
    }
}

.bl_inPageLink_link:after {
    display: inline-block;
    content: "";
    width: 0;
    height: 0;
    margin-left: 10px;
    border-top: 7px solid #ff9955;
    border-right: 5px solid transparent;
    border-left: 5px solid transparent;
    vertical-align: 0.125em
}

@media screen and (min-width: 48em) {
    .bl_inPageLink_link:after {
        margin-left:15px
    }
}

.bl_timeline {
    position: relative
}

.bl_timeline:before {
    position: absolute;
    left: 4px;
    content: "";
    width: 1px;
    height: 100%;
    background: #ff9955
}

@media screen and (min-width: 48em) {
    .bl_timeline:before {
        left:calc(38.3% - 14px/2)
    }
}

.bl_timeline_item {
    position: relative;
    z-index: 2;
    padding: 24px 0 24px 24px;
    border-bottom: 1px dashed #e4e1e1
}

@media screen and (min-width: 48em) {
    .bl_timeline_item {
        display:-webkit-box;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-pack: center;
        -ms-flex-pack: center;
        justify-content: center;
        padding: 32px 0;
        -webkit-box-align: start;
        -ms-flex-align: start;
        align-items: flex-start
    }
}

@media screen and (min-width: 64em) {
    .bl_timeline_item {
        padding:48px 0
    }
}

.bl_timeline_item:last-child:after {
    position: absolute;
    bottom: 0;
    left: 0;
    content: "";
    width: 8px;
    height: calc(100% - 2.88rem - 8px);
    background: #fff
}

@media screen and (min-width: 48em) {
    .bl_timeline_item:last-child:after {
        left:38.3%;
        -webkit-transform: translateX(-100%);
        transform: translateX(-100%);
        width: 14px;
        height: calc(100% - 3.24rem - 14px)
    }
}

@media screen and (min-width: 64em) {
    .bl_timeline_item:last-child:after {
        height:calc(100% - 62px)
    }
}

.bl_timeline_time {
    position: relative;
    z-index: 2;
    color: #ff9955;
    font-family: "Noto Sans JP",cursive;
    font-size: 2.4rem;
    font-weight: 400;
    line-height: 1.2;
    letter-spacing: 0.03em
}

@media screen and (min-width: 48em) {
    .bl_timeline_time {
        width:38.3%;
        padding: 0 58px 0 0;
        font-size: 2.7rem;
        text-align: right
    }
}

@media screen and (min-width: 64em) {
    .bl_timeline_time {
        font-size:3rem
    }
}

.bl_timeline_time:before {
    position: absolute;
    top: 0.6em;
    left: -24px;
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
    content: "";
    width: 14px;
    width: 8px;
    height: 14px;
    height: 8px;
    border-radius: 50%;
    background: currentColor
}

@media screen and (min-width: 48em) {
    .bl_timeline_time:before {
        right:0;
        left: auto;
        width: 14px;
        height: 14px
    }
}

.bl_timeline_item:first-child .bl_timeline_time:after {
    position: absolute;
    top: -24px;
    left: -24px;
    z-index: -1;
    content: "";
    width: 8px;
    height: calc(0.6em + 28px);
    background: #fff
}

@media screen and (min-width: 48em) {
    .bl_timeline_item:first-child .bl_timeline_time:after {
        top:-48px;
        right: 0;
        left: auto;
        width: 14px;
        height: calc(1.2em/2 + 55px)
    }
}

@media screen and (min-width: 48em) {
    .bl_timeline_content {
        width:51.33%;
        margin-left: 10.37%
    }
}

.el_map {
    position: relative;
    min-height: 250px
}

.el_map:before {
    display: block;
    content: "";
    width: 100%;
    padding-top: 34.58%
}

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

.bl_banner {
    position: relative;
    padding: 31px 6% 38px;
    background: #fff4ed
}

@media screen and (min-width: 48em) {
    .bl_banner {
        padding:40px 6.66%
    }
}

@media screen and (min-width: 64em) {
    .bl_banner {
        padding:60px 6.66%
    }
}

@media screen and (min-width: 48em) {
    .bl_banner_content {
        width:70%
    }
}

.bl_banner_title {
    width: 100%;
    padding: 14px 0;
    border-top: 1px solid #333;
    border-bottom: 1px solid #333;
    font-size: 2.5rem;
    font-weight: 500;
    line-height: 1.5;
    text-align: center;
    letter-spacing: 0.03em
}

@media screen and (min-width: 64em) {
    .bl_banner_title {
        padding:26px 0;
        font-size: 3rem
    }
}

.bl_banner_title__hasLabel {
    padding: 0 0 20px;
    border-top: none
}

@media screen and (min-width: 64em) {
    .bl_banner_title__hasLabel {
        padding:0 0 40px
    }
}

.bl_banner_title__color {
    color: #ff9955
}

.bl_banner_label {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    margin-bottom: 15px;
    color: #ff9955;
    font-size: 1.8rem;
    font-weight: 500;
    letter-spacing: 0;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center
}

@media screen and (min-width: 64em) {
    .bl_banner_label {
        margin-bottom:28px;
        font-size: 2.3rem
    }
}

.bl_banner_label:after,.bl_banner_label:before {
    display: block;
    content: "";
    width: 100%;
    height: 1px;
    background: #333
}

.bl_banner_inner {
    display: inline-block;
    -ms-flex-negative: 0;
    flex-shrink: 0;
    max-width: 95%;
    padding: 0 13px
}

.bl_banner_text {
    margin-top: 18px
}

@media screen and (min-width: 48em) {
    .bl_banner_text {
        margin-top:40px;
        text-align: center
    }
}

.bl_banner_button {
    margin-top: 32px;
    text-align: center
}

.bl_banner_image {
    display: none;
    width: 34%;
    margin: 18px 0 0 1.8%
}

@media screen and (min-width: 48em) {
    .bl_banner_image {
        display:block;
        position: absolute;
        right: 5.25%;
        bottom: 0;
        width: 23.58%;
        margin: 0
    }
}

.bl_banner_content__mobileNoImage .bl_banner_image {
    display: none
}

@media screen and (min-width: 48em) {
    .bl_banner_content__mobileNoImage .bl_banner_image {
        display:block
    }
}

.bl_example {
    position: relative
}

@media screen and (min-width: 64em) {
    .bl_example:after,.bl_example:before {
        position:absolute;
        top: 0;
        z-index: -1;
        content: "";
        width: 50%;
        height: 100%
    }
}

.bl_example:before {
    left: 0;
    background: #f4e3d7
}

.bl_example:after {
    right: 0;
    background: #fff4ed
}

@media screen and (min-width: 48em) {
    .bl_example_inner {
        display:-webkit-box;
        display: -ms-flexbox;
        display: flex;
        -ms-flex-wrap: wrap;
        flex-wrap: wrap
    }
}

.bl_example_item {
    padding: 23px 6% 32px;
    background: #f4e3d7
}

@media screen and (min-width: 48em) {
    .bl_example_item {
        width:50%;
        padding: 23px 3.5% 32px
    }
}

@media screen and (min-width: 64em) {
    .bl_example_item {
        width:25%
    }
}

.bl_example_item:nth-child(2n) {
    background: #fff4ed
}

@media screen and (min-width: 48em) {
    .bl_example_item:nth-child(3) {
        background:#fff4ed
    }
}

@media screen and (min-width: 64em) {
    .bl_example_item:nth-child(3) {
        background:#f4e3d7
    }
}

@media screen and (min-width: 48em) {
    .bl_example_item:nth-child(4) {
        background:#f4e3d7
    }
}

@media screen and (min-width: 64em) {
    .bl_example_item:nth-child(4) {
        background:#fff4ed
    }
}

@media screen and (min-width: 64em) {
    .bl_example_item:first-child {
        padding-left:0
    }
}

@media screen and (min-width: 64em) {
    .bl_example_item:last-child {
        padding-right:0
    }
}

.bl_example_icon {
    display: block;
    width: 71px;
    margin: 0 auto
}

.bl_example_title {
    margin-top: 10px;
    font-size: 1.8rem;
    font-weight: 500;
    line-height: 1.5;
    text-align: center
}

@media screen and (min-width: 48em) {
    .bl_example_title {
        font-size:2rem
    }
}

@media screen and (min-width: 64em) {
    .bl_example_title {
        font-size:2.3rem
    }
}

.bl_example_text {
    margin-top: 19px
}

.js_parallaxImage {
    overflow: hidden;
    position: relative
}

.js_parallaxImage_image {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 110vh;
    height: 110lvh;
    height: min(200%,110lvh);
    will-change: transform
}

.js_parallaxImage__fixed .js_parallaxImage_image {
    height: 100vh;
    height: 100lvh
}

.is_fixed .js_parallaxImage_image {
    position: fixed;
    top: auto;
    bottom: 0
}

.bl_pageMainVisual_inner {
    position: relative;
    margin: 0 6px;
    padding-top: 30px
}

@media screen and (min-width: 48em) {
    .bl_pageMainVisual_inner {
        margin:0 0 0 14px;
        padding: 4.6% 0 4.3%
    }
}

@media screen and (min-width: 48em) {
    .bl_pageMainVisual_body {
        width:64%
    }
}

@media screen and (min-width: 64em) {
    .bl_pageMainVisual_body {
        width:68%
    }
}

@media screen and (min-width: 80em) {
    .bl_pageMainVisual_body {
        width:61%
    }
}

@media screen and (min-width: 90em) {
    .bl_pageMainVisual_body {
        width:57%
    }
}

@media screen and (min-width: 48em) {
    .bl_pageMainVisual__small .bl_pageMainVisual_body {
        width:75%
    }
}

@media screen and (min-width: 80em) {
    .bl_pageMainVisual__small .bl_pageMainVisual_body {
        width:68%
    }
}

@media screen and (min-width: 90em) {
    .bl_pageMainVisual__small .bl_pageMainVisual_body {
        width:64%
    }
}

.bl_pageMainVisual_head {
    margin: 0 -6px;
    padding-right: 10px
}

@media screen and (min-width: 48em) {
    .bl_pageMainVisual_head {
        margin:0 0 0 -14px;
        padding-right: 20px
    }
}

.bl_pageMainVisual_title {
    display: block;
    position: relative;
    padding: 2px 12px 2px 16px;
    background: #ff9955;
    color: #fff;
    font-family: "Shippori Mincho B1",serif;
    font-size: 2.3rem;
    font-weight: 500;
    line-height: 1.5;
    text-align: center
}

@media screen and (min-width: 48em) {
    .bl_pageMainVisual_title {
        font-size:2.8rem
    }
}

@media screen and (min-width: 64em) {
    .bl_pageMainVisual_title {
        padding-top:6px;
        padding-bottom: 6px;
        font-size: 3.2rem
    }
}

@media screen and (min-width: 80em) {
    .bl_pageMainVisual_title {
        font-size:4rem
    }
}

.bl_pageMainVisual__small .bl_pageMainVisual_title {
    letter-spacing: 0.03em
}

@media screen and (min-width: 64em) {
    .bl_pageMainVisual__small .bl_pageMainVisual_title {
        display:inline-block;
        padding-right: 24px;
        padding-left: 30px;
        font-size: 2.8rem
    }
}

@media screen and (min-width: 80em) {
    .bl_pageMainVisual__small .bl_pageMainVisual_title {
        font-size:3rem
    }
}

.bl_pageMainVisual_title:after,.bl_pageMainVisual_title:before {
    position: absolute;
    content: ""
}

.bl_pageMainVisual_title:before {
    top: 100%;
    left: 0;
    border: 3px solid transparent;
    border-top-color: #ff9955;
    border-right-color: #ff9955
}

@media screen and (min-width: 48em) {
    .bl_pageMainVisual_title:before {
        border-width:7px
    }
}

.bl_pageMainVisual_title:after {
    top: 0;
    left: 100%;
    width: 10px;
    height: 100%;
    background: url(../img/common/shape_ribbon.svg) no-repeat;
    background-size: 100% 100%
}

@media screen and (min-width: 64em) {
    .bl_pageMainVisual_title:after {
        width:20px
    }
}

.bl_pageMainVisual_small {
    font-size: 1.6rem
}

@media screen and (min-width: 48em) {
    .bl_pageMainVisual_small {
        font-size:0.75em
    }
}

.bl_pageMainVisual_english {
    font-size: 2.5rem
}

@media screen and (min-width: 48em) {
    .bl_pageMainVisual_english {
        font-size:0.95em
    }
}

.bl_pageMainVisual_content {
    margin-top: 37px;
    padding: 0 4%
}

@media screen and (min-width: 48em) {
    .bl_pageMainVisual_content {
        padding:0 0 0 4%
    }
}

@media screen and (min-width: 80em) {
    .bl_pageMainVisual_content {
        margin-top:45px;
        padding-left: 7.5%
    }
}

.bl_pageMainVisual_keyword {
    color: #ff9955
}

@media screen and (min-width: 64em) {
    .bl_pageMainVisual_keyword {
        font-size:1.25em
    }
}

.bl_pageMainVisual_image {
    margin-top: 30px
}

@media screen and (min-width: 48em) {
    .bl_pageMainVisual_image {
        position:absolute;
        top: 0;
        right: 0;
        z-index: -1;
        width: 100%;
        height: 100%;
        margin: 0
    }
}

.bl_pageMainVisual_image img {
    -o-object-position: 60% 0;
    object-position: 60% 0
}

.bl_pageMainVisual_background {
    position: absolute;
    top: 0;
    left: 0;
    z-index: -2;
    width: 100%;
    height: 100%
}

@media screen and (min-width: 48em) {
    .bl_columnTitleIcon {
        display:-webkit-box;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-pack: center;
        -ms-flex-pack: center;
        justify-content: center;
        -webkit-box-align: center;
        -ms-flex-align: center;
        align-items: center
    }
}

.bl_columnTitleIcon_head {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-negative: 0;
    flex-shrink: 0;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center
}

@media screen and (min-width: 48em) {
    .bl_columnTitleIcon_head {
        max-width:50%
    }
}

.bl_columnTitleIcon_icon {
    -ms-flex-negative: 0;
    flex-shrink: 0;
    width: 16%;
    max-width: 67px
}

@media screen and (min-width: 48em) {
    .bl_columnTitleIcon_icon {
        width:20%
    }
}

@media screen and (min-width: 64em) {
    .bl_columnTitleIcon_icon {
        max-width:79px
    }
}

.bl_columnTitleIcon_title {
    margin-left: 10px;
    font-size: 1.6rem;
    font-weight: 500
}

@media screen and (min-width: 48em) {
    .bl_columnTitleIcon_title {
        margin-left:15px;
        font-size: 1.8rem;
        line-height: 1.7
    }
}

@media screen and (min-width: 64em) {
    .bl_columnTitleIcon_title {
        font-size:2rem
    }
}

@media screen and (min-width: 80em) {
    .bl_columnTitleIcon_title {
        margin-left:20px;
        font-size: 2.3rem
    }
}

.bl_columnTitleIcon_keyword {
    color: #ff9955
}

@media screen and (min-width: 48em) {
    .bl_columnTitleIcon_keyword {
        font-size:2rem;
        line-height: 1.6
    }
}

@media screen and (min-width: 64em) {
    .bl_columnTitleIcon_keyword {
        font-size:2.2rem
    }
}

@media screen and (min-width: 80em) {
    .bl_columnTitleIcon_keyword {
        font-size:2.5rem
    }
}

.bl_columnTitleIcon_content {
    margin-top: 15px;
    padding-top: 15px;
    border-top: 1px dashed #333;
    font-size: 1.5rem
}

@media screen and (min-width: 48em) {
    .bl_columnTitleIcon_content {
        margin-top:0;
        margin-left: 4.16%;
        padding-top: 0;
        border-top: none;
        font-size: 1.6rem
    }
}

@media screen and (min-width: 64em) {
    .bl_columnTitleIcon_content {
        font-size:1.8rem
    }
}

.bl_imageTitleCard {
    background: #fff4ed
}

.bl_imageTitleCard_head {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    position: relative;
    z-index: 2;
    min-height: 50vw;
    padding: 15px 5%;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center
}

@media screen and (min-width: 48em) {
    .bl_imageTitleCard_head {
        min-height:150px
    }
}

@media screen and (min-width: 64em) {
    .bl_imageTitleCard_head {
        min-height:193px
    }
}

.bl_imageTitleCard_icon {
    display: block;
    width: 24.4%;
    max-width: 93px;
    margin: 0 auto
}

.bl_imageTitleCard_title {
    margin-top: 5px;
    color: #fff;
    font-size: 1.8rem;
    font-weight: 500;
    line-height: 1.6;
    text-align: center;
    text-shadow: 0 0 20px rgba(0,0,0,0.8)
}

@media screen and (min-width: 64em) {
    .bl_imageTitleCard_title {
        font-size:2rem
    }
}

.bl_imageTitleCard_background {
    position: absolute;
    top: 0;
    left: 0;
    z-index: -1;
    width: 100%;
    height: 100%
}

.bl_imageTitleCard_content {
    padding: 5.2% 7.9%
}

.bl_tags {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    gap: 10px;
    font-size: 1.4rem
}

.bl_tags_inner {
    color: #5b5b5b
}

.bl_tags_inner:before {
    content: "#"
}

.bl_tags_inner[href] {
    text-decoration: underline
}

.bl_tags_inner[href]:hover {
    text-decoration: none
}

.bl_tags_inner[href]:focus-visible {
    text-decoration: none
}

:root .bl_tags_inner[href]:focus,_:-ms-fullscreen {
    text-decoration: none
}

@media screen and (min-width: 48em) {
    .el_infographic__hasCross {
        display:-webkit-box;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-pack: center;
        -ms-flex-pack: center;
        justify-content: center
    }
}

.el_infographic_item {
    padding: 40px 28px;
    background: #fff;
    font-size: 1.8rem;
    font-weight: 500
}

@media screen and (min-width: 48em) {
    .el_infographic_item {
        font-size:2rem
    }
}

@media screen and (min-width: 64em) {
    .el_infographic_item {
        font-size:2.3rem
    }
}

@media screen and (min-width: 48em) {
    :where(.el_infographic__hasCross) .el_infographic_item {
        width:calc((100% - 98px) / 2);
        max-width: 400px
    }
}

:where(.el_infographic__hasCross) .el_infographic_item:nth-child(n+2) {
    position: relative;
    margin-top: 98px
}

@media screen and (min-width: 48em) {
    :where(.el_infographic__hasCross) .el_infographic_item:nth-child(n+2) {
        margin:0 0 0 98px
    }
}

:where(.el_infographic__hasCross) .el_infographic_item:nth-child(n+2):before {
    position: absolute;
    top: -36px;
    left: 50%;
    -webkit-transform: translate(-50%,-100%);
    transform: translate(-50%,-100%);
    content: "";
    width: 26px;
    background: url(../img/common/icon_cross.svg) no-repeat;
    background-size: contain;
    aspect-ratio: 1
}

@media screen and (min-width: 48em) {
    :where(.el_infographic__hasCross) .el_infographic_item:nth-child(n+2):before {
        top:50%;
        left: -36px;
        -webkit-transform: translate(-100%,-50%);
        transform: translate(-100%,-50%)
    }
}

.el_infographic_title {
    color: #ff9955;
    font: inherit;
    text-align: center
}

.el_infographic_icon {
    display: block;
    width: 50%;
    max-width: 81px;
    margin: 8px auto 0
}

.el_infographic_content {
    margin-top: 8px
}

.el_infographic_point {
    color: #ff9955;
    line-height: 1.2;
    text-align: center
}

.el_infographic_emphasis {
    font-size: 2.78em;
    vertical-align: baseline
}

.el_infographic_text {
    margin-top: 16px;
    font-size: 1.6rem;
    font-weight: 400
}

@media screen and (min-width: 48em) {
    .el_infographic_text {
        margin-top:28px
    }
}

.el_price {
    font-size: 3.2rem;
    line-height: 1.1
}

@media screen and (min-width: 48em) {
    .el_price {
        font-size:4.8rem
    }
}

@media screen and (min-width: 64em) {
    .el_price {
        font-size:6.4rem
    }
}

.el_price_number {
    font-weight: 500
}

.el_price_unit {
    font-size: 1.4rem
}

@media screen and (min-width: 48em) {
    .el_price_unit {
        font-size:1.8rem
    }
}

@media screen and (min-width: 64em) {
    .el_price_unit {
        font-size:2.3rem
    }
}

.el_priceText {
    text-align: center
}

.el_priceText_title {
    font-weight: 500
}

@media screen and (min-width: 48em) {
    .el_priceText_title {
        font-size:1.8rem
    }
}

.el_priceText_price {
    color: #ff9955
}

.el_icons {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    gap: 16px
}

.el_icons_icon {
    width: 40px
}

@media screen and (min-width: 48em) {
    :where(.el_icons__large) .el_icons_icon {
        width:80px
    }
}

.el_labelEnglish {
    display: block;
    color: #d2dadf;
    font-family: "Noto Sans JP",cursive;
    font-size: 2.4rem;
    font-weight: 400;
    line-height: 1.2;
    letter-spacing: 0.03em
}

@media screen and (min-width: 48em) {
    .el_labelEnglish {
        font-size:2.8rem
    }
}

@media screen and (min-width: 64em) {
    .el_labelEnglish {
        font-size:3rem
    }
}

.el_labelEnglish_large {
    font-size: 7.2rem
}

@media screen and (min-width: 48em) {
    .el_labelEnglish_large {
        font-size:8rem
    }
}

@media screen and (min-width: 64em) {
    .el_labelEnglish_large {
        font-size:9rem
    }
}

.bl_pager {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center
}

.bl_pager__large {
    max-width: 600px;
    margin-right: auto;
    margin-left: auto
}

.bl_pager_item:not(:last-child) {
    margin-right: 8px
}

.bl_pager_item__previous:not(:last-child) {
    margin-right: 40px
}

.bl_pager_item__next:not(:first-child) {
    margin-left: 40px
}

.bl_pager__large .bl_pager_item__next:not(:first-child) {
    margin-left: 0
}

.bl_pager__large .bl_pager_item {
    width: 32%
}

.bl_pager__large .bl_pager_item:not(:last-child) {
    margin-right: 2%
}

.bl_pager_inner {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    min-width: 3.9rem;
    height: 4.2rem;
    padding: 0.4rem 8px;
    background: #fff4ed;
    font-size: 1.8rem;
    font-weight: 500;
    text-align: center;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center
}

.bl_pager_inner:hover {
    background: #fff4ed
}

.bl_pager_item__previous .bl_pager_inner:hover .bl_pager_icon {
    left: -10px
}

.bl_pager_item__next .bl_pager_inner:hover .bl_pager_icon {
    right: -10px
}

.bl_pager_inner:focus-visible {
    background: #fff4ed
}

.bl_pager_item__previous .bl_pager_inner:focus-visible .bl_pager_icon {
    left: -10px
}

.bl_pager_item__next .bl_pager_inner:focus-visible .bl_pager_icon {
    right: -10px
}

:root .bl_pager_inner:focus,_:-ms-fullscreen {
    background: #fff4ed
}

.bl_pager_item__previous :root .bl_pager_inner:focus .bl_pager_icon,.bl_pager_item__previous _:-ms-fullscreen .bl_pager_icon {
    left: -10px
}

.bl_pager_item__next :root .bl_pager_inner:focus .bl_pager_icon,.bl_pager_item__next _:-ms-fullscreen .bl_pager_icon {
    right: -10px
}

.bl_pager_item__next .bl_pager_inner,.bl_pager_item__previous .bl_pager_inner {
    padding: 0;
    background: transparent
}

.bl_pager__large .bl_pager_inner {
    width: 100%;
    height: auto;
    padding: 6px 8px
}

.bl_pager__large .bl_pager_item__next .bl_pager_inner,.bl_pager__large .bl_pager_item__previous .bl_pager_inner {
    background: #fff4ed
}

.bl_pager__large .bl_pager_item__next .bl_pager_inner:hover,.bl_pager__large .bl_pager_item__previous .bl_pager_inner:hover {
    background: #fff4ed
}

.bl_pager__large .bl_pager_item__next .bl_pager_inner:focus-visible,.bl_pager__large .bl_pager_item__previous .bl_pager_inner:focus-visible {
    background: #fff4ed
}

:root .bl_pager__large .bl_pager_item__next .bl_pager_inner:focus,:root .bl_pager__large .bl_pager_item__previous .bl_pager_inner:focus,_:-ms-fullscreen {
    background: #fff4ed
}

.bl_pager_item__list .bl_pager_inner {
    background: #ff9955;
    color: #fff
}

.bl_pager_item__list .bl_pager_inner:hover {
    background: #333
}

.bl_pager_item__list .bl_pager_inner:focus-visible {
    background: #333
}

:root .bl_pager_item__list .bl_pager_inner:focus,_:-ms-fullscreen {
    background: #333
}

.bl_pager_inner__current {
    background: #ff9955;
    color: #fff;
    pointer-events: none
}

.bl_pager_icon {
    display: block;
    position: relative;
    right: 0;
    width: 25px;
    -webkit-transition: left 0.5s ease,right 0.5s ease;
    transition: left 0.5s ease,right 0.5s ease
}

.bl_pager__large .bl_pager_item__previous .bl_pager_icon {
    margin-right: 16px
}

.bl_pager__large .bl_pager_item__next .bl_pager_icon {
    margin-left: 16px
}

.bl_pager_item__previous .bl_pager_icon {
    right: auto;
    left: 0;
    -webkit-transform: scale(-1,1);
    transform: scale(-1,1)
}

label {
    cursor: pointer;
    display: inline-block
}

.el_select {
    display: inline-block;
    position: relative
}

.el_select_input {
    border: 1px solid #e4e1e1;
    padding: 8px 44px 8px 18px
}

.el_select:after {
    border-bottom: 2px solid #ff9955;
    border-right: 2px solid #ff9955;
    content: "";
    height: 8px;
    pointer-events: none;
    position: absolute;
    right: 18px;
    top: 50%;
    -webkit-transform: translateY(-50%) rotate(45deg);
    transform: translateY(-50%) rotate(45deg);
    width: 8px
}

.bl_step {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    margin-left: auto;
    margin-right: auto;
    max-width: 518px
}

.bl_step_item {
    background: #fff4ed;
    font-size: 1.4rem;
    padding: 0 8px 6px;
    position: relative;
    text-align: center;
    width: 48.26%
}

@media screen and (min-width: 48em) {
    .bl_step_item {
        -webkit-box-align:center;
        -ms-flex-align: center;
        align-items: center;
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        font-size: 1.5rem;
        -webkit-box-pack: center;
        -ms-flex-pack: center;
        justify-content: center;
        padding: 8px
    }
}

@media screen and (min-width: 64em) {
    .bl_step_item {
        font-size:1.6rem
    }
}

.bl_step_item:not(:last-child):after {
    background: url('data:image/svg+xml;utf-8,<svg preserveAspectRatio="none" xmlns="http://www.w3.org/2000/svg" width="24" height="71" viewBox="0 0 24 71"><path d="M35.5,0,71,24H0Z" transform="translate(24) rotate(90)" fill="%23f2f6f9"/></svg>') no-repeat right center;
    background-size: 100% 100%;
    border-left: 8px solid #fff4ed;
    content: "";
    -webkit-filter: drop-shadow(8px 0 0 #fff);
    filter: drop-shadow(8px 0 0 #fff);
    height: 100%;
    left: 100%;
    pointer-events: none;
    position: absolute;
    top: 0;
    -webkit-transform: translateX(-8px);
    transform: translateX(-8px);
    width: 32px;
    z-index: 2
}

.bl_step_item:not(:first-child) {
    padding-left: 40px;
    width: 51.74%
}

.bl_step_item[aria-current=page] {
    background: #ff9955;
    color: #fff
}

.bl_step_item[aria-current=page]:after {
    background-image: url('data:image/svg+xml;utf-8,<svg preserveAspectRatio="none" xmlns="http://www.w3.org/2000/svg" width="24" height="71" viewBox="0 0 24 71"><path d="M35.5,0,71,24H0Z" transform="translate(24) rotate(90)" fill="%233fa3c5"/></svg>');
    border-left-color: #ff9955
}

.bl_step_label {
    color: #ff9955;
    display: block;
    font-family: "Noto Sans JP",cursive;
    font-size: 1.6rem;
    letter-spacing: 0.03em;
    line-height: 1.2
}

@media screen and (min-width: 48em) {
    .bl_step_label {
        display:inline-block;
        font-size: 1.8rem;
        margin-right: 18px
    }
}

@media screen and (min-width: 64em) {
    .bl_step_label {
        font-size:2rem
    }
}

[aria-current=page] .bl_step_label {
    color: #fff
}

.bl_step_number {
    display: inline-block;
    font-size: 4rem;
    line-height: 1.1;
    margin-left: 2px;
    vertical-align: -0.125em
}

@media screen and (min-width: 48em) {
    .bl_step_number {
        font-size:4.5rem
    }
}

@media screen and (min-width: 64em) {
    .bl_step_number {
        font-size:5rem
    }
}

.mwform-radio-field {
    display: block
}

.mwform-radio-field input {
    clip: rect(1px,1px,1px,1px);
    height: 1px;
    overflow: hidden;
    position: absolute;
    width: 1px
}

.mwform-radio-field input:focus+.mwform-radio-field-text:before {
    border-color: #ff9955
}

.mwform-radio-field input:checked+.mwform-radio-field-text:after {
    opacity: 1
}

.mwform-radio-field-text {
    display: block;
    padding-left: 21px;
    position: relative
}

.mwform-radio-field-text:after,.mwform-radio-field-text:before {
    border-radius: 50%;
    left: 0;
    position: absolute;
    top: 0.9375em;
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%)
}

.mwform-radio-field-text:before {
    border: 1px solid #b5b2b2;
    content: "";
    height: 12px;
    width: 12px
}

.mwform-radio-field-text:after {
    background: #ff9955;
    content: "";
    height: 6px;
    margin-left: 3px;
    opacity: 0;
    position: absolute;
    width: 6px
}

.mwform-checkbox-field {
    display: block
}

.mwform-checkbox-field input {
    clip: rect(1px,1px,1px,1px);
    height: 1px;
    overflow: hidden;
    position: absolute;
    width: 1px
}

.mwform-checkbox-field input:focus+.mwform-checkbox-field-text:before {
    border-color: #ff9955
}

.mwform-checkbox-field input:checked+.mwform-checkbox-field-text:after {
    opacity: 1
}

.mwform-checkbox-field-text {
    display: block;
    padding-left: 21px;
    position: relative
}

.mwform-checkbox-field-text:before {
    border: 1px solid #b5b2b2;
    content: "";
    height: 12px;
    left: 0;
    position: absolute;
    top: 0.9375em;
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
    width: 12px
}

.mwform-checkbox-field-text:after {
    border-bottom: 1px solid #333;
    border-left: 1px solid #333;
    content: "";
    height: 5px;
    left: 2px;
    opacity: 0;
    position: absolute;
    top: 0.9375em;
    -webkit-transform: translateY(-70%) rotate(-45deg);
    transform: translateY(-70%) rotate(-45deg);
    -webkit-transition: opacity 0.5s ease;
    transition: opacity 0.5s ease;
    width: 8px
}

.mw_wp_form .horizontal-item+.horizontal-item {
    margin-left: 0
}

.bl_form {
    border-top: 1px solid #e4e1e1
}

.bl_form_item {
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    border-bottom: 1px solid #e4e1e1;
    padding: 16px 0
}

@media screen and (min-width: 48em) {
    .bl_form_item {
        display:-webkit-box;
        display: -ms-flexbox;
        display: flex
    }
}

@media screen and (min-width: 64em) {
    .bl_form_item {
        padding:26px 0
    }
}

@media screen and (min-width: 48em) {
    .bl_form__wrap .bl_form_item {
        display:block;
        padding-inline:5%}
}

@media screen and (min-width: 64em) {
    .bl_form__wrap .bl_form_item {
        padding-inline:10%
    }
}

.bl_form_item__long {
    -webkit-box-align: start;
    -ms-flex-align: start;
    align-items: flex-start
}

@media screen and (min-width: 48em) {
    .bl_form_title {
        width:33.33%
    }
}

@media screen and (min-width: 64em) {
    .bl_form_title {
        padding-left:5.125%
    }
}

@media screen and (min-width: 80em) {
    .bl_form_title {
        padding-left:10.25%
    }
}

.bl_form__wrap .bl_form_title {
    padding-left: 0;
    width: 100%
}

.bl_form_data {
    margin-top: 8px
}

@media screen and (min-width: 48em) {
    .bl_form_data {
        margin:0 0 0 9.17%;
        width: 57.5%
    }
}

@media screen and (min-width: 64em) {
    .bl_form_data {
        padding-right:6.625%
    }
}

@media screen and (min-width: 80em) {
    .bl_form_data {
        padding-right:13.25%
    }
}

.bl_form__wrap .bl_form_data {
    margin: 16px 0 0;
    padding-right: 0;
    width: 100%
}

.bl_form_required {
    background: #ff9955;
    color: #fff;
    display: inline-block;
    font-size: 1.3rem;
    line-height: 1.5;
    margin-left: 14px;
    padding: 0 8px
}

.bl_form_subItem:not(:first-child) {
    margin-top: 14px
}

.bl_form_input {
    background: #fff;
    border: 1px solid #e4e1e1;
    padding: 8px 18px;
    width: 100%
}

@media screen and (min-width: 64em) {
    .bl_form_input {
        font-size:1.4rem
    }
}

.bl_form_input:focus {
    border-color: #ff9955
}

.bl_form_input::-moz-placeholder,.bl_form_input::-ms-input-placeholder,.bl_form_input::-webkit-input-placeholder {
    color: #b5b3b3
}

.bl_form_input:-webkit-autofill {
    -webkit-box-shadow: 0 0 0 1000px #fff inset;
    box-shadow: 0 0 0 1000px #fff inset
}

.bl_form_button {
    margin-top: 32px;
    text-align: center
}

@media screen and (min-width: 48em) {
    .bl_form_button {
        margin-top:58px
    }
}

@media screen and (min-width: 64em) {
    .bl_form_button {
        margin-top:85px
    }
}

textarea {
    height: 160px;
    resize: vertical
}

.el_zip {
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap
}

.el_zip_icon {
    -ms-flex-negative: 0;
    flex-shrink: 0;
    margin-right: 8px
}

.el_zip_input {
    width: calc(100% - 1.6rem - 8px)
}

.el_zip .error {
    width: 100%
}

.el_inputHasUnit {
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex
}

.el_inputHasUnit_input {
    max-width: 248px
}

.el_inputHasUnit_unit {
    margin-left: 10px
}

.el_inputDate {
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    border: none;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex
}

.el_inputDate_item {
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex
}

.el_inputDate_item:not(:last-child) {
    margin-right: 8px
}

.el_inputDate_input {
    -moz-appearance: textfield!important;
    max-width: 80px
}

.el_inputDate_input::-webkit-inner-spin-button,.el_inputDate_input::-webkit-outer-spin-button {
    -webkit-appearance: none!important;
    margin: 0!important
}

.el_inputDate_text {
    margin-left: 8px
}

@media screen and (min-width: 48em) {
    .el_checkboxWithInput {
        display:-webkit-box;
        display: -ms-flexbox;
        display: flex
    }
}

@media screen and (min-width: 48em) {
    .el_checkboxWithInput:nth-child(n+2) {
        margin-top:8px
    }
}

@media screen and (min-width: 48em) {
    .el_checkboxWithInput .mwform-checkbox-field {
        -ms-flex-negative:0;
        flex-shrink: 0;
        max-width: 45%;
        padding-top: 4px
    }
}

.el_checkboxWithInput_input {
    margin: 8px 0 0 21px
}

@media screen and (min-width: 48em) {
    .el_checkboxWithInput_input {
        margin:0 0 0 24px
    }
}

.el_title__main {
    position: relative;
    padding-bottom: 29px;
    font-size: 2rem;
    font-weight: 500;
    text-align: center;
    letter-spacing: 0.05em
}

@media screen and (min-width: 48em) {
    .el_title__main {
        padding-bottom:37px;
        font-size: 2.4rem
    }
}

@media screen and (min-width: 64em) {
    .el_title__main {
        font-size:2.6rem
    }
}

.el_title__main:after {
    position: absolute;
    bottom: 0;
    left: 50%;
    content: "";
    width: 1px;
    height: 20px;
    background: #ff9955
}

.el_title__main+* {
    margin-top: 32px
}

@media screen and (min-width: 48em) {
    .el_title__main+* {
        margin-top:36px
    }
}

@media screen and (min-width: 80em) {
    .el_title__main+.bl_columnContent {
        margin-top:62px
    }
}

.el_title__main.el_title__hasEnglish {
    font-size: 1.8rem
}

@media screen and (min-width: 48em) {
    .el_title__main.el_title__hasEnglish {
        font-size:2rem
    }
}

.el_title__main.el_title__hasEnglish .el_title_english {
    display: block;
    font-family: "Noto Sans JP",cursive;
    font-size: 4rem;
    font-weight: 400;
    line-height: 1.225;
    letter-spacing: 0.03em
}

@media screen and (min-width: 48em) {
    .el_title__main.el_title__hasEnglish .el_title_english {
        font-size:5rem
    }
}

.el_title__horizontal {
    font-size: 1.8rem;
    font-weight: 500;
    letter-spacing: 0.1em
}

@media screen and (min-width: 48em) {
    .el_title__horizontal {
        font-size:2rem
    }
}

.el_title__horizontal .el_title_english {
    display: inline-block;
    margin-right: 12px;
    font-family: "Noto Sans JP",cursive;
    font-size: 4rem;
    font-weight: 400;
    line-height: 1.225;
    letter-spacing: 0.03em
}

@media screen and (min-width: 48em) {
    .el_title__horizontal .el_title_english {
        margin-right:14px;
        font-size: 5rem
    }
}

.el_title__sub {
    position: relative;
    padding-left: 28px;
    color: #ff9955;
    font-size: 2rem;
    font-weight: 500;
    line-height: 1.75
}

@media screen and (min-width: 48em) {
    .el_title__sub {
        font-size:2.2rem
    }
}

@media screen and (min-width: 64em) {
    .el_title__sub {
        font-size:2.6rem
    }
}

.el_title__sub:before {
    position: absolute;
    top: 0.875em;
    left: 0;
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
    content: "";
    width: 20px;
    height: 1px;
    background: #ff9955
}

.el_title__sub+* {
    margin-top: 23px
}

@media screen and (min-width: 48em) {
    .el_title__sub+* {
        margin-top:35px
    }
}

@media screen and (min-width: 64em) {
    .el_title__sub+* {
        margin-top:47px
    }
}

.el_title__fill {
    padding: 14px 8px;
    background: #fff4ed;
    font-size: 1.8rem;
    font-weight: 500;
    text-align: center
}

@media screen and (min-width: 48em) {
    .el_title__fill {
        font-size:2rem
    }
}

.el_title__fill+* {
    margin-top: 26px
}

@media screen and (min-width: 48em) {
    .el_title__fill+* {
        margin-top:33px
    }
}

.el_title__mini {
    color: #ff9955;
    font-size: 1.8rem;
    font-weight: 500
}

@media screen and (min-width: 48em) {
    .el_title__mini {
        font-size:2rem
    }
}

@media screen and (min-width: 64em) {
    .el_title__mini {
        font-size:2.3rem
    }
}

.el_title__mini+* {
    margin-top: 16px
}

@media screen and (min-width: 48em) {
    .el_title__mini+* {
        margin-top:24px
    }
}

@media screen and (min-width: 64em) {
    .el_title__mini+* {
        margin-top:32px
    }
}

.el_title__noLine {
    padding-left: 0
}

.el_title__noLine:before {
    content: none
}

.el_title__decoration {
    position: relative;
    padding-left: 22px;
    font-size: 1.8rem;
    font-weight: 400
}

@media screen and (min-width: 48em) {
    .el_title__decoration {
        font-size:2rem
    }
}

.el_title__decoration:after {
    position: absolute;
    top: 0.9375em;
    left: 0;
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
    content: "";
    border-top: 7px solid transparent;
    border-bottom: 7px solid transparent;
    border-left: 12px solid #ff9955
}

.el_title__dark {
    color: #333
}

.el_title__center {
    text-align: center
}

.el_title__bubble {
    font-family: "Shippori Mincho B1",serif;
    font-size: 2.4rem;
    font-weight: 500;
    text-align: center;
    letter-spacing: 0.03em
}

@media screen and (min-width: 48em) {
    .el_title__bubble {
        font-size:2.8rem
    }
}

@media screen and (min-width: 64em) {
    .el_title__bubble {
        font-size:3rem
    }
}

.el_title__bubble+* {
    margin-top: 16px
}

@media screen and (min-width: 48em) {
    .el_title__bubble+* {
        margin-top:28px
    }
}

@media screen and (min-width: 64em) {
    .el_title__bubble+* {
        margin-top:40px
    }
}

.el_title_bubble {
    display: block;
    margin-bottom: 15px;
    color: #ff9955
}

.el_title_small {
    font-size: 0.9em
}

@media screen and (min-width: 48em) {
    .el_title_small {
        font-size:0.857em
    }
}

.el_title_color {
    color: #ff9955
}

.el_title_text {
    display: block;
    margin-top: 13px;
    color: #ff9955;
    font-size: 1.6rem;
    font-weight: 500
}

@media screen and (min-width: 48em) {
    .el_title_text {
        font-size:1.8rem
    }
}

.el_title_icon {
    display: block;
    width: 84px;
    margin: 0 auto 11px
}

.el_title__text {
    font-size: inherit;
    font-weight: inherit
}

.el_titleSimple {
    font-family: "Shippori Mincho B1",serif;
    font-size: 2.4rem;
    font-weight: 500;
    line-height: 1.72
}

@media screen and (min-width: 48em) {
    .el_titleSimple {
        font-size:3.2rem;
        line-height: 1.57;
        text-align: center;
        letter-spacing: 0.05em
    }
}

@media screen and (min-width: 64em) {
    .el_titleSimple {
        font-size:3.5rem
    }
}

.el_titleSimple+* {
    margin-top: 30px
}

@media screen and (min-width: 48em) {
    .el_titleSimple+* {
        margin-top:40px
    }
}

@media screen and (min-width: 64em) {
    .el_titleSimple+* {
        margin-top:52px
    }
}

@media not screen and (min-width: 48em) {
    .el_titleSimple__mobileCenter {
        text-align:center
    }
}

.el_titleSimple__small {
    font-size: 2rem;
    line-height: 1.7;
    letter-spacing: 0
}

@media screen and (min-width: 48em) {
    .el_titleSimple__small {
        font-size:2.4rem
    }
}

@media screen and (min-width: 64em) {
    .el_titleSimple__small {
        font-size:2.6rem
    }
}

.el_titleSimple__small+* {
    margin-top: 12px
}

@media screen and (min-width: 48em) {
    .el_titleSimple__small+* {
        margin-top:18px
    }
}

@media screen and (min-width: 64em) {
    .el_titleSimple__small+* {
        margin-top:24px
    }
}

.el_titleSimple__smallest {
    font-size: 1.8rem;
    letter-spacing: 0
}

@media screen and (min-width: 48em) {
    .el_titleSimple__smallest {
        font-size:2rem
    }
}

.el_titleSimple__left {
    text-align: left
}

.el_titleSimple__color {
    color: #ff9955
}

.el_titleSimple_color {
    color: #ff9955
}

.el_titleSimple_small {
    font-size: 0.9em
}

@media screen and (min-width: 48em) {
    .el_titleSimple_small {
        font-size:0.857em
    }
}

.el_bubble {
    padding-bottom: 16px
}

.el_bubble_inner {
    display: inline-block;
    position: relative;
    padding: 1px 14px;
    border-top: 1px solid;
    border-bottom: 1px solid;
    font-family: "Noto Sans JP",sans-serif;
    font-size: 2rem;
    font-weight: 500
}

@media screen and (min-width: 48em) {
    .el_bubble_inner {
        min-width:min(349px,100%);
        font-size: 2.3rem
    }
}

@media screen and (min-width: 64em) {
    .el_bubble_inner {
        font-size:2.6rem
    }
}

.el_bubble_inner:after {
    position: absolute;
    top: 100%;
    right: 50%;
    content: "";
    width: 12px;
    height: 16px;
    background: url('data:image/svg+xml;utf-8,<svg xmlns="http://www.w3.org/2000/svg" width="12" height="15.741" viewBox="0 0 12 15.741"><g transform="translate(-1005 -2338)"><rect width="12" height="1" transform="translate(1005 2338)" fill="%23fff"/><path d="M-20818.379,6082h-.621v-1l1.211,0,.143.258,8.336,15-.879.484Z" transform="translate(21824 -3743)" fill="%233fa3c5"/></g></svg>') no-repeat top right;
    background-size: contain
}

.el_bubble__inBase .el_bubble_inner:after {
    background-image: url('data:image/svg+xml;utf-8,<svg xmlns="http://www.w3.org/2000/svg" width="12" height="15.741" viewBox="0 0 12 15.741"><g transform="translate(-1005 -2338)"><rect width="12" height="1" transform="translate(1005 2338)" fill="%23f2f6f9"/><path d="M-20818.379,6082h-.621v-1l1.211,0,.143.258,8.336,15-.879.484Z" transform="translate(21824 -3743)" fill="%233fa3c5"/></g></svg>')
}

.el_titleLine {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: start;
    -ms-flex-pack: start;
    justify-content: flex-start;
    color: #ff9955;
    font-size: 1.8rem;
    font-weight: 500;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center
}

@media screen and (min-width: 48em) {
    .el_titleLine {
        font-size:2rem
    }
}

.el_titleLine_inner {
    -ms-flex-negative: 0;
    flex-shrink: 0;
    max-width: 80%;
    margin-right: 18px
}

@media screen and (min-width: 48em) {
    .el_titleLine_inner {
        font-size:20px
    }
}

.el_titleLine:after {
    content: "";
    width: 100%;
    height: 1px;
    background: #e4e1e1
}

.el_button {
    display: inline-block;
    -webkit-transition: color 0.5s ease,opacity 0.5s ease,background 0.5s ease,border 0.5s ease;
    transition: color 0.5s ease,opacity 0.5s ease,background 0.5s ease,border 0.5s ease
}

.el_button__main {
    position: relative;
    min-width: 330px;
    min-width: min(330px,100%);
    padding: 17px 49px 17px 16px;
    background: #ff9955;
    color: #fff;
    font-size: 1.5rem;
    font-weight: 400;
    line-height: 1.46;
    text-align: center;
    letter-spacing: 0.03em
}

@media screen and (min-width: 64em) {
    .el_button__main {
        padding-left:58px
    }
}

.el_button__main:hover {
    background: #338000
}

.el_button__main:hover:after {
    right: 7px
}

.el_button__main:focus-visible {
    background: #338000
}

.el_button__main:focus-visible:after {
    right: 7px
}

:root .el_button__main:focus,_:-ms-fullscreen {
    background: #338000
}

:root .el_button__main:focus:after,_:-ms-fullscreen:after {
    right: 7px
}

.el_button__main:after {
    position: absolute;
    top: 50%;
    right: 18px;
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
    content: "";
    width: 25px;
    height: 8px;
    background: url(../img/common/icon_arrow_right_white.svg) no-repeat;
    background-size: contain;
    -webkit-transition: right 0.5s ease;
    transition: right 0.5s ease
}

.el_button__sub {
    position: relative;
    padding-right: 34px;
    text-decoration: underline
}

.el_button__sub:hover:after {
    right: -8px
}

.el_button__sub:focus-visible:after {
    right: -8px
}

:root .el_button__sub:focus:after,_:-ms-fullscreen:after {
    right: -8px
}

.el_button__sub:after {
    position: absolute;
    top: 50%;
    right: 0;
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
    content: "";
    width: 21px;
    height: 4px;
    background: url(../img/common/icon_arrow_fill_right_dark.svg) no-repeat;
    background-size: contain;
    -webkit-transition: right 0.5s ease;
    transition: right 0.5s ease
}

@media screen and (min-width: 48em) {
    .bl_pageLink {
        display:-webkit-box;
        display: -ms-flexbox;
        display: flex;
        -ms-flex-wrap: wrap;
        flex-wrap: wrap
    }
}

.bl_pageLink_item {
    background: #fff
}

@media screen and (min-width: 48em) {
    .bl_pageLink_item {
        width:31.75%
    }
}

.bl_pageLink_item:not(:first-child) {
    border-top: none;
    margin-top: 16px
}

@media screen and (min-width: 48em) {
    .bl_pageLink_item:not(:first-child) {
        border-left:none;
        margin-top: 0
    }
}

@media screen and (min-width: 48em) {
    .bl_pageLink_item:not(:nth-child(3n)) {
        margin-right:2.375%
    }
}

@media screen and (min-width: 48em) {
    .bl_pageLink_item:nth-child(3)~.bl_pageLink_item {
        margin-top:24px
    }
}

.bl_pageLink__wide .bl_pageLink_item {
    margin-top: 0
}

@media screen and (min-width: 48em) {
    .bl_pageLink__wide .bl_pageLink_item {
        width:50%
    }
}

@media screen and (min-width: 48em) {
    .bl_pageLink__wide .bl_pageLink_item:not(:nth-child(3n)) {
        margin-right:0
    }
}

.bl_pageLink__wide .bl_pageLink_item:not(:first-child) {
    border-top: 1px solid #e4e1e1
}

@media screen and (min-width: 48em) {
    .bl_pageLink__wide .bl_pageLink_item:not(:first-child) {
        border-top:none;
        border-left: 1px solid #e4e1e1
    }
}

.bl_pageLink_link {
    display: block;
    position: relative;
    height: 100%;
    padding: 18px 6%;
    letter-spacing: 0.03em;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center
}

@media screen and (min-width: 48em) {
    .bl_pageLink_link {
        padding:18px 20px 18px 16px
    }
}

@media screen and (min-width: 80em) {
    .bl_pageLink_link {
        padding:18px 30px 18px 43px
    }
}

.bl_pageLink_link:hover {
    background: #fff4ed
}

.bl_pageLink_link:hover:before {
    right: 0
}

.bl_pageLink_link:hover:after {
    border-right-color: #338000;
    border-bottom-color: #338000
}

.bl_pageLink_link:focus-visible {
    background: #fff4ed
}

.bl_pageLink_link:focus-visible:before {
    right: 0
}

.bl_pageLink_link:focus-visible:after {
    border-right-color: #338000;
    border-bottom-color: #338000
}

:root .bl_pageLink_link:focus,_:-ms-fullscreen {
    background: #fff4ed
}

:root .bl_pageLink_link:focus:before,_:-ms-fullscreen:before {
    right: 0
}

:root .bl_pageLink_link:focus:after,_:-ms-fullscreen:after {
    border-right-color: #338000;
    border-bottom-color: #338000
}

.bl_pageLink_item__hasIcon .bl_pageLink_link {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    height: 100%;
    padding: 20px 5% 24px;
    line-height: 1.45
}

@media screen and (min-width: 48em) {
    .bl_pageLink_item__hasIcon .bl_pageLink_link {
        padding:30px 4px 37px 8px
    }
}

@media screen and (min-width: 64em) {
    .bl_pageLink_item__hasIcon .bl_pageLink_link {
        padding:30px 2% 37px 4%
    }
}

@media screen and (min-width: 90em) {
    .bl_pageLink_item__hasIcon .bl_pageLink_link {
        padding:30px 3.6% 37px 9.71%
    }
}

.bl_pageLink__wide .bl_pageLink_link {
    padding: 24px 29px 24px 4%;
    font-weight: 400
}

@media screen and (min-width: 64em) {
    .bl_pageLink__wide .bl_pageLink_link {
        padding:44px 10px 44px 16px
    }
}

@media screen and (min-width: 80em) {
    .bl_pageLink__wide .bl_pageLink_link {
        padding-left:30px
    }
}

.bl_pageLink__wide .bl_pageLink_link:hover {
    background: #fff4ed
}

.bl_pageLink__wide .bl_pageLink_link:hover:before {
    right: 0
}

.bl_pageLink__wide .bl_pageLink_link:focus-visible {
    background: #fff4ed
}

.bl_pageLink__wide .bl_pageLink_link:focus-visible:before {
    right: 0
}

:root .bl_pageLink__wide .bl_pageLink_link:focus,_:-ms-fullscreen {
    background: #fff4ed
}

:root .bl_pageLink__wide .bl_pageLink_link:focus:before,_:-ms-fullscreen:before {
    right: 0
}

.bl_pageLink_link:before {
    position: absolute;
    right: 10px;
    bottom: 11px;
    z-index: 2;
    content: "";
    width: 25px;
    height: 9px;
    background: url(../img/common/icon_arrow_right_white.svg) no-repeat;
    background-size: contain;
    -webkit-transition: right 0.5s ease;
    transition: right 0.5s ease
}

.bl_pageLink__wide .bl_pageLink_link:before {
    right: 20px;
    bottom: 20px;
    width: 38px;
    height: 13px
}

.bl_pageLink_link:after {
    position: absolute;
    right: 5px;
    bottom: 5px;
    content: "";
    border: 19px solid transparent;
    border-right-color: #ff9955;
    border-bottom-color: #ff9955;
    -webkit-transition: border 0.5s ease;
    transition: border 0.5s ease
}

.bl_pageLink__wide .bl_pageLink_link:after {
    right: 10px;
    bottom: 10px;
    border-width: 29px
}

.bl_pageLink_title {
    color: #ff9955;
    font-size: 1.8rem;
    font-weight: 500;
    line-height: 1.5
}

@media screen and (min-width: 64em) {
    .bl_pageLink_title {
        font-size:2rem
    }
}

.bl_pageLink_text {
    margin-top: 11px
}

@media screen and (min-width: 48em) {
    .bl_pageLink_text {
        font-size:1.5rem
    }
}

@media screen and (min-width: 64em) {
    .bl_pageLink_text {
        font-size:1.6rem
    }
}

.bl_pageLink_icon {
    -ms-flex-negative: 0;
    flex-shrink: 0;
    position: relative;
    width: 31.8%;
    margin: 0 auto
}

@media screen and (min-width: 48em) {
    .bl_pageLink_icon {
        display:none
    }
}

@media screen and (min-width: 64em) {
    .bl_pageLink_icon {
        display:block
    }
}

.bl_pageLink__wide .bl_pageLink_icon {
    width: 25%;
    margin: 0;
    border-radius: 50%;
    background: #fff4ed
}

@media screen and (min-width: 48em) {
    .bl_pageLink__wide .bl_pageLink_icon {
        display:block
    }
}

@media screen and (min-width: 64em) {
    .bl_pageLink__wide .bl_pageLink_icon {
        width:17.3%
    }
}

.bl_pageLink__wide .bl_pageLink_icon:before {
    display: block;
    content: "";
    width: 100%;
    padding-top: 100%
}

.bl_pageLink__wide .bl_pageLink_icon img {
    position: absolute;
    top: 50%;
    left: 50%;
    -webkit-transform: translate(-50%,-50%);
    transform: translate(-50%,-50%);
    width: 72.16%
}

.bl_pageLink_item__iconSquare .bl_pageLink_icon {
    width: 22.7%
}

.bl_pageLink_content {
    margin: 0 8px 0 0;
    font-weight: 500
}

@media screen and (min-width: 48em) {
    .bl_pageLink_content {
        margin:0
    }
}

@media screen and (min-width: 64em) {
    .bl_pageLink_content {
        margin-right:8px
    }
}

@media screen and (min-width: 80em) {
    .bl_pageLink_content {
        font-size:2rem
    }
}

.bl_pageLink__wide .bl_pageLink_content {
    margin-left: 5%;
    font-size: 1.6rem;
    font-weight: 400
}

@media screen and (min-width: 64em) {
    .bl_pageLink__wide .bl_pageLink_content {
        margin-left:3%;
        font-size: 1.8rem
    }
}

@media screen and (min-width: 80em) {
    .bl_pageLink__wide .bl_pageLink_content {
        font-size:2rem
    }
}

.bl_pageLink_category {
    display: block;
    margin-bottom: 4px;
    font-family: "Noto Sans JP",cursive;
    font-size: 2.1rem;
    font-weight: 400;
    line-height: 1.24;
    word-break: break-all
}

@media screen and (min-width: 64em) {
    .bl_pageLink_category {
        margin-bottom:9px
    }
}

.bl_pageLink__wide .bl_pageLink_category {
    color: #bdcdd2;
    font-size: 3.6rem;
    line-height: 1.22
}

@media screen and (min-width: 64em) {
    .bl_pageLink__wide .bl_pageLink_category {
        margin-bottom:7px;
        font-size: 4rem
    }
}

@media screen and (min-width: 80em) {
    .bl_pageLink__wide .bl_pageLink_category {
        font-size:4.5rem
    }
}

@media screen and (min-width: 48em) {
    .bl_pageLargeLink {
        display:-webkit-box;
        display: -ms-flexbox;
        display: flex;
        -ms-flex-wrap: wrap;
        flex-wrap: wrap;
        -webkit-box-align: stretch;
        -ms-flex-align: stretch;
        align-items: stretch
    }
}

@media screen and (min-width: 48em) {
    .bl_pageLargeLink_item {
        width:31.8%
    }
}

.bl_pageLargeLink_item:not(:first-child) {
    margin-top: 24px
}

@media screen and (min-width: 48em) {
    .bl_pageLargeLink_item:not(:first-child) {
        margin-top:0
    }
}

@media screen and (min-width: 48em) {
    .bl_pageLargeLink_item:not(:nth-child(3n)) {
        margin-right:2.3%
    }
}

@media screen and (min-width: 48em) {
    .bl_pageLargeLink_item:nth-child(3)~.bl_pageLargeLink_item {
        margin-top:30px
    }
}

.bl_pageLargeLink_link {
    display: block;
    position: relative;
    height: 100%;
    padding: 22px 6% 24px;
    background: #fff
}

@media screen and (min-width: 48em) {
    .bl_pageLargeLink_link {
        display:-webkit-box;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-orient: vertical;
        -webkit-box-direction: normal;
        -ms-flex-direction: column;
        flex-direction: column
    }
}

@media screen and (min-width: 64em) {
    .bl_pageLargeLink_link {
        padding:34px 7.3% 19px
    }
}

.bl_pageLargeLink_link:hover {
    background: #fff4ed
}

.bl_pageLargeLink_link:hover:before {
    right: 4.26%
}

@media screen and (min-width: 48em) {
    .bl_pageLargeLink_link:hover:before {
        right:0
    }
}

.bl_pageLargeLink_link:hover:after {
    border-right-color: #338000;
    border-bottom-color: #338000
}

.bl_pageLargeLink_link:focus-visible {
    background: #fff4ed
}

.bl_pageLargeLink_link:focus-visible:before {
    right: 4.26%
}

@media screen and (min-width: 48em) {
    .bl_pageLargeLink_link:focus-visible:before {
        right:0
    }
}

.bl_pageLargeLink_link:focus-visible:after {
    border-right-color: #338000;
    border-bottom-color: #338000
}

:root .bl_pageLargeLink_link:focus,_:-ms-fullscreen {
    background: #fff4ed
}

:root .bl_pageLargeLink_link:focus:before,_:-ms-fullscreen:before {
    right: 4.26%
}

@media screen and (min-width: 48em) {
    :root .bl_pageLargeLink_link:focus:before,_:-ms-fullscreen:before {
        right:0
    }
}

:root .bl_pageLargeLink_link:focus:after,_:-ms-fullscreen:after {
    border-right-color: #338000;
    border-bottom-color: #338000
}

.bl_pageLargeLink_link:before {
    position: absolute;
    right: 8.5%;
    bottom: 29px;
    z-index: 2;
    content: "";
    width: 38px;
    height: 13px;
    background: url(../img/common/icon_arrow_right_white.svg) no-repeat;
    background-size: contain;
    -webkit-transition: right 0.5s ease;
    transition: right 0.5s ease
}

@media screen and (min-width: 48em) {
    .bl_pageLargeLink_link:before {
        right:10px;
        bottom: 11px;
        width: 25px;
        height: 9px
    }
}

@media screen and (min-width: 80em) {
    .bl_pageLargeLink_link:before {
        right:20px;
        bottom: 20px;
        width: 38px;
        height: 13px
    }
}

.bl_pageLargeLink_link:after {
    position: absolute;
    right: 6%;
    bottom: 20px;
    content: "";
    border: 29px solid transparent;
    border-right-color: #ff9955;
    border-bottom-color: #ff9955;
    -webkit-transition: border-color 0.5s ease;
    transition: border-color 0.5s ease
}

@media screen and (min-width: 48em) {
    .bl_pageLargeLink_link:after {
        right:5px;
        bottom: 5px;
        border-width: 19px
    }
}

@media screen and (min-width: 80em) {
    .bl_pageLargeLink_link:after {
        right:10px;
        bottom: 10px;
        border-width: 29px
    }
}

.bl_pageLargeLink_item__image .bl_pageLargeLink_link {
    padding: 0 0 24px;
    -webkit-box-orient: vertical;
    -webkit-box-direction: reverse;
    -ms-flex-direction: column-reverse;
    flex-direction: column-reverse;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex
}

@media screen and (min-width: 64em) {
    .bl_pageLargeLink_item__image .bl_pageLargeLink_link {
        padding-bottom:19px
    }
}

.bl_pageLargeLink_link__noLink:hover {
    background: #fff
}

.bl_pageLargeLink_link__noLink:focus-visible {
    background: #fff
}

:root .bl_pageLargeLink_link__noLink:focus,_:-ms-fullscreen {
    background: #fff
}

.bl_pageLargeLink_link__noLink:after,.bl_pageLargeLink_link__noLink:before {
    content: none
}

.bl_pageLargeLink_content {
    padding: 0 6%;
    margin-top: 20px;
    height: 100%
}

@media screen and (min-width: 48em) {
    .bl_pageLargeLink_content {
        display:-webkit-box;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-orient: vertical;
        -webkit-box-direction: normal;
        -ms-flex-direction: column;
        flex-direction: column
    }
}

@media screen and (min-width: 64em) {
    .bl_pageLargeLink_content {
        padding:0 7.4%
    }
}

.bl_pageLargeLink_icon {
    display: block;
    width: 24.8%;
    max-width: 81px;
    margin: 0 auto
}

.bl_pageLargeLink_title {
    color: #ff9955;
    font-size: 1.8rem;
    font-weight: 500;
    line-height: 1.3;
    text-align: center
}

@media screen and (min-width: 48em) {
    .bl_pageLargeLink_title {
        font-size:2rem
    }
}

@media screen and (min-width: 64em) {
    .bl_pageLargeLink_title {
        font-size:2.3rem
    }
}

@media screen and (min-width: 64em) {
    .bl_pageLargeLink_item__image .bl_pageLargeLink_title {
        font-size:2rem
    }
}

.bl_pageLargeLink_title:not(:first-child) {
    margin-top: 22px
}

.bl_pageLargeLink_note {
    font-size: 1.6rem
}

@media screen and (min-width: 64em) {
    .bl_pageLargeLink_note {
        font-size:1.8rem
    }
}

.bl_pageLargeLink_text {
    margin: 18px 0 25px
}

@media screen and (min-width: 48em) {
    .bl_pageLargeLink_text {
        margin:23px 0 25px
    }
}

@media screen and (min-width: 64em) {
    .bl_pageLargeLink_text {
        margin:28px 0
    }
}

.bl_pageLargeLink_item__image .bl_pageLargeLink_text {
    margin: 20px 0 38px
}

.bl_pageLargeLink_item__image .bl_pageLargeLink_text:last-child {
    margin-bottom: 0
}

.bl_pageLargeLink_more {
    margin-top: auto;
    padding-right: 57px;
    font-size: 1.4rem;
    text-align: right
}

@media screen and (min-width: 48em) {
    .bl_pageLargeLink_more {
        padding-right:32px
    }
}

@media screen and (min-width: 64em) {
    .bl_pageLargeLink_more {
        padding-right:38px
    }
}

@media screen and (min-width: 48em) {
    .bl_pageLinkBanner {
        display:-webkit-box;
        display: -ms-flexbox;
        display: flex;
        -ms-flex-wrap: wrap;
        flex-wrap: wrap
    }
}

.bl_pageLinkBanner_item {
    overflow: hidden;
    background: #f4e3d7
}

@media screen and (min-width: 48em) {
    .bl_pageLinkBanner_item {
        width:48.66%
    }
}

.bl_pageLinkBanner_item:not(:first-child) {
    margin-top: 18px
}

@media screen and (min-width: 48em) {
    .bl_pageLinkBanner_item:not(:first-child) {
        margin-top:0
    }
}

@media screen and (min-width: 48em) {
    .bl_pageLinkBanner_item:nth-child(odd) {
        margin-right:2.68%
    }
}

.bl_pageLinkBanner_item__white {
    background: #fff
}

@media screen and (min-width: 48em) {
    .bl_pageLinkBanner_item__wide {
        width:100%
    }
}

@media screen and (min-width: 48em) {
    .bl_pageLinkBanner_item__wide:nth-child(odd) {
        margin-right:0
    }
}

@media screen and (min-width: 48em) {
    .bl_pageLinkBanner_item__wide:not(:first-child) {
        margin-top:36px
    }
}

.bl_pageLinkBanner_link {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column
}

@media screen and (min-width: 48em) {
    .bl_pageLinkBanner_link {
        height:100%
    }
}

@media screen and (min-width: 64em) {
    .bl_pageLinkBanner_link {
        -webkit-box-orient:horizontal;
        -webkit-box-direction: normal;
        -ms-flex-direction: row;
        flex-direction: row;
        -webkit-box-pack: justify;
        -ms-flex-pack: justify;
        justify-content: space-between;
        padding-left: 5%;
        -webkit-box-align: center;
        -ms-flex-align: center;
        align-items: center
    }
}

@media screen and (min-width: 80em) {
    .bl_pageLinkBanner_link {
        padding-left:6.3%
    }
}

.bl_pageLinkBanner_link:hover {
    background: #fff4ed
}

.bl_pageLinkBanner_link:hover .bl_pageLinkBanner_button {
    background: #333
}

.bl_pageLinkBanner_link:hover .bl_pageLinkBanner_button:after {
    right: 7px
}

.bl_pageLinkBanner_link:hover .bl_pageLinkBanner_image:before {
    opacity: 0
}

.bl_pageLinkBanner_link:focus-visible {
    background: #fff4ed
}

.bl_pageLinkBanner_link:focus-visible .bl_pageLinkBanner_button {
    background: #333
}

.bl_pageLinkBanner_link:focus-visible .bl_pageLinkBanner_button:after {
    right: 7px
}

.bl_pageLinkBanner_link:focus-visible .bl_pageLinkBanner_image:before {
    opacity: 0
}

:root .bl_pageLinkBanner_link:focus,_:-ms-fullscreen {
    background: #fff4ed
}

:root .bl_pageLinkBanner_link:focus .bl_pageLinkBanner_button,_:-ms-fullscreen .bl_pageLinkBanner_button {
    background: #333
}

:root .bl_pageLinkBanner_link:focus .bl_pageLinkBanner_button:after,_:-ms-fullscreen .bl_pageLinkBanner_button:after {
    right: 7px
}

:root .bl_pageLinkBanner_link:focus .bl_pageLinkBanner_image:before,_:-ms-fullscreen .bl_pageLinkBanner_image:before {
    opacity: 0
}

@media screen and (min-width: 48em) {
    .bl_pageLinkBanner_item__wide .bl_pageLinkBanner_link {
        -webkit-box-orient:horizontal;
        -webkit-box-direction: normal;
        -ms-flex-direction: row;
        flex-direction: row;
        padding-left: 0
    }
}

.bl_pageLinkBanner_content {
    width: 90%;
    margin: 0 auto 22px;
    padding-top: 24px
}

@media screen and (min-width: 64em) {
    .bl_pageLinkBanner_content {
        width:51.6%;
        margin: 0;
        padding: 24px 0 28px
    }
}

@media screen and (min-width: 64em) {
    .bl_pageLinkBanner_item__white .bl_pageLinkBanner_content {
        width:53.7%;
        padding: 16px 0
    }
}

@media screen and (min-width: 80em) {
    .bl_pageLinkBanner_item__white .bl_pageLinkBanner_content {
        padding:28px 0
    }
}

.bl_pageLinkBanner_item__wide .bl_pageLinkBanner_content {
    margin-bottom: 0;
    padding-bottom: 5%;
    text-align: center
}

@media screen and (min-width: 48em) {
    .bl_pageLinkBanner_item__wide .bl_pageLinkBanner_content {
        padding:27px 0
    }
}

.bl_pageLinkBanner_title {
    font-size: 2rem;
    font-weight: 500;
    line-height: 1.66;
    letter-spacing: 0.05em
}

@media screen and (min-width: 64em) {
    .bl_pageLinkBanner_title {
        font-size:2.1rem
    }
}

.bl_pageLinkBanner_item__white .bl_pageLinkBanner_title {
    color: #ff9955
}

.bl_pageLinkBanner_item__wide .bl_pageLinkBanner_title {
    font-size: 2.3rem
}

.bl_pageLinkBanner_button {
    margin-top: 16px
}

@media screen and (min-width: 48em) {
    .bl_pageLinkBanner_button {
        margin-top:21px
    }
}

.bl_pageLinkBanner_text {
    margin-top: 10px;
    font-size: 1.5rem
}

@media screen and (min-width: 80em) {
    .bl_pageLinkBanner_text {
        margin-top:14px;
        font-size: 1.6rem
    }
}

.bl_pageLinkBanner_item__wide .bl_pageLinkBanner_text {
    margin-top: 8px;
    font-size: 1.4rem
}

@media screen and (min-width: 64em) {
    .bl_pageLinkBanner_item__wide .bl_pageLinkBanner_text {
        font-size:1.6rem
    }
}

.bl_pageLinkBanner_image {
    -ms-flex-negative: 0;
    flex-shrink: 0;
    overflow: hidden;
    position: relative;
    margin-top: auto
}

@media screen and (min-width: 64em) {
    .bl_pageLinkBanner_image {
        width:47.44%;
        height: 100%;
        margin: 0 0 0 1%
    }
}

.bl_pageLinkBanner_image:after,.bl_pageLinkBanner_image:before {
    position: absolute;
    top: 0;
    right: 0;
    width: 100%;
    height: 100%;
    background: url('data:image/svg+xml;utf-8,<svg xmlns="http://www.w3.org/2000/svg" width="72" height="258" viewBox="0 0 72 258"><path d="M0,0H72L0,258Z" fill="%23d8eef4"/></svg>') no-repeat left top;
    background-size: auto 100%;
    -webkit-transition: opacity 0.5s ease;
    transition: opacity 0.5s ease
}

@media screen and (min-width: 64em) {
    .bl_pageLinkBanner_image:after,.bl_pageLinkBanner_image:before {
        content:""
    }
}

.bl_pageLinkBanner_image:before {
    z-index: 1
}

.bl_pageLinkBanner_item__white .bl_pageLinkBanner_image:before {
    background-image: url('data:image/svg+xml;utf-8,<svg xmlns="http://www.w3.org/2000/svg" width="72" height="258" viewBox="0 0 72 258"><path d="M0,0H72L0,258Z" fill="%23fff"/></svg>')
}

.bl_pageLinkBanner_image:after {
    background-image: url('data:image/svg+xml;utf-8,<svg xmlns="http://www.w3.org/2000/svg" width="72" height="258" viewBox="0 0 72 258"><path d="M0,0H72L0,258Z" fill="%23e0e8ee"/></svg>')
}

.bl_pageLinkBanner_item__white .bl_pageLinkBanner_image:after {
    background-image: url('data:image/svg+xml;utf-8,<svg xmlns="http://www.w3.org/2000/svg" width="72" height="258" viewBox="0 0 72 258"><path d="M0,0H72L0,258Z" fill="%23e0e8ee"/></svg>')
}

@media screen and (min-width: 64em) {
    .bl_pageLinkBanner_item__white .bl_pageLinkBanner_image {
        width:44.4%;
        margin-left: 1.9%
    }
}

@media screen and (min-width: 48em) {
    .bl_pageLinkBanner_item__wide .bl_pageLinkBanner_image {
        width:20%;
        height: 100%
    }
}

@media screen and (min-width: 64em) {
    .bl_pageLinkBanner_item__wide .bl_pageLinkBanner_image {
        width:29%
    }
}

.bl_pageLinkBanner_item__wide .bl_pageLinkBanner_image:after,.bl_pageLinkBanner_item__wide .bl_pageLinkBanner_image:before {
    content: none
}

.bl_pageLinkBanner_item__wide .bl_pageLinkBanner_image:not(.bl_pageLinkBanner_image__left):not(.bl_pageLinkBanner_image__right) {
    margin: 17px -5.5% 0
}

@media screen and (min-width: 48em) {
    .bl_pageLinkBanner_image__right {
        margin-left:2%
    }
}

@media screen and (min-width: 48em) {
    .bl_pageLinkBanner_image__left {
        margin:0 2% 0 0
    }
}

@media screen and (min-width: 48em) {
    .bl_pageLinkBanner_item__white .bl_pageLinkBanner_image__left {
        margin-left:0
    }
}

@media screen and (min-width: 48em) {
    .bl_listCheck__columnTwo {
        display:-webkit-box;
        display: -ms-flexbox;
        display: flex;
        -ms-flex-wrap: wrap;
        flex-wrap: wrap
    }
}

.bl_listCheck_item {
    position: relative;
    padding-left: 21px;
    line-height: 1.75
}

@media screen and (min-width: 48em) {
    .bl_listCheck_item {
        line-height:1.875
    }
}

.bl_listCheck_item:not(:first-child) {
    margin-top: 8px
}

@media screen and (min-width: 48em) {
    .bl_listCheck_item:not(:first-child) {
        margin-top:0
    }
}

.bl_listCheck_item:before {
    position: absolute;
    top: 0.875em;
    left: 0;
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
    content: "";
    width: 15px;
    height: 15px;
    background: url(../img/common/icon_check.svg) no-repeat;
    background-size: contain
}

@media screen and (min-width: 48em) {
    .bl_listCheck_item:before {
        top:0.9375em
    }
}

.bl_listCheck__white .bl_listCheck_item:before {
    background-image: url(../img/common/icon_check_white.svg)
}

@media screen and (min-width: 48em) {
    .bl_listCheck__columntwo .bl_listCheck_item {
        width:46.8%
    }
}

@media screen and (min-width: 48em) {
    .bl_listCheck__columntwo .bl_listCheck_item:nth-child(odd) {
        margin-right:6.4%
    }
}

.bl_listHorizontal {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap
}

.bl_listHorizontal__center {
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center
}

.bl_listHorizontal_item:not(:last-child) {
    margin-right: 8px
}

.bl_listHorizontal_item:not(:last-child):after {
    content: "/";
    margin-left: 8px;
    color: #ff9955
}

:where(.bl_listHorizontal__white) .bl_listHorizontal_item:not(:last-child):after {
    color: #fff
}

.bl_listSquare_item {
    position: relative;
    padding-left: 1.3125em
}

.bl_listSquare_item:before {
    position: absolute;
    top: 0.9375em;
    left: 0.125em;
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
    content: "";
    width: 0.75em;
    height: 0.75em;
    border: 1px solid
}

.bl_listCountBox {
    counter-reset: listCountBox
}

.bl_listCountBox_item {
    counter-increment: listCountBox;
    padding: 24px 6%;
    background: #fff
}

@media screen and (min-width: 48em) {
    .bl_listCountBox_item {
        padding:24px 3.3%
    }
}

@media screen and (min-width: 64em) {
    .bl_listCountBox_item {
        display:-webkit-box;
        display: -ms-flexbox;
        display: flex
    }
}

.bl_listCountBox_item:not(:first-child) {
    margin-top: 9px
}

.bl_listCountBox_title {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    color: #ff9955;
    font-family: "Shippori Mincho B1",serif;
    font-size: 1.8rem;
    font-weight: 500;
    line-height: 1.52;
    -webkit-box-align: start;
    -ms-flex-align: start;
    align-items: flex-start
}

@media screen and (min-width: 48em) {
    .bl_listCountBox_title {
        font-size:2rem
    }
}

@media screen and (min-width: 64em) {
    .bl_listCountBox_title {
        width:45%;
        font-size: 2.3rem
    }
}

@media screen and (min-width: 80em) {
    .bl_listCountBox_title {
        width:40%
    }
}

@media screen and (min-width: 90em) {
    .bl_listCountBox_title {
        width:36.875%
    }
}

.bl_listCountBox_title:before {
    content: counter(listCountBox,decimal-leading-zero);
    margin-top: -0.125em;
    margin-right: 16px;
    font-family: "Noto Sans JP",cursive;
    font-size: 2.8rem;
    font-weight: 400;
    line-height: 1.2
}

@media screen and (min-width: 48em) {
    .bl_listCountBox_title:before {
        font-size:3.2rem
    }
}

@media screen and (min-width: 64em) {
    .bl_listCountBox_title:before {
        margin-right:24px;
        font-size: 3.5rem
    }
}

.bl_listCountBox_content {
    margin-top: 8px
}

@media screen and (min-width: 64em) {
    .bl_listCountBox_content {
        width:53%;
        margin: 0 0 0 2%
    }
}

@media screen and (min-width: 80em) {
    .bl_listCountBox_content {
        width:56%;
        margin-left: 4%
    }
}

@media screen and (min-width: 90em) {
    .bl_listCountBox_content {
        width:58.75%;
        margin-left: 4.375%
    }
}

.bl_listNumber_item {
    list-style: decimal;
    margin-left: 1em
}

.bl_listSimple_item {
    position: relative;
    padding-left: 16px
}

.bl_listSimple_item:before {
    position: absolute;
    top: 0.9375em;
    left: 6px;
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
    content: "";
    width: 3px;
    height: 3px;
    border-radius: 50%;
    background: #333
}

.bl_listSimple__isolate .bl_listSimple_item:not(:first-child) {
    margin-top: 20px
}

@media screen and (min-width: 48em) {
    .bl_listTitle__horizontal {
        display:-webkit-box;
        display: -ms-flexbox;
        display: flex;
        -ms-flex-wrap: wrap;
        flex-wrap: wrap
    }
}

.bl_listTitle__emphasis {
    font-weight: 500
}

@media screen and (min-width: 48em) {
    .bl_listTitle_item {
        display:-webkit-box;
        display: -ms-flexbox;
        display: flex
    }
}

.bl_listTitle__horizontal .bl_listTitle_item {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap
}

@media screen and (min-width: 48em) {
    .bl_listTitle__horizontal .bl_listTitle_item:not(:last-child) {
        margin-right:16px
    }
}

@media screen and (min-width: 48em) {
    .bl_listTitle__horizontal .bl_listTitle_item:not(:last-child):after {
        content:"/";
        margin-left: 16px
    }
}

.bl_listTitle_title {
    -ms-flex-negative: 0;
    flex-shrink: 0
}

@media screen and (min-width: 48em) {
    .bl_listTitle_title {
        max-width:50%
    }
}

.bl_listTitle__horizontal .bl_listTitle_title {
    max-width: inherit
}

.bl_listTitle_title:after {
    content: "："
}

.bl_listNumberCircle {
    counter-reset: listNumberCircle
}

.bl_listNumberCircle_item {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    counter-increment: listNumberCircle;
    font-weight: 500
}

@media screen and (min-width: 64em) {
    .bl_listNumberCircle_item {
        font-size:1.8rem;
        -webkit-box-align: center;
        -ms-flex-align: center;
        align-items: center
    }
}

@media screen and (min-width: 80em) {
    .bl_listNumberCircle_item {
        font-size:2rem
    }
}

.bl_listNumberCircle_item:not(:first-child) {
    margin-top: 20px;
    padding-top: 20px;
    border-top: 1px dashed #333
}

@media screen and (min-width: 48em) {
    .bl_listNumberCircle_item:not(:first-child) {
        margin-top:15px;
        padding-top: 15px
    }
}

.bl_listNumberCircle_item:before {
    display: block;
    -ms-flex-negative: 0;
    flex-shrink: 0;
    content: counter(listNumberCircle,decimal-leading-zero);
    width: 3.2rem;
    max-width: 40%;
    height: 3.2rem;
    margin-right: 10px;
    padding: 0 0 0.25em 0.05em;
    border-radius: 50%;
    background: #99ff55;
    font-family: "Noto Sans JP",cursive;
    font-size: 2.4rem;
    line-height: 1.5;
    letter-spacing: 0.03em
}

@media screen and (min-width: 48em) {
    .bl_listNumberCircle_item:before {
        width:4.4rem;
        height: 4.4rem;
        margin-right: 12px;
        font-size: 3.2rem
    }
}

@media screen and (min-width: 64em) {
    .bl_listNumberCircle_item:before {
        width:6.6rem;
        height: 6.6rem;
        margin-right: 21px;
        padding-left: 0.1em;
        font-size: 4.7rem
    }
}

.bl_titleList_item {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex
}

@media screen and (min-width: 48em) {
    .bl_titleList_item {
        font-size:1.8rem
    }
}

.bl_titleList_item:not(:first-child) {
    margin-top: 15px
}

.bl_titleList_title {
    -ms-flex-negative: 0;
    flex-shrink: 0;
    position: relative;
    max-width: 50%;
    padding-left: 17px;
    font-weight: 500
}

.bl_titleList_title:before {
    position: absolute;
    top: 0.9375em;
    left: 0;
    content: "";
    width: 12px;
    height: 2px;
    background: #ff9955
}

.bl_titleList_data {
    margin-left: 10px
}

.el_listIcon {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    position: relative
}

.el_listIcon:after {
    position: absolute;
    bottom: 0;
    left: 0;
    content: "";
    width: 100%;
    height: 1px;
    background: #fff
}

.el_listIcon_item {
    position: relative;
    width: 31.4%;
    padding: 19px 0;
    border-bottom: 1px solid #e4e1e1;
    font-size: 1.1rem;
    font-weight: 500;
    line-height: 1.5;
    text-align: center
}

@media screen and (min-width: 48em) {
    .el_listIcon_item {
        width:15%;
        font-size: 1.2rem
    }
}

@media screen and (min-width: 64em) {
    .el_listIcon_item {
        min-height:180px;
        font-size: 1.4rem
    }
}

.el_listIcon_item:before {
    position: absolute;
    top: 8px;
    right: -4.5%;
    width: 1px;
    height: calc(100% - 16px);
    background: #e4e1e1
}

@media screen and (min-width: 48em) {
    .el_listIcon_item:before {
        top:15px;
        right: -6.6%;
        height: calc(100% - 30px)
    }
}

@media screen and (min-width: 64em) {
    .el_listIcon_item:before {
        top:22px;
        height: calc(100% - 44px)
    }
}

@media not screen and (min-width: 48em) {
    .el_listIcon_item:not(:nth-child(3n)) {
        margin-right:2.9%
    }
}

@media not screen and (min-width: 48em) {
    .el_listIcon_item:not(:nth-child(3n)):before {
        content:""
    }
}

@media screen and (min-width: 48em) {
    .el_listIcon_item:not(:nth-child(6n)) {
        margin-right:2%
    }
}

@media screen and (min-width: 48em) {
    .el_listIcon_item:not(:nth-child(6n)):before {
        content:""
    }
}

@media screen and (min-width: 48em) {
    :where(.el_listIcon__column5) .el_listIcon_item {
        -webkit-box-flex:1;
        -ms-flex-positive: 1;
        flex-grow: 1
    }
}

@media screen and (min-width: 48em) {
    :where(.el_listIcon__column5) .el_listIcon_item:last-child:before {
        content:none
    }
}

.el_listIcon_icon {
    display: block;
    width: 92%;
    max-width: 81px;
    margin: 0 auto
}

.bl_boxFill {
    padding: 24px 6% 29px;
    background: #fff4ed
}

@media screen and (min-width: 48em) {
    .bl_boxFill {
        padding:36px 6% 44px
    }
}

@media screen and (min-width: 64em) {
    .bl_boxFill {
        padding:49px 7.5% 58px
    }
}

.bl_boxFill__white {
    background: #fff
}

@media screen and (min-width: 48em) {
    .bl_boxFill__half {
        padding:18px 4.3% 30px
    }
}

@media screen and (min-width: 64em) {
    .bl_boxFill__half {
        padding:28px 4.3% 46px
    }
}

.bl_boxFill__inBox {
    padding: 15px
}

@media screen and (min-width: 48em) {
    .bl_boxFill__inBox {
        padding:30px
    }
}

.bl_boxFill_title {
    font-size: 2rem;
    font-weight: 400;
    text-align: center;
    letter-spacing: 0.03em
}

@media screen and (min-width: 48em) {
    .bl_boxFill_title {
        font-size:2.3rem
    }
}

@media screen and (min-width: 64em) {
    .bl_boxFill_title {
        font-size:2.6rem
    }
}

.bl_boxFill_title__hasIcon {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center
}

.bl_boxFill_title__color {
    color: #ff9955
}

.bl_boxFill_title__small {
    font-size: 1.8rem
}

@media screen and (min-width: 48em) {
    .bl_boxFill_title__small {
        font-size:2rem
    }
}

@media screen and (min-width: 64em) {
    .bl_boxFill_title__small {
        font-size:2.3rem
    }
}

.bl_boxFill_title__smallest {
    font-size: 1.8rem;
    text-align: left
}

.bl_boxFill_title__left {
    text-align: left
}

.bl_boxFill_icon {
    width: 40px;
    margin-right: 16px
}

@media screen and (min-width: 48em) {
    .bl_boxFill_icon {
        width:52px
    }
}

@media screen and (min-width: 64em) {
    .bl_boxFill_icon {
        width:64px;
        margin-right: 20px
    }
}

.bl_boxFill_text {
    margin-top: 12px
}

@media screen and (min-width: 48em) {
    .bl_boxFill_text {
        margin-top:19px
    }
}

@media screen and (min-width: 64em) {
    .bl_boxFill_text {
        margin-top:26px
    }
}

@media screen and (min-width: 48em) {
    .bl_boxFill_text__center {
        text-align:center
    }
}

.bl_boxFill_text__emphasis {
    font-weight: 500
}

@media screen and (min-width: 48em) {
    .bl_boxFill_text__emphasis {
        font-size:1.8rem
    }
}

.bl_boxFill_image {
    margin-top: 12px
}

@media screen and (min-width: 48em) {
    .bl_boxFill_image {
        margin-top:19px
    }
}

@media screen and (min-width: 64em) {
    .bl_boxFill_image {
        margin-top:26px
    }
}

.bl_boxFill_content:not(:first-child) {
    margin-top: 25px
}

@media screen and (min-width: 48em) {
    .bl_boxFill_content:not(:first-child) {
        margin-top:38px
    }
}

@media screen and (min-width: 64em) {
    .bl_boxFill_content:not(:first-child) {
        margin-top:50px
    }
}

.bl_boxFill_footer {
    margin-top: 24px;
    text-align: center
}

@media screen and (min-width: 48em) {
    .bl_boxFill_footer {
        margin-top:40px
    }
}

@media screen and (min-width: 64em) {
    .bl_boxFill_footer {
        margin-top:57px
    }
}

.bl_boxFill_button {
    width: 100%
}

.bl_boxFill_button__center {
    text-align: center
}

.bl_boxFrame {
    padding: 24px 6% 24px;
    border: 1px solid #e4e1e1
}

@media screen and (min-width: 48em) {
    .bl_boxFrame {
        padding:32px 4% 32px
    }
}

@media screen and (min-width: 64em) {
    .bl_boxFrame {
        padding:45px 3.5% 45px
    }
}

.bl_boxFrame__small {
    padding: 30px
}

@media screen and (min-width: 48em) {
    .bl_boxFrame__small {
        padding:2.5%
    }
}

.bl_boxFrame__color {
    border-color: #ff9955
}

.bl_boxFrame__textCenter {
    text-align: center
}

@media screen and (min-width: 48em) {
    .bl_boxFrame__column {
        display:-webkit-box;
        display: -ms-flexbox;
        display: flex
    }
}

@media screen and (min-width: 48em) {
    .bl_boxFrame_column {
        width:46.4%
    }
}

.bl_boxFrame_column:not(:first-child) {
    margin-top: 24px
}

@media screen and (min-width: 48em) {
    .bl_boxFrame_column:not(:first-child) {
        margin:0 0 0 7.2%
    }
}

.bl_boxFrame_item:not(:first-child) {
    margin-top: 34px
}

.bl_boxFrame_title {
    position: relative;
    padding-left: 21px;
    font-size: 1.8rem;
    font-weight: 400
}

@media screen and (min-width: 48em) {
    .bl_boxFrame_title {
        font-size:2rem
    }
}

.bl_boxFrame_title:before {
    position: absolute;
    top: 50%;
    left: 0;
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
    content: "";
    border-top: 7px solid transparent;
    border-bottom: 7px solid transparent;
    border-left: 12px solid #ff9955
}

.bl_boxFrame_title__center {
    padding: 0;
    text-align: center
}

.bl_boxFrame_title__center:before {
    content: none
}

.bl_boxFrame_text {
    margin-top: 14px
}

.bl_boxComment {
    padding: 20px;
    background: #fff4ed
}

@media screen and (min-width: 48em) {
    .bl_boxComment {
        padding:20px 25px
    }
}

.bl_boxComment_title {
    position: relative;
    padding-left: calc(1.1em + 8px);
    color: #ff9955;
    font-size: 1.9rem;
    font-weight: 500;
    letter-spacing: 0.03em
}

.bl_boxComment_title:before {
    position: absolute;
    top: 0.9375em;
    left: 0;
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
    content: "";
    width: 1.1em;
    height: 1.1em;
    background: url(../img/common/icon_comment.svg) no-repeat;
    background-size: contain
}

.bl_boxComment_text {
    margin-top: 10px
}

.bl_iconBox_icon {
    display: block;
    position: relative;
    z-index: 0;
    z-index: 0;
    width: 81px;
    max-width: 80%;
    margin: 0 auto -17px;
    border-radius: 50%;
    background: #dbe1e5
}

.bl_iconBox_content {
    padding: 30px;
    background: #fff
}

.bl_iconBox_title {
    color: #ff9955;
    font-size: 2.1rem;
    font-weight: 500
}

.bl_iconBox_text {
    margin-top: 19px
}

.bl_table {
    border-top: 1px solid #e4e1e1
}

.bl_table_item {
    border-bottom: 1px solid #e4e1e1
}

@media screen and (min-width: 48em) {
    .bl_table_item {
        display:-webkit-box;
        display: -ms-flexbox;
        display: flex
    }
}

.bl_table_data,.bl_table_title {
    padding: 14px 6%
}

@media screen and (min-width: 48em) {
    .bl_table_data,.bl_table_title {
        padding:18px 24px
    }
}

@media screen and (min-width: 64em) {
    .bl_table_data,.bl_table_title {
        padding:18px 16px 18px 64px
    }
}

.bl_table_title {
    background: #fff4ed
}

@media screen and (min-width: 48em) {
    .bl_table_title {
        -ms-flex-negative:0;
        flex-shrink: 0;
        width: 21%
    }
}

@media screen and (min-width: 64em) {
    .bl_table_title {
        width:17.5%
    }
}

.bl_table_data {
    width: 100%
}

@media screen and (min-width: 64em) {
    .bl_table_data {
        padding-left:74px
    }
}

.bl_pageLead_title {
    position: relative;
    padding-top: 6.1rem;
    color: #ff9955;
    font-family: "Shippori Mincho B1",serif;
    font-size: 2.8rem;
    font-weight: 500;
    line-height: 1.6;
    text-align: center;
    letter-spacing: 0.03em
}

@media screen and (min-width: 48em) {
    .bl_pageLead_title {
        padding-top:8.5rem;
        font-size: 3.2rem
    }
}

@media screen and (min-width: 64em) {
    .bl_pageLead_title {
        padding-top:11rem;
        font-size: 3.5rem
    }
}

.bl_pageLead_english {
    display: block;
    opacity: 0.3;
    position: absolute;
    top: 1.1rem;
    left: 50%;
    -webkit-transform: translateX(-50%);
    transform: translateX(-50%);
    color: #99ff55;
    font-family: "Noto Sans JP",cursive;
    font-size: 9.5rem;
    font-weight: 400;
    line-height: 1;
    white-space: nowrap
}

@media screen and (min-width: 48em) {
    .bl_pageLead_english {
        font-size:12.2rem
    }
}

@media screen and (min-width: 64em) {
    .bl_pageLead_english {
        font-size:15rem
    }
}

.bl_pageLead_text {
    max-width: 738px;
    margin: 16px auto 0;
    letter-spacing: 0.03em
}

@media screen and (min-width: 48em) {
    .bl_pageLead_text {
        margin-top:24px
    }
}

@media screen and (min-width: 64em) {
    .bl_pageLead_text {
        margin-top:32px
    }
}

.bl_pageLead_image {
    display: block;
    overflow: hidden;
    position: relative;
    margin-top: 40px
}

@media screen and (min-width: 48em) {
    .bl_pageLead_image {
        margin-top:62px
    }
}

@media screen and (min-width: 64em) {
    .bl_pageLead_image {
        margin-top:84px
    }
}

.bl_pageLead_image:before {
    display: block;
    content: "";
    width: 100%;
    padding-top: 40%
}

@media screen and (min-width: 48em) {
    .bl_pageLead_image:before {
        padding-top:27.4%
    }
}

.bl_pageLead_image img {
    position: absolute;
    top: 0;
    left: 0
}

.bl_columnPageLead {
    padding: 50px 0 60px;
    background: #fff4ed
}

@media screen and (min-width: 48em) {
    .bl_columnPageLead {
        padding:0
    }
}

.bl_columnPageLead__wide {
    position: relative;
    padding: 30px 0;
    background: url(../img/common/bg_pattern.svg)
}

@media screen and (min-width: 64em) {
    .bl_columnPageLead__wide {
        padding:0
    }
}

@media screen and (min-width: 48em) {
    .bl_columnPageLead_inner {
        display:-webkit-box;
        display: -ms-flexbox;
        display: flex;
        position: relative;
        -webkit-box-align: center;
        -ms-flex-align: center;
        align-items: center
    }
}

.bl_columnPageLead__wide .bl_columnPageLead_inner {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: reverse;
    -ms-flex-direction: column-reverse;
    flex-direction: column-reverse
}

@media screen and (min-width: 64em) {
    .bl_columnPageLead__wide .bl_columnPageLead_inner {
        position:static;
        display: block
    }
}

@media screen and (min-width: 48em) {
    .bl_columnPageLead_content {
        width:52%;
        padding: 63px 0
    }
}

@media screen and (min-width: 64em) {
    .bl_columnPageLead_content {
        padding:84px 0
    }
}

.bl_columnPageLead__wide .bl_columnPageLead_content {
    margin-top: 30px
}

@media screen and (min-width: 48em) {
    .bl_columnPageLead__wide .bl_columnPageLead_content {
        padding:0;
        width: 100%
    }
}

@media screen and (min-width: 64em) {
    .bl_columnPageLead__wide .bl_columnPageLead_content {
        padding:84px 0;
        width: 62%;
        margin-top: 0
    }
}

@media screen and (min-width: 90em) {
    .bl_columnPageLead__wide .bl_columnPageLead_content {
        padding:84px 0;
        width: 66%
    }
}

.bl_columnPageLead_title {
    color: #ff9955;
    font-size: 2rem;
    font-weight: 500
}

@media screen and (min-width: 48em) {
    .bl_columnPageLead_title {
        font-size:2.4rem
    }
}

@media screen and (min-width: 64em) {
    .bl_columnPageLead_title {
        font-size:2.6rem
    }
}

@media screen and (min-width: 64em) {
    .bl_columnPageLead_text {
        font-size:1.8rem
    }
}

.bl_columnPageLead_text:not(:first-child) {
    margin-top: 19px
}

.bl_columnPageLead_image {
    overflow: hidden;
    margin-top: 30px
}

@media screen and (min-width: 48em) {
    .bl_columnPageLead_image {
        position:absolute;
        top: 0;
        left: 54.16%;
        width: 56.6%;
        height: 100%;
        margin: 0
    }
}

@media screen and (min-width: 48em) {
    .bl_columnPageLead__wide .bl_columnPageLead_image {
        position:relative;
        top: auto;
        left: auto;
        width: 100%
    }
}

@media screen and (min-width: 64em) {
    .bl_columnPageLead__wide .bl_columnPageLead_image {
        position:absolute;
        -webkit-mask-image: url(../img/common/mask_skew_left.svg);
        mask-image: url(../img/common/mask_skew_left.svg);
        -webkit-mask-repeat: no-repeat;
        mask-repeat: no-repeat;
        -webkit-mask-size: auto 100%;
        mask-size: auto 100%;
        -webkit-mask-position: left top;
        mask-position: left top;
        -webkit-mask: url(../img/common/mask_skew_left.svg) no-repeat auto 100% left top;
        mask: url(../img/common/mask_skew_left.svg) no-repeat auto 100% left top;
        right: 0;
        top: 0;
        width: 37.5%
    }
}

.bl_columnPageLead_image:after,.bl_columnPageLead_image:before {
    background-image: url('data:image/svg+xml;utf-8,<svg xmlns="http://www.w3.org/2000/svg" width="115" height="410" viewBox="0 0 115 410"><path d="M0,0H115L0,410Z" fill="%23f2f6f9"/></svg>')
}

@media screen and (min-width: 48em) {
    .bl_columnPageLead_image:after {
        display:none
    }
}

@media screen and (min-width: 80em) {
    .bl_columnPageLead_image:after {
        display:block
    }
}

.bl_imagePageLead {
    position: relative;
    padding: 40px 0
}

@media screen and (min-width: 48em) {
    .bl_imagePageLead {
        padding:56px 0
    }
}

@media screen and (min-width: 64em) {
    .bl_imagePageLead {
        padding:74px 0
    }
}

@media screen and (min-width: 48em) {
    .bl_imagePageLead_text {
        text-align:center;
        letter-spacing: 0.03em
    }
}

@media screen and (min-width: 64em) {
    .bl_imagePageLead_text {
        font-size:1.8rem
    }
}

.bl_imagePageLead_background {
    position: absolute;
    top: 0;
    left: 0;
    z-index: -1;
    width: 100%;
    height: 100%;
    -webkit-clip-path: inset(0 0 0 0);
    clip-path: inset(0 0 0 0)
}

.bl_imagePageLead_background img {
    position: fixed;
    top: 0;
    left: 0
}

.bl_pagePointLead {
    padding: 0 0 50px;
    background: #fff4ed
}

.bl_pagePointLead_head {
    position: relative;
    z-index: 2;
    padding: 42px 0 66.9%;
    text-align: center
}

@media screen and (min-width: 48em) {
    .bl_pagePointLead_head {
        padding:59px 0 calc(6.15rem + 70px)
    }
}

@media screen and (min-width: 64em) {
    .bl_pagePointLead_head {
        padding-top:76px
    }
}

@media screen and (min-width: 48em) {
    .bl_pagePointLead_content {
        width:50%
    }
}

@media screen and (min-width: 64em) {
    .bl_pagePointLead_content {
        width:45.66%
    }
}

.bl_pagePointLead_image {
    position: absolute;
    top: 0;
    left: 0;
    z-index: -1;
    width: 100%;
    height: 100%
}

.bl_pagePointLead_category {
    display: block;
    margin-bottom: 6px;
    font-family: "Noto Sans JP",sans-serif;
    font-size: 2.1rem;
    font-weight: 400;
    line-height: 1;
    text-align: center
}

@media screen and (min-width: 64em) {
    .bl_pagePointLead_category {
        margin-bottom:25px;
        font-size: 2.3rem
    }
}

.bl_pagePointLead_letter {
    display: inline-block;
    width: 2.4rem;
    height: 2.4rem;
    background: #ff9955;
    color: #fff
}

@media screen and (min-width: 64em) {
    .bl_pagePointLead_letter {
        width:2.9rem;
        height: 2.9rem;
        padding-top: 0.1em
    }
}

.bl_pagePointLead_letter:not(:first-child) {
    margin-left: 4px
}

@media screen and (min-width: 23.4375em) {
    .bl_pagePointLead_letter:not(:first-child) {
        margin-left:6px
    }
}

@media screen and (min-width: 48em) {
    .bl_pagePointLead_letter:not(:first-child) {
        margin-left:4px
    }
}

@media screen and (min-width: 64em) {
    .bl_pagePointLead_letter:not(:first-child) {
        margin-left:6px
    }
}

.bl_pagePointLead_feature {
    font-size: 3rem;
    font-weight: 500;
    letter-spacing: 0.03em
}

@media screen and (min-width: 48em) {
    .bl_pagePointLead_feature {
        margin-top:26px
    }
}

@media screen and (min-width: 64em) {
    .bl_pagePointLead_feature {
        font-size:3.2rem
    }
}

.bl_pagePointLead_title {
    font-family: "Shippori Mincho B1",serif;
    font-size: 3.2rem;
    font-weight: 500;
    line-height: 1.5625;
    letter-spacing: 0.03em
}

.bl_pagePointLead_keyword {
    color: #ff9955;
    font-size: 4rem
}

@media screen and (min-width: 48em) {
    .bl_pagePointLead_keyword {
        font-size:4.5rem
    }
}

@media screen and (min-width: 64em) {
    .bl_pagePointLead_keyword {
        font-size:5rem
    }
}

@media screen and (min-width: 48em) {
    .bl_pagePointLead_body {
        display:-webkit-box;
        display: -ms-flexbox;
        display: flex
    }
}

.bl_pagePointLead_item {
    position: relative;
    margin-top: calc(6.15rem + 20px);
    padding: calc(6.15rem + 16px) 6% 32px;
    background: #fff
}

@media screen and (min-width: 48em) {
    .bl_pagePointLead_item {
        width:32.5%;
        margin-top: 0;
        padding: calc(6.15rem + 16px) 1.83% 32px
    }
}

@media screen and (min-width: 64em) {
    .bl_pagePointLead_item {
        padding:calc(7.7rem + 20px) 1.83% 64px
    }
}

@media screen and (min-width: 48em) {
    .bl_pagePointLead_item:not(:nth-child(3n)) {
        margin-right:1.25%
    }
}

.bl_pagePointLead_label {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    position: relative;
    position: absolute;
    top: 0;
    left: 50%;
    -webkit-transform: translate(-50%,-50%);
    transform: translate(-50%,-50%);
    z-index: 2;
    width: 12.3rem;
    height: 12.3rem;
    margin: 0 auto;
    font-family: "Noto Sans JP",cursive;
    font-size: 2rem;
    line-height: 1.2;
    text-align: center;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center
}

@media screen and (min-width: 64em) {
    .bl_pagePointLead_label {
        width:15.4rem;
        height: 15.4rem;
        font-size: 2.5rem
    }
}

.bl_pagePointLead_label:after {
    position: absolute;
    top: 50%;
    left: 50%;
    -webkit-transform: translate(-50%,-50%) rotate(45deg);
    transform: translate(-50%,-50%) rotate(45deg);
    z-index: -1;
    content: "";
    width: 8.72rem;
    height: 8.72rem;
    border: 6px solid #fff;
    background: #f4e3d7
}

@media screen and (min-width: 64em) {
    .bl_pagePointLead_label:after {
        width:10.9rem;
        height: 10.9rem
    }
}

.bl_pagePointLead_number {
    display: block;
    margin: -0.125em 0 0 -0.25em;
    font-size: 2em;
    line-height: 1
}

.bl_pagePointLead_subTitle {
    color: #ff9955;
    font-family: "Shippori Mincho B1",serif;
    font-size: 1.8rem;
    font-weight: 500;
    text-align: center
}

@media screen and (min-width: 64em) {
    .bl_pagePointLead_subTitle {
        font-size:2.3rem
    }
}

.bl_pagePointLead_text {
    max-width: 300px;
    margin: 20px auto 0
}

@media screen and (min-width: 64em) {
    .bl_pagePointLead_text {
        margin-top:24px
    }
}

.bl_flow_icon:before,.bl_flow_item:before {
    content: "Step" counter(flow,decimal-leading-zero);
    font-family: "Noto Sans JP",cursive;
    font-size: 30px;
    font-weight: 400;
    line-height: 1.1;
    text-align: center;
    letter-spacing: 0.03em;
    white-space: nowrap;
    overflow: hidden;
    z-index: 2
}

.bl_flow {
    counter-reset: flow
}

.bl_flow_item {
    counter-increment: flow;
    position: relative
}

@media screen and (min-width: 48em) {
    .bl_flow_item {
        display:-webkit-box;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-orient: vertical;
        -webkit-box-direction: normal;
        -ms-flex-direction: column;
        flex-direction: column;
        -webkit-box-pack: center;
        -ms-flex-pack: center;
        justify-content: center;
        min-height: 120px;
        padding-left: 160px
    }
}

@media screen and (min-width: 48em) {
    .bl_flow_item__hasComment {
        display:block;
        min-height: 0
    }
}

.bl_flow_item:not(:first-child) {
    margin-top: 70px
}

@media screen and (min-width: 48em) {
    .bl_flow_item:not(:first-child) {
        margin-top:20px
    }
}

.bl_flow__hasIcon .bl_flow_item:not(:first-child) {
    margin-top: 87px
}

@media screen and (min-width: 48em) {
    .bl_flow__hasIcon .bl_flow_item:not(:first-child) {
        margin-top:61px
    }
}

.bl_flow_item:before {
    color: #fff;
    width: 120px;
    height: 120px;
    background: #ff9955;
    border-radius: 50%;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    margin: 0 auto
}

@media screen and (min-width: 48em) {
    .bl_flow_item:before {
        position:absolute;
        top: 0;
        left: 0
    }
}

.bl_flow__hasIcon .bl_flow_item:before {
    content: none
}

@media screen and (min-width: 48em) {
    .bl_flow_item:not(:last-child) {
        padding-bottom:60px
    }
}

@media screen and (min-width: 48em) {
    .bl_flow__hasIcon .bl_flow_item:not(:last-child) {
        padding-bottom:0
    }
}

.bl_flow_item:not(:last-child):after {
    content: "";
    border-left: 2px dotted #ff9955;
    position: absolute;
    left: 50%;
    height: 30px;
    bottom: -50px
}

@media screen and (min-width: 48em) {
    .bl_flow_item:not(:last-child):after {
        height:calc(100% - 140px);
        left: 59px;
        bottom: 0
    }
}

.bl_flow__hasIcon .bl_flow_item:not(:last-child):after {
    height: 28px;
    bottom: -53px
}

@media screen and (min-width: 48em) {
    .bl_flow__hasIcon .bl_flow_item:not(:last-child):after {
        height:calc(100% - 102px);
        bottom: -38px
    }
}

@media screen and (min-width: 80em) {
    .bl_flow__hasIcon .bl_flow_item:not(:last-child):after {
        height:calc(50% - 42px)
    }
}

.bl_flow_icon {
    width: 120px;
    height: 120px;
    border-radius: 50%;
    background: #fff4ed;
    text-align: center;
    padding: 7px 25px 0;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    margin: 0 auto
}

@media screen and (min-width: 48em) {
    .bl_flow_icon {
        position:absolute;
        left: 0;
        top: 0
    }
}

@media screen and (min-width: 80em) {
    .bl_flow_icon {
        top:50%;
        -webkit-transform: translateY(-50%);
        transform: translateY(-50%)
    }
}

.bl_flow_icon:before {
    top: -7px;
    position: absolute;
    left: 0;
    color: #ff9955;
    width: 100%
}

@media screen and (min-width: 48em) {
    .bl_flow_icon:before {
        width:120px
    }
}

.bl_flow_title {
    font-size: 2rem;
    font-weight: 500;
    letter-spacing: 0.03em;
    margin-top: 20px;
    text-align: center
}

@media screen and (min-width: 48em) {
    .bl_flow_title {
        text-align:left;
        margin-top: 0
    }
}

@media screen and (min-width: 64em) {
    .bl_flow_title {
        font-size:2.3rem
    }
}

.bl_flow__hasIcon .bl_flow_title {
    margin-top: 15px
}

@media screen and (min-width: 48em) {
    .bl_flow__hasIcon .bl_flow_title {
        margin-top:0
    }
}

.bl_flow_text {
    margin-top: 10px
}

.bl_flow_comment {
    margin-top: 25px
}

@media screen and (min-width: 48em) {
    .bl_flow_comment {
        margin-top:40px
    }
}

.bl_imageFlow {
    counter-reset: imageFlow
}

@media screen and (min-width: 48em) {
    .bl_imageFlow {
        display:-webkit-box;
        display: -ms-flexbox;
        display: flex;
        -ms-flex-wrap: wrap;
        flex-wrap: wrap
    }
}

.bl_imageFlow_item {
    position: relative;
    z-index: 2;
    counter-increment: imageFlow;
    background: #ff9955
}

@media screen and (min-width: 48em) {
    .bl_imageFlow_item {
        display:-webkit-box;
        display: -ms-flexbox;
        display: flex;
        width: 48.66%;
        -webkit-box-align: end;
        -ms-flex-align: end;
        align-items: flex-end
    }
}

.bl_imageFlow_item:not(:first-child) {
    margin-top: 16px
}

@media screen and (min-width: 48em) {
    .bl_imageFlow_item:not(:first-child) {
        margin-top:0
    }
}

@media screen and (min-width: 48em) {
    .bl_imageFlow_item:nth-child(odd) {
        margin-right:2.68%
    }
}

@media screen and (min-width: 48em) {
    .bl_imageFlow_item:nth-child(2)~.bl_imageFlow_item {
        margin-top:30px
    }
}

.bl_imageFlow_item:before {
    position: absolute;
    top: 10px;
    left: 10px;
    content: counter(imageFlow,decimal-leading-zero);
    width: 1.324em;
    height: 1.324em;
    padding: 0.05em 0 0 0.1em;
    border-radius: 50%;
    background: #ff9955;
    color: #fff;
    font-family: "Noto Sans JP",cursive;
    font-size: 3rem;
    font-weight: 400;
    line-height: 1.2;
    letter-spacing: 0.03em
}

@media screen and (min-width: 48em) {
    .bl_imageFlow_item:before {
        padding-left:0.05em;
        font-size: 3.4rem
    }
}

@media screen and (min-width: 64em) {
    .bl_imageFlow_item:before {
        top:20px;
        left: 20px;
        font-size: 3.7rem
    }
}

.bl_imageFlow_inner {
    width: 100%;
    padding-top: 47.6%
}

.bl_imageFlow_item__noText .bl_imageFlow_inner {
    padding-top: 61.815%
}

.bl_imageFlow_image {
    position: absolute;
    top: 0;
    left: 0;
    z-index: -1
}

.bl_imageFlow_text {
    padding: 8.39% 8px 10px;
    background: -webkit-gradient(linear,left top,left bottom,from(rgba(51,51,51,0)),to(rgba(51,51,51,0.6)));
    background: linear-gradient(rgba(51,51,51,0) 0%,rgba(51,51,51,0.6) 100%);
    color: #fff;
    font-size: 1.4rem;
    line-height: 1.5;
    text-align: center
}

@media screen and (min-width: 64em) {
    .bl_imageFlow_text {
        font-size:1.6rem
    }
}

.bl_flowSimple {
    counter-reset: flowSimple
}

.bl_flowSimple_item {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    position: relative;
    counter-increment: flowSimple
}

.bl_flowSimple_item:before {
    -ms-flex-negative: 0;
    flex-shrink: 0;
    content: counter(flowSimple,decimal-leading-zero);
    width: 3.7rem;
    max-width: 40%;
    height: 3.7rem;
    margin-right: 13px;
    padding: 0.2em 0.125em 0 0;
    border-radius: 50%;
    border: 1px solid;
    background: #fff;
    color: #ff9955;
    font-family: "Noto Sans JP",cursive;
    font-size: 2.3rem;
    line-height: 1.2;
    text-align: center;
    letter-spacing: 0.03em
}

@media screen and (min-width: 48em) {
    .bl_flowSimple_item:before {
        padding-top:0.125em;
        padding-right: 0.25em
    }
}

.bl_flowSimple_item:not(:last-child) {
    padding-bottom: 28px
}

.bl_flowSimple_item:not(:last-child):after {
    position: absolute;
    top: 0;
    left: 1.85rem;
    z-index: -1;
    content: "";
    width: 1px;
    height: 100%;
    background: #ff9955
}

.bl_flowSimple_title {
    margin-bottom: 4px;
    color: #ff9955;
    font-size: 1.8rem;
    font-weight: 500
}

@media screen and (min-width: 64em) {
    .bl_flowSimple_title {
        font-size:2rem
    }
}

.bl_faq_item {
    border-bottom: 1px solid #e4e1e1
}

.bl_faq__open .bl_faq_item {
    padding-bottom: 38px
}

.bl_faq__open .bl_faq_item:not(:first-child) {
    margin-top: 29px
}

.bl_faq_title {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    position: relative;
    width: 100%;
    padding: 25px 27px 25px 0;
    font-size: 1.8rem;
    font-weight: 500;
    text-align: left;
    letter-spacing: 0.03em;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center
}

@media screen and (min-width: 64em) {
    .bl_faq_title {
        font-size:2rem
    }
}

.bl_faq__open .bl_faq_title {
    padding: 0
}

.bl_faq_title:before {
    display: block;
    -ms-flex-negative: 0;
    flex-shrink: 0;
    content: "";
    width: 39px;
    max-width: 30%;
    height: 39px;
    margin-right: 10px;
    border-radius: 50%;
    background: #ff9955 url(../img/common/icon_q_white.svg) no-repeat center center;
    background-size: 23px auto
}

.bl_faq_content {
    padding: 25px 30px;
    background: #fff4ed
}

@media screen and (min-width: 48em) {
    .bl_faq_content {
        padding:25px 47px
    }
}

.bl_faq__open .bl_faq_content {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    margin-top: 30px;
    padding: 0 0 0 12px
}

.bl_faq__open .bl_faq_content:before {
    display: block;
    -ms-flex-negative: 0;
    flex-shrink: 0;
    content: "";
    width: 24px;
    max-width: 30%;
    height: 24px;
    margin-right: 12px;
    background: url(../img/common/icon_a.svg) no-repeat center center;
    background-size: contain
}

.bl_faq_inner {
    max-width: 978px
}

.bl_faq_subContent {
    margin-top: 32px;
    padding: 23px 6% 34px 47px;
    background: #fff
}

@media screen and (min-width: 48em) {
    .bl_faq_subContent {
        padding-right:47px
    }
}

.bl_faq_subItem:not(:first-child) {
    margin-top: 25px
}

.bl_accordion_toggle {
    padding-right: calc(6% + 27px)
}

.bl_accordion_toggle__fill {
    position: relative;
    width: 100%;
    padding-top: 17px;
    padding-bottom: 17px;
    padding-left: 6%;
    background: #fff4ed;
    font-size: 1.8rem;
    font-weight: 500;
    text-align: left
}

@media screen and (min-width: 64em) {
    .bl_accordion_toggle__fill {
        padding-left:39px;
        font-size: 2rem
    }
}

.bl_accordion_icon {
    position: absolute;
    top: 50%;
    right: 6%;
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
    width: 19px;
    height: 19px;
    pointer-events: none
}

@media screen and (min-width: 48em) {
    .bl_accordion_icon {
        right:27px
    }
}

.bl_accordion_icon:after,.bl_accordion_icon:before {
    position: absolute;
    top: 50%;
    left: 0;
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
    content: "";
    width: 100%;
    height: 2px;
    background: #ff9955
}

.bl_accordion_icon:after {
    -webkit-transform: translateY(-50%) rotate(90deg);
    transform: translateY(-50%) rotate(90deg);
    -webkit-transition: -webkit-transform 0.5s ease;
    transition: -webkit-transform 0.5s ease;
    transition: transform 0.5s ease;
    transition: transform 0.5s ease,-webkit-transform 0.5s ease
}

.is_open .bl_accordion_icon:after {
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%)
}

.bl_accordion_content {
    margin-top: 30px
}

.bl_categoryList {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    margin-bottom: -4px
}

.bl_categoryList_item {
    margin-bottom: 4px
}

.bl_categoryList_item:not(:last-child) {
    margin-right: 8px
}

.bl_categoryList_inner {
    display: block;
    padding: 0 9px;
    background: #ff9955;
    color: #fff;
    font-size: 1.4rem
}

.bl_articleMeta {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center
}

.bl_articleMeta__hasUpdateDate {
    display: block;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    margin-bottom: -4px
}

@media screen and (min-width: 48em) {
    .bl_articleMeta__hasUpdateDate {
        display:-webkit-box;
        display: -ms-flexbox;
        display: flex
    }
}

.bl_articleMeta_date {
    margin-right: 20px
}

.bl_articleMeta__hasupdatedate .bl_articleMeta_date {
    margin-right: 25px;
    margin-bottom: 4px
}

.bl_articleMeta__hasupdatedate .bl_articleMeta_date:not(:first-child) {
    margin-right: 0
}

@media screen and (min-width: 48em) {
    .bl_articleMeta__hasupdatedate .bl_articleMeta_date:not(:first-child) {
        margin-right:25px
    }
}

.bl_articleMeta_category {
    margin-top: 0.25em
}

.bl_articleMeta__hasupdatedate .bl_articleMeta_category {
    margin-top: 0;
    margin-bottom: 0
}

.bl_simpleArticleList_item:not(:first-child) {
    margin-top: 9px;
    padding-top: 12px;
    border-top: 1px solid #e4e1e1
}

@media screen and (min-width: 48em) {
    .bl_simpleArticleList_item:not(:first-child) {
        margin-top:18px;
        padding-top: 24px
    }
}

.bl_simpleArticleList_link:hover .bl_simpleArticleList_title {
    color: #55798a
}

.bl_simpleArticleList_link:focus-visible .bl_simpleArticleList_title {
    color: #55798a
}

:root .bl_simpleArticleList_link:focus .bl_simpleArticleList_title,_:-ms-fullscreen .bl_simpleArticleList_title {
    color: #55798a
}

.bl_simpleArticleList_meta {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center
}

.bl_simpleArticleList_date {
    margin-right: 15px
}

.bl_simpleArticleList_title {
    margin-top: 14px;
    font-size: 1.6rem;
    font-weight: 400;
    text-decoration: underline;
    -webkit-transition: color 0.5s ease;
    transition: color 0.5s ease
}

.bl_articleList_page {
    font-size: 1.6rem;
    text-align: center
}

@media screen and (min-width: 64em) {
    .bl_articleList_page {
        font-size:1.8rem
    }
}

.bl_articleList_count {
    color: #ff9955;
    font-size: 2rem
}

@media screen and (min-width: 64em) {
    .bl_articleList_count {
        font-size:2.3rem
    }
}

.bl_articleList_list:not(:first-child) {
    margin-top: 32px
}

@media screen and (min-width: 48em) {
    .bl_articleList_list:not(:first-child) {
        margin-top:47px
    }
}

@media screen and (min-width: 64em) {
    .bl_articleList_list:not(:first-child) {
        margin-top:62px
    }
}

.bl_articleList_item {
    padding-bottom: 24px;
    border-bottom: 1px solid #e4e1e1
}

@media screen and (min-width: 48em) {
    .bl_articleList_item {
        padding-bottom:32px
    }
}

@media screen and (min-width: 64em) {
    .bl_articleList_item {
        padding-bottom:42px
    }
}

.bl_articleList_item:not(:first-child) {
    margin-top: 26px
}

@media screen and (min-width: 48em) {
    .bl_articleList_item:not(:first-child) {
        margin-top:34px
    }
}

@media screen and (min-width: 64em) {
    .bl_articleList_item:not(:first-child) {
        margin-top:44px
    }
}

.bl_articleList__hasThumbnail .bl_articleList_item {
    padding-bottom: 25px
}

.bl_articleList__hasThumbnail .bl_articleList_item:not(:first-child) {
    margin-top: 25px
}

.bl_articleList__search .bl_articleList_item {
    padding-bottom: 28px
}

.bl_articleList__search .bl_articleList__search .bl_articleList_item:not(:first-child) {
    margin-top: 34px
}

.bl_articleList_link:hover .bl_articleList_title {
    color: #ff9955
}

.bl_articleList_link:focus-visible .bl_articleList_title {
    color: #ff9955
}

:root .bl_articleList_link:focus .bl_articleList_title,_:-ms-fullscreen .bl_articleList_title {
    color: #ff9955
}

.bl_articleList__hasThumbnail .bl_articleList_link,.bl_articleList__search .bl_articleList_link {
    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;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-align: start;
    -ms-flex-align: start;
    align-items: flex-start
}

.bl_articleList_meta__wide {
    width: 100%;
    margin-bottom: 8px
}

@media screen and (min-width: 48em) {
    .bl_articleList_meta__wide {
        display:none
    }
}

.bl_articleList_meta__inContent {
    display: none
}

@media screen and (min-width: 48em) {
    .bl_articleList_meta__inContent {
        display:-webkit-box;
        display: -ms-flexbox;
        display: flex
    }
}

.bl_articleList_content {
    width: 67.1%;
    margin: 0 0 0 3.5%
}

.bl_articleList__search .bl_articleList_content {
    width: 73.66%;
    margin: 0 0 0 5.54%
}

.bl_articleList_image {
    width: 29.4%
}

.bl_articleList__search .bl_articleList_image {
    width: 20.8%;
    border: 1px solid #e4e1e1
}

.bl_articleList_title {
    font-size: 2rem;
    font-weight: 500;
    line-height: 1.45;
    -webkit-transition: color 0.5s ease;
    transition: color 0.5s ease
}

@media screen and (min-width: 48em) {
    .bl_articleList_title {
        font-size:2.2rem
    }
}

@media screen and (min-width: 64em) {
    .bl_articleList_title {
        font-size:2.4rem
    }
}

.bl_articleList_title:not(:first-child) {
    margin-top: 18px
}

.bl_articleList__hasThumbnail .bl_articleList_title {
    margin-top: 0;
    font-size: 1.8rem;
    line-height: 1.59
}

@media screen and (min-width: 48em) {
    .bl_articleList__hasThumbnail .bl_articleList_title {
        margin-top:12px;
        font-size: 2rem
    }
}

@media screen and (min-width: 64em) {
    .bl_articleList__hasThumbnail .bl_articleList_title {
        font-size:2.2rem
    }
}

.bl_articleList__search .bl_articleList_title {
    font-size: 1.8rem;
    text-decoration: underline
}

.bl_articleList_text {
    margin-top: 14px
}

.bl_articleList_url {
    margin-top: 14px;
    font-weight: 500
}

.bl_articleList_pager {
    margin-top: 54px
}

@media screen and (min-width: 48em) {
    .bl_articleList_pager {
        margin-top:80px
    }
}

@media screen and (min-width: 64em) {
    .bl_articleList_pager {
        margin-top:108px
    }
}

.bl_card_link {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: reverse;
    -ms-flex-direction: column-reverse;
    flex-direction: column-reverse
}

.bl_card_link:hover .bl_card_title {
    padding-bottom: 0.125em;
    border-bottom-color: currentColor
}

.bl_card_link:focus-visible .bl_card_title {
    padding-bottom: 0.125em;
    border-bottom-color: currentColor
}

:root .bl_card_link:focus .bl_card_title,_:-ms-fullscreen .bl_card_title {
    padding-bottom: 0.125em;
    border-bottom-color: currentColor
}

.bl_card__imageFrame .bl_card_link:hover .bl_card_image:after {
    opacity: 0.4
}

.bl_card__imageFrame .bl_card_link:hover .bl_card_title {
    padding-bottom: 0
}

.bl_card__imageFrame .bl_card_link:focus-visible .bl_card_image:after {
    opacity: 0.4
}

.bl_card__imageFrame .bl_card_link:focus-visible .bl_card_title {
    padding-bottom: 0
}

:root .bl_card__imageFrame .bl_card_link:focus .bl_card_image:after,_:-ms-fullscreen .bl_card_image:after {
    opacity: 0.4
}

:root .bl_card__imageFrame .bl_card_link:focus .bl_card_title,_:-ms-fullscreen .bl_card_title {
    padding-bottom: 0
}

.bl_card__mobileColumn .bl_card_link {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: reverse;
    -ms-flex-direction: row-reverse;
    flex-direction: row-reverse;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap
}

@media screen and (min-width: 48em) {
    .bl_card__mobileColumn .bl_card_link {
        -webkit-box-orient:vertical;
        -webkit-box-direction: reverse;
        -ms-flex-direction: column-reverse;
        flex-direction: column-reverse
    }
}

:where(.bl_card__imageFrame) .bl_card_image {
    position: relative;
    padding: 10px;
    background: #fff4ed
}

:where(.bl_card__imageFrame) .bl_card_image:after {
    opacity: 0;
    position: absolute;
    top: 10px;
    left: 10px;
    content: "";
    width: calc(100% - 20px);
    height: calc(100% - 20px);
    background: #333;
    -webkit-transition: opacity 0.5s linear;
    transition: opacity 0.5s linear
}

:where(.bl_card__imageFrame.bl_card__inBackground) .bl_card_image {
    background: #fff
}

.bl_card_head {
    position: relative
}

.bl_card__mobileColumn .bl_card_head {
    width: 36%
}

@media screen and (min-width: 48em) {
    .bl_card__mobileColumn .bl_card_head {
        width:100%
    }
}

.bl_card_content {
    margin-top: 12px
}

.bl_card__imageFrame .bl_card_content {
    margin-top: 20px
}

@media not screen and (min-width: 48em) {
    .bl_card__mobileColumn .bl_card_content {
        width:60%;
        margin: 0 0 0 4%
    }
}

.bl_card_meta {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    width: 100%;
    margin-bottom: 8px
}

@media screen and (min-width: 48em) {
    .bl_card_meta {
        display:none
    }
}

.bl_card_category {
    overflow: hidden;
    position: absolute;
    bottom: 0;
    left: 0;
    color: #929292;
    white-space: nowrap
}

:where(.bl_card__imageFrame) .bl_card_category {
    position: static;
    margin-top: 16px;
    color: inherit;
    white-space: normal
}

.bl_card_category__inMeta {
    position: static;
    white-space: normal
}

@media screen and (min-width: 48em) {
    .bl_card_category__inMeta {
        display:none
    }
}

.bl_card_category__inImage {
    display: none
}

@media screen and (min-width: 48em) {
    .bl_card_category__inImage {
        display:-webkit-box;
        display: -ms-flexbox;
        display: flex
    }
}

.bl_card_date {
    color: #989696;
    font-size: 1.4rem
}

.bl_card_date__inMeta {
    margin-right: 16px
}

.bl_card_date__inContent {
    display: none
}

@media screen and (min-width: 48em) {
    .bl_card_date__inContent {
        display:block
    }
}

.bl_card_title {
    display: inline;
    border-bottom: 1px solid transparent;
    font-size: 1.6rem;
    font-weight: 400;
    -webkit-transition: border 0.5s ease,padding 0.5s ease;
    transition: border 0.5s ease,padding 0.5s ease
}

:where(.bl_card__imageFrame) .bl_card_title {
    border: none;
    font-size: 1.8rem
}

.bl_searchForm_text {
    color: #ff9955;
    text-align: center
}

.bl_searchForm_body {
    position: relative;
    max-width: 521px;
    margin: 13px auto 0
}

.bl_searchForm_input {
    width: 100%;
    padding: 9px 50px 12px 26px;
    border: 2px solid
}

.bl_searchForm_input:focus {
    border-color: #ff9955
}

.bl_searchForm_input::-moz-placeholder,.bl_searchForm_input::-ms-input-placeholder,.bl_searchForm_input::-webkit-input-placeholder {
    color: #c9c7c7
}

.bl_searchForm_input:-webkit-autofill {
    -webkit-box-shadow: 0 0 0 1000px #fff inset;
    box-shadow: 0 0 0 1000px #fff inset
}

.bl_searchForm_button {
    position: absolute;
    top: 50%;
    right: 17px;
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
    z-index: 2
}

.bl_searchForm_icon {
    display: block;
    width: 25px
}

.bl_document_name {
    color: #ff9955;
    font-family: "Shippori Mincho B1",serif;
    font-size: 2.8rem;
    font-weight: 500;
    text-align: center;
    letter-spacing: 0.03em
}

@media screen and (min-width: 48em) {
    .bl_document_name {
        font-size:3.2rem
    }
}

@media screen and (min-width: 64em) {
    .bl_document_name {
        font-size:3.5rem
    }
}

@media screen and (min-width: 48em) {
    .bl_document_name+.bl_document_item:not(:first-child) {
        margin-top:53px
    }
}

@media screen and (min-width: 64em) {
    .bl_document_name+.bl_document_item:not(:first-child) {
        margin-top:67px
    }
}

.bl_document_item:not(:first-child) {
    margin-top: 40px
}

@media screen and (min-width: 48em) {
    .bl_document_item:not(:first-child) {
        margin-top:58px
    }
}

@media screen and (min-width: 64em) {
    .bl_document_item:not(:first-child) {
        margin-top:76px
    }
}

.bl_document_title {
    position: relative;
    padding-left: 34px;
    font-family: "Shippori Mincho B1",serif;
    font-size: 2rem;
    font-weight: 500
}

@media screen and (min-width: 48em) {
    .bl_document_title {
        font-size:2.2rem
    }
}

@media screen and (min-width: 64em) {
    .bl_document_title {
        font-size:2.5rem
    }
}

.bl_document_title:before {
    position: absolute;
    top: 0.9375em;
    left: 0;
    content: "";
    width: 20px;
    height: 1px;
    background: #ff9955
}

.bl_document_subItem:not(:first-child) {
    margin-top: 20px
}

@media screen and (min-width: 48em) {
    .bl_document_subItem:not(:first-child) {
        margin-top:28px
    }
}

@media screen and (min-width: 64em) {
    .bl_document_subItem:not(:first-child) {
        margin-top:38px
    }
}

.bl_document_subTitle {
    font-size: 1.6rem;
    font-weight: 500
}

.bl_document_content {
    margin-top: 21px
}

.bl_document_text:not(:first-child) {
    margin-top: 16px
}

.bl_share {
    border-bottom: 1px solid #e4e1e1;
    padding-bottom: 15px
}

.bl_share_head {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center
}

.bl_share_head:after,.bl_share_head:before {
    content: "";
    width: 100%;
    height: 1px;
    background: #e4e1e1;
    display: block
}

.bl_share_title {
    color: #ff9955;
    font-family: "Noto Sans JP",cursive;
    -ms-flex-negative: 0;
    flex-shrink: 0;
    letter-spacing: 0.03em;
    font-size: 2.2rem;
    line-height: 1;
    margin: 0 16px
}

.bl_share_list {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    margin-top: 15px;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center
}

.bl_share_item {
    width: 30px
}

.bl_share_item:not(:first-child) {
    margin-left: 30px
}

.bl_share_link {
    display: block
}

.bl_share_link:hover {
    opacity: 0.7
}

.bl_share_link:focus-visible {
    opacity: 0.7
}

:root .bl_share_link:focus,_:-ms-fullscreen {
    opacity: 0.7
}

.bl_bannerLead {
    background: #f4e3d7;
    padding: 12% 6%;
    position: relative;
    overflow: hidden;
    z-index: 2
}

@media screen and (min-width: 48em) {
    .bl_bannerLead {
        padding:4% 6%;
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-align: center;
        -ms-flex-align: center;
        align-items: center
    }
}

@media screen and (min-width: 64em) {
    .bl_bannerLead {
        min-height:405px;
        padding: 52px 74px 48px
    }
}

.bl_bannerLead:before {
    width: 29.5%;
    padding-top: 29.5%;
    display: block
}

@media screen and (min-width: 48em) {
    .bl_bannerLead:before {
        content:""
    }
}

.bl_bannerLead:after {
    content: "";
    position: absolute;
    width: calc(100% - 24px);
    height: calc(100% - 24px);
    top: 12px;
    left: 12px;
    border: 2px solid #fff;
    pointer-events: none
}

@media screen and (min-width: 48em) {
    .bl_bannerLead__background:before {
        content:none
    }
}

@media screen and (min-width: 64em) {
    .bl_bannerLead__background {
        padding:74px 64px
    }
}

.bl_bannerLead__noFrame {
    padding: 32px 4px 47px
}

@media screen and (min-width: 64em) {
    .bl_bannerLead__noFrame {
        padding:50px 5% 40px;
        min-height: 0
    }
}

.bl_bannerLead__noFrame:after {
    content: none
}

@media screen and (min-width: 64em) {
    .bl_bannerLead__low {
        padding:48px;
        min-height: 0
    }
}

@media screen and (min-width: 48em) {
    .bl_bannerLead_inner {
        width:66%;
        margin-left: auto
    }
}

@media screen and (min-width: 48em) {
    .bl_bannerLead__background .bl_bannerLead_inner {
        width:100%
    }
}

.bl_bannerLead__noFrame .bl_bannerLead_inner {
    margin: 0 auto
}

.bl_bannerLead_title {
    font-size: 1.8rem;
    font-weight: 500;
    font-family: "Shippori Mincho B1",serif;
    text-align: center;
    line-height: 1.7
}

@media screen and (min-width: 48em) {
    .bl_bannerLead_title {
        line-height:1.57;
        text-align: left;
        font-size: 2.6rem
    }
}

@media screen and (min-width: 64em) {
    .bl_bannerLead_title {
        font-size:3.2rem
    }
}

@media screen and (min-width: 90em) {
    .bl_bannerLead_title {
        font-size:3.6rem
    }
}

.bl_bannerLead__background .bl_bannerLead_title {
    text-align: center
}

@media screen and (min-width: 48em) {
    .bl_bannerLead__background .bl_bannerLead_title {
        font-size:2.8rem
    }
}

@media screen and (min-width: 64em) {
    .bl_bannerLead__background .bl_bannerLead_title {
        font-size:3.8rem
    }
}

.bl_bannerLead__noFrame .bl_bannerLead_title {
    line-height: 1.66
}

@media screen and (min-width: 48em) {
    .bl_bannerLead__noFrame .bl_bannerLead_title {
        line-height:1.875;
        font-size: 2.5rem
    }
}

@media screen and (min-width: 64em) {
    .bl_bannerLead__noFrame .bl_bannerLead_title {
        font-size:3.2rem
    }
}

.bl_bannerLead_image {
    margin-top: 16px
}

@media screen and (min-width: 48em) {
    .bl_bannerLead_image {
        margin:0;
        left: 3.8%;
        top: 50%;
        -webkit-transform: translateY(-50%);
        transform: translateY(-50%);
        width: 30.8%;
        position: absolute
    }
}

.bl_bannerLead_content {
    text-align: center;
    margin-top: 16px;
    font-size: 1.5rem;
    font-weight: 500
}

@media screen and (min-width: 48em) {
    .bl_bannerLead_content {
        text-align:left;
        margin-top: 24px
    }
}

@media screen and (min-width: 64em) {
    .bl_bannerLead_content {
        margin-top:30px
    }
}

.bl_bannerLead__background .bl_bannerLead_content {
    margin-top: 20px
}

@media screen and (min-width: 48em) {
    .bl_bannerLead__background .bl_bannerLead_content {
        margin-top:30px;
        text-align: center
    }
}

@media screen and (min-width: 64em) {
    .bl_bannerLead__background .bl_bannerLead_content {
        margin-top:38px
    }
}

.bl_bannerLead_content__pcOnly {
    display: none
}

@media screen and (min-width: 64em) {
    .bl_bannerLead_content__pcOnly {
        display:block
    }
}

@media screen and (min-width: 64em) {
    .bl_bannerLead_text {
        font-size:1.8rem
    }
}

.bl_bannerLead_text:not(:first-child) {
    margin-top: 8px
}

@media screen and (min-width: 48em) {
    .bl_bannerLead_text:not(:first-child) {
        margin-top:12px
    }
}

@media screen and (min-width: 64em) {
    .bl_bannerLead_text:not(:first-child) {
        margin-top:18px
    }
}

.bl_bannerLead__background .bl_bannerLead_text {
    margin-top: 29px
}

@media screen and (min-width: 48em) {
    .bl_bannerLead__background .bl_bannerLead_text {
        font-size:1.8rem
    }
}

@media screen and (min-width: 64em) {
    .bl_bannerLead__background .bl_bannerLead_text {
        font-size:2rem
    }
}

.bl_bannerLead_point {
    color: #ff9955;
    line-height: 2
}

@media screen and (min-width: 48em) {
    .bl_bannerLead_point {
        font-size:2rem
    }
}

@media screen and (min-width: 80em) {
    .bl_bannerLead_point {
        font-size:2.3rem
    }
}

.bl_bannerLead__background .bl_bannerLead_point {
    background: #ff9955;
    color: #fff;
    font-size: 1.4rem;
    letter-spacing: 0.05em;
    max-width: 950px;
    margin: 0 auto;
    padding: 1px 8px
}

@media screen and (min-width: 48em) {
    .bl_bannerLead__background .bl_bannerLead_point {
        font-size:2rem
    }
}

@media screen and (min-width: 64em) {
    .bl_bannerLead__background .bl_bannerLead_point {
        font-size:2.5rem;
        letter-spacing: 0.1em
    }
}

.bl_bannerLead_point__ribbon {
    max-width: calc(100% - 24px);
    position: relative;
    display: inline-block;
    font-weight: 500;
    line-height: 1.5
}

.bl_bannerLead__background .bl_bannerLead_point__ribbon {
    padding: 8px 18px
}

@media screen and (min-width: 48em) {
    .bl_bannerLead__background .bl_bannerLead_point__ribbon {
        font-size:1.8rem
    }
}

.bl_bannerLead_point__ribbon:after,.bl_bannerLead_point__ribbon:before {
    content: "";
    height: 100%;
    width: 12px;
    position: absolute;
    background: url(../img/common/shape_ribbon.svg) no-repeat;
    top: 0;
    background-size: 100% 100%
}

.bl_bannerLead_point__ribbon:before {
    right: 100%;
    -webkit-transform: scale(-1,1);
    transform: scale(-1,1)
}

.bl_bannerLead_point__ribbon:after {
    left: 100%
}

.bl_bannerLead_point__left {
    text-align: left
}

.bl_bannerLead_keyword {
    color: #ff9955
}

.bl_bannerLead_small {
    font-size: 0.84em
}

.bl_bannerLead_background {
    position: absolute;
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
    z-index: -1
}

.bl_bannerSimple {
    max-width: 745px;
    margin: 0 auto
}

.bl_bannerSimple_link {
    overflow: hidden;
    background: #f4e3d7;
    position: relative;
    display: block;
    z-index: 2;
    padding: 0 14% 15px
}

@media screen and (min-width: 48em) {
    .bl_bannerSimple_link {
        display:-webkit-box;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-align: end;
        -ms-flex-align: end;
        align-items: flex-end;
        -webkit-box-pack: justify;
        -ms-flex-pack: justify;
        justify-content: space-between;
        padding: 0 12.75% 0 7.25%
    }
}

.bl_bannerSimple_link:hover {
    background: #fff4ed
}

.bl_bannerSimple_link:hover:before {
    border-bottom-color: #338000;
    border-right-color: #338000
}

.bl_bannerSimple_link:hover:after {
    right: 0
}

.bl_bannerSimple_link:focus-visible {
    background: #fff4ed
}

.bl_bannerSimple_link:focus-visible:before {
    border-bottom-color: #338000;
    border-right-color: #338000
}

.bl_bannerSimple_link:focus-visible:after {
    right: 0
}

:root .bl_bannerSimple_link:focus,_:-ms-fullscreen {
    background: #fff4ed
}

:root .bl_bannerSimple_link:focus:before,_:-ms-fullscreen:before {
    border-bottom-color: #338000;
    border-right-color: #338000
}

:root .bl_bannerSimple_link:focus:after,_:-ms-fullscreen:after {
    right: 0
}

.bl_bannerSimple_link:after,.bl_bannerSimple_link:before {
    content: "";
    position: absolute
}

.bl_bannerSimple_link:before {
    border: 23px solid transparent;
    border-bottom-color: #ff9955;
    border-right-color: #ff9955;
    -webkit-transition: border-color 0.5s ease;
    transition: border-color 0.5s ease;
    bottom: 0;
    right: 0
}

@media screen and (min-width: 48em) {
    .bl_bannerSimple_link:before {
        bottom:5px;
        right: 5px;
        border-width: 29px
    }
}

.bl_bannerSimple_link:after {
    background: url(../img/common/icon_arrow_right_white.svg) no-repeat;
    background-size: contain;
    -webkit-transition: right 0.5s ease;
    transition: right 0.5s ease;
    width: 31px;
    height: 10px;
    bottom: 7px;
    right: 4px
}

@media screen and (min-width: 48em) {
    .bl_bannerSimple_link:after {
        right:14px;
        bottom: 14px;
        width: 39px;
        height: 14px
    }
}

.bl_bannerSimple_image {
    display: none;
    width: 30.7%
}

@media screen and (min-width: 48em) {
    .bl_bannerSimple_image {
        display:block
    }
}

.bl_bannerSimple_english {
    position: absolute;
    font-size: 5.5rem;
    font-family: "Noto Sans JP",cursive;
    letter-spacing: 0.03em;
    color: #fff;
    top: 14px;
    left: 13px;
    line-height: 1;
    z-index: -1
}

@media screen and (min-width: 48em) {
    .bl_bannerSimple_english {
        top:18px;
        left: 37.5%;
        font-size: 7.8rem
    }
}

.bl_bannerSimple_text {
    font-weight: 500;
    font-family: "Shippori Mincho B1",serif;
    text-align: right;
    padding-top: 4.4rem;
    font-size: 1.6rem;
    display: block;
    line-height: 1.5
}

@media screen and (min-width: 48em) {
    .bl_bannerSimple_text {
        margin-left:16px;
        padding: 6.3rem 0 22px;
        font-size: 2.3rem
    }
}

.bl_bannerSimple_text:before {
    content: "";
    position: absolute;
    width: calc(100% - 10px);
    left: 5px;
    height: calc(100% - 10px);
    top: 5px;
    border: 1px dashed #F2F8FF;
    z-index: -1
}

.lp_bl_backgroundColor {
    padding: 0 0 103px;
    background: #bfd1e1
}

.lp_el_textLink {
    text-decoration: underline
}

.lp_el_textLink:hover {
    opacity: 0.7
}

.lp_el_textLink:focus-visible {
    opacity: 0.7
}

:root .lp_el_textLink:focus,_:-ms-fullscreen {
    opacity: 0.7
}

.lp_el_tel {
    line-height: 1.5;
    text-align: center
}

.lp_el_tel_link {
    display: inline-block;
    position: relative;
    padding-left: 28px;
    font-size: 2.6rem;
    font-weight: 500
}

.lp_el_tel_link:before {
    position: absolute;
    top: 50%;
    left: 0;
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
    content: "";
    width: 21px;
    height: 14px;
    background: url(../img/lp/common/icon_free.svg) no-repeat;
    background-size: contain
}

.lp_el_textDecoration {
    background: -webkit-gradient(linear,left top,left bottom,color-stop(70%,transparent),color-stop(70%,#eee06d));
    background: linear-gradient(transparent 70%,#eee06d 70%)
}

.lp_el_textDecoration__large {
    padding-bottom: 4px;
    border-bottom: 4px solid #eee06d;
    background: transparent;
    font-size: 2.2rem
}

@media screen and (min-width: 48em) {
    .lp_el_textDecoration__large {
        border-bottom-width:5px;
        font-size: 2.6rem
    }
}

.lp_el_price {
    font-size: 2.4rem;
    font-weight: 700;
    letter-spacing: 0.04em
}

@media screen and (min-width: 48em) {
    .lp_el_price {
        font-size:2.8rem
    }
}

.lp_el_price_num {
    color: #e96300;
    font-family: "Roboto",sans-serif;
    font-size: 3.2rem
}

@media screen and (min-width: 48em) {
    .lp_el_price_num {
        font-size:4rem
    }
}

.lp_el_price_tax {
    font-size: 1.6rem;
    font-weight: 400
}

@media screen and (min-width: 48em) {
    .lp_el_price_tax {
        font-size:2rem
    }
}

.lp_bl_faq_item:not(:last-child) {
    margin-bottom: 25px
}

.lp_bl_faq_content,.lp_bl_faq_toggle {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    padding: 18px 5%;
    font-size: 1.8rem;
    font-weight: 500;
    -webkit-box-align: stretch;
    -ms-flex-align: stretch;
    align-items: stretch
}

@media screen and (min-width: 48em) {
    .lp_bl_faq_content,.lp_bl_faq_toggle {
        padding:18px 40px;
        font-size: 2rem
    }
}

.lp_bl_faq_content:before,.lp_bl_faq_toggle:before {
    display: block;
    -ms-flex-negative: 0;
    flex-shrink: 0;
    content: "";
    width: 48px;
    height: 48px;
    margin-right: 5%;
    border-radius: 50%
}

@media screen and (min-width: 48em) {
    .lp_bl_faq_content:before,.lp_bl_faq_toggle:before {
        width:54px;
        height: 54px;
        margin-right: 31px
    }
}

.lp_bl_faq_toggle {
    position: relative;
    width: 100%;
    padding-right: calc(10% + 24px);
    background: #e8eff5;
    text-align: left
}

@media screen and (min-width: 48em) {
    .lp_bl_faq_toggle {
        padding-right:104px
    }
}

.lp_bl_faq_toggle:before {
    background: #365082 url(../img/lp/common/icon_q.svg) no-repeat center center
}

.lp_bl_faq_inner {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center
}

.lp_bl_faq_icon {
    position: absolute;
    top: 22px;
    right: 5%;
    width: 24px;
    height: 24px
}

@media screen and (min-width: 48em) {
    .lp_bl_faq_icon {
        top:34px;
        right: 40px
    }
}

.lp_bl_faq_icon:after,.lp_bl_faq_icon:before {
    position: absolute;
    top: 50%;
    left: 50%;
    content: "";
    width: 100%;
    height: 3px;
    background: #365082;
    -webkit-transition: -webkit-transform 0.5s ease;
    transition: -webkit-transform 0.5s ease;
    transition: transform 0.5s ease;
    transition: transform 0.5s ease,-webkit-transform 0.5s ease
}

.lp_bl_faq_icon:before {
    -webkit-transform: translate(-50%,-50%);
    transform: translate(-50%,-50%)
}

.lp_bl_faq_icon:after {
    -webkit-transform: translate(-50%,-50%) rotate(90deg);
    transform: translate(-50%,-50%) rotate(90deg)
}

.is_open .lp_bl_faq_icon:after {
    -webkit-transform: translate(-50%,-50%);
    transform: translate(-50%,-50%)
}

.lp_bl_faq_content {
    border: 1px solid #e8eff5
}

.lp_bl_faq_content:before {
    background: #e8eff5 url(../img/lp/common/icon_a.svg) no-repeat center center
}

.lp_bl_imageContent_title {
    color: #ff9955;
    font-size: 2rem;
    font-weight: 900;
    text-align: center
}

.lp_bl_imageContent_img {
    margin-top: 10px
}

.lp_bl_imageContent_text:not(:first-child) {
    margin-bottom: 16px
}

.lp_bl_imageContent_button {
    margin-top: 24px
}

.lp_el_listSimple {
    color: #365082;
    font-weight: 700
}

.lp_el_listSimple_item {
    position: relative;
    padding-left: 16px;
    font-size: 1.8rem;
    line-height: 1.66
}

.lp_el_listSimple_item:not(:last-child) {
    margin-bottom: 4px
}

.lp_el_listSimple_item:before {
    position: absolute;
    top: 0.83em;
    left: 0;
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
    content: "";
    width: 4px;
    height: 4px;
    border-radius: 50%;
    background: currentColor
}

@media screen and (min-width: 48em) {
    .lp_bl_imageColumn_item {
        display:-webkit-box;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-pack: justify;
        -ms-flex-pack: justify;
        justify-content: space-between
    }
}

.lp_bl_imageColumn_item:nth-child(2n) {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: reverse;
    -ms-flex-direction: row-reverse;
    flex-direction: row-reverse
}

.lp_bl_imageColumn_item:not(:first-child) {
    margin-top: 77px
}

@media screen and (min-width: 48em) {
    .lp_bl_imageColumn_content {
        width:45%
    }
}

.lp_bl_imageColumn_image {
    margin-top: 40px
}

@media screen and (min-width: 48em) {
    .lp_bl_imageColumn_image {
        width:50%;
        margin: 0
    }
}

.lp_el_pcNavigationOnly {
    display: none
}

@media screen and (min-width: 108em) {
    .lp_el_pcNavigationOnly {
        display:block
    }
}

.lp_el_title {
    text-align: center
}

.lp_el_title__simple {
    font-size: 2.8rem
}

@media screen and (min-width: 48em) {
    .lp_el_title__simple {
        font-size:3.4rem
    }
}

@media screen and (min-width: 64em) {
    .lp_el_title__simple {
        font-size:4rem
    }
}

.lp_el_title__simple+* {
    margin-top: 40px
}

@media screen and (min-width: 48em) {
    .lp_el_title__simple+* {
        margin-top:61px
    }
}

@media screen and (min-width: 64em) {
    .lp_el_title__simple+* {
        margin-top:82px
    }
}

.lp_el_title__decoration {
    display: block;
    margin-bottom: 52px;
    font-size: 2.8rem;
    font-weight: 700;
    line-height: 1.5
}

@media screen and (min-width: 48em) {
    .lp_el_title__decoration {
        font-size:3.4rem
    }
}

@media screen and (min-width: 64em) {
    .lp_el_title__decoration {
        font-size:4rem
    }
}

.lp_el_title__decoration .lp_el_title_inner {
    display: inline-block;
    position: relative;
    padding: 0 24px
}

.lp_el_title__decoration .lp_el_title_inner:after,.lp_el_title__decoration .lp_el_title_inner:before {
    position: absolute;
    bottom: 0.25em;
    content: "";
    width: 1px;
    height: 1em;
    background: #365082
}

.lp_el_title__decoration .lp_el_title_inner:before {
    left: 0;
    -webkit-transform: rotate(-15deg);
    transform: rotate(-15deg)
}

.lp_el_title__decoration .lp_el_title_inner:after {
    right: 0;
    -webkit-transform: rotate(15deg);
    transform: rotate(15deg)
}

.lp_el_title__arrow {
    position: relative;
    margin-bottom: 91px;
    padding: 40px 0;
    background: #e8eff5;
    font-size: 2.8rem
}

@media screen and (min-width: 48em) {
    .lp_el_title__arrow {
        padding:61px 0;
        font-size: 3.4rem
    }
}

@media screen and (min-width: 64em) {
    .lp_el_title__arrow {
        padding:82px 0;
        font-size: 4rem
    }
}

.lp_el_title__arrow:after {
    position: absolute;
    top: 100%;
    left: 50%;
    -webkit-transform: translateX(-50%);
    transform: translateX(-50%);
    content: "";
    border-top: 32px solid #e8eff5;
    border-right: 34px solid transparent;
    border-left: 34px solid transparent
}

.lp_el_title_smallText {
    color: #365082;
    font-size: 2.3rem;
    font-weight: 700
}

.lp_el_button {
    display: inline-block;
    text-align: center
}

.lp_el_button__main {
    width: 100%;
    padding: 19px 16px;
    border: 1px solid #00789f;
    background: #00789f;
    color: #fff;
    font-size: 1.8rem;
    line-height: 1.5
}

@media screen and (min-width: 48em) {
    .lp_el_button__main {
        font-size:2rem
    }
}

.lp_el_button__main:focus,.lp_el_button__main:hover {
    background: #fff;
    color: #00789f
}

.lp_bl_experience_content {
    overflow: hidden;
    padding-top: 56px;
    background: #e8eff5
}

@media screen and (min-width: 48em) {
    .lp_bl_experience_content {
        padding:89px 0
    }
}

.lp_bl_experience_list {
    margin-bottom: 40px
}

@media screen and (min-width: 48em) {
    .lp_bl_experience_list {
        width:57%;
        margin: 0 0 0 auto
    }
}

@media screen and (min-width: 48em) {
    .lp_bl_experience_item:nth-child(2n) .lp_bl_experience_list {
        margin:0 auto 0 0
    }
}

.lp_bl_experience_item {
    position: relative;
    z-index: 2
}

@media screen and (min-width: 48em) {
    .lp_bl_experience_item:not(:first-child) {
        margin-top:74px;
        padding-top: 69px
    }
}

.lp_bl_experience_item:nth-child(2n) {
    padding-top: 16px
}

@media screen and (min-width: 48em) {
    .lp_bl_experience_item:nth-child(2n) {
        padding-top:69px
    }
}

.lp_bl_experience_item:nth-child(2n):after {
    position: absolute;
    top: -32px;
    left: 0;
    -webkit-transform: skewY(16deg);
    transform: skewY(16deg);
    z-index: -1;
    content: "";
    width: 100%;
    height: 200%;
    background: #fff
}

@media screen and (min-width: 48em) {
    .lp_bl_experience_item:nth-child(2n):after {
        top:-50px;
        height: 200vw
    }
}

@media screen and (min-width: 64em) {
    .lp_bl_experience_item:nth-child(2n):after {
        top:-15px
    }
}

.lp_bl_experience_inner {
    position: relative
}

.lp_bl_experience_image {
    width: 80%;
    max-width: 335px;
    margin-left: -7%
}

@media screen and (min-width: 48em) {
    .lp_bl_experience_image {
        position:absolute;
        bottom: 0;
        left: 0;
        width: 41%;
        margin: 0
    }
}

@media screen and (min-width: 64em) {
    .lp_bl_experience_image {
        width:32.2%
    }
}

.lp_bl_experience_item:nth-child(2n) .lp_bl_experience_image {
    max-width: 332px;
    margin: 0 -7% 0 auto
}

@media screen and (min-width: 48em) {
    .lp_bl_experience_item:nth-child(2n) .lp_bl_experience_image {
        right:0;
        bottom: -89px;
        left: auto;
        width: 40%
    }
}

@media screen and (min-width: 64em) {
    .lp_bl_experience_item:nth-child(2n) .lp_bl_experience_image {
        width:31.9%
    }
}

.lp_bl_experience_text {
    position: relative;
    padding-left: 2em;
    font-size: 1.8rem;
    font-weight: 700
}

@media screen and (min-width: 48em) {
    .lp_bl_experience_text {
        font-size:2.2rem
    }
}

.lp_bl_experience_text:before {
    position: absolute;
    top: 1em;
    left: 0;
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
    content: "";
    width: 1.36em;
    height: 1.36em;
    background: url(../img/lp/blog/icon_check.svg) no-repeat;
    background-size: contain
}

.lp_bl_experience_text:not(:first-child) {
    margin-top: 20px
}

@media screen and (min-width: 48em) {
    .lp_bl_experience_text:not(:first-child) {
        margin-top:42px
    }
}

.lp_bl_voice {
    counter-reset: voice
}

.lp_bl_voice_item {
    position: relative;
    counter-increment: voice;
    padding: 61px 4% 32px;
    border: 1px solid #365082
}

@media screen and (min-width: 48em) {
    .lp_bl_voice_item {
        display:-webkit-box;
        display: -ms-flexbox;
        display: flex;
        padding-bottom: 61px;
        -webkit-box-align: start;
        -ms-flex-align: start;
        align-items: flex-start
    }
}

.lp_bl_voice_item:before {
    position: absolute;
    top: 0;
    left: 0;
    content: "Voice" counter(voice,decimal-leading-zero);
    padding: 9px 28px;
    background: #365082;
    color: #fff;
    font-size: 1.7rem;
    line-height: 1.5;
    text-transform: uppercase
}

.lp_bl_voice_item:not(:last-child) {
    margin-bottom: 56px
}

.lp_bl_voice_content {
    margin-bottom: 40px
}

@media screen and (min-width: 48em) {
    .lp_bl_voice_content {
        width:50%;
        margin: 0 13% 0 0
    }
}

.lp_bl_voice_title {
    margin-bottom: 5px;
    font-size: 2.52rem;
    font-weight: 700;
    line-height: 1.5
}

.lp_bl_voice_lead {
    margin-bottom: 20px;
    padding-bottom: 20px;
    border-bottom: 1px solid;
    color: #365082;
    font-size: 2.2rem;
    font-weight: 700;
    line-height: 1.5
}

.lp_bl_voice_year {
    margin-bottom: 27px;
    padding-bottom: 28px;
    border-bottom: 1px solid #365082;
    font-size: 2.2rem;
    line-height: 1.5
}

.lp_bl_voice_text {
    font-size: 1.8rem
}

.lp_bl_voice_text:not(:last-child) {
    margin-bottom: 25px
}

@media screen and (min-width: 48em) {
    .lp_bl_voice_img {
        width:37%
    }
}

.lp_bl_flow {
    counter-reset: flow
}

.lp_bl_flow_item {
    counter-increment: flow;
    padding: 16px 5%;
    background: #fff;
    font-size: 1.8rem;
    font-weight: 700
}

@media screen and (min-width: 48em) {
    .lp_bl_flow_item {
        display:-webkit-box;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-align: start;
        -ms-flex-align: start;
        align-items: flex-start
    }
}

@media screen and (min-width: 64em) {
    .lp_bl_flow_item {
        padding:16px 40px;
        font-size: 2rem
    }
}

.lp_bl_flow_item:before {
    content: "Step " counter(flow,decimal-leading-zero);
    color: #365082;
    font-family: "Roboto",sans-serif;
    font-size: 1.25em;
    font-weight: 700;
    line-height: 1.5;
    text-transform: uppercase
}

@media screen and (min-width: 48em) {
    .lp_bl_flow_item:before {
        -ms-flex-negative:0;
        flex-shrink: 0;
        max-width: 40%
    }
}

.lp_bl_flow_item:not(:last-child) {
    position: relative;
    margin-bottom: 42px
}

.lp_bl_flow_item:not(:last-child):after {
    position: absolute;
    top: calc(100% + 13px);
    left: 50%;
    -webkit-transform: translateX(-50%);
    transform: translateX(-50%);
    content: "";
    border-top: 16px solid #9cbfdf;
    border-right: 12px solid transparent;
    border-left: 12px solid transparent
}

.lp_bl_flow_inner {
    display: block;
    margin-top: 16px;
    padding-top: 16px;
    border-top: 1px solid #365082
}

@media screen and (min-width: 48em) {
    .lp_bl_flow_inner {
        margin:0 0 0 6.25%;
        padding: 0 0 0 6.25%;
        border-top: none;
        border-left: 1px solid #365082
    }
}

.lp_bl_price_table {
    border: 1px solid #365082
}

@media screen and (min-width: 48em) {
    .lp_bl_price_item {
        display:-webkit-box;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-align: stretch;
        -ms-flex-align: stretch;
        align-items: stretch
    }
}

.lp_bl_price_title {
    padding: 16px 5%;
    background: #365082;
    color: #fff;
    font-size: 2.2rem;
    font-weight: 500;
    line-height: 1.5;
    text-align: center
}

@media screen and (min-width: 48em) {
    .lp_bl_price_title {
        display:-webkit-box;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-pack: center;
        -ms-flex-pack: center;
        justify-content: center;
        width: 43%;
        padding: 23px 4%;
        -webkit-box-align: center;
        -ms-flex-align: center;
        align-items: center
    }
}

@media screen and (min-width: 64em) {
    .lp_bl_price_title {
        font-size:2.5rem
    }
}

.lp_bl_price_item:not(:first-child) .lp_bl_price_title {
    border-top: 1px solid #fff
}

.lp_bl_price_data {
    padding: 8px 5%;
    line-height: 1.5;
    text-align: right
}

@media screen and (min-width: 48em) {
    .lp_bl_price_data {
        width:57%;
        padding: 23px 4%
    }
}

@media screen and (min-width: 64em) {
    .lp_bl_price_data {
        padding:23px 10%
    }
}

.lp_bl_price_item:not(:first-child) .lp_bl_price_data {
    border-top: 1px solid #365082
}

.lp_bl_price_note {
    margin-top: 4px
}

@media screen and (min-width: 48em) {
    .lp_bl_price_note {
        text-align:right
    }
}

.lp_bl_cta {
    padding: 56px 0;
    background: #365082;
    color: #fff;
    font-weight: 500
}

@media screen and (min-width: 64em) {
    .lp_bl_cta {
        padding:77px 0
    }
}

.lp_bl_cta_title {
    margin-bottom: 16px;
    font-size: 2.8rem;
    line-height: 1.5;
    text-align: center
}

@media screen and (min-width: 48em) {
    .lp_bl_cta_title {
        font-size:3.4rem
    }
}

@media screen and (min-width: 64em) {
    .lp_bl_cta_title {
        margin-bottom:31px;
        font-size: 4rem
    }
}

.lp_bl_cta_text {
    margin-bottom: 24px;
    font-size: 2.2rem;
    text-align: center
}

@media screen and (min-width: 48em) {
    .lp_bl_cta_text {
        margin-bottom:45px
    }
}

@media screen and (min-width: 64em) {
    .lp_bl_cta_text {
        font-size:2.6rem
    }
}

@media screen and (min-width: 48em) {
    .lp_bl_cta_contact {
        display:-webkit-box;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-align: center;
        -ms-flex-align: center;
        align-items: center
    }
}

.lp_bl_cta_item {
    text-align: center
}

@media screen and (min-width: 48em) {
    .lp_bl_cta_item {
        width:43.5%
    }
}

@media screen and (min-width: 80em) {
    .lp_bl_cta_item {
        text-align:right
    }
}

.lp_bl_cta_item:nth-child(odd) {
    margin-bottom: 16px;
    padding-bottom: 16px;
    border-bottom: 1px solid #000
}

@media screen and (min-width: 48em) {
    .lp_bl_cta_item:nth-child(odd) {
        margin:0 13% 0 0;
        padding: 0 13% 0 0;
        -webkit-box-sizing: content-box;
        box-sizing: content-box;
        border-right: 1px solid #000;
        border-bottom: none
    }
}

.lp_bl_cta_tel {
    color: #fee50a;
    font-size: 4rem;
    font-weight: 700;
    line-height: 1.5;
    letter-spacing: 0.005em
}

@media screen and (min-width: 48em) {
    .lp_bl_cta_tel {
        font-size:3.2rem
    }
}

@media screen and (min-width: 64em) {
    .lp_bl_cta_tel {
        font-size:4.2rem
    }
}

@media screen and (min-width: 80em) {
    .lp_bl_cta_tel {
        font-size:5.1rem
    }
}

.lp_bl_cta_tel:hover {
    color: #fff
}

.lp_bl_cta_tel:focus-visible {
    color: #fff
}

:root .lp_bl_cta_tel:focus,_:-ms-fullscreen {
    color: #fff
}

.lp_bl_cta_tel:before {
    display: inline-block;
    content: "";
    width: 0.6em;
    height: 0.8em;
    margin-right: 10px;
    background: url(../img/lp/common/icon_tel.svg) no-repeat center bottom;
    background-size: contain;
    vertical-align: baseline
}

.lp_bl_cta_hour {
    font-size: 2.1rem
}

@media screen and (min-width: 80em) {
    .lp_bl_cta_hour {
        font-size:2.6rem
    }
}

.lp_bl_cta_button {
    display: block;
    padding: 16px 5%;
    border: 1px solid #e96300;
    background: #e96300;
    color: #fff;
    font-size: 2.2rem;
    font-weight: 500;
    line-height: 1.5;
    text-align: center
}

@media screen and (min-width: 64em) {
    .lp_bl_cta_button {
        padding:24px 5%;
        font-size: 2.8rem
    }
}

@media screen and (min-width: 80em) {
    .lp_bl_cta_button {
        padding:34px 16px
    }
}

.lp_bl_cta_button:hover {
    border-color: #fff;
    background: transparent
}

.lp_bl_cta_button:focus-visible {
    border-color: #fff;
    background: transparent
}

:root .lp_bl_cta_button:focus,_:-ms-fullscreen {
    border-color: #fff;
    background: transparent
}

body {
    position: relative;
    margin: 0 auto;
    background: #fff;
    color: #333;
    font-family: "Noto Sans JP",sans-serif;
    font-size: 1.6rem;
    font-weight: 400;
    line-height: 1.875;
    word-wrap: break-word;
    overflow-wrap: break-word
}

.hp_noscript {
    padding: 10px 0;
    background: #fff4ed;
    font-weight: 600;
    text-align: center
}

.bl_background {
    visibility: hidden;
    opacity: 0;
    position: fixed;
    top: 0;
    left: 0;
    z-index: 998;
    width: 100%;
    height: 100vh;
    background: rgba(0,0,0,0.7);
    -webkit-transition: opacity 0.5s ease,visibility 0.5s ease;
    transition: opacity 0.5s ease,visibility 0.5s ease
}

.bl_background.is_show {
    visibility: visible;
    opacity: 1
}

.ly_header {
    position: sticky;
    top: 0;
    left: 0;
    z-index: 999;
    width: 100%
}

.bl_header {
    background: #fff
}

.bl_header__expanded {
    background: transparent;
    -webkit-transition: background 0.2s linear;
    transition: background 0.2s linear;
    -webkit-animation: fadeIn 0.5s ease-in-out 0.5s both;
    animation: fadeIn 0.5s ease-in-out 0.5s both
}

.bl_header__expanded.is_fill {
    background: #fff
}

.bl_header__expanded+* {
    margin-top: calc(var(--headerHeight) * -1)
}

.bl_header_inner {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
    width: 88%;
    max-width: 1562px;
    margin: 0 auto;
    padding: 14px 0;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center
}

@media screen and (min-width: 64em) {
    .bl_header_inner {
        width:95%;
        padding: 14px 0 23px;
        -webkit-box-align: end;
        -ms-flex-align: end;
        align-items: flex-end
    }
}

.bl_header__expanded .bl_header_inner {
    max-width: 1516px
}

@media screen and (min-width: 64em) {
    .bl_header__expanded .bl_header_inner {
        padding:29px 0
    }
}

.bl_header_logo {
    -ms-flex-negative: 0;
    flex-shrink: 0;
    width: 39.7%;
    max-width: 131px
}

@media screen and (min-width: 64em) {
    .bl_header_logo {
        width:11.4%;
        max-width: 178px;
        padding-bottom: 2px
    }

    .bl_header__expanded .bl_header_logo {
        width: 13.58%;
        max-width: 206px
    }
}

.bl_header_navigation {
    margin-left: 24px
}

@media screen and (min-width: 64em) {
    .bl_header_navigation {
        width:100%
    }
}

.bl_header_button {
    display: block;
    padding: 7px 8px;
    background: #ff9955;
    color: #fff;
    font-size: 1.4rem;
    line-height: 1.5;
    text-align: center;
    letter-spacing: 0.03em
}

.bl_header_button:hover {
    color: rgba(255,255,255,0.7)
}

.bl_header_button:hover .bl_header_icon {
    opacity: 0.7
}

.bl_header_button:focus-visible {
    color: rgba(255,255,255,0.7)
}

.bl_header_button:focus-visible .bl_header_icon {
    opacity: 0.7
}

:root .bl_header_button:focus,_:-ms-fullscreen {
    color: rgba(255,255,255,0.7)
}

:root .bl_header_button:focus .bl_header_icon,_:-ms-fullscreen .bl_header_icon {
    opacity: 0.7
}

@media screen and (min-width: 64em) {
    .bl_header_button {
        padding-right:18px;
        padding-left: 18px
    }
}

@media screen and (min-width: 80em) {
    .bl_header_button {
        padding-top:6px;
        padding-bottom: 6px;
        font-size: 1.6rem
    }
}

.bl_header_button__sns {
    background: #333;
    letter-spacing: 0.05em
}

.bl_header_button__emphasis {
    padding: 4px 8px;
    background: #333;
    font-family: "Roboto",sans-serif;
    font-size: 1.8rem;
    font-weight: 500
}

@media screen and (min-width: 64em) {
    .bl_header_button__emphasis {
        padding-right:18px;
        padding-left: 18px
    }
}

@media screen and (min-width: 80em) {
    .bl_header_button__emphasis {
        padding-top:2px;
        padding-bottom: 2px;
        font-size: 2.1rem
    }
}

.bl_header_icon {
    display: inline-block;
    width: 15px;
    margin-right: 6px;
    vertical-align: -0.125em
}

@media screen and (min-width: 64em) {
    .bl_header_icon {
        width:17px;
        margin-right: 8px
    }
}

.bl_header_button__line .bl_header_icon {
    width: 20px;
    margin-right: 10px;
    vertical-align: -0.25em
}

.bl_header_button__emphasis .bl_header_icon {
    margin-right: 3px;
    vertical-align: -0.05em
}

@media screen and (min-width: 64em) {
    .bl_header_button__emphasis .bl_header_icon {
        margin-right:4px
    }
}

.bl_globalNavigation_toggle {
    display: block;
    position: relative;
    padding-top: 22px
}

@media screen and (min-width: 64em) {
    .bl_globalNavigation_toggle {
        display:none
    }
}

.bl_globalNavigation_bar {
    position: absolute;
    left: 50%;
    -webkit-transform: translateX(-50%);
    transform: translateX(-50%);
    -webkit-transform-origin: center center;
    transform-origin: center center;
    width: 25px;
    height: 1px;
    border-radius: 500px;
    background: currentColor;
    -webkit-transition: top 0.3s ease,opacity 0.3s ease,-webkit-transform 0.3s ease;
    transition: top 0.3s ease,opacity 0.3s ease,-webkit-transform 0.3s ease;
    transition: top 0.3s ease,transform 0.3s ease,opacity 0.3s ease;
    transition: top 0.3s ease,transform 0.3s ease,opacity 0.3s ease,-webkit-transform 0.3s ease
}

.bl_globalNavigation_bar:first-child {
    top: 0
}

.bl_globalNavigation_toggle[aria-expanded=true] .bl_globalNavigation_bar:first-child {
    top: 9px;
    -webkit-transform: translateX(-50%) rotate(45deg);
    transform: translateX(-50%) rotate(45deg)
}

.bl_globalNavigation_bar:nth-child(2) {
    top: 8px
}

.bl_globalNavigation_toggle[aria-expanded=true] .bl_globalNavigation_bar:nth-child(2) {
    opacity: 0
}

.bl_globalNavigation_bar:nth-child(3) {
    top: 16px
}

.bl_globalNavigation_toggle[aria-expanded=true] .bl_globalNavigation_bar:nth-child(3) {
    top: 9px;
    -webkit-transform: translateX(-50%) rotate(-45deg);
    transform: translateX(-50%) rotate(-45deg)
}

.bl_globalNavigation_text {
    display: block;
    font-family: "Lora",serif;
    font-size: 1rem;
    line-height: 1.3;
    text-align: center;
    text-transform: uppercase
}

.bl_globalNavigation_content {
    overflow: auto;
    visibility: hidden;
    position: fixed;
    top: var(--headerHeight);
    right: 0;
    -webkit-transform: translate3d(100%,0,0);
    transform: translate3d(100%,0,0);
    width: 100%;
    height: calc(100vh - var(--headerHeight));
    background: #fff;
    -webkit-transition: visibility 0.3s ease,-webkit-transform 0.3s ease;
    transition: visibility 0.3s ease,-webkit-transform 0.3s ease;
    transition: transform 0.3s ease,visibility 0.3s ease;
    transition: transform 0.3s ease,visibility 0.3s ease,-webkit-transform 0.3s ease;
    -webkit-overflow-scrolling: touch
}

@media screen and (min-width: 64em) {
    .bl_globalNavigation_content {
        display:-webkit-box;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-orient: vertical;
        -webkit-box-direction: reverse;
        -ms-flex-direction: column-reverse;
        flex-direction: column-reverse;
        overflow: visible;
        position: static;
        -webkit-transform: none;
        transform: none;
        height: auto;
        background: transparent;
        -webkit-transition: none;
        transition: none
    }
}

.bl_globalNavigation_content[aria-hidden=false] {
    visibility: visible;
    -webkit-transform: translate3d(0,0,0);
    transform: translate3d(0,0,0)
}

@media screen and (min-width: 64em) {
    .bl_globalNavigation_content[aria-hidden=false] {
        -webkit-transform:none;
        transform: none
    }
}

.bl_globalNavigation_list {
    background: #fff4ed
}

@media screen and (min-width: 64em) {
    .bl_globalNavigation_list {
        display:-webkit-box;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-pack: end;
        -ms-flex-pack: end;
        justify-content: flex-end;
        margin-top: 12px;
        background: transparent;
        -webkit-box-align: center;
        -ms-flex-align: center;
        align-items: center
    }

    .bl_header__expanded .bl_globalNavigation_list {
        margin-top: 17px
    }
}

.bl_globalNavigation_item {
    width: auto
}

.bl_globalNavigation_item:not(:first-child) {
    border-top: 1px solid #fff
}

@media screen and (min-width: 64em) {
    .bl_globalNavigation_item:not(:first-child) {
        margin-left:24px;
        border-top: none
    }
}

@media screen and (min-width: 80em) {
    .bl_globalNavigation_item:not(:first-child) {
        margin-left:32px
    }
}

@media screen and (min-width: 90em) {
    .bl_globalNavigation_item:not(:first-child) {
        margin-left:46px
    }
}

.bl_globalNavigation_trigger {
    display: block;
    padding: 10px 9.3%
}

@media screen and (min-width: 64em) {
    .bl_globalNavigation_trigger {
        padding:0;
        font-size: 1.4rem;
        line-height: 1.5;
        letter-spacing: 0.005em
    }
}

@media screen and (min-width: 80em) {
    .bl_globalNavigation_trigger {
        font-size:1.6rem
    }
}

.bl_globalNavigation_footer {
    width: 88%;
    margin: 0 auto;
    padding: 22px 0 25px
}

@media screen and (min-width: 64em) {
    .bl_globalNavigation_footer {
        display:-webkit-box;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-pack: end;
        -ms-flex-pack: end;
        justify-content: flex-end;
        width: 100%;
        margin: 0;
        padding: 0;
        -webkit-box-align: center;
        -ms-flex-align: center;
        align-items: center
    }
}

.bl_globalNavigation_company {
    display: none;
    font-size: 1.4rem;
    font-weight: 500
}

@media screen and (min-width: 64em) {
    .bl_globalNavigation_company {
        display:block
    }
}

.bl_globalNavigation_subList {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap
}

@media screen and (min-width: 64em) {
    .bl_globalNavigation_subList {
        margin-left:29px
    }
}

.bl_globalNavigation_subItem {
    width: 48.4%
}

@media screen and (min-width: 64em) {
    .bl_globalNavigation_subItem {
        width:auto
    }
}

.bl_globalNavigation_subItem:not(:first-child) {
    margin-left: 3.2%
}

@media screen and (min-width: 64em) {
    .bl_globalNavigation_subItem:not(:first-child) {
        margin-left:0
    }
}

.bl_globalNavigation_subItem__wide {
    width: 100%
}

.bl_globalNavigation_subItem__wide:not(:first-child) {
    margin: 19px 0 0 0
}

.bl_toggleNavigation_toggle {
    position: relative;
    width: 100%;
    padding-right: calc(9.3% + 28px);
    text-align: left
}

@media screen and (min-width: 64em) {
    .bl_toggleNavigation_toggle {
        padding-right:15px
    }
}

.bl_toggleNavigation_toggle:after {
    position: absolute;
    top: 50%;
    right: 9.3%;
    -webkit-transform: translateY(-50%) rotate(45deg);
    transform: translateY(-50%) rotate(45deg);
    content: "";
    width: 8px;
    height: 8px;
    border-right: 1px solid #ff9955;
    border-bottom: 1px solid #ff9955;
    -webkit-transition: -webkit-transform 0.5s ease;
    transition: -webkit-transform 0.5s ease;
    transition: transform 0.5s ease;
    transition: transform 0.5s ease,-webkit-transform 0.5s ease
}

@media screen and (min-width: 64em) {
    .bl_toggleNavigation_toggle:after {
        right:0;
        width: 6px;
        height: 6px;
        border-right-width: 2px;
        border-bottom-width: 2px
    }
}

.bl_toggleNavigation_toggle[aria-expanded=true]:after {
    -webkit-transform: translateY(-20%) rotate(-135deg);
    transform: translateY(-20%) rotate(-135deg)
}

.bl_toggleNavigation_content {
    display: none;
    top: 100%;
    left: 0;
    z-index: -1;
    width: 100%;
    padding: 13px 11.2% 20px;
    -webkit-transition: visibility 0.3s ease,-webkit-transform 0.3s ease;
    transition: visibility 0.3s ease,-webkit-transform 0.3s ease;
    transition: transform 0.3s ease,visibility 0.3s ease;
    transition: transform 0.3s ease,visibility 0.3s ease,-webkit-transform 0.3s ease
}

@media screen and (min-width: 64em) {
    .bl_toggleNavigation_content {
        display:block;
        visibility: hidden;
        position: absolute;
        -webkit-transform: translate3d(0,-100%,0);
        transform: translate3d(0,-100%,0);
        padding: 64px 0 87px;
        background: #fff
    }
}

.bl_toggleNavigation_content[aria-hidden=true] {
    -webkit-transition: none;
    transition: none
}

.bl_toggleNavigation_content[aria-hidden=false] {
    display: block
}

@media screen and (min-width: 64em) {
    .bl_toggleNavigation_content[aria-hidden=false] {
        visibility:visible;
        -webkit-transform: translate3d(0,0,0);
        transform: translate3d(0,0,0);
        -webkit-transition: visibility 0.3s 0.2s ease,-webkit-transform 0.3s 0.2s ease;
        transition: visibility 0.3s 0.2s ease,-webkit-transform 0.3s 0.2s ease;
        transition: transform 0.3s 0.2s ease,visibility 0.3s 0.2s ease;
        transition: transform 0.3s 0.2s ease,visibility 0.3s 0.2s ease,-webkit-transform 0.3s 0.2s ease
    }
}

.bl_toggleNavigation_title {
    display: none;
    width: 88%;
    max-width: 1200px;
    margin: 0 auto;
    color: #ff9955;
    font-size: 1.8rem;
    font-weight: 400
}

@media screen and (min-width: 64em) {
    .bl_toggleNavigation_title {
        display:block
    }
}

.bl_toggleNavigation_english {
    display: inline-block;
    margin-right: 14px;
    color: #333;
    font-family: "Noto Sans JP",cursive;
    font-size: 4rem;
    line-height: 1.225;
    letter-spacing: 0.03em
}

@media screen and (min-width: 64em) {
    .bl_toggleNavigation_list {
        display:-webkit-box;
        display: -ms-flexbox;
        display: flex;
        width: 88%;
        max-width: 1200px;
        margin: 51px auto 0;
        padding: 0
    }
}

.bl_toggleNavigation_item {
    position: relative;
    padding-left: 17px;
    line-height: 1.5;
    letter-spacing: 0.05em
}

@media screen and (min-width: 64em) {
    .bl_toggleNavigation_item {
        width:25%;
        padding-left: 0;
        border-left: 1px solid #e4e1e1;
        font-weight: 500
    }
}

.bl_toggleNavigation_item:not(:first-child) {
    margin-top: 14px
}

@media screen and (min-width: 64em) {
    .bl_toggleNavigation_item:not(:first-child) {
        margin-top:0
    }
}

@media screen and (min-width: 64em) {
    .bl_toggleNavigation_item:last-child {
        border-right:1px solid #e4e1e1
    }
}

.bl_toggleNavigation_item:before {
    position: absolute;
    top: 0.75em;
    left: 2px;
    content: "";
    width: 12px;
    height: 1px;
    background: currentColor
}

@media screen and (min-width: 64em) {
    .bl_toggleNavigation_item:before {
        content:none
    }
}

.bl_toggleNavigation_item__hasChildren {
    padding-left: 0
}

@media screen and (min-width: 64em) {
    .bl_toggleNavigation_item__hasChildren {
        padding:0 20px
    }
}

@media screen and (min-width: 90em) {
    .bl_toggleNavigation_item__hasChildren {
        padding:0 50px
    }
}

.bl_toggleNavigation_item__hasChildren:before {
    content: none
}

.bl_toggleNavigation_link {
    height: 100%
}

@media screen and (min-width: 64em) {
    .bl_toggleNavigation_link {
        display:-webkit-box;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-orient: vertical;
        -webkit-box-direction: normal;
        -ms-flex-direction: column;
        flex-direction: column;
        -webkit-box-pack: center;
        -ms-flex-pack: center;
        justify-content: center;
        padding: 16px 8px;
        font-weight: 500;
        text-align: center;
        -webkit-box-align: center;
        -ms-flex-align: center;
        align-items: center
    }

    .bl_toggleNavigation_link:hover {
        background: #fff4ed
    }

    .bl_toggleNavigation_link:focus-visible {
        background: #fff4ed
    }

    :root .bl_toggleNavigation_link:focus,_:-ms-fullscreen {
        background: #fff4ed
    }
}

@media screen and (min-width: 90em) {
    .bl_toggleNavigation_link {
        padding:16px 50px
    }
}

.bl_toggleNavigation_icon {
    display: none;
    max-width: 107px;
    margin: 0 auto 14px
}

@media screen and (min-width: 64em) {
    .bl_toggleNavigation_icon {
        display:block
    }
}

.bl_toggleNavigation_subTitle {
    display: none;
    text-align: center
}

@media screen and (min-width: 64em) {
    .bl_toggleNavigation_subTitle {
        display:block
    }
}

@media screen and (min-width: 64em) {
    .bl_toggleNavigation_subList {
        margin-top:15px
    }
}

.bl_toggleNavigation_subItem {
    position: relative;
    padding-left: 17px
}

@media screen and (min-width: 64em) {
    .bl_toggleNavigation_subItem {
        font-size:1.4rem
    }
}

@media screen and (min-width: 80em) {
    .bl_toggleNavigation_subItem {
        font-size:1.6rem
    }
}

.bl_toggleNavigation_subItem:not(:first-child) {
    margin-top: 14px
}

.bl_toggleNavigation_subItem:before {
    position: absolute;
    top: 0.9375em;
    left: 2px;
    content: "";
    width: 12px;
    height: 1px;
    background: currentColor
}

.bl_toggleNavigation_subLink {
    border-bottom: 1px solid transparent;
    -webkit-transition: border 0.5s ease,padding 0.5s ease;
    transition: border 0.5s ease,padding 0.5s ease
}

.bl_toggleNavigation_subLink:hover {
    padding-bottom: 0.125em;
    border-bottom-color: currentColor
}

.bl_toggleNavigation_subLink:focus-visible {
    padding-bottom: 0.125em;
    border-bottom-color: currentColor
}

:root .bl_toggleNavigation_subLink:focus,_:-ms-fullscreen {
    padding-bottom: 0.125em;
    border-bottom-color: currentColor
}

.ly_fixedButton {
    position: fixed;
    bottom: 0;
    left: 0;
    -webkit-transform: translate3d(0,100%,0);
    transform: translate3d(0,100%,0);
    z-index: 997;
    width: 100%;
    -webkit-transition: -webkit-transform 0.5s ease;
    transition: -webkit-transform 0.5s ease;
    transition: transform 0.5s ease;
    transition: transform 0.5s ease,-webkit-transform 0.5s ease;
    pointer-events: none
}

@media screen and (min-width: 64em) {
    .ly_fixedButton {
        display:-webkit-box;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-orient: vertical;
        -webkit-box-direction: normal;
        -ms-flex-direction: column;
        flex-direction: column;
        overflow: hidden auto;
        right: 0;
        bottom: 17px;
        left: auto;
        -webkit-transform: translate3d(100%,0,0);
        transform: translate3d(100%,0,0);
        width: -webkit-fit-content;
        width: -moz-fit-content;
        width: fit-content;
        max-width: 100%;
        max-height: calc(100vh - var(--headerHeight) - 34px);
        gap: 26px;
        -webkit-box-align: end;
        -ms-flex-align: end;
        align-items: flex-end
    }
}

.ly_fixedButton.is_show {
    -webkit-transform: translate3d(0,0,0);
    transform: translate3d(0,0,0)
}

.ly_fixedButton_item {
    pointer-events: initial
}

.bl_fixedButton {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    padding: 10px 6%;
    background: #fff4ed
}

@media screen and (min-width: 64em) {
    .bl_fixedButton {
        display:none
    }
}

.bl_fixedButton_item {
    width: 48%
}

.bl_fixedButton_item:not(:first-child) {
    margin-left: 4%
}

.bl_fixedButton_link {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    height: 100%;
    padding: 4px 5px;
    background: #ff9955;
    color: #fff;
    font-size: 1.4rem;
    font-weight: 400;
    line-height: 1.5;
    letter-spacing: 0.03em;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center
}

.bl_fixedButton_link__tel {
    background: #333;
    color: #fff;
    font-family: "Roboto",sans-serif;
    font-size: 1.8rem;
    font-weight: 500
}

.bl_fixedButton_icon {
    display: block;
    width: 13px;
    margin-right: 4px
}

.bl_fixedButtonLarge {
    display: none;
    -webkit-transform: translate3d(238px,0,0);
    transform: translate3d(238px,0,0);
    width: 328px;
    padding: 12px;
    border-top-left-radius: 7px;
    border-bottom-left-radius: 7px;
    border: 1px solid #e9e9e9;
    background: #fff;
    -webkit-transition: -webkit-transform 0.5s ease;
    transition: -webkit-transform 0.5s ease;
    transition: transform 0.5s ease;
    transition: transform 0.5s ease,-webkit-transform 0.5s ease
}

@media screen and (min-width: 64em) {
    .bl_fixedButtonLarge {
        display:block
    }
}

.bl_fixedButtonLarge:hover {
    -webkit-transform: translate3d(0,0,0);
    transform: translate3d(0,0,0)
}

.bl_fixedButtonLarge:focus-within {
    -webkit-transform: translate3d(0,0,0);
    transform: translate3d(0,0,0)
}

.bl_fixedButtonLarge_item:nth-child(n+2) {
    margin-top: 10px
}

.bl_fixedButtonLarge_link {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center
}

.bl_fixedButtonLarge_link:hover {
    color: #ff9955
}

.bl_fixedButtonLarge_link:hover .bl_fixedButtonLarge_icon {
    opacity: 0.6
}

.bl_fixedButtonLarge_link:focus-visible {
    color: #ff9955
}

.bl_fixedButtonLarge_link:focus-visible .bl_fixedButtonLarge_icon {
    opacity: 0.6
}

:root .bl_fixedButtonLarge_link:focus,_:-ms-fullscreen {
    color: #ff9955
}

:root .bl_fixedButtonLarge_link:focus .bl_fixedButtonLarge_icon,_:-ms-fullscreen .bl_fixedButtonLarge_icon {
    opacity: 0.6
}

.bl_fixedButtonLarge_icon {
    width: 66px
}

.bl_fixedButtonLarge_text {
    margin-left: 16px
}

.bl_popupBanner {
    display: none;
    -webkit-transform: translate3d(415px,0,0);
    transform: translate3d(415px,0,0);
    width: 400px;
    max-width: calc(100% - 30px);
    margin: 0 17px 5px 0;
    -webkit-transition: visibility 0.5s ease,-webkit-transform 0.5s ease;
    transition: visibility 0.5s ease,-webkit-transform 0.5s ease;
    transition: transform 0.5s ease,visibility 0.5s ease;
    transition: transform 0.5s ease,visibility 0.5s ease,-webkit-transform 0.5s ease
}

@media screen and (min-width: 64em) {
    .bl_popupBanner {
        display:block
    }
}

.bl_popupBanner.is_show {
    -webkit-transform: translate3d(0,0,0);
    transform: translate3d(0,0,0)
}

.bl_popupBanner[aria-hidden=true] {
    display: none;
    visibility: hidden
}

.bl_popupBanner_link {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    width: 100%;
    padding: 20px;
    border: 1px solid #fff;
    background: #333;
    color: #fff;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center
}

.bl_popupBanner_link:hover {
    background: #ff9955
}

.bl_popupBanner_link:hover .bl_popupBanner_icon__hover {
    opacity: 1
}

.bl_popupBanner_link:hover+.bl_popupBanner_toggle {
    background: #fff4ed
}

.bl_popupBanner_link:hover+.bl_popupBanner_toggle:after,.bl_popupBanner_link:hover+.bl_popupBanner_toggle:before {
    background: #ff9955
}

.bl_popupBanner_link:focus-visible {
    background: #ff9955
}

.bl_popupBanner_link:focus-visible .bl_popupBanner_icon__hover {
    opacity: 1
}

.bl_popupBanner_link:focus-visible+.bl_popupBanner_toggle {
    background: #fff4ed
}

.bl_popupBanner_link:focus-visible+.bl_popupBanner_toggle:after,.bl_popupBanner_link:focus-visible+.bl_popupBanner_toggle:before {
    background: #ff9955
}

:root .bl_popupBanner_link:focus,_:-ms-fullscreen {
    background: #ff9955
}

:root .bl_popupBanner_link:focus .bl_popupBanner_icon__hover,_:-ms-fullscreen .bl_popupBanner_icon__hover {
    opacity: 1
}

:root .bl_popupBanner_link:focus+.bl_popupBanner_toggle,_:-ms-fullscreen+.bl_popupBanner_toggle {
    background: #fff4ed
}

:root .bl_popupBanner_link:focus+.bl_popupBanner_toggle:after,:root .bl_popupBanner_link:focus+.bl_popupBanner_toggle:before,_:-ms-fullscreen+.bl_popupBanner_toggle:after,_:-ms-fullscreen+.bl_popupBanner_toggle:before {
    background: #ff9955
}

.bl_popupBanner_link:after {
    opacity: 0.5;
    position: absolute;
    top: 5px;
    left: 5px;
    z-index: -1;
    content: "";
    width: 100%;
    height: 100%;
    background: inherit
}

.bl_popupBanner_decoration {
    -ms-flex-negative: 0;
    flex-shrink: 0;
    position: relative;
    width: 15.4%
}

.bl_popupBanner_decoration:before {
    display: block;
    content: "";
    padding-top: 100%
}

.bl_popupBanner_icon {
    position: absolute;
    top: 0;
    left: 0
}

.bl_popupBanner_icon__hover {
    opacity: 0;
    z-index: 1
}

.bl_popupBanner_content {
    width: 100%;
    margin-left: 20px;
    line-height: 1.66
}

.bl_popupBanner_title {
    display: block;
    font-size: 1.8rem;
    font-weight: 500
}

.bl_popupBanner_text {
    display: block
}

.bl_popupBanner_toggle {
    position: absolute;
    top: 8px;
    right: 10px;
    z-index: 2;
    width: 23px;
    height: 23px;
    background: #d2dadf;
    -webkit-transition: background 0.5s ease;
    transition: background 0.5s ease
}

.bl_popupBanner_toggle:after,.bl_popupBanner_toggle:before {
    position: absolute;
    top: 50%;
    left: 50%;
    content: "";
    width: 21px;
    height: 2px;
    background: #333;
    -webkit-transition: background 0.5s ease;
    transition: background 0.5s ease
}

.bl_popupBanner_toggle:before {
    -webkit-transform: translate(-50%,-50%) rotate(45deg);
    transform: translate(-50%,-50%) rotate(45deg)
}

.bl_popupBanner_toggle:after {
    -webkit-transform: translate(-50%,-50%) rotate(-45deg);
    transform: translate(-50%,-50%) rotate(-45deg)
}

.bl_pageTitle {
    position: relative;
    padding: 38px 0 40px
}

@media screen and (min-width: 48em) {
    .bl_pageTitle {
        padding:56px 0 62px
    }
}

@media screen and (min-width: 64em) {
    .bl_pageTitle {
        padding:75px 0 83px
    }
}

.bl_pageTitle__image {
    padding: 80px 0 84px;
    color: #fff
}

@media screen and (min-width: 48em) {
    .bl_pageTitle__image {
        padding:120px 0 126px
    }
}

@media screen and (min-width: 64em) {
    .bl_pageTitle__image {
        padding:159px 0 168px
    }
}

.bl_pageTitle_inner {
    font-size: 1.6rem;
    font-weight: 400
}

@media screen and (min-width: 48em) {
    .bl_pageTitle_inner {
        font-size:1.8rem
    }
}

.bl_pageTitle_english {
    display: block;
    font-family: "Noto Sans JP",cursive;
    font-size: 4rem;
    line-height: 1.22;
    letter-spacing: 0.03em
}

@media screen and (min-width: 48em) {
    .bl_pageTitle_english {
        font-size:4.5rem
    }
}

.bl_pageTitle_background {
    position: absolute;
    top: 0;
    left: 0;
    z-index: -1;
    width: 100%;
    height: 100%
}

.bl_breadcrumb {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    margin-top: 14px
}

.bl_breadcrumb_item:not(:last-child) {
    margin-right: 5px
}

.bl_breadcrumb_item:not(:last-child):after {
    content: "＞";
    margin-left: 5px
}

.bl_breadcrumb_item:last-child {
    cursor: text
}

.bl_breadcrumb_link {
    color: #ff9955;
    font-size: 1.4rem
}

.bl_breadcrumb_item:last-child .bl_breadcrumb_link {
    color: #333;
    pointer-events: none
}

main {
    overflow: hidden;
    margin: 0 auto
}

.js_pageContent {
    -webkit-animation: fadeIn 0.4s ease-in-out both;
    animation: fadeIn 0.4s ease-in-out both
}

.is_pageTransition .js_pageCover {
    visibility: visible
}

.bl_pageCover {
    overflow: hidden;
    visibility: hidden;
    position: fixed;
    top: 0;
    left: 0;
    z-index: 99999;
    width: 100%;
    height: 100vh
}

.bl_pageCover_inner {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: start;
    -ms-flex-pack: start;
    justify-content: flex-start;
    position: absolute;
    top: 50%;
    left: 50%;
    -webkit-transform: skew(-37deg) translate(-50%,-50%);
    transform: skew(-37deg) translate(-50%,-50%);
    -webkit-transform-origin: top left;
    transform-origin: top left;
    width: 200vmax;
    height: 100%
}

.bl_pageCover_item {
    -webkit-transform: scale3d(0,1,1);
    transform: scale3d(0,1,1);
    -webkit-transform-origin: top left;
    transform-origin: top left;
    width: calc(100% / 3);
    height: 100%;
    background: #f4e3d7;
    -webkit-transition: -webkit-transform 0.3s ease;
    transition: -webkit-transform 0.3s ease;
    transition: transform 0.3s ease;
    transition: transform 0.3s ease,-webkit-transform 0.3s ease
}

.bl_pageCover_item:nth-child(2) {
    -webkit-transition-delay: 0.15s;
    transition-delay: 0.15s
}

.bl_pageCover_item:nth-child(3) {
    -webkit-transition-delay: 0.3s;
    transition-delay: 0.3s
}

.is_pageTransition .bl_pageCover_item {
    -webkit-transform: scale3d(1.01,1,1);
    transform: scale3d(1.01,1,1)
}

.ly_pageBody {
    margin-top: 52px
}

@media screen and (min-width: 48em) {
    .ly_pageBody {
        margin-top:78px
    }
}

@media screen and (min-width: 64em) {
    .ly_pageBody {
        margin-top:104px
    }
}

@media screen and (min-width: 48em) {
    .ly_pageBody__close {
        margin-top:68px
    }
}

@media screen and (min-width: 64em) {
    .ly_pageBody__close {
        margin-top:84px
    }
}

@media screen and (min-width: 48em) {
    .ly_pageBody__isolate {
        margin-top:92px
    }
}

@media screen and (min-width: 64em) {
    .ly_pageBody__isolate {
        margin-top:131px
    }
}

.ly_pageBody__hasHighImage {
    margin-top: 40px
}

@media screen and (min-width: 64em) {
    .ly_pageBody__hasHighImage {
        margin-top:23px
    }
}

.ly_pageBody__hasColumnLead {
    margin-top: 32px
}

@media screen and (min-width: 48em) {
    .ly_pageBody__hasColumnLead {
        margin-top:40px
    }
}

@media screen and (min-width: 64em) {
    .ly_pageBody__hasColumnLead {
        margin-top:50px
    }
}

.ly_content:not(:first-child) {
    margin-top: 60px
}

@media screen and (min-width: 48em) {
    .ly_content:not(:first-child) {
        margin-top:90px
    }
}

@media screen and (min-width: 64em) {
    .ly_content:not(:first-child) {
        margin-top:120px
    }
}

@media screen and (min-width: 48em) {
    .ly_content__close:not(:first-child) {
        margin-top:60px
    }
}

@media screen and (min-width: 64em) {
    .ly_content__close:not(:first-child) {
        margin-top:80px
    }
}

.ly_content_item:not(:first-child) {
    margin-top: 50px
}

@media screen and (min-width: 48em) {
    .ly_content_item:not(:first-child) {
        margin-top:75px
    }
}

@media screen and (min-width: 64em) {
    .ly_content_item:not(:first-child) {
        margin-top:100px
    }
}

@media screen and (min-width: 48em) {
    .ly_content_item__close:not(:first-child) {
        margin-top:40px
    }
}

@media screen and (min-width: 64em) {
    .ly_content_item__close:not(:first-child) {
        margin-top:52px
    }
}

.ly_content_item__line:not(:first-child) {
    margin-top: 60px;
    padding-top: 40px;
    border-top: 1px solid #e4e1e1
}

@media screen and (min-width: 48em) {
    .ly_content_item__line:not(:first-child) {
        margin-top:90px;
        padding-top: 58px
    }
}

@media screen and (min-width: 64em) {
    .ly_content_item__line:not(:first-child) {
        margin-top:120px;
        padding-top: 74px
    }
}

.ly_content_item__line.ly_content_item__close:not(:first-child) {
    margin-top: 40px;
    padding-top: 40px;
    border-top: 1px solid #e4e1e1
}

.ly_content_item__lineBottom {
    padding-bottom: 40px;
    border-bottom: 1px solid #e4e1e1
}

@media screen and (min-width: 48em) {
    .ly_content_item__lineBottom {
        padding-bottom:58px
    }
}

@media screen and (min-width: 64em) {
    .ly_content_item__lineBottom {
        padding-top:74px
    }
}

.ly_content_item__lineBottom.ly_content_item__close {
    padding-bottom: 40px
}

.ly_layout {
    width: 88%;
    max-width: 1200px;
    margin-right: auto;
    margin-left: auto
}

.ly_layout__narrow {
    max-width: 1040px
}

.ly_layout__mobileWide {
    width: 100%
}

@media screen and (min-width: 48em) {
    .ly_layout__mobileWide {
        width:88%
    }
}

@media screen and (min-width: 48em) {
    .ly_layout__hasColumn {
        display:-webkit-box;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-align: start;
        -ms-flex-align: start;
        align-items: flex-start
    }
}

@media screen and (min-width: 48em) {
    .ly_layout_main {
        width:70.8%
    }
}

@media not screen and (min-width: 48em) {
    :where(.ly_layout__sideLeft) .ly_layout_main {
        margin-top:60px
    }
}

.ly_layout_side {
    margin-top: 60px
}

@media screen and (min-width: 48em) {
    .ly_layout_side {
        position:sticky;
        top: 0;
        right: 0;
        width: 24.16%;
        margin: calc(var(--headerHeight) * -1) 0 0 auto;
        padding-top: var(--headerHeight)
    }

    :where(.ly_layout__sideLeft) .ly_layout_side {
        margin-inline:0 auto}
}

@media not screen and (min-width: 48em) {
    :where(.ly_layout__sideLeft) .ly_layout_side {
        margin-top:0
    }
}

.bl_backgroundColor {
    position: relative;
    z-index: 2;
    padding: 48px 0
}

@media screen and (min-width: 48em) {
    .bl_backgroundColor {
        padding:72px 0
    }
}

@media screen and (min-width: 64em) {
    .bl_backgroundColor {
        padding:96px 0
    }
}

@media screen and (min-width: 48em) {
    .bl_backgroundColor__close {
        padding:52px 0
    }
}

@media screen and (min-width: 64em) {
    .bl_backgroundColor__close {
        padding:70px 0
    }
}

.bl_backgroundColor__aboveFooter {
    padding-bottom: 105px
}

@media screen and (min-width: 48em) {
    .bl_backgroundColor__aboveFooter {
        padding-bottom:158px
    }
}

@media screen and (min-width: 64em) {
    .bl_backgroundColor__aboveFooter {
        padding-bottom:210px
    }
}

@media not screen and (min-width: 48em) {
    .bl_backgroundColor__mobileBottomFit {
        padding-bottom:0
    }
}

.bl_backgroundColor__white {
    background: #fff
}

.bl_backgroundColor__base {
    background: #fff4ed
}

.bl_backgroundColor_image {
    position: absolute;
    top: 0;
    left: 0;
    z-index: -1;
    width: 100%;
    height: 100%
}

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

.bl_content_point {
    font-size: 1.8rem;
    font-weight: 500;
    text-align: center;
    letter-spacing: 0.05em
}

@media screen and (min-width: 48em) {
    .bl_content_point {
        font-size:2rem
    }
}

@media screen and (min-width: 64em) {
    .bl_content_point {
        font-size:2.3rem
    }
}

.bl_content_point__color {
    color: #ff9955
}

.el_title__main+.bl_content_point {
    margin-top: 12px
}

@media screen and (min-width: 48em) {
    .el_title__main+.bl_content_point {
        margin-top:18px
    }
}

@media screen and (min-width: 64em) {
    .el_title__main+.bl_content_point {
        margin-top:25px
    }
}

.bl_content_point+* {
    margin-top: 32px
}

@media screen and (min-width: 48em) {
    .bl_content_point+* {
        margin-top:50px
    }
}

@media screen and (min-width: 64em) {
    .bl_content_point+* {
        margin-top:68px
    }
}

.bl_content_decoration {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    opacity: 0.65;
    margin-left: -4vw;
    color: #ff9955;
    font-family: "Noto Sans JP",cursive;
    font-size: 3.5rem;
    line-height: 1;
    text-align: center;
    letter-spacing: 0.03em;
    white-space: nowrap;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center
}

@media screen and (min-width: 48em) {
    .bl_content_decoration {
        font-size:7rem
    }
}

@media screen and (min-width: 64em) {
    .bl_content_decoration {
        font-size:10rem
    }
}

.bl_content_lead {
    margin-right: auto;
    margin-left: auto;
    letter-spacing: 0.03em
}

@media screen and (min-width: 48em) {
    .bl_content_lead {
        text-align:center
    }
}

@media screen and (min-width: 48em) {
    .bl_content_lead__left {
        text-align:left
    }
}

.bl_content_lead__narrow {
    max-width: 758px
}

.bl_content_lead__medium {
    max-width: 904px
}

@media screen and (min-width: 48em) {
    .bl_content_lead__emphasis {
        font-size:1.8rem
    }
}

@media screen and (min-width: 64em) {
    .bl_content_lead__emphasis {
        font-size:2.1rem
    }
}

.bl_content_lead__color {
    color: #ff9955;
    font-weight: 500
}

.bl_content_lead p:not(:first-child) {
    margin-top: 16px
}

.bl_content_decoration+.bl_content_lead {
    margin-top: 37px
}

@media screen and (min-width: 64em) {
    .bl_content_decoration+.bl_content_lead {
        font-size:1.8rem
    }
}

.bl_content_point+.bl_content_lead {
    margin-top: 14px
}

@media screen and (min-width: 48em) {
    .bl_content_point+.bl_content_lead {
        margin-top:20px
    }
}

@media screen and (min-width: 64em) {
    .bl_content_point+.bl_content_lead {
        margin-top:27px
    }
}

.bl_content_text:not(:first-child) {
    margin-top: 16px
}

.bl_content_button {
    text-align: center
}

.bl_content_button:not(:first-child) {
    margin-top: 26px
}

@media screen and (min-width: 48em) {
    .bl_content_button:not(:first-child) {
        margin-top:56px
    }
}

.bl_content_button__close {
    margin-top: 16px
}

.bl_content_button__close:not(:first-child) {
    margin-top: 32px
}

.bl_hasImageContent {
    position: relative;
    z-index: 2
}

.bl_hasImageContent__color {
    padding-bottom: 34px;
    background: #fff4ed
}

@media screen and (min-width: 48em) {
    .bl_hasImageContent__color {
        padding-bottom:64px
    }
}

@media screen and (min-width: 64em) {
    .bl_hasImageContent__color {
        padding-bottom:93px
    }
}

.bl_hasImageContent__hasFillContent {
    padding-top: 43%
}

@media screen and (min-width: 48em) {
    .bl_hasImageContent__hasFillContent {
        padding-top:12.4%
    }
}

.bl_hasImageContent_head {
    position: absolute;
    top: 0;
    right: 0;
    z-index: -1;
    width: 100%
}

.bl_hasImageContent_head:before {
    display: block;
    content: "";
    width: 100%;
    padding-top: 45%
}

@media screen and (min-width: 48em) {
    .bl_hasImageContent_head:before {
        padding-top:40%
    }
}

@media screen and (min-width: 64em) {
    .bl_hasImageContent_head:before {
        padding-top:21.77%
    }
}

.bl_hasImageContent_head__fill:before {
    padding-top: 50%
}

@media screen and (min-width: 48em) {
    .bl_hasImageContent_head__fill:before {
        padding-top:40%
    }
}

@media screen and (min-width: 64em) {
    .bl_hasImageContent_head__fill:before {
        padding-top:21.77%
    }
}

.bl_hasImageContent__hasFillContent .bl_hasImageContent_head:before {
    padding-top: 69%
}

@media screen and (min-width: 48em) {
    .bl_hasImageContent__hasFillContent .bl_hasImageContent_head:before {
        padding-top:40%
    }
}

@media screen and (min-width: 64em) {
    .bl_hasImageContent__hasFillContent .bl_hasImageContent_head:before {
        padding-top:20.3%
    }
}

.bl_hasImageContent_content {
    position: relative;
    z-index: 2;
    padding-top: 9.79%
}

.bl_hasImageContent_content__titleNoSpace {
    padding-top: 3.95%
}

.bl_hasImageContent_content__space {
    padding-top: 12.76%
}

.bl_hasImageContent_content__background {
    padding: 30px 5% 40px;
    background: #ff9955;
    color: #fff
}

@media screen and (min-width: 64em) {
    .bl_hasImageContent_content__background {
        padding:30px 97px 40px
    }
}

.bl_hasImageContent_head__fill+.bl_hasImageContent_content {
    padding-top: 30%
}

@media screen and (min-width: 48em) {
    .bl_hasImageContent_head__fill+.bl_hasImageContent_content {
        padding-top:20.73%
    }
}

.bl_hasImageContent_head__fill+.bl_hasImageContent_content:after {
    position: absolute;
    top: 16.05vw;
    left: 50%;
    -webkit-transform: translateX(-50%);
    transform: translateX(-50%);
    z-index: -1;
    content: "";
    width: 90%;
    max-width: 1346px;
    height: 36vw;
    background: #fff
}

@media screen and (min-width: 48em) {
    .bl_hasImageContent_head__fill+.bl_hasImageContent_content:after {
        height:24vw
    }
}

@media screen and (min-width: 64em) {
    .bl_hasImageContent_head__fill+.bl_hasImageContent_content:after {
        top:17.15vw;
        height: 4.6875vw
    }
}

.bl_hasImageContent_title {
    padding-bottom: 20px;
    border-bottom: 1px solid;
    font-size: 2rem;
    font-weight: 500;
    text-align: center
}

@media screen and (min-width: 48em) {
    .bl_hasImageContent_title {
        font-size:2.2rem
    }
}

@media screen and (min-width: 64em) {
    .bl_hasImageContent_title {
        font-size:2.6rem
    }
}

.bl_hasImageContent_title+* {
    margin-top: 20px
}

.bl_countContent {
    counter-reset: countContent
}

.bl_countContent_item {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: reverse;
    -ms-flex-direction: column-reverse;
    flex-direction: column-reverse;
    position: relative;
    counter-increment: countContent
}

@media screen and (min-width: 48em) {
    .bl_countContent_item {
        -webkit-box-orient:horizontal;
        -webkit-box-direction: reverse;
        -ms-flex-direction: row-reverse;
        flex-direction: row-reverse;
        -webkit-box-align: end;
        -ms-flex-align: end;
        align-items: flex-end
    }
}

@media screen and (min-width: 48em) {
    .bl_countContent_item:nth-child(odd) {
        -webkit-box-orient:horizontal;
        -webkit-box-direction: normal;
        -ms-flex-direction: row;
        flex-direction: row
    }
}

.bl_countContent_item:not(:first-child) {
    margin-top: 80px
}

@media screen and (min-width: 48em) {
    .bl_countContent_item:not(:first-child) {
        margin-top:100px
    }
}

@media screen and (min-width: 64em) {
    .bl_countContent_item:not(:first-child) {
        margin-top:120px
    }
}

@media screen and (min-width: 48em) {
    .bl_countContent_item:before {
        display:block;
        content: "";
        width: 30%;
        padding-top: 43.33%
    }
}

@media screen and (min-width: 64em) {
    .bl_countContent_item:before {
        width:37%
    }
}

@media screen and (min-width: 80em) {
    .bl_countContent_item:before {
        width:46.25%
    }
}

@media screen and (min-width: 48em) {
    .bl_countContent_image {
        position:absolute;
        top: 0;
        right: -5%;
        z-index: -1;
        width: 61%
    }

    .bl_countContent_item:nth-child(odd) .bl_countContent_image {
        right: auto;
        left: -5%
    }
}

.bl_countContent_content {
    position: relative;
    width: 88%;
    margin: 23px auto 0;
    background: #fff
}

@media screen and (min-width: 48em) {
    .bl_countContent_content {
        width:70%;
        margin: 88px 0 0;
        padding: 54px 4.3% 48px
    }
}

@media screen and (min-width: 64em) {
    .bl_countContent_content {
        width:63%;
        margin-top: 71px
    }
}

@media screen and (min-width: 80em) {
    .bl_countContent_content {
        width:53.75%
    }
}

.bl_countContent_content:before {
    position: absolute;
    top: -193px;
    right: 0;
    color: #fff4ed;
    font-family: "Noto Sans JP",cursive;
    font-size: 207px;
    line-height: 1.22;
    letter-spacing: 0.03em
}

@media screen and (min-width: 48em) {
    .bl_countContent_content:before {
        content:counter(countContent,decimal-leading-zero)
    }
}

@media screen and (min-width: 64em) {
    .bl_countContent_content:before {
        top:-215px;
        font-size: 230px
    }
}

.bl_countContent_item:nth-child(2n) .bl_countContent_content:before {
    right: auto;
    left: 0
}

.bl_countContent_title {
    color: #ff9955;
    font-size: 2rem;
    font-weight: 400;
    line-height: 1.75;
    letter-spacing: 0.05em
}

@media screen and (min-width: 64em) {
    .bl_countContent_title {
        font-size:2.3rem;
        font-weight: 500
    }
}

.bl_countContent_text {
    margin-top: 18px
}

@media screen and (min-width: 64em) {
    .bl_countContent_text {
        margin-top:21px
    }
}

.bl_countContent_subContent {
    margin-top: 20px;
    padding: 9px 3% 13px;
    background: #fff4ed;
    font-weight: 500
}

@media screen and (min-width: 48em) {
    .bl_countContent_subContent {
        margin-top:30px;
        padding: 17px 5.3% 20px
    }
}

@media screen and (min-width: 64em) {
    .bl_countContent_subContent {
        margin-top:40px;
        font-size: 1.7rem
    }
}

@media screen and (min-width: 48em) {
    .bl_columnContent_item {
        display:-webkit-box;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-align: start;
        -ms-flex-align: start;
        align-items: flex-start
    }
}

.bl_columnContent_item:nth-child(2n) {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: reverse;
    -ms-flex-direction: row-reverse;
    flex-direction: row-reverse
}

.bl_columnContent_item:not(:first-child) {
    margin-top: 30px
}

@media screen and (min-width: 48em) {
    .bl_columnContent_content {
        width:55.5%;
        margin-right: -5.5%;
        padding: 31px 9.66% 31px 3.5%;
        background: #fff
    }
}

@media screen and (min-width: 48em) {
    .bl_columnContent_item:nth-child(2n) .bl_columnContent_content {
        margin:0 0 0 -5.5%;
        padding-right: 3.5%;
        padding-left: 9.66%
    }
}

.bl_columnContent_image {
    z-index: 0;
    margin-top: 24px
}

@media screen and (min-width: 48em) {
    .bl_columnContent_image {
        width:50%;
        margin-top: 32px
    }
}

.bl_columnContent_title {
    font-size: 1.8rem;
    font-weight: 500;
    letter-spacing: 0.05em
}

@media screen and (min-width: 48em) {
    .bl_columnContent_title {
        font-size:2rem
    }
}

@media screen and (min-width: 64em) {
    .bl_columnContent_title {
        font-size:2.3rem
    }
}

.bl_columnContent_subText {
    display: block;
    margin: 10px 0 7px;
    margin-bottom: 7px;
    font-weight: 400
}

@media screen and (min-width: 64em) {
    .bl_columnContent_subText {
        font-size:1.8rem
    }
}

.bl_columnContent_text {
    margin-top: 27px
}

@media screen and (min-width: 48em) {
    .bl_imageColumn {
        display:-webkit-box;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-align: start;
        -ms-flex-align: start;
        align-items: flex-start
    }
}

@media screen and (min-width: 48em) {
    .bl_imageColumn__reverse {
        -webkit-box-orient:horizontal;
        -webkit-box-direction: reverse;
        -ms-flex-direction: row-reverse;
        flex-direction: row-reverse
    }
}

.bl_imageColumn_body {
    position: relative;
    width: 100%
}

.bl_imageColumn__hasCount .bl_imageColumn_body {
    padding-top: 8rem
}

@media screen and (min-width: 48em) {
    .bl_imageColumn__hasCount .bl_imageColumn_body {
        padding-top:52px
    }
}

.bl_imageColumn_count {
    position: absolute;
    top: -5rem;
    left: 0;
    z-index: -1;
    color: #fff4ed;
    font-family: "Noto Sans JP",cursive;
    font-size: 16rem;
    line-height: 1.2;
    letter-spacing: 0.03em
}

@media screen and (min-width: 48em) {
    .bl_imageColumn_count {
        top:-93px;
        font-size: 18rem
    }
}

@media screen and (min-width: 64em) {
    .bl_imageColumn_count {
        top:-104px;
        font-size: 20rem
    }
}

.bl_imageColumn_item:not(:first-child) {
    margin-top: 20px
}

@media screen and (min-width: 48em) {
    .bl_imageColumn_item:not(:first-child) {
        margin-top:30px
    }
}

@media screen and (min-width: 64em) {
    .bl_imageColumn_item:not(:first-child) {
        margin-top:40px
    }
}

.bl_imageColumn_hasLabel {
    padding-left: 0
}

.bl_imageColumn_hasLabel:before {
    content: none
}

.bl_imageColumn_label {
    display: block;
    color: #d2dadf;
    font-family: "Noto Sans JP",cursive;
    font-size: 2.4rem;
    font-weight: 400;
    line-height: 1.2;
    letter-spacing: 0.03em
}

@media screen and (min-width: 48em) {
    .bl_imageColumn_label {
        font-size:2.8rem
    }
}

@media screen and (min-width: 64em) {
    .bl_imageColumn_label {
        font-size:3rem
    }
}

.bl_imageColumn_number {
    font-size: 7.2rem
}

@media screen and (min-width: 48em) {
    .bl_imageColumn_number {
        font-size:8rem
    }
}

@media screen and (min-width: 64em) {
    .bl_imageColumn_number {
        font-size:9rem
    }
}

.bl_imageColumn_lead {
    font-size: 1.8rem;
    font-weight: 500
}

@media screen and (min-width: 64em) {
    .bl_imageColumn_lead {
        font-size:2rem
    }
}

.bl_imageColumn_lead:not(:first-child) {
    margin-top: 14px
}

@media screen and (min-width: 64em) {
    .bl_imageColumn_lead:not(:first-child) {
        margin-top:27px
    }
}

.bl_imageColumn_lead+.bl_imageColumn_content {
    margin-top: 12px
}

@media screen and (min-width: 48em) {
    .bl_imageColumn_lead+.bl_imageColumn_content {
        margin-top:25px
    }
}

.bl_imageColumn_lead+.bl_imageColumn_text:not(:first-child) {
    margin-top: 10px
}

.bl_imageColumn_text:not(:first-child) {
    margin-top: 16px
}

.bl_imageColumn_image {
    margin-top: 24px
}

@media screen and (min-width: 48em) {
    .bl_imageColumn_image {
        -ms-flex-negative:0;
        flex-shrink: 0;
        width: 47.75%;
        margin: 0 0 0 2.25%;
        padding: 0 14px 14px 0;
        -webkit-filter: drop-shadow(14px 14px 0 #fff4ed);
        filter: drop-shadow(14px 14px 0 #fff4ed)
    }
}

@media screen and (min-width: 48em) {
    .bl_imageColumn__reverse .bl_imageColumn_image {
        margin:0 2.25% 0 0
    }
}

.bl_imageColumn_image .el_mediaQueryImage_inner {
    padding-top: 60.26%
}

@media screen and (min-width: 48em) {
    .bl_imageColumn_image__wide {
        width:56.6%;
        margin: 0 -11% 0 4.4%;
        padding: 0;
        -webkit-filter: none;
        filter: none
    }
}

@media screen and (min-width: 48em) {
    .bl_imageColumn__reverse .bl_imageColumn_image__wide {
        margin:0 4.4% 0 -11%
    }
}

@media screen and (min-width: 48em) {
    .bl_imageColumn_image__narrow {
        width:25.75%;
        margin: 0 0 0 5%;
        padding: 0;
        -webkit-filter: none;
        filter: none
    }
}

@media screen and (min-width: 48em) {
    .bl_imageColumn_image__medium {
        width:32.75%;
        margin: 0 0 0 8.5%;
        padding: 0;
        -webkit-filter: none;
        filter: none
    }
}

@media screen and (min-width: 48em) {
    .bl_imageColumn__reverse .bl_imageColumn_image__medium {
        margin:0 8.5% 0 0
    }
}

.bl_imageColumn_comment {
    margin-top: 30px
}

@media screen and (min-width: 48em) {
    .bl_imageColumn_comment {
        margin-top:60px
    }
}

.bl_titleContent_title {
    color: #ff9955;
    font-size: 1.8rem;
    font-weight: 500;
    line-height: 1.52;
    letter-spacing: 0.03em
}

@media screen and (min-width: 48em) {
    .bl_titleContent_title {
        font-size:2rem
    }
}

@media screen and (min-width: 64em) {
    .bl_titleContent_title {
        font-size:2.3rem
    }
}

.bl_titleContent_title:not(:first-child) {
    margin-top: 18px
}

.bl_titleContent__mini .bl_titleContent_title {
    font-size: 1.8rem
}

@media screen and (min-width: 64em) {
    .bl_titleContent__mini .bl_titleContent_title {
        font-size:2rem
    }
}

.bl_titleContent_text {
    margin-top: 18px
}

.bl_titleContent__mini .bl_titleContent_text {
    margin-top: 7px
}

.bl_titleContent_image:not(:first-child) {
    margin-top: 15px
}

@media screen and (min-width: 48em) {
    .bl_columnTitleContent {
        display:-webkit-box;
        display: -ms-flexbox;
        display: flex
    }
}

.bl_columnTitleContent__large {
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center
}

.bl_columnTitleContent__low {
    -webkit-box-align: end;
    -ms-flex-align: end;
    align-items: flex-end
}

.bl_columnTitleContent_title {
    position: relative;
    z-index: 2
}

@media screen and (min-width: 48em) {
    .bl_columnTitleContent_title {
        width:20%
    }
}

.bl_columnTitleContent__large .bl_columnTitleContent_title {
    padding-top: 5rem;
    color: #ff9955;
    font-size: 2rem;
    font-weight: 500;
    text-align: center;
    letter-spacing: 0.05em
}

@media screen and (min-width: 48em) {
    .bl_columnTitleContent__large .bl_columnTitleContent_title {
        width:43.33%;
        padding-top: 7.1rem;
        font-size: 2.3rem
    }
}

@media screen and (min-width: 64em) {
    .bl_columnTitleContent__large .bl_columnTitleContent_title {
        padding-top:9.2rem;
        font-size: 2.6rem
    }
}

.bl_columnTitleContent_english {
    display: block;
    opacity: 0.5;
    position: absolute;
    top: -0.15em;
    left: 50%;
    -webkit-transform: translateX(-50%);
    transform: translateX(-50%);
    z-index: -1;
    color: #d2dadf;
    font-family: "Noto Sans JP",cursive;
    font-size: 9.5rem;
    line-height: 1.2;
    letter-spacing: 0.03em;
    white-space: nowrap
}

@media screen and (min-width: 48em) {
    .bl_columnTitleContent_english {
        font-size:12.2rem
    }
}

@media screen and (min-width: 64em) {
    .bl_columnTitleContent_english {
        font-size:15rem
    }
}

@media screen and (min-width: 48em) {
    .bl_columnTitleContent_content {
        width:78.4%;
        margin: 0 0 0 1.6%;
        padding-left: 6%;
        border-left: 1px solid #e4e1e1
    }
}

.bl_columnTitleContent__large .bl_columnTitleContent_content {
    margin-top: 24px
}

@media screen and (min-width: 48em) {
    .bl_columnTitleContent__large .bl_columnTitleContent_content {
        width:55%;
        margin: 0 0 0 1.67%;
        padding-left: 0;
        border-left: none
    }
}

.bl_columnTitleContent_subTitle+.bl_columnTitleContent_text {
    margin-top: 19px
}

.bl_columnTitleContent_text p:not(:first-child) {
    margin-top: 19px
}

.bl_layeredContent {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: reverse;
    -ms-flex-direction: column-reverse;
    flex-direction: column-reverse;
    position: relative
}

@media screen and (min-width: 48em) {
    .bl_layeredContent {
        display:block;
        padding-top: 55px
    }
}

@media screen and (min-width: 48em) {
    .bl_layeredContent+.bl_layeredContent {
        margin-top:60px
    }
}

@media screen and (min-width: 64em) {
    .bl_layeredContent+.bl_layeredContent {
        margin-top:120px
    }
}

.bl_layeredContent__wide {
    margin-right: -6vw;
    margin-left: -6vw
}

@media screen and (min-width: 48em) {
    .bl_layeredContent__wide {
        display:-webkit-box;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-orient: horizontal;
        -webkit-box-direction: normal;
        -ms-flex-direction: row;
        flex-direction: row;
        margin-right: 0;
        margin-left: 0;
        padding-top: 76px;
        -webkit-box-align: start;
        -ms-flex-align: start;
        align-items: flex-start
    }
}

.bl_layeredContent__wide:after {
    display: block;
    content: "";
    width: 100%;
    padding-top: 66.6%
}

@media screen and (min-width: 48em) {
    .bl_layeredContent__wide:after {
        width:36%;
        padding-top: 40.3%
    }
}

@media screen and (min-width: 64em) {
    .bl_layeredContent__wide:after {
        width:46.4%
    }
}

@media screen and (min-width: 48em) {
    .bl_layeredContent__wide.bl_layeredContent__reverse {
        -webkit-box-orient:horizontal;
        -webkit-box-direction: reverse;
        -ms-flex-direction: row-reverse;
        flex-direction: row-reverse
    }
}

.bl_layeredContent_body {
    position: relative;
    padding: 30px 6%;
    background: #fff4ed
}

@media screen and (min-width: 48em) {
    .bl_layeredContent_body {
        width:64%;
        padding: 5.6% 4.16%
    }
}

@media screen and (min-width: 64em) {
    .bl_layeredContent_body {
        width:53.6%
    }
}

.bl_layeredContent__reverse .bl_layeredContent_body {
    margin-left: auto
}

.bl_layeredContent__white .bl_layeredContent_body {
    background: #fff;
    color: #333
}

.bl_layeredContent__wide .bl_layeredContent_body {
    padding: 30px 10.6%
}

@media screen and (min-width: 48em) {
    .bl_layeredContent__wide .bl_layeredContent_body {
        padding:4.5% 5%
    }
}

@media screen and (min-width: 64em) {
    .bl_layeredContent__wide .bl_layeredContent_body {
        width:55.4%
    }
}

@media not screen and (min-width: 48em) {
    .bl_layeredContent__wide .bl_layeredContent_body:has(.bl_layeredContent_label) {
        padding-top:0
    }
}

.bl_layeredContent_title {
    color: #ff9955;
    font-size: 2rem;
    font-weight: 500;
    line-height: 1.56
}

@media screen and (min-width: 48em) {
    .bl_layeredContent_title {
        font-size:2.2rem
    }
}

@media screen and (min-width: 64em) {
    .bl_layeredContent_title {
        font-size:2.6rem
    }
}

.bl_layeredContent__wide .bl_layeredContent_title {
    padding-bottom: 0;
    border-bottom: none
}

@media not screen and (min-width: 48em) {
    .bl_layeredContent__wide .bl_layeredContent_title {
        font-size:2.2rem
    }
}

:where(.bl_layeredContent__simple) .bl_layeredContent_title {
    color: #333;
    font-size: 1.8rem
}

@media screen and (min-width: 48em) {
    :where(.bl_layeredContent__simple) .bl_layeredContent_title {
        font-size:2rem
    }
}

@media screen and (min-width: 64em) {
    :where(.bl_layeredContent__simple) .bl_layeredContent_title {
        font-size:2.3rem
    }
}

.bl_layeredContent_header+.bl_layeredContent_title {
    margin-top: 40px
}

.bl_layeredContent_header {
    font-size: 1.4rem;
    font-weight: 500
}

.bl_layeredContent_label {
    display: block;
    position: relative;
    width: 3.7em;
    height: 3.7em;
    margin: -10px auto 30px;
    padding-top: 0.3em;
    font-family: "Noto Sans JP",cursive;
    font-size: 1.8rem;
    line-height: 1;
    text-align: center;
    letter-spacing: 0.03em
}

@media screen and (min-width: 48em) {
    .bl_layeredContent_label {
        margin:calc(-80px - 10.5%) auto 40px;
        padding-top: 0.5em;
        font-size: 2.6rem
    }
}

@media screen and (min-width: 64em) {
    .bl_layeredContent_label {
        margin-top:calc(-110px - 10.5%);
        font-size: 3.4rem
    }
}

.bl_layeredContent_label:before {
    position: absolute;
    top: 50%;
    left: 50%;
    -webkit-transform: rotate(45deg);
    transform: rotate(45deg);
    -webkit-transform: rotate(45deg) translate(-50%,-50%);
    transform: rotate(45deg) translate(-50%,-50%);
    -webkit-transform-origin: top left;
    transform-origin: top left;
    content: "";
    width: 100%;
    height: 100%;
    border-top: 1px solid;
    border-bottom: 1px solid;
    pointer-events: none
}

:where(.bl_layeredContent__simple) .bl_layeredContent_label {
    width: 100%;
    height: auto;
    margin: 0;
    padding: 0;
    color: #ff9955;
    font-size: 3.2rem;
    font-weight: 400;
    line-height: 1.2;
    text-align: left
}

@media screen and (min-width: 48em) {
    :where(.bl_layeredContent__simple) .bl_layeredContent_label {
        font-size:4.8rem
    }
}

@media screen and (min-width: 64em) {
    :where(.bl_layeredContent__simple) .bl_layeredContent_label {
        font-size:6.4rem
    }
}

:where(.bl_layeredContent__simple) .bl_layeredContent_label:before {
    content: none
}

.bl_layeredContent_subLabel {
    margin-top: 20px
}

.bl_layeredContent_number {
    display: block;
    margin-top: -0.125em;
    padding-right: 0.2em;
    font-size: 2.4em
}

.bl_layeredContent_titleText {
    display: block;
    margin-top: 32px
}

.bl_layeredContent_subText {
    display: block;
    margin-bottom: 10px;
    font-size: 1.6rem
}

.bl_layeredContent_content {
    font-weight: 500
}

@media screen and (min-width: 64em) {
    .bl_layeredContent_content {
        font-size:1.8rem
    }
}

.bl_layeredContent__wide .bl_layeredContent_content {
    font-weight: 400
}

@media screen and (min-width: 64em) {
    .bl_layeredContent__wide .bl_layeredContent_content {
        font-size:1.6rem
    }
}

.bl_layeredContent_content:not(:first-child) {
    margin-top: 20px
}

.bl_layeredContent__wide .bl_layeredContent_content:not(:first-child) {
    margin-top: 14px
}

@media screen and (min-width: 48em) {
    .bl_layeredContent__wide .bl_layeredContent_content:not(:first-child) {
        margin-top:20px
    }
}

:where(.bl_layeredContent__simple) .bl_layeredContent_content {
    font-size: 1.6rem;
    font-weight: 400
}

.bl_layeredContent_subContent {
    min-height: calc(28vw + 30px);
    margin-top: 14px;
    padding-top: 14px;
    border-top: 1px solid #ff9955
}

@media screen and (min-width: 48em) {
    .bl_layeredContent_subContent {
        min-height:0;
        margin-top: 30px;
        padding-top: 30px;
        padding-right: 12.3%
    }
}

.bl_layeredContent_button {
    margin-top: 20px
}

.bl_layeredContent_human {
    display: none
}

@media screen and (min-width: 48em) {
    .bl_layeredContent_human {
        display:block;
        position: absolute;
        right: -3.6%;
        bottom: 0;
        width: 26.7%
    }
}

.bl_layeredContent_image {
    z-index: -1
}

@media screen and (min-width: 48em) {
    .bl_layeredContent_image {
        position:absolute;
        top: 0;
        right: 0;
        width: 55.7%
    }
}

.bl_layeredContent__wide .bl_layeredContent_image {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%
}

@media screen and (min-width: 48em) {
    .bl_layeredContent__wide .bl_layeredContent_image {
        right:auto;
        left: 50%;
        width: 70%
    }
}

@media screen and (min-width: 48em) {
    .bl_layeredContent__reverse .bl_layeredContent_image {
        right:auto;
        left: 0
    }
}

@media screen and (min-width: 48em) {
    .bl_layeredContent__wide.bl_layeredContent__reverse .bl_layeredContent_image {
        right:50%;
        left: auto
    }
}

.bl_labelTitleContent {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex
}

.bl_labelTitleContent_title {
    -ms-flex-negative: 0;
    flex-shrink: 0;
    width: 35.4%;
    max-width: 150px
}

@media screen and (min-width: 64em) {
    .bl_labelTitleContent_title {
        width:31.7%
    }
}

.bl_labelTitleContent_content {
    margin-left: 12px;
    font-size: 1.8rem;
    font-weight: 500;
    line-height: 1.7
}

@media screen and (min-width: 64em) {
    .bl_labelTitleContent_content {
        font-size:2rem
    }
}

.bl_keyPoint {
    position: relative;
    z-index: 2
}

.bl_keyPoint__color {
    padding-top: 66px;
    background: #ff9955;
    color: #fff
}

.bl_keyPoint__color:after {
    content: none
}

.bl_keyPoint .bl_keyPoint:after,.bl_keyPoint .bl_keyPoint_inner:after {
    display: block;
    content: "";
    width: 100%;
    margin-top: 36px;
    padding-top: 52%
}

@media screen and (min-width: 48em) {
    .bl_keyPoint .bl_keyPoint:after,.bl_keyPoint .bl_keyPoint_inner:after {
        margin-top:0;
        padding-top: 9.2%
    }
}

.bl_keyPoint_inner {
    position: relative
}

.bl_keyPoint_title {
    color: #ff9955;
    font-size: 2rem;
    font-weight: 500;
    line-height: 1.75;
    text-align: center;
    letter-spacing: 0.03em
}

@media screen and (min-width: 48em) {
    .bl_keyPoint_title {
        font-size:2.2rem
    }
}

@media screen and (min-width: 64em) {
    .bl_keyPoint_title {
        font-size:2.6rem
    }
}

.bl_keyPoint__color .bl_keyPoint_title {
    color: inherit
}

.bl_keyPoint_content {
    width: -webkit-fit-content;
    width: -moz-fit-content;
    width: fit-content;
    max-width: min(100%,619px);
    margin: 50px auto 0
}

@media screen and (min-width: 64em) {
    .bl_keyPoint_content {
        font-size:1.8rem
    }
}

.bl_keyPoint_content__narrow {
    max-width: min(100%,520px)
}

@media screen and (min-width: 64em) {
    .bl_keyPoint_content__narrow {
        max-width:min(100%,577px)
    }
}

.bl_keyPoint_decoration {
    position: absolute;
    bottom: 0;
    z-index: -1
}

.bl_keyPoint_decoration__left {
    left: -8%;
    width: 51.3%
}

@media screen and (min-width: 48em) {
    .bl_keyPoint_decoration__left {
        left:-10%;
        width: 22.5%
    }
}

@media screen and (min-width: 80em) {
    .bl_keyPoint_decoration__left {
        left:0
    }
}

.bl_keyPoint_decoration__right {
    right: -8%;
    width: 55.5%
}

@media screen and (min-width: 48em) {
    .bl_keyPoint_decoration__right {
        right:-10%;
        width: 22.5%
    }
}

@media screen and (min-width: 80em) {
    .bl_keyPoint_decoration__right {
        right:0
    }
}

.bl_bicolorContent {
    overflow: hidden;
    position: relative
}

@media screen and (min-width: 48em) {
    .bl_bicolorContent_inner {
        display:-webkit-box;
        display: -ms-flexbox;
        display: flex
    }
}

.bl_bicolorContent:after,.bl_bicolorContent:before {
    position: absolute;
    top: 0;
    z-index: -1;
    width: 50%;
    height: 100%
}

@media screen and (min-width: 48em) {
    .bl_bicolorContent:after,.bl_bicolorContent:before {
        content:""
    }
}

.bl_bicolorContent:before {
    left: 0;
    background: #fff4ed
}

.bl_bicolorContent:after {
    right: 0;
    background: #fbfbfb
}

.bl_bicolorContent_item {
    position: relative;
    padding: 30px 0 35px
}

@media screen and (min-width: 48em) {
    .bl_bicolorContent_item {
        width:45.8%;
        padding: 60px 0 70px
    }
}

.bl_bicolorContent_item:after {
    position: absolute;
    top: 0;
    left: -6vw;
    z-index: -1;
    content: "";
    width: 100vw;
    height: 100%;
    background: #fff4ed
}

@media screen and (min-width: 48em) {
    .bl_bicolorContent_item:after {
        content:none
    }
}

@media screen and (min-width: 48em) {
    .bl_bicolorContent_item:nth-child(2n) {
        margin-left:8.4%
    }
}

.bl_bicolorContent_item:nth-child(2n):after {
    background: #fbfbfb
}

.bl_bicolorContent_content {
    margin-top: 20px
}

.ly_button {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    gap: 16px 24px;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center
}

@media screen and (min-width: 48em) {
    .ly_button {
        -webkit-box-orient:horizontal;
        -webkit-box-direction: normal;
        -ms-flex-direction: row;
        flex-direction: row
    }
}

.el_contentHasLineDecoration {
    position: relative
}

.el_contentHasLineDecoration:before {
    position: absolute;
    left: 50%;
    z-index: 1;
    content: "";
    width: 1px;
    height: 26px
}

@media screen and (min-width: 48em) {
    .el_contentHasLineDecoration:before {
        height:60px
    }
}

.el_contentHasLineDecoration__top:before {
    top: 0;
    background: #ff9955
}

.el_contentHasLineDecoration__bottom:before {
    bottom: 0;
    background: #e4e1e1
}

.bl_sidebar_content:not(:first-child) {
    margin-top: 30px
}

.bl_sidebar_title {
    padding: 14px 6%;
    border-bottom: 1px solid #e4e1e1;
    background: #fff4ed;
    color: #ff9955;
    font-size: 1.8rem;
    font-weight: 500;
    line-height: 1.5
}

@media screen and (min-width: 64em) {
    .bl_sidebar_title {
        padding:14px 25px;
        font-size: 2.1rem
    }
}

.bl_sidebar_list {
    margin-top: 5px
}

.bl_sidebar_list__child {
    margin: 0 0 0 24px;
    border-top: 1px solid #e4e1e1
}

.bl_sidebar_item {
    border-bottom: 1px solid #e4e1e1
}

.bl_sidebar_list__child .bl_sidebar_item:last-child {
    border-bottom: none
}

.bl_sidebar_link {
    display: block;
    position: relative;
    padding: 12px calc(6% + 33px) 12px 6%
}

@media screen and (min-width: 64em) {
    .bl_sidebar_link {
        padding:16px 58px 16px 25px
    }
}

.bl_sidebar_link:hover {
    background: #fff4ed
}

.bl_sidebar_link:hover:after {
    right: 3%
}

@media screen and (min-width: 64em) {
    .bl_sidebar_link:hover:after {
        right:15px
    }
}

.bl_sidebar_link:focus-visible {
    background: #fff4ed
}

.bl_sidebar_link:focus-visible:after {
    right: 3%
}

@media screen and (min-width: 64em) {
    .bl_sidebar_link:focus-visible:after {
        right:15px
    }
}

:root .bl_sidebar_link:focus,_:-ms-fullscreen {
    background: #fff4ed
}

:root .bl_sidebar_link:focus:after,_:-ms-fullscreen:after {
    right: 3%
}

@media screen and (min-width: 64em) {
    :root .bl_sidebar_link:focus:after,_:-ms-fullscreen:after {
        right:15px
    }
}

.bl_sidebar_link:after {
    position: absolute;
    top: 50%;
    right: 6%;
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
    content: "";
    width: 25px;
    height: 9px;
    background: url(../img/common/icon_arrow_right.svg) no-repeat;
    background-size: contain;
    -webkit-transition: right 0.5s ease;
    transition: right 0.5s ease
}

@media screen and (min-width: 64em) {
    .bl_sidebar_link:after {
        right:25px
    }
}

.ly_footerWrapper {
    position: relative;
    z-index: 2;
    background: #fff
}

.ly_footer {
    margin-top: 105px
}

@media screen and (min-width: 48em) {
    .ly_footer {
        margin-top:158px
    }
}

@media screen and (min-width: 64em) {
    .ly_footer {
        margin-top:210px
    }
}

.ly_pageLink+.ly_footer {
    margin-top: 4px
}

.error404 .ly_footer,.recruit .ly_footer {
    margin-top: 0
}

.ly_pageLink {
    margin-top: 12px;
    border-bottom: 1px solid #e4e1e1
}

.home .ly_pageLink {
    margin-top: 0;
    padding-top: 12px
}

.ly_pageLink__isolate {
    margin-top: 120px;
    border-top: 1px solid #e4e1e1
}

@media screen and (min-width: 48em) {
    .ly_pageLink__isolate {
        padding-top:18px
    }
}

.bl_catchcopy:after,.bl_footer:before {
    position: absolute;
    left: 50%;
    z-index: 2;
    content: "";
    width: 1px;
    height: 26px;
    background: #e4e1e1
}

@media screen and (min-width: 48em) {
    .bl_catchcopy:after,.bl_footer:before {
        height:60px
    }
}

.bl_catchcopy {
    position: relative
}

.bl_catchcopy:after {
    bottom: 0
}

.bl_catchcopy_inner {
    padding: 76px 0 116px;
    text-align: center
}

@media screen and (min-width: 48em) {
    .bl_catchcopy_inner {
        padding:92px 0
    }
}

@media screen and (min-width: 64em) {
    .bl_catchcopy_inner {
        padding:109px 0
    }
}

.bl_catchcopy_text {
    width: auto;
    max-width: 85px
}

@media screen and (min-width: 48em) {
    .bl_catchcopy_text {
        max-width:104px
    }
}

.bl_catchcopy_background {
    position: absolute;
    top: 0;
    left: 0;
    z-index: -1;
    width: 100%;
    height: 100%
}

.bl_footer {
    position: relative
}

.bl_footer:before {
    top: 0
}

.bl_footer_mainContent {
    position: relative;
    padding: 28px 0 38px;
    background: #333;
    color: #fff
}

@media screen and (min-width: 48em) {
    .bl_footer_mainContent {
        padding:86px 0 calc(8.6rem + 32px)
    }
}

@media screen and (min-width: 80em) {
    .bl_footer_mainContent {
        padding-bottom:80px
    }
}

.bl_footer_navigation {
    margin-top: 40px
}

@media screen and (min-width: 48em) {
    .bl_footer_navigation {
        margin-top:85px
    }
}

.bl_footer_subContent {
    position: relative;
    padding: 30px 0 calc(32px + var(--fixedButtonHeight))
}

@media screen and (min-width: 48em) {
    .bl_footer_subContent {
        display:-webkit-box;
        display: -ms-flexbox;
        display: flex;
        padding: 42px 0 calc(42px + var(--fixedButtonHeight));
        -webkit-box-align: center;
        -ms-flex-align: center;
        align-items: center
    }
}

@media screen and (min-width: 64em) {
    .bl_footer_subContent {
        padding:42px 0
    }
}

.bl_footer_logo {
    width: 42.42%
}

@media screen and (min-width: 48em) {
    .bl_footer_logo {
        width:17.66%;
        max-width: 212px
    }
}

.bl_footer_follow {
    -webkit-box-pack: end;
    -ms-flex-pack: end;
    justify-content: flex-end;
    position: absolute;
    top: 36px;
    right: 0;
    width: 38.78%;
    max-width: 120px
}

@media screen and (min-width: 48em) {
    .bl_footer_follow {
        top:53px
    }
}

.bl_footer_info {
    margin-top: 21px;
    font-size: 1.5rem
}

@media screen and (min-width: 48em) {
    .bl_footer_info {
        margin:0 0 0 6.4%
    }
}

.bl_footer_company {
    font-weight: 500
}

@media screen and (min-width: 48em) {
    .bl_footer_company {
        font-size:1.6rem
    }
}

.bl_footer_address {
    margin-top: 10px;
    font-style: normal
}

.bl_footer_tel {
    margin-right: 16px
}

.bl_footer_copyright {
    margin-top: 24px
}

@media screen and (min-width: 48em) {
    .bl_footer_copyright {
        margin:0 0 0 auto;
        -ms-flex-item-align: end;
        align-self: flex-end
    }
}

.bl_footer_pageTop {
    display: none;
    position: absolute;
    right: 70px;
    bottom: 0
}

@media screen and (min-width: 48em) {
    .bl_footer_pageTop {
        display:block
    }
}

.bl_pageTop {
    font-family: "Lora",serif;
    font-size: 1.4rem;
    letter-spacing: 0.03em;
    -webkit-writing-mode: vertical-rl;
    -ms-writing-mode: tb-rl;
    writing-mode: vertical-rl;
    text-transform: uppercase
}

.bl_pageTop_link {
    display: block;
    padding: 0 0 14px 21px;
    background: url(../img/common/icon_arrow_top_white.svg) no-repeat left bottom;
    background-size: contain
}

.bl_pageTop_link:hover {
    opacity: 0.7
}

.bl_pageTop_link:focus-visible {
    opacity: 0.7
}

:root .bl_pageTop_link:focus,_:-ms-fullscreen {
    opacity: 0.7
}

.bl_copyright {
    font-family: "Lora",serif;
    text-align: center
}

@media screen and (min-width: 48em) {
    .bl_copyright {
        text-align:right
    }
}

.bl_follow {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center
}

.bl_follow_item:not(:first-child) {
    margin-left: 21px
}

.bl_follow_link {
    display: inline-block
}

.bl_follow_link:hover {
    opacity: 0.7
}

.bl_follow_link:focus-visible {
    opacity: 0.7
}

:root .bl_follow_link:focus,_:-ms-fullscreen {
    opacity: 0.7
}

.bl_follow_icon {
    display: block;
    width: 28px
}

.bl_cta_title {
    font-family: "Noto Sans JP",cursive;
    font-size: 4rem;
    font-weight: 400;
    line-height: 1.22;
    text-align: center;
    letter-spacing: 0.03em
}

@media screen and (min-width: 64em) {
    .bl_cta_title {
        font-size:5rem
    }
}

.bl_cta_body {
    margin-top: 26px
}

@media screen and (min-width: 64em) {
    .bl_cta_body {
        margin-top:48px
    }
}

.bl_cta_item {
    padding: 20px 16px 24px;
    background: rgba(255,255,255,0.05)
}

@media screen and (min-width: 64em) {
    .bl_cta_item {
        padding:40px 54px 56px
    }
}

.bl_cta_item:nth-child(n+2) {
    margin-top: 16px
}

.bl_cta_item__small {
    padding: 24px 32px
}

@media screen and (min-width: 64em) {
    .bl_cta_item__small {
        display:-webkit-box;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-pack: center;
        -ms-flex-pack: center;
        justify-content: center;
        -webkit-box-align: center;
        -ms-flex-align: center;
        align-items: center
    }
}

.bl_cta_subTitle {
    font-size: 1.8rem;
    font-weight: 500;
    line-height: 1.94;
    text-align: center
}

@media screen and (min-width: 64em) {
    .bl_cta_subTitle {
        font-size:2rem
    }
}

@media screen and (min-width: 64em) {
    :where(.bl_cta_item__small) .bl_cta_subTitle {
        font-size:1.8rem
    }
}

.bl_cta_text {
    margin-top: 16px;
    font-size: 1.5rem;
    text-align: center
}

@media screen and (min-width: 48em) {
    .bl_cta_text {
        font-size:1.6rem
    }
}

.bl_cta_content {
    margin-top: 20px;
    text-align: center
}

@media screen and (min-width: 48em) {
    .bl_cta_content {
        margin-top:30px
    }
}

@media screen and (min-width: 64em) {
    .bl_cta_content {
        margin-top:40px
    }
}

@media screen and (min-width: 80em) {
    .bl_cta_content {
        display:-webkit-box;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-pack: center;
        -ms-flex-pack: center;
        justify-content: center;
        -webkit-box-align: stretch;
        -ms-flex-align: stretch;
        align-items: stretch
    }
}

@media screen and (min-width: 64em) {
    :where(.bl_cta_item__small) .bl_cta_content {
        margin:0 0 0 40px
    }
}

.bl_cta_subContent {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    gap: 16px;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center
}

@media screen and (min-width: 48em) {
    .bl_cta_subContent {
        -webkit-box-orient:horizontal;
        -webkit-box-direction: normal;
        -ms-flex-direction: row;
        flex-direction: row;
        width: 100%;
        gap: 24px
    }
}

@media screen and (min-width: 48em) {
    .bl_cta_subContent__hasButton {
        gap:42px
    }
}

@media screen and (min-width: 80em) {
    .bl_cta_subContent__hasButton {
        -ms-flex-negative:0;
        flex-shrink: 0;
        width: 49%
    }
}

@media screen and (min-width: 90em) {
    .bl_cta_subContent__hasButton {
        width:52.7%
    }
}

.bl_cta_subContent:nth-child(n+2) {
    margin-top: 16px;
    padding-top: 16px;
    border-top: 1px solid
}

@media screen and (min-width: 48em) {
    .bl_cta_subContent:nth-child(n+2) {
        margin-top:30px;
        padding-top: 30px
    }
}

@media screen and (min-width: 80em) {
    .bl_cta_subContent:nth-child(n+2) {
        margin:0 0 0 42px;
        padding: 0 0 0 42px;
        border-top: none;
        border-left: 1px solid
    }
}

.bl_cta_icon {
    display: inline-block;
    width: 24px;
    margin-right: 12px;
    vertical-align: -0.25em
}

.bl_cta_icon__tel {
    vertical-align: -0.125em
}

.bl_cta_icon__inButton {
    width: 19px;
    margin-right: 10px
}

.bl_cta_button {
    display: inline-block;
    width: 100%;
    max-width: 267px;
    padding: 10px 16px;
    background: #ff9955;
    font-weight: 500
}

.bl_cta_button:hover {
    opacity: 0.7
}

.bl_cta_button:focus-visible {
    opacity: 0.7
}

:root .bl_cta_button:focus,_:-ms-fullscreen {
    opacity: 0.7
}

@media screen and (min-width: 48em) {
    .bl_cta_button {
        width:calc((100% - 42px) / 2)
    }
}

.bl_cta_button__tel {
    padding-block:4px;background: #333;
    font-family: "Roboto",sans-serif;
    font-size: 2.3rem
}

.bl_cta_link {
    text-decoration: underline
}

.bl_cta_link:hover {
    opacity: 0.7
}

.bl_cta_link:focus-visible {
    opacity: 0.7
}

:root .bl_cta_link:focus,_:-ms-fullscreen {
    opacity: 0.7
}

.bl_cta_link__emphasis {
    font-size: 1.8rem
}

@media screen and (min-width: 48em) {
    .bl_subNavigation {
        display:-webkit-box;
        display: -ms-flexbox;
        display: flex;
        -ms-flex-wrap: wrap;
        flex-wrap: wrap
    }
}

@media screen and (min-width: 64em) {
    .bl_subNavigation {
        -ms-flex-wrap:nowrap;
        flex-wrap: nowrap
    }
}

.bl_subNavigation_title {
    position: relative;
    padding-left: 17px;
    font-weight: 500
}

.bl_subNavigation_title:before {
    position: absolute;
    top: 0.9375em;
    left: 2px;
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
    content: "";
    width: 12px;
    height: 2px;
    background: currentColor
}

.bl_subNavigation_toggle {
    position: relative;
    padding-right: 20px
}

.bl_subNavigation_toggle:after {
    position: absolute;
    top: 50%;
    right: 0;
    -webkit-transform: translateY(-50%) rotate(45deg);
    transform: translateY(-50%) rotate(45deg);
    content: "";
    width: 7px;
    height: 7px;
    border-right: 2px solid;
    border-bottom: 2px solid;
    -webkit-transition: -webkit-transform 0.5s ease;
    transition: -webkit-transform 0.5s ease;
    transition: transform 0.5s ease;
    transition: transform 0.5s ease,-webkit-transform 0.5s ease
}

@media screen and (min-width: 64em) {
    .bl_subNavigation_toggle:after {
        content:none
    }
}

.is_open .bl_subNavigation_toggle:after {
    -webkit-transform: translateY(0) rotate(-135deg);
    transform: translateY(0) rotate(-135deg)
}

@media screen and (min-width: 48em) {
    .bl_subNavigation_list {
        width:44%
    }
}

@media screen and (min-width: 64em) {
    .bl_subNavigation_list {
        width:22%
    }
}

.bl_subNavigation_list:not(:first-child) {
    margin-top: 20px
}

@media screen and (min-width: 48em) {
    .bl_subNavigation_list:not(:first-child) {
        margin:20px 0 0 12%
    }
}

@media screen and (min-width: 64em) {
    .bl_subNavigation_list:not(:first-child) {
        margin:0 0 0 3%
    }
}

@media screen and (min-width: 48em) {
    .bl_subNavigation_list__wide {
        width:100%
    }
}

@media screen and (min-width: 64em) {
    .bl_subNavigation_list__wide {
        width:50%
    }
}

@media screen and (min-width: 80em) {
    .bl_subNavigation_list__wide {
        width:48%
    }
}

@media screen and (min-width: 48em) {
    .bl_subNavigation_list__wide+.bl_subNavigation_list {
        margin-left:0
    }
}

@media screen and (min-width: 64em) {
    .bl_subNavigation_list__wide+.bl_subNavigation_list {
        margin-left:3%
    }
}

@media screen and (min-width: 80em) {
    .bl_subNavigation_list__wide+.bl_subNavigation_list {
        margin-left:5%
    }
}

.bl_subNavigation_item:not(:first-child) {
    margin-top: 16px
}

.bl_subNavigation_group {
    margin-top: 18px;
    -webkit-box-align: start;
    -ms-flex-align: start;
    align-items: start
}

@media screen and (min-width: 48em) {
    .bl_subNavigation_group {
        display:-webkit-box;
        display: -ms-flexbox;
        display: flex
    }
}

.bl_subNavigation_groupTitle {
    font-weight: 500;
    text-align: left
}

.bl_subNavigation_groupColumn {
    padding-left: 17px
}

@media screen and (min-width: 48em) {
    .bl_subNavigation_groupColumn {
        width:44%
    }
}

.bl_subNavigation_groupColumn:not(:first-child) {
    margin-top: 18px
}

@media screen and (min-width: 48em) {
    .bl_subNavigation_groupColumn:not(:first-child) {
        margin:0 0 0 12%;
        padding-left: 0
    }
}

.bl_subNavigation_groupItem:not(:first-child) {
    margin-top: 18px
}

@media screen and (min-width: 48em) {
    .bl_subNavigation_groupItem:not(:first-child) {
        margin-top:28px
    }
}

.bl_subNavigation_subList {
    margin-top: 12px;
    color: #c4c2c2;
    font-size: 1.5rem;
    line-height: 1.66
}

@media screen and (min-width: 48em) {
    .bl_subNavigation_subList {
        margin-top:9px
    }
}

.bl_subNavigation_title+.bl_subNavigation_subList {
    margin-left: 17px
}

.bl_subNavigation_subItem:not(:first-child) {
    margin-top: 12px
}

.bl_subNavigation_link {
    border-bottom: 1px solid transparent;
    -webkit-transition: border 0.5s ease,padding 0.5s ease;
    transition: border 0.5s ease,padding 0.5s ease
}

.bl_subNavigation_link:hover {
    padding-bottom: 0.125em;
    border-bottom-color: currentColor
}

.bl_subNavigation_link:focus-visible {
    padding-bottom: 0.125em;
    border-bottom-color: currentColor
}

:root .bl_subNavigation_link:focus,_:-ms-fullscreen {
    padding-bottom: 0.125em;
    border-bottom-color: currentColor
}

.lp_ly_header {
    position: fixed;
    top: 0;
    right: 0;
    z-index: 99999
}

@media screen and (min-width: 108em) {
    .lp_ly_header {
        overflow:auto;
        top: 50%;
        right: 24px;
        -webkit-transform: translateY(-60%);
        transform: translateY(-60%);
        max-width: 215px;
        max-height: 75vh
    }
}

@media screen and (min-width: 110em) {
    .lp_ly_header {
        right:32px
    }
}

@media screen and (min-width: 120em) {
    .lp_ly_header {
        right:80px;
        -webkit-transform: translateY(-50%);
        transform: translateY(-50%);
        max-height: 80vh
    }
}

.lp_bl_header {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
    width: 100%;
    margin: 0 auto;
    padding: 14px 5%;
    -webkit-box-align: start;
    -ms-flex-align: start;
    align-items: flex-start
}

@media screen and (min-width: 108em) {
    .lp_bl_header {
        display:block;
        padding: 0
    }
}

.lp_bl_header_rootContent {
    display: none
}

@media screen and (min-width: 108em) {
    .lp_bl_header_rootContent {
        display:block
    }
}

.lp_bl_header_title {
    position: relative;
    z-index: 999;
    width: 105px;
    max-width: 50%
}

@media screen and (min-width: 48em) {
    .lp_bl_header_title {
        width:128px
    }
}

@media screen and (min-width: 108em) {
    .lp_bl_header_title {
        width:100%;
        max-width: 100%
    }
}

.lp_bl_header_tel {
    margin-top: 16px
}

.lp_bl_header_tel__inNavigation {
    margin-top: 18px
}

@media screen and (min-width: 108em) {
    .lp_bl_header_tel__inNavigation {
        display:none
    }
}

.lp_bl_header_hour {
    font-size: 1.7rem;
    font-weight: 400
}

.lp_bl_header_contact {
    margin-top: 16px
}

@media screen and (min-width: 108em) {
    .lp_bl_header_contact__inNavigation {
        display:none
    }
}

.lp_bl_header_button {
    padding: 16px;
    font-size: 1.6rem
}

.lp_bl_header_message {
    margin-top: 21px;
    padding: 4px 0;
    border-top: 1px solid #040606;
    border-bottom: 1px solid #040606;
    text-align: center;
    letter-spacing: 0.005em
}

@media screen and (min-width: 108em) {
    .lp_bl_header_navigation {
        margin-top:17px
    }
}

.lp_bl_globalNavigation_toggle {
    display: block;
    position: relative;
    z-index: 999;
    width: 34px;
    height: 25px;
    cursor: pointer
}

@media screen and (min-width: 108em) {
    .lp_bl_globalNavigation_toggle {
        display:none
    }
}

.lp_bl_globalNavigation_bar {
    display: block;
    position: absolute;
    top: 50%;
    width: 100%;
    height: 3px;
    background: #1e1e1e;
    -webkit-transition: top 0.5s ease,margin 0.5s ease,opacity 0.5s ease,-webkit-transform 0.5s ease;
    transition: top 0.5s ease,margin 0.5s ease,opacity 0.5s ease,-webkit-transform 0.5s ease;
    transition: transform 0.5s ease,top 0.5s ease,margin 0.5s ease,opacity 0.5s ease;
    transition: transform 0.5s ease,top 0.5s ease,margin 0.5s ease,opacity 0.5s ease,-webkit-transform 0.5s ease
}

.lp_bl_globalNavigation_bar:first-of-type {
    margin-top: -12px
}

.lp_bl_globalNavigation_bar:nth-of-type(3) {
    margin-top: 12px
}

[aria-expanded=true] .lp_bl_globalNavigation_bar:first-of-type {
    top: 10px;
    -webkit-transform: rotate(45deg);
    transform: rotate(45deg);
    margin-top: 0
}

[aria-expanded=true] .lp_bl_globalNavigation_bar:nth-of-type(2) {
    opacity: 0
}

[aria-expanded=true] .lp_bl_globalNavigation_bar:nth-of-type(3) {
    top: 10px;
    -webkit-transform: rotate(-45deg);
    transform: rotate(-45deg);
    margin-top: 0
}

.lp_bl_globalNavigation_content {
    position: fixed;
    top: 0;
    left: 0;
    -webkit-transform: translate3d(100%,0,0);
    transform: translate3d(100%,0,0);
    z-index: 998;
    width: 88%;
    width: 100%;
    height: 100vh;
    padding: 63px 0;
    background: #fff;
    font-size: 1.7rem;
    font-weight: 400;
    letter-spacing: 0.005em;
    -webkit-transition: -webkit-transform 0.5s ease;
    transition: -webkit-transform 0.5s ease;
    transition: transform 0.5s ease;
    transition: transform 0.5s ease,-webkit-transform 0.5s ease
}

@media screen and (min-width: 48em) {
    .lp_bl_globalNavigation_content {
        padding-top:73px
    }
}

@media screen and (min-width: 108em) {
    .lp_bl_globalNavigation_content {
        position:static;
        -webkit-transform: none;
        transform: none;
        height: auto;
        margin: 0;
        padding: 0;
        background: transparent;
        -webkit-transition: none;
        transition: none
    }
}

.lp_bl_globalNavigation_content[aria-hidden=false] {
    -webkit-transform: translate3d(0,0,0);
    transform: translate3d(0,0,0)
}

.lp_bl_globalNavigation_inner {
    overflow-y: auto;
    width: 88%;
    height: 100%;
    margin: 0 auto;
    -webkit-overflow-scrolling: touch
}

@media screen and (min-width: 108em) {
    .lp_bl_globalNavigation_inner {
        width:100%;
        height: auto;
        margin: 0
    }
}

.lp_bl_globalNavigation_item {
    padding: 17px 0;
    border-bottom: 1px solid rgba(112,112,112,0.21)
}

@media screen and (min-width: 108em) {
    .lp_bl_globalNavigation_item {
        padding:0;
        border-bottom: none
    }
}

@media screen and (min-width: 108em) {
    .lp_bl_globalNavigation_item:not(:last-child) {
        margin-bottom:8px
    }
}

.lp_bl_globalNavigation_item:first-child {
    border-top: 1px solid rgba(112,112,112,0.21)
}

@media screen and (min-width: 108em) {
    .lp_bl_globalNavigation_item:first-child {
        border-top:none
    }
}

.lp_bl_globalNavigation_link {
    display: block;
    position: relative;
    padding: 0 20% 0 7%;
    color: #040606;
    -webkit-transition: opacity 0.5s ease;
    transition: opacity 0.5s ease
}

@media screen and (min-width: 108em) {
    .lp_bl_globalNavigation_link {
        display:inline-block;
        padding: 0 0 0 29px
    }
}

.lp_bl_globalNavigation_link:hover {
    opacity: 0.7
}

.lp_bl_globalNavigation_link:focus-visible {
    opacity: 0.7
}

:root .lp_bl_globalNavigation_link:focus,_:-ms-fullscreen {
    opacity: 0.7
}

.lp_bl_globalNavigation_link:before {
    position: absolute;
    top: 50%;
    right: 18.8%;
    -webkit-transform: translateY(-50%) rotate(45deg);
    transform: translateY(-50%) rotate(45deg);
    content: "";
    width: 8px;
    height: 8px;
    border-top: 1px solid #00789f;
    border-right: 1px solid #00789f
}

@media screen and (min-width: 108em) {
    .lp_bl_globalNavigation_link:before {
        right:auto;
        left: 0
    }
}

.ly_column {
    --width: 48.416%;
    gap: calc(100% - var(--width) * 2)
}

@media screen and (min-width: 48em) {
    .ly_column {
        display:-webkit-box;
        display: -ms-flexbox;
        display: flex;
        -ms-flex-wrap: wrap;
        flex-wrap: wrap
    }
}

.ly_column__center {
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center
}

.ly_column__three {
    --width: 31.66%;
    gap: 86px calc((100% - var(--width) * 3) / 2)
}

.ly_column__three.ly_column__verticalClose {
    row-gap: 32px
}

.ly_column__four {
    --width: 23.25%;
    gap: calc((100% - var(--width) * 4) / 3)
}

@media screen and (min-width: 48em) {
    .ly_column_item {
        width:var(--width)
    }
}

.ly_column_item:nth-child(n+2) {
    margin-top: 30px
}

@media screen and (min-width: 48em) {
    .ly_column_item:nth-child(n+2) {
        margin-top:0
    }
}

:where(.ly_column__four) .ly_column_item:nth-child(n+2) {
    margin-top: 28px
}

@media screen and (min-width: 48em) {
    :where(.ly_column__four) .ly_column_item:nth-child(n+2) {
        margin-top:0
    }
}

.ly_columnStep {
    display: -ms-grid;
    display: grid;
    gap: 24px;
    -webkit-box-align: start;
    -ms-flex-align: start;
    align-items: start;
    -ms-grid-columns: 1fr;
    grid-template-columns: 1fr;
    --step: 50px
}

@media screen and (min-width: 48em) {
    .ly_columnStep {
        padding-bottom:var(--step);
        -ms-grid-columns: (1fr)[2];
        grid-template-columns: repeat(2,1fr)
    }
}

@media screen and (min-width: 64em) {
    .ly_columnStep {
        --step:100px
    }
}

.ly_columnStep_item {
    width: 100%
}

.ly_columnStep_item:nth-child(2n) {
    position: relative
}

@media screen and (min-width: 48em) {
    .ly_columnStep_item:nth-child(2n) {
        top:var(--step)
    }
}

@media screen and (min-width: 48em) {
    .bl_decorationTitleContent {
        display:-webkit-box;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-align: end;
        -ms-flex-align: end;
        align-items: flex-end
    }
}

.bl_decorationTitleContent__hasBackgroundImage {
    position: relative
}

@media screen and (min-width: 48em) {
    .bl_decorationTitleContent__hasBackgroundImage {
        display:block
    }
}

@media screen and (min-width: 48em) {
    .bl_decorationTitleContent_content {
        width:61.66%;
        padding-bottom: 42px
    }
}

@media screen and (min-width: 64em) {
    .bl_decorationTitleContent_content {
        padding-bottom:84px
    }
}

.bl_decorationTitleContent__hasBackgroundImage .bl_decorationTitleContent_content {
    padding: 45px 0
}

@media screen and (min-width: 48em) {
    .bl_decorationTitleContent__hasBackgroundImage .bl_decorationTitleContent_content {
        padding:22px 0
    }
}

@media screen and (min-width: 64em) {
    .bl_decorationTitleContent__hasBackgroundImage .bl_decorationTitleContent_content {
        padding:91px 0 84px
    }
}

@media screen and (min-width: 48em) {
    .bl_decorationTitleContent__contentHalf .bl_decorationTitleContent_content {
        width:50%;
        padding-bottom: 46px
    }
}

@media screen and (min-width: 80em) {
    .bl_decorationTitleContent__contentHalf .bl_decorationTitleContent_content {
        padding-bottom:93px
    }
}

.bl_decorationTitleContent_head {
    padding: 20px 0;
    border-top: 1px solid;
    border-bottom: 1px solid
}

@media screen and (min-width: 48em) {
    .bl_decorationTitleContent_head {
        padding:30px 0
    }
}

@media screen and (min-width: 80em) {
    .bl_decorationTitleContent_head {
        padding:40px 0
    }
}

.bl_decorationTitleContent_head__hasLabel {
    padding-top: 0;
    border-top: none
}

.bl_decorationTitleContent_label {
    position: relative;
    font-weight: 400;
    line-height: 1;
    text-align: center
}

.bl_decorationTitleContent_label:before {
    position: absolute;
    top: 50%;
    left: 0;
    z-index: -1;
    content: "";
    width: 100%;
    height: 1px;
    background: #333
}

.bl_decorationTitleContent_inner {
    display: inline-block;
    -ms-flex-negative: 0;
    flex-shrink: 0;
    max-width: 90%;
    padding: 0 12px;
    background: #fff;
    font-size: 0
}

@media screen and (min-width: 23.4375em) {
    .bl_decorationTitleContent_inner {
        padding:0 16px
    }
}

@media screen and (min-width: 64em) {
    .bl_decorationTitleContent_inner {
        padding:0 24px
    }
}

.bl_decorationTitleContent_letter {
    display: inline-block;
    width: 2.4rem;
    height: 2.4rem;
    padding-top: 0.05em;
    background: #ff9955;
    color: #fff;
    font-size: 2.1rem
}

@media screen and (min-width: 64em) {
    .bl_decorationTitleContent_letter {
        width:2.9rem;
        height: 2.9rem;
        padding-top: 0.1em;
        font-size: 2.3rem
    }
}

.bl_decorationTitleContent_letter:not(:first-child) {
    margin-left: 4px
}

@media screen and (min-width: 23.4375em) {
    .bl_decorationTitleContent_letter:not(:first-child) {
        margin-left:6px
    }
}

@media screen and (min-width: 48em) {
    .bl_decorationTitleContent_letter:not(:first-child) {
        margin-left:4px
    }
}

@media screen and (min-width: 64em) {
    .bl_decorationTitleContent_letter:not(:first-child) {
        margin-left:6px
    }
}

.bl_decorationTitleContent_bubble {
    display: inline-block;
    position: relative;
    margin-bottom: 12px;
    padding: 0 26px;
    background: #ff9955;
    color: #fff;
    font-size: 3rem;
    font-weight: 500;
    line-height: 1.5;
    letter-spacing: 0.03em
}

.bl_decorationTitleContent_bubble:after {
    position: absolute;
    top: 100%;
    left: 50%;
    content: "";
    border: 5px solid #ff9955;
    border-right-color: transparent;
    border-bottom-color: transparent
}

.bl_decorationTitleContent_title {
    font-size: 1.8rem;
    line-height: 1.73;
    text-align: center;
    letter-spacing: 0.03em
}

@media screen and (min-width: 64em) {
    .bl_decorationTitleContent_title {
        font-size:2.4rem
    }
}

@media screen and (min-width: 80em) {
    .bl_decorationTitleContent_title {
        font-size:3rem
    }
}

.bl_decorationTitleContent_title:not(:first-child) {
    margin-top: 16px
}

@media screen and (min-width: 64em) {
    .bl_decorationTitleContent_title:not(:first-child) {
        margin-top:24px
    }
}

@media screen and (min-width: 80em) {
    .bl_decorationTitleContent_title:not(:first-child) {
        margin-top:32px
    }
}

.bl_decorationTitleContent_title .bl_decorationTitleContent__contentHalf {
    font-size: 1.6rem;
    line-height: 1.5
}

@media screen and (min-width: 64em) {
    .bl_decorationTitleContent_title .bl_decorationTitleContent__contentHalf {
        font-size:2.2rem
    }
}

@media screen and (min-width: 80em) {
    .bl_decorationTitleContent_title .bl_decorationTitleContent__contentHalf {
        font-size:2.7rem
    }
}

.bl_decorationTitleContent_problem {
    display: block;
    margin-top: 9px;
    font-size: 2rem
}

@media screen and (min-width: 64em) {
    .bl_decorationTitleContent_problem {
        font-size:2.6rem
    }
}

@media screen and (min-width: 80em) {
    .bl_decorationTitleContent_problem {
        font-size:3.2rem
    }
}

.bl_decorationTitleContent_text {
    margin-top: 20px
}

@media screen and (min-width: 48em) {
    .bl_decorationTitleContent_text {
        margin-top:30px
    }
}

@media screen and (min-width: 64em) {
    .bl_decorationTitleContent_text {
        margin-top:40px
    }
}

.bl_decorationTitleContent_image {
    max-width: 230px;
    margin: 24px auto 0
}

@media screen and (min-width: 48em) {
    .bl_decorationTitleContent_image {
        width:38.33%;
        max-width: 100%;
        margin: 0
    }
}

.bl_decorationTitleContent__contentHalf .bl_decorationTitleContent_image {
    max-width: 100%
}

@media screen and (min-width: 48em) {
    .bl_decorationTitleContent__contentHalf .bl_decorationTitleContent_image {
        width:44.9%;
        margin: 0 0 0 5.1%
    }
}

.bl_decorationTitleContent_background {
    position: absolute;
    top: 0;
    left: 0;
    z-index: -1;
    width: 100%;
    height: 100%
}

@-webkit-keyframes animationText {
    0% {
        opacity: 0;
        -webkit-transform: translate3d(0,-50%,0);
        transform: translate3d(0,-50%,0)
    }

    to {
        opacity: 1;
        -webkit-transform: translate3d(0,0,0);
        transform: translate3d(0,0,0)
    }
}

@keyframes animationText {
    0% {
        opacity: 0;
        -webkit-transform: translate3d(0,-50%,0);
        transform: translate3d(0,-50%,0)
    }

    to {
        opacity: 1;
        -webkit-transform: translate3d(0,0,0);
        transform: translate3d(0,0,0)
    }
}

@-webkit-keyframes animationDashedLine {
    0% {
        -webkit-transform: translate3d(-100%,0,0);
        transform: translate3d(-100%,0,0)
    }

    to {
        -webkit-transform: translate3d(0,0,0);
        transform: translate3d(0,0,0)
    }
}

@keyframes animationDashedLine {
    0% {
        -webkit-transform: translate3d(-100%,0,0);
        transform: translate3d(-100%,0,0)
    }

    to {
        -webkit-transform: translate3d(0,0,0);
        transform: translate3d(0,0,0)
    }
}

@-webkit-keyframes animationLine {
    0% {
        stroke-dashoffset: 900px
    }

    to {
        stroke-dashoffset: 0
    }
}

@keyframes animationLine {
    0% {
        stroke-dashoffset: 900px
    }

    to {
        stroke-dashoffset: 0
    }
}

.bl_mainVisualShape_shape {
    -webkit-animation: fadeIn 0.3s ease-in-out 0.6s both;
    animation: fadeIn 0.3s ease-in-out 0.6s both
}

.bl_mainVisualShape_line {
    -webkit-animation: animationLine 0.5s ease-in-out 1.4s both;
    animation: animationLine 0.5s ease-in-out 1.4s both;
    stroke-dasharray: 900px
}

.bl_animationText {
    overflow: hidden
}

.bl_animationText_letter {
    display: inline-block;
    -webkit-animation: animationText 0.4s cubic-bezier(0,0,0,0.5) both;
    animation: animationText 0.4s cubic-bezier(0,0,0,0.5) both;
    will-change: transform
}

.bl_animationText_letter:first-child {
    -webkit-animation-delay: 1.94s;
    animation-delay: 1.94s
}

.bl_animationText_letter:nth-child(2) {
    -webkit-animation-delay: 1.98s;
    animation-delay: 1.98s
}

.bl_animationText_letter:nth-child(3) {
    -webkit-animation-delay: 2.02s;
    animation-delay: 2.02s
}

.bl_animationText_letter:nth-child(4) {
    -webkit-animation-delay: 2.06s;
    animation-delay: 2.06s
}

.bl_animationText_letter:nth-child(5) {
    -webkit-animation-delay: 2.1s;
    animation-delay: 2.1s
}

.bl_animationText_letter:nth-child(6) {
    -webkit-animation-delay: 2.14s;
    animation-delay: 2.14s
}

.bl_animationText_letter:nth-child(7) {
    -webkit-animation-delay: 2.18s;
    animation-delay: 2.18s
}

.bl_animationText_letter:nth-child(8) {
    -webkit-animation-delay: 2.22s;
    animation-delay: 2.22s
}

.bl_animationText_letter:nth-child(9) {
    -webkit-animation-delay: 2.26s;
    animation-delay: 2.26s
}

.bl_animationText_letter:nth-child(10) {
    -webkit-animation-delay: 2.3s;
    animation-delay: 2.3s
}

.bl_animationText_letter:nth-child(11) {
    -webkit-animation-delay: 2.34s;
    animation-delay: 2.34s
}

.bl_animationText_lineWrap {
    overflow: hidden
}

.bl_animationText_line {
    display: inline-block;
    -webkit-animation: fadeIn 0.5s ease-in-out 2.5s both;
    animation: fadeIn 0.5s ease-in-out 2.5s both
}

.bl_mainVisual {
    overflow: hidden;
    position: relative;
    left: 0;
    z-index: -1;
    width: 100%;
    padding-top: calc(var(--headerHeight) + 102px)
}

@media screen and (min-width: 48em) {
    .bl_mainVisual {
        padding:calc(var(--headerHeight) + 80px) 0 72px;
        padding-bottom: min(3.75%,72px)
    }
}

@media screen and (min-width: 64em) {
    .bl_mainVisual {
        padding-top:calc(var(--headerHeight) + 16px)
    }
}

.bl_mainVisual.is_fixed {
    position: fixed
}

.bl_mainVisual:before {
    position: absolute;
    right: 9%;
    bottom: 11px;
    content: "";
    width: 97px;
    height: 77px;
    background: url(../img/index/mv_decoration_mobile.svg) no-repeat;
    background-size: contain;
    -webkit-animation: fadeIn 0.5s cubic-bezier(1,0,0.58,1) 0.2s both;
    animation: fadeIn 0.5s cubic-bezier(1,0,0.58,1) 0.2s both
}

@media screen and (min-width: 48em) {
    .bl_mainVisual:before {
        content:none
    }
}

@media screen and (min-width: 64em) {
    .bl_mainVisual:before {
        top:154px;
        right: 3.59375%;
        bottom: 670px;
        bottom: auto;
        content: "";
        width: 149px;
        height: 118px;
        background: url(../img/index/mv_decoration_right.svg) no-repeat;
        background-size: contain
    }
}

.bl_mainVisual:after {
    position: absolute;
    top: 0;
    left: 0;
    content: "";
    border: 86px solid transparent;
    border-top-color: #fff4ed;
    border-left-color: #fff4ed;
    -webkit-animation: fadeIn 0.5s cubic-bezier(1,0,0.58,1) 0.2s both;
    animation: fadeIn 0.5s cubic-bezier(1,0,0.58,1) 0.2s both
}

@media screen and (min-width: 64em) {
    .bl_mainVisual:after {
        border-width:147px
    }
}

.bl_mainVisual_inner {
    position: relative;
    max-width: 1200px;
    margin: 0 auto
}

.bl_mainVisual_inner:before {
    position: absolute;
    bottom: 0;
    left: -25%;
    width: 215px;
    height: 169px;
    background: url(../img/index/mv_decoration_left.svg) no-repeat;
    background-size: contain;
    -webkit-animation: fadeIn 0.5s cubic-bezier(1,0,0.58,1) 0.2s both;
    animation: fadeIn 0.5s cubic-bezier(1,0,0.58,1) 0.2s both
}

@media screen and (min-width: 64em) {
    .bl_mainVisual_inner:before {
        content:""
    }
}

.bl_mainVisual_content {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    position: relative;
    z-index: 2;
    width: 83.7%;
    max-width: 416px;
    padding: 23.46% 12.5% 24% 6%;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center
}

@media screen and (min-width: 48em) {
    .bl_mainVisual_content {
        display:block;
        width: 50%;
        max-width: 100%;
        padding: 18% 12.5% 17% 6%
    }
}

@media screen and (min-width: 64em) {
    .bl_mainVisual_content {
        width:57.25%;
        margin-left: -12.33%;
        padding: 17.33% 12.5% 15.5% 16.33%;
        background-position: center center;
        background-size: contain
    }
}

@media screen and (min-width: 80em) {
    .bl_mainVisual_content {
        margin-left:-18.33%;
        padding: 17.33% 12.33% 15.5% 18.33%
    }
}

.bl_mainVisual_contentBackground {
    position: absolute;
    top: 50%;
    right: 0;
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
    z-index: -1;
    width: auto;
    max-width: 500%;
    height: 100%
}

@media screen and (min-width: 64em) {
    .bl_mainVisual_contentBackground {
        left:50%;
        -webkit-transform: translate(-50%,-50%);
        transform: translate(-50%,-50%);
        width: 100%;
        height: auto
    }
}

.bl_mainVisual_catchcopy {
    display: block;
    max-width: 319px;
    margin-bottom: 20px
}

@media screen and (min-width: 48em) {
    .bl_mainVisual_catchcopy {
        margin-bottom:34px
    }
}

.bl_mainVisual_title {
    color: #ff9955;
    font-size: 1.4rem;
    font-weight: 500;
    letter-spacing: 0.05em
}

@media screen and (min-width: 48em) {
    .bl_mainVisual_title {
        font-size:1.7rem
    }
}

.bl_mainVisual_company,.bl_mainVisual_text {
    -webkit-animation: fadeIn 0.5s ease-in-out 2.4s both;
    animation: fadeIn 0.5s ease-in-out 2.4s both
}

.bl_mainVisual_company {
    font: inherit
}

.bl_mainVisual_text {
    width: 100%;
    max-width: 319px;
    margin-top: 5px;
    font-size: 1.4rem;
    font-weight: 500;
    line-height: 1.64
}

@media screen and (min-width: 48em) {
    .bl_mainVisual_text {
        max-width:100%;
        margin-top: 8px;
        font-size: 1.5rem
    }
}

.bl_mainVisual_background {
    position: absolute;
    top: 0;
    right: 0;
    z-index: -1;
    width: 100%
}

@media screen and (min-width: 48em) {
    .bl_mainVisual_background {
        height:100%
    }
}

@media screen and (min-width: 80em) {
    .bl_mainVisual_background {
        width:80.4%
    }
}

.bl_mainVisual_image {
    opacity: 0;
    -webkit-animation: fadeIn 0.5s ease-in-out 0.9s both;
    animation: fadeIn 0.5s ease-in-out 0.9s both
}

@media screen and (min-width: 48em) {
    .bl_mainVisual_image {
        height:100%
    }
}

@media screen and (min-width: 48em) {
    .bl_mainVisual_image img {
        height:100%;
        -o-object-fit: cover;
        object-fit: cover;
        -o-object-position: 25% bottom;
        object-position: 25% bottom
    }
}

@media screen and (min-width: 64em) {
    .bl_mainVisual_image img {
        -o-object-position:center bottom;
        object-position: center bottom
    }
}

.bl_mainVisual_decorationRight {
    opacity: 0;
    position: absolute;
    right: 0;
    bottom: 0;
    width: 20%;
    -webkit-animation: fadeIn 0.5s cubic-bezier(1,0,0.58,1) 0.2s both;
    animation: fadeIn 0.5s cubic-bezier(1,0,0.58,1) 0.2s both
}

.bl_mainVisual_shapeRight {
    display: none
}

@media screen and (min-width: 48em) {
    .bl_mainVisual_shapeRight {
        display:block;
        opacity: 0;
        position: absolute;
        top: 0;
        left: 32%;
        z-index: -2;
        width: auto;
        max-width: 200%;
        height: 100%;
        -webkit-animation: fadeIn 0.5s cubic-bezier(1,0,0.58,1) 0.2s both;
        animation: fadeIn 0.5s cubic-bezier(1,0,0.58,1) 0.2s both
    }
}

@media screen and (min-width: 80em) {
    .bl_mainVisual_shapeRight {
        left:17%
    }
}

@media screen and (min-width: 90em) {
    .bl_mainVisual_shapeRight {
        right:0;
        left: auto
    }
}

.bl_indexContents {
    position: relative;
    z-index: 2;
    background: #fff
}

.bl_indexWorks {
    padding: 34px 0 58px;
    background: #fff
}

@media screen and (min-width: 48em) {
    .bl_indexWorks {
        padding:64px 0 72px
    }
}

@media screen and (min-width: 64em) {
    .bl_indexWorks {
        padding:5.3% 0 90px
    }
}

.bl_indexWorks_head {
    position: relative
}

@media screen and (min-width: 48em) {
    .bl_indexWorks_head {
        position:relative
    }
}

@media screen and (min-width: 80em) {
    .bl_indexWorks_head {
        padding-bottom:42px
    }
}

@media screen and (min-width: 48em) {
    .bl_indexWorks_title {
        width:50%
    }
}

@media screen and (min-width: 64em) {
    .bl_indexWorks_title {
        width:54.5%
    }
}

.bl_indexWorks_text {
    margin-top: 8px
}

@media screen and (min-width: 48em) {
    .bl_indexWorks_text {
        margin-top:16px
    }
}

@media screen and (min-width: 64em) {
    .bl_indexWorks_text {
        width:54.5%;
        margin-top: 8px
    }
}

.bl_indexWorks_feature {
    margin-top: 24px
}

@media screen and (min-width: 48em) {
    .bl_indexWorks_feature {
        position:absolute;
        top: 0;
        right: 0;
        -webkit-transform: translateY(-71%);
        transform: translateY(-71%);
        width: 43.5%;
        margin: 0
    }
}

@media screen and (min-width: 64em) {
    .bl_indexWorks_feature {
        -webkit-transform:translateY(-60%);
        transform: translateY(-60%)
    }
}

@media screen and (min-width: 80em) {
    .bl_indexWorks_feature {
        top:auto;
        bottom: 0;
        -webkit-transform: none;
        transform: none
    }
}

.bl_indexWorks_pickup {
    display: none
}

@media screen and (min-width: 48em) {
    .bl_indexWorks_pickup {
        display:-webkit-box;
        display: -ms-flexbox;
        display: flex;
        margin-top: 57px
    }
}

.bl_indexLead {
    position: relative;
    padding: 76px 0;
    background: rgba(255,255,255,0.5);
    -webkit-backdrop-filter: blur(16px);
    backdrop-filter: blur(16px)
}

.bl_indexLead:before {
    opacity: 0.3;
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: -webkit-gradient(linear,left top,right top,from(transparent),color-stop(40%,#fff));
    background: linear-gradient(90deg,transparent,#fff 40%)
}

@media screen and (min-width: 64em) {
    .bl_indexLead:before {
        content:""
    }
}

.bl_indexLead_inner {
    position: relative
}

@media screen and (min-width: 64em) {
    .bl_indexLead_inner {
        display:-webkit-box;
        display: -ms-flexbox;
        display: flex
    }
}

@media screen and (min-width: 64em) {
    .bl_indexLead_head {
        display:-webkit-box;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-orient: vertical;
        -webkit-box-direction: normal;
        -ms-flex-direction: column;
        flex-direction: column;
        width: 42%
    }
}

.bl_indexLead_title {
    font-family: "Shippori Mincho B1",serif;
    font-size: 2.5rem;
    font-size: 2.4rem;
    font-weight: 500;
    line-height: 1.44;
    letter-spacing: 0.03em
}

@media screen and (min-width: 23.4375em) {
    .bl_indexLead_title {
        font-size:2.5rem
    }
}

@media screen and (min-width: 48em) {
    .bl_indexLead_title {
        font-size:2.8rem
    }
}

@media screen and (min-width: 64em) {
    .bl_indexLead_title {
        margin-bottom:50px
    }
}

@media screen and (min-width: 80em) {
    .bl_indexLead_title {
        font-size:3.5rem
    }
}

.bl_indexLead_keyword {
    color: #ff9955
}

.bl_indexLead_row {
    display: inline-block;
    padding: 0 10px;
    background: #fff
}

@media screen and (min-width: 64em) {
    .bl_indexLead_row {
        padding:0;
        background: transparent
    }
}

.bl_indexLead_row:not(:first-child) {
    margin-top: 9px
}

.bl_indexLead_content {
    margin-top: 37px
}

@media screen and (min-width: 64em) {
    .bl_indexLead_content {
        width:57%;
        margin: 0 0 0 1%
    }
}

.bl_indexLead_decoration {
    margin-top: 26px;
    color: #fff;
    font-family: "Noto Sans JP",cursive;
    font-size: 9.1rem;
    line-height: 1;
    text-align: center;
    letter-spacing: 0.03em;
    white-space: nowrap
}

@media screen and (min-width: 64em) {
    .bl_indexLead_decoration {
        display:none
    }
}

.bl_indexLead_text:not(:first-child) {
    margin-top: 32px
}

.bl_indexLead_decoration+.bl_indexLead_text {
    margin-top: 11px
}

.bl_indexLead_button {
    margin-top: 50px;
    text-align: center
}

@media screen and (min-width: 64em) {
    .bl_indexLead_button {
        display:none;
        margin-top: auto;
        text-align: left
    }
}

.bl_indexLead_button__inHead {
    display: none
}

@media screen and (min-width: 64em) {
    .bl_indexLead_button__inHead {
        display:block
    }
}

.bl_indexLead_shape {
    display: none;
    position: absolute;
    top: -60px;
    right: 4.5%;
    z-index: 2;
    width: 141px
}

@media screen and (min-width: 64em) {
    .bl_indexLead_shape {
        display:block
    }
}

@media screen and (min-width: 48em) {
    .bl_serviceLink {
        display:-webkit-box;
        display: -ms-flexbox;
        display: flex;
        -ms-flex-wrap: wrap;
        flex-wrap: wrap
    }
}

.bl_serviceLink_item {
    background: #f4e3d7
}

@media screen and (min-width: 48em) {
    .bl_serviceLink_item {
        width:49.88%;
        background: #fff4ed
    }
}

.bl_serviceLink_item:not(:first-child) {
    margin-top: 4px
}

@media screen and (min-width: 48em) {
    .bl_serviceLink_item:not(:first-child) {
        margin-top:0
    }
}

.bl_serviceLink_item:nth-child(odd) {
    background: #fff4ed
}

@media screen and (min-width: 48em) {
    .bl_serviceLink_item:nth-child(odd) {
        margin-right:0.24%
    }
}

@media screen and (min-width: 48em) {
    .bl_serviceLink_item:nth-child(2)~.bl_serviceLink_item {
        margin-top:0.24%
    }
}

@media screen and (min-width: 48em) {
    .bl_serviceLink_item:nth-child(2),.bl_serviceLink_item:nth-child(3) {
        background:#f4e3d7
    }
}

.bl_serviceLink_link {
    display: block;
    position: relative;
    padding: 25px 6% 29px
}

@media screen and (min-width: 48em) {
    .bl_serviceLink_link {
        display:-webkit-box;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-orient: vertical;
        -webkit-box-direction: normal;
        -ms-flex-direction: column;
        flex-direction: column;
        height: 100%
    }
}

@media screen and (min-width: 64em) {
    .bl_serviceLink_link {
        padding:36px 8.86% 20px
    }
}

.bl_serviceLink_link:hover {
    background: #fff4ed
}

.bl_serviceLink_link:hover:before {
    right: 4.26%
}

@media screen and (min-width: 64em) {
    .bl_serviceLink_link:hover:before {
        right:4px
    }
}

.bl_serviceLink_link:hover:after {
    border-right-color: #338000;
    border-bottom-color: #338000
}

.bl_serviceLink_link:focus-visible {
    background: #fff4ed
}

.bl_serviceLink_link:focus-visible:before {
    right: 4.26%
}

@media screen and (min-width: 64em) {
    .bl_serviceLink_link:focus-visible:before {
        right:4px
    }
}

.bl_serviceLink_link:focus-visible:after {
    border-right-color: #338000;
    border-bottom-color: #338000
}

:root .bl_serviceLink_link:focus,_:-ms-fullscreen {
    background: #fff4ed
}

:root .bl_serviceLink_link:focus:before,_:-ms-fullscreen:before {
    right: 4.26%
}

@media screen and (min-width: 64em) {
    :root .bl_serviceLink_link:focus:before,_:-ms-fullscreen:before {
        right:4px
    }
}

:root .bl_serviceLink_link:focus:after,_:-ms-fullscreen:after {
    border-right-color: #338000;
    border-bottom-color: #338000
}

.bl_serviceLink_link:before {
    position: absolute;
    right: 8.5%;
    bottom: 29px;
    z-index: 2;
    content: "";
    width: 38px;
    height: 13px;
    background: url(../img/common/icon_arrow_right_white.svg) no-repeat;
    background-size: contain;
    -webkit-transition: right 0.5s ease;
    transition: right 0.5s ease
}

@media screen and (min-width: 64em) {
    .bl_serviceLink_link:before {
        right:20px;
        bottom: 20px
    }
}

.bl_serviceLink_link:after {
    position: absolute;
    right: 6%;
    bottom: 20px;
    content: "";
    border: 29px solid transparent;
    border-right-color: #ff9955;
    border-bottom-color: #ff9955;
    -webkit-transition: border 0.5s ease;
    transition: border 0.5s ease
}

@media screen and (min-width: 64em) {
    .bl_serviceLink_link:after {
        right:10px;
        bottom: 10px
    }
}

.bl_serviceLink_title {
    font-size: 1.8rem;
    font-weight: 500;
    text-align: center;
    letter-spacing: 0.03em
}

@media screen and (min-width: 64em) {
    .bl_serviceLink_title {
        font-size:2rem
    }
}

.bl_serviceLink_icon {
    display: block;
    width: 84px;
    margin: 0 auto 12px
}

@media screen and (min-width: 64em) {
    .bl_serviceLink_icon {
        width:102px;
        margin-bottom: 14px
    }
}

.bl_serviceLink_text {
    margin: 23px 0 25px
}

@media screen and (min-width: 64em) {
    .bl_serviceLink_text {
        margin-bottom:56px
    }
}

.bl_serviceLink_more {
    margin-top: auto;
    padding-right: 57px;
    font-size: 1.4rem;
    text-align: right
}

@media screen and (min-width: 64em) {
    .bl_serviceLink_more {
        padding-right:24px
    }
}

@media screen and (min-width: 80em) {
    .bl_serviceLink_more {
        padding-right:14px
    }
}

@media screen and (min-width: 48em) {
    .bl_columnBanner {
        display:-webkit-box;
        display: -ms-flexbox;
        display: flex
    }
}

@media screen and (min-width: 48em) {
    .bl_columnBanner_item {
        width:33.3333333333%
    }
}

.bl_columnBanner_link {
    display: block;
    position: relative;
    height: 100%;
    padding: 22% 8px 19.8%;
    font-size: 2rem;
    font-weight: 500
}

@media screen and (min-width: 48em) {
    .bl_columnBanner_link {
        display:-webkit-box;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-pack: center;
        -ms-flex-pack: center;
        justify-content: center;
        padding: 17% 8px 14.8%;
        font-size: 1.6rem;
        -webkit-box-align: center;
        -ms-flex-align: center;
        align-items: center
    }
}

@media screen and (min-width: 64em) {
    .bl_columnBanner_link {
        padding:22% 8px 19.8%;
        font-size: 1.8rem
    }
}

@media screen and (min-width: 80em) {
    .bl_columnBanner_link {
        font-size:2.3rem
    }
}

.bl_columnBanner_link:hover .bl_columnBanner_image {
    -webkit-transform: scale(1.1);
    transform: scale(1.1)
}

.bl_columnBanner_link:focus-visible .bl_columnBanner_image {
    -webkit-transform: scale(1.1);
    transform: scale(1.1)
}

:root .bl_columnBanner_link:focus .bl_columnBanner_image,_:-ms-fullscreen .bl_columnBanner_image {
    transform: scale(1.1)
}

.bl_columnBanner_item:first-child .bl_columnBanner_link {
    padding-left: 53%
}

@media screen and (min-width: 48em) {
    .bl_columnBanner_item:first-child .bl_columnBanner_link {
        padding-left:45%
    }
}

@media screen and (min-width: 64em) {
    .bl_columnBanner_item:first-child .bl_columnBanner_link {
        padding-left:53%
    }
}

.bl_columnBanner_item:nth-child(2) .bl_columnBanner_link {
    padding: 24% 8px 17.9%;
    text-align: center
}

.bl_columnBanner_item:nth-child(3) .bl_columnBanner_link {
    padding-right: 60%;
    text-align: right
}

@media screen and (min-width: 48em) {
    .bl_columnBanner_item:nth-child(3) .bl_columnBanner_link {
        padding-right:50%
    }
}

@media screen and (min-width: 64em) {
    .bl_columnBanner_item:nth-child(3) .bl_columnBanner_link {
        padding-right:60%
    }
}

.bl_columnBanner_background {
    overflow: hidden;
    position: absolute;
    top: 0;
    left: 0;
    z-index: -1;
    width: 100%;
    height: 100%
}

.bl_columnBanner_image {
    -webkit-transition: -webkit-transform 0.5s ease;
    transition: -webkit-transform 0.5s ease;
    transition: transform 0.5s ease;
    transition: transform 0.5s ease,-webkit-transform 0.5s ease
}

@media screen and (min-width: 48em) {
    .bl_indexPost {
        display:-webkit-box;
        display: -ms-flexbox;
        display: flex
    }
}

@media screen and (min-width: 48em) {
    .bl_indexPost_item {
        width:43.8%
    }
}

.bl_indexPost_item:not(:first-child) {
    margin-top: 60px
}

@media screen and (min-width: 48em) {
    .bl_indexPost_item:not(:first-child) {
        margin-top:0
    }
}

@media screen and (min-width: 48em) {
    .bl_indexPost_item:nth-child(odd) {
        margin-right:12.4%
    }
}

@media screen and (min-width: 48em) {
    .bl_serviceFeature {
        display:-webkit-box;
        display: -ms-flexbox;
        display: flex
    }
}

.bl_serviceFeature_item {
    padding: 24px 16px 32px;
    background: #fff4ed;
    text-align: center;
    letter-spacing: 0.03em
}

@media screen and (min-width: 48em) {
    .bl_serviceFeature_item {
        width:calc((100% - (16px + 6.16%) * 2) / 3)
    }
}

@media screen and (min-width: 64em) {
    .bl_serviceFeature_item {
        width:calc((100% - (26px + 6.16%) * 2) / 3);
        padding: 30px 8px 36px
    }
}

@media screen and (min-width: 80em) {
    .bl_serviceFeature_item {
        padding-bottom:49px
    }
}

.bl_serviceFeature_item:not(:first-child) {
    margin-top: 58px
}

@media screen and (min-width: 48em) {
    .bl_serviceFeature_item:not(:first-child) {
        margin-top:0
    }
}

.bl_serviceFeature_item:not(:last-child) {
    position: relative
}

@media screen and (min-width: 48em) {
    .bl_serviceFeature_item:not(:last-child) {
        margin-right:calc(16px + 6.16%)
    }
}

@media screen and (min-width: 64em) {
    .bl_serviceFeature_item:not(:last-child) {
        margin-right:calc(26px + 6.16%)
    }
}

.bl_serviceFeature_item:not(:last-child):before {
    position: absolute;
    top: calc(100% + 16px);
    left: 50%;
    -webkit-transform: translateX(-50%);
    transform: translateX(-50%);
    content: "";
    content: "";
    width: 26px;
    height: 26px;
    background: url(../img/common/icon_cross.svg) no-repeat;
    background-size: contain
}

@media screen and (min-width: 48em) {
    .bl_serviceFeature_item:not(:last-child):before {
        top:50%;
        left: 111%;
        -webkit-transform: translateY(-50%);
        transform: translateY(-50%);
        width: 16px;
        height: 16px
    }
}

@media screen and (min-width: 64em) {
    .bl_serviceFeature_item:not(:last-child):before {
        width:26px;
        height: 26px
    }
}

.bl_serviceFeature_label {
    display: block;
    color: #d2dadf;
    font-family: "Noto Sans JP",cursive;
    font-size: 3.2rem;
    font-weight: 400;
    line-height: 1.225;
    line-height: 1.1
}

@media screen and (min-width: 64em) {
    .bl_serviceFeature_label {
        font-size:4rem
    }
}

.bl_serviceFeature_number {
    display: block;
    margin: -0.125em 0 0 -0.25em;
    font-size: 4rem
}

@media screen and (min-width: 64em) {
    .bl_serviceFeature_number {
        font-size:5rem
    }
}

.bl_serviceFeature_icon {
    display: block;
    width: 33%;
    max-width: 104px;
    margin: 6px auto 0
}

@media screen and (min-width: 64em) {
    .bl_serviceFeature_icon {
        margin-top:12px
    }
}

.bl_serviceFeature_text {
    display: block;
    margin-top: 13px;
    font-size: 1.8rem
}

@media screen and (min-width: 48em) {
    .bl_serviceFeature_text {
        font-size:1.6rem
    }
}

@media screen and (min-width: 64em) {
    .bl_serviceFeature_text {
        margin-top:26px;
        font-size: 2rem
    }
}

.bl_countCard {
    counter-reset: countCard
}

@media screen and (min-width: 48em) {
    .bl_countCard {
        display:-webkit-box;
        display: -ms-flexbox;
        display: flex;
        -ms-flex-wrap: wrap;
        flex-wrap: wrap
    }
}

.bl_countCard_item {
    counter-increment: countCard
}

@media screen and (min-width: 48em) {
    .bl_countCard_item {
        width:49%
    }
}

@media screen and (min-width: 64em) {
    .bl_countCard_item {
        width:32%
    }
}

@media screen and (min-width: 48em) {
    .bl_countCard_item:nth-child(odd) {
        margin-right:2%
    }
}

@media screen and (min-width: 64em) {
    .bl_countCard_item:nth-child(odd) {
        margin-right:0
    }
}

@media screen and (min-width: 48em) {
    .bl_countCard_item:nth-child(2)~.bl_countCard_item {
        margin-top:2%
    }
}

@media screen and (min-width: 64em) {
    .bl_countCard_item:nth-child(2)~.bl_countCard_item {
        margin-top:0
    }
}

@media screen and (min-width: 64em) {
    .bl_countCard_item:not(:nth-child(3n)) {
        margin-right:2%
    }
}

@media screen and (min-width: 64em) {
    .bl_countCard_item:nth-child(3)~.bl_countCard_item {
        margin-top:2%
    }
}

.bl_countCard_item:not(:first-child) {
    margin-top: 16px
}

@media screen and (min-width: 48em) {
    .bl_countCard_item:not(:first-child) {
        margin-top:0
    }
}

.bl_countCard_link {
    display: block;
    position: relative;
    z-index: 2;
    height: 100%;
    padding: 31px 6% 50px;
    background: #fff
}

@media screen and (min-width: 64em) {
    .bl_countCard_link {
        padding:31px 8.5% 50px
    }
}

.bl_countCard_link:hover {
    background: #fff4ed
}

.bl_countCard_link:focus-visible {
    background: #fff4ed
}

:root .bl_countCard_link:focus,_:-ms-fullscreen {
    background: #fff4ed
}

.bl_countCard_link:hover:before {
    border-right-color: #338000;
    border-bottom-color: #338000
}

.bl_countCard_link:hover:after {
    right: -8px
}

.bl_countCard_link:focus-visible:before {
    border-right-color: #338000;
    border-bottom-color: #338000
}

.bl_countCard_link:focus-visible:after {
    right: -8px
}

:root .bl_countCard_link:focus:before,_:-ms-fullscreen:before {
    border-right-color: #338000;
    border-bottom-color: #338000
}

:root .bl_countCard_link:focus:after,_:-ms-fullscreen:after {
    right: -8px
}

.bl_countCard_link:after,.bl_countCard_link:before {
    position: absolute;
    content: ""
}

.bl_countCard_link:before {
    right: 0;
    bottom: 0;
    border: 29px solid transparent;
    border-right-color: #ff9955;
    border-bottom-color: #ff9955;
    -webkit-transition: border 0.5s ease;
    transition: border 0.5s ease
}

.bl_countCard_link:after {
    right: 9px;
    bottom: 9px;
    width: 39px;
    height: 13px;
    background: url(../img/common/icon_arrow_right_white.svg) no-repeat;
    background-size: contain;
    -webkit-transition: right 0.5s ease;
    transition: right 0.5s ease
}

.bl_countCard_title {
    color: #ff9955;
    font-size: 1.8rem;
    font-weight: 500;
    line-height: 1.66
}

@media screen and (min-width: 64em) {
    .bl_countCard_title {
        font-size:2.1rem
    }
}

.bl_countCard_title:before {
    position: absolute;
    top: -11px;
    right: 11.4%;
    z-index: -1;
    content: counter(countCard,decimal-leading-zero);
    color: #fff4ed;
    font-family: "Noto Sans JP",cursive;
    font-size: 120px;
    font-weight: 400;
    line-height: 1.216;
    letter-spacing: 0.03em
}

.bl_countCard_text {
    margin-top: 19px
}

.bl_servicePoint {
    padding: 24px 6% 25px;
    background: #fff4ed
}

@media screen and (min-width: 64em) {
    .bl_servicePoint {
        padding:24px 2% 25px;
        background: #fff4ed url(../img/common/service_point_line.svg) no-repeat center 22px;
        background-size: 85% 86.9%
    }
}

@media screen and (min-width: 80em) {
    .bl_servicePoint {
        padding:46px 2.25% 49px
    }
}

.bl_servicePoint_title {
    color: #ff9955;
    font-size: 2rem;
    font-weight: 400;
    line-height: 1.5;
    text-align: center;
    letter-spacing: 0.05em
}

@media screen and (min-width: 48em) {
    .bl_servicePoint_title {
        font-size:2.2rem
    }
}

@media screen and (min-width: 80em) {
    .bl_servicePoint_title {
        font-size:2.5rem
    }
}

.bl_servicePoint_subText {
    display: block
}

@media screen and (min-width: 64em) {
    .bl_servicePoint_subText {
        font-size:1.8rem
    }
}

.bl_servicePoint_count {
    display: inline-block;
    margin-top: -0.25em;
    margin-right: 0.1em;
    font-family: "Noto Sans JP",cursive;
    font-size: 4.8rem;
    line-height: 1.2;
    letter-spacing: 0.03em
}

@media screen and (min-width: 48em) {
    .bl_servicePoint_count {
        font-size:5.4rem
    }
}

@media screen and (min-width: 64em) {
    .bl_servicePoint_count {
        font-size:6rem
    }
}

.bl_servicePoint_list {
    counter-reset: servicePoint;
    margin-top: 24px
}

@media screen and (min-width: 64em) {
    .bl_servicePoint_list {
        display:-webkit-box;
        display: -ms-flexbox;
        display: flex;
        -ms-flex-wrap: wrap;
        flex-wrap: wrap;
        margin-top: -8px
    }
}

@media screen and (min-width: 80em) {
    .bl_servicePoint_list {
        margin-top:-16px
    }
}

.bl_servicePoint_item {
    counter-increment: servicePoint;
    text-align: center
}

@media screen and (min-width: 64em) {
    .bl_servicePoint_item {
        width:38%;
        text-align: left
    }
}

@media screen and (min-width: 80em) {
    .bl_servicePoint_item {
        width:35.5%
    }
}

.bl_servicePoint_item:before {
    display: block;
    content: counter(servicePoint);
    width: 0.94em;
    height: 0.94em;
    margin: 0 auto;
    padding-right: 0.125em;
    border-radius: 50%;
    background: #fff;
    color: #d2dadf;
    font-family: "Noto Sans JP",cursive;
    font-size: 4rem;
    font-weight: 400;
    line-height: 0.94em;
    text-align: center;
    letter-spacing: 0.03em
}

@media screen and (min-width: 48em) {
    .bl_servicePoint_item:before {
        font-size:4.5rem
    }
}

@media screen and (min-width: 80em) {
    .bl_servicePoint_item:before {
        font-size:5rem
    }
}

.bl_servicePoint_item:not(:first-child) {
    margin-top: 24px
}

@media screen and (min-width: 48em) {
    .bl_servicePoint_item:not(:first-child) {
        margin-top:0
    }
}

.bl_servicePoint_item:nth-child(2) {
    margin-left: auto
}

@media screen and (min-width: 64em) {
    .bl_servicePoint_item:nth-child(2) {
        width:34%
    }
}

@media screen and (min-width: 80em) {
    .bl_servicePoint_item:nth-child(2) {
        width:35.5%
    }
}

@media screen and (min-width: 64em) {
    .bl_servicePoint_item:nth-child(3) {
        width:45%;
        margin: -23px auto 0;
        text-align: center
    }
}

.bl_servicePoint_subTitle {
    margin-top: 6px;
    color: #ff9955;
    font-size: 1.8rem;
    font-weight: 500;
    text-align: center;
    letter-spacing: 0.1em
}

@media screen and (min-width: 80em) {
    .bl_servicePoint_subTitle {
        margin-top:10px;
        font-size: 2rem
    }
}

.bl_servicePoint_text {
    margin-top: 8px
}

@media screen and (min-width: 48em) {
    .bl_servicePoint_text {
        font-size:1.4rem
    }
}

@media screen and (min-width: 80em) {
    .bl_servicePoint_text {
        margin-top:11px;
        font-size: 1.6rem
    }
}

.bl_postContent {
    overflow: hidden
}

.bl_postContent :first-child {
    margin-top: 0
}

.bl_postContent :last-child {
    margin-bottom: 0
}

.bl_postContent:after {
    display: block;
    clear: both;
    content: ""
}

.bl_postContent p {
    overflow: hidden;
    margin: 16px 0
}

.bl_postContent h2,.bl_postContent h3,.bl_postContent h4 {
    margin: 15px 0 10px
}

@media screen and (min-width: 48em) {
    .bl_postContent h2,.bl_postContent h3,.bl_postContent h4 {
        margin:22px 0 15px
    }
}

@media screen and (min-width: 64em) {
    .bl_postContent h2,.bl_postContent h3,.bl_postContent h4 {
        margin:30px 0 20px
    }
}

.bl_postContent h2,.bl_postContent h3 {
    margin: 40px 0 15px
}

@media screen and (min-width: 48em) {
    .bl_postContent h2,.bl_postContent h3 {
        margin:60px 0 22px
    }
}

@media screen and (min-width: 64em) {
    .bl_postContent h2,.bl_postContent h3 {
        margin:80px 0 30px
    }
}

.bl_postContent h2 {
    padding: 12px 15px;
    background: #fff4ed;
    font-size: 2rem;
    font-weight: 500;
    line-height: 1.59
}

@media screen and (min-width: 64em) {
    .bl_postContent h2 {
        font-size:2.2rem
    }
}

.bl_postContent h3 {
    padding-left: 11px;
    border-left: 5px solid #ff9955;
    font-size: 1.8rem;
    font-weight: 500;
    line-height: 1.65
}

@media screen and (min-width: 64em) {
    .bl_postContent h3 {
        font-size:2rem
    }
}

.bl_postContent h4 {
    margin: 30px 0 16px;
    font-size: 1.6rem;
    font-weight: 500;
    line-height: 1.66
}

@media screen and (min-width: 48em) {
    .bl_postContent h4 {
        margin-top:45px
    }
}

@media screen and (min-width: 64em) {
    .bl_postContent h4 {
        margin-top:60px;
        font-size: 1.8rem
    }
}

.bl_postContent img {
    width: auto
}

.bl_postContent blockquote {
    position: relative;
    z-index: 2;
    margin: 15px 0;
    padding: 12px 6%;
    background: #fff4ed
}

@media screen and (min-width: 48em) {
    .bl_postContent blockquote {
        margin:22px 0;
        padding: 12px 4%
    }
}

@media screen and (min-width: 64em) {
    .bl_postContent blockquote {
        margin:30px 0;
        padding: 24px 4%
    }
}

.bl_postContent blockquote:after,.bl_postContent blockquote:before {
    position: absolute;
    z-index: -1;
    content: "";
    width: 48px;
    height: 42px;
    background: url(../img/common/icon_quote_white.svg) no-repeat;
    background-size: contain
}

.bl_postContent blockquote:before {
    top: 14px;
    left: 14px
}

.bl_postContent blockquote:after {
    right: 20px;
    bottom: 25px;
    -webkit-transform: scale(-1,-1);
    transform: scale(-1,-1)
}

.bl_postContent blockquote cite {
    display: block;
    margin: 18px 0;
    font-style: normal;
    text-align: right
}

@media screen and (min-width: 48em) {
    .bl_postContent blockquote cite {
        margin:27px 0
    }
}

@media screen and (min-width: 64em) {
    .bl_postContent blockquote cite {
        margin:37px 0
    }
}

.bl_postContent a:not(.bl_blogCard_link) {
    border-bottom: 1px solid transparent;
    color: #ff9955;
    -webkit-transition: border 0.5s ease,padding 0.5s ease;
    transition: border 0.5s ease,padding 0.5s ease
}

.bl_postContent a:not(.bl_blogCard_link):hover {
    padding-bottom: 0.125em;
    border-bottom-color: currentColor
}

.bl_postContent a:not(.bl_blogCard_link):focus-visible {
    padding-bottom: 0.125em;
    border-bottom-color: currentColor
}

:root .bl_postContent a:not(.bl_blogCard_link):focus,_:-ms-fullscreen {
    padding-bottom: 0.125em;
    border-bottom-color: currentColor
}

.bl_postContent strong {
    font-weight: 500
}

.bl_postContent ul {
    margin: 16px 0
}

.bl_postContent ul li {
    list-style: disc;
    margin-left: 1.25em
}

.bl_postContent ol:not(.bl_index_list) {
    margin: 16px 0
}

.bl_postContent ol:not(.bl_index_list) li {
    list-style: decimal;
    margin-left: 1.25em
}

.bl_postContent .bl_blogCard {
    margin: 30px 0
}

.bl_single_title {
    margin-top: 18px;
    padding-bottom: 25px;
    border-bottom: 1px solid #e4e1e1;
    font-size: 2.2rem;
    font-weight: 500
}

@media screen and (min-width: 64em) {
    .bl_single_title {
        font-size:2.4rem
    }
}

.bl_single_index {
    margin: 20px 0 25px
}

@media screen and (min-width: 48em) {
    .bl_single_index {
        margin:35px 0 40px
    }
}

@media screen and (min-width: 64em) {
    .bl_single_index {
        margin:40px 0 45px
    }
}

.bl_single_content {
    margin-top: 15px
}

@media screen and (min-width: 48em) {
    .bl_single_content {
        margin-top:22px
    }
}

@media screen and (min-width: 64em) {
    .bl_single_content {
        margin-top:30px
    }
}

.bl_single_cta .bl_blogCard {
    margin-top: 0
}

.bl_single_item:nth-child(n+2) {
    margin-top: 30px
}

@media screen and (min-width: 48em) {
    .bl_single_item:nth-child(n+2) {
        margin-top:40px
    }
}

@media screen and (min-width: 64em) {
    .bl_single_item:nth-child(n+2) {
        margin-top:54px
    }
}

.bl_single_pager {
    margin-top: 25px
}

@media screen and (min-width: 48em) {
    .bl_single_pager {
        margin-top:38px
    }
}

@media screen and (min-width: 64em) {
    .bl_single_pager {
        margin-top:50px
    }
}

.bl_index {
    padding: 20px 30px;
    border: 1px solid #e4e1e1
}

.bl_index_title {
    font-size: 2.3rem;
    font-weight: 500;
    text-align: center
}

.bl_index_list {
    margin-left: 1em
}

.bl_index_item {
    list-style: decimal
}

.bl_index_item:not(:first-child) {
    margin-top: 4px
}

.bl_index .bl_index_link {
    color: #333
}

.bl_blogCard_link {
    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;
    padding: 5%;
    border: 1px solid #e4e1e1;
    color: #333;
    -webkit-box-align: start;
    -ms-flex-align: start;
    align-items: flex-start
}

.bl_blogCard_link:hover .bl_blogCard_more {
    background: #333
}

.bl_blogCard_link:focus-visible .bl_blogCard_more {
    background: #333
}

:root .bl_blogCard_link:focus .bl_blogCard_more,_:-ms-fullscreen .bl_blogCard_more {
    background: #333
}

@media screen and (min-width: 64em) {
    .bl_blogCard_link {
        padding:25px
    }
}

.bl_blogCard_image {
    -ms-flex-negative: 0;
    flex-shrink: 0;
    width: 31.25%
}

.bl_blogCard_content {
    width: 100%;
    margin-left: 3%
}

@media screen and (min-width: 48em) {
    .bl_blogCard_content {
        margin-left:4.25%
    }
}

.bl_blogCard .bl_blogCard_title {
    display: -webkit-box;
    -webkit-box-orient: vertical;
    overflow: hidden;
    margin: 0;
    color: #ff9955;
    -webkit-line-clamp: 2
}

@media screen and (min-width: 48em) {
    .bl_blogCard .bl_blogCard_title {
        font-size:1.8rem
    }
}

.bl_blogCard .bl_blogCard_text {
    display: -webkit-box;
    -webkit-box-orient: vertical;
    overflow: hidden;
    margin-top: 10px;
    font-size: 1.4rem;
    -webkit-line-clamp: 3
}

@media screen and (min-width: 48em) {
    .bl_blogCard .bl_blogCard_text {
        font-size:1.6rem
    }
}

.bl_blogCard_footer {
    margin-top: 18px
}

.bl_blogCard_more {
    display: inline-block;
    position: relative;
    padding: 1px 48px 1px 24px;
    background: #ff9955;
    color: #fff;
    font-size: 1.4rem;
    -webkit-transition: background 0.3s ease;
    transition: background 0.3s ease
}

.bl_blogCard_more:after,.bl_blogCard_more:before {
    position: absolute;
    top: 50%;
    -webkit-transform: rotate(45deg) translateX(-50%);
    transform: rotate(45deg) translateX(-50%);
    -webkit-transform-origin: top;
    transform-origin: top;
    content: "";
    width: 6px;
    height: 6px;
    border-top: 1px solid;
    border-right: 1px solid
}

.bl_blogCard_more:before {
    right: 29px
}

.bl_blogCard_more:after {
    right: 24px
}

.bl_singleCTA {
    letter-spacing: 0.03em
}

.bl_singleCTA_checklist {
    font-weight: 500;
    letter-spacing: 0
}

@media screen and (min-width: 48em) {
    .bl_singleCTA_checklist {
        font-size:1.8rem
    }
}

.bl_errorButton {
    margin-top: 21px;
    text-align: center
}

.bl_pageList_title {
    font-family: "Noto Sans JP",cursive;
    font-size: 3.2rem;
    font-weight: 400;
    line-height: 1.225;
    text-align: center;
    letter-spacing: 0.03em
}

@media screen and (min-width: 48em) {
    .bl_pageList_title {
        font-size:3.6rem
    }
}

@media screen and (min-width: 64em) {
    .bl_pageList_title {
        font-size:4rem
    }
}

.bl_pageList_list {
    margin-top: 16px
}

@media screen and (min-width: 48em) {
    .bl_pageList_list {
        display:-webkit-box;
        display: -ms-flexbox;
        display: flex;
        margin-top: 43px
    }
}

@media screen and (min-width: 64em) {
    .bl_pageList_list {
        margin-top:70px
    }
}

@media screen and (min-width: 48em) {
    .bl_pageList_item {
        width:20%
    }
}

.bl_pageList_item:not(:first-child) {
    border-top: 1px solid #e4e1e1
}

@media screen and (min-width: 48em) {
    .bl_pageList_item:not(:first-child) {
        border-top:none;
        border-left: 1px solid #e4e1e1
    }
}

.bl_pageList_link {
    display: block;
    padding: 16px 8px 14px
}

@media screen and (min-width: 48em) {
    .bl_pageList_link {
        display:-webkit-box;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-orient: vertical;
        -webkit-box-direction: normal;
        -ms-flex-direction: column;
        flex-direction: column;
        -webkit-box-pack: center;
        -ms-flex-pack: center;
        justify-content: center;
        height: 100%;
        padding: 8px;
        -webkit-box-align: center;
        -ms-flex-align: center;
        align-items: center
    }
}

.bl_pageList_link:hover {
    background: #fff4ed
}

.bl_pageList_link:focus-visible {
    background: #fff4ed
}

:root .bl_pageList_link:focus,_:-ms-fullscreen {
    background: #fff4ed
}

.bl_pageList_icon {
    display: block;
    width: 38.33%;
    max-width: 92px;
    margin: 0 auto
}

@media screen and (min-width: 48em) {
    .bl_pageList_icon {
        width:50%
    }
}

@media screen and (min-width: 64em) {
    .bl_pageList_icon {
        width:38.33%
    }
}

.bl_pageList_name {
    display: block;
    margin-top: 16px;
    font-weight: 500;
    line-height: 1.5;
    text-align: center;
    letter-spacing: 0.05em
}

@media screen and (min-width: 48em) {
    .bl_pageList_name {
        font-size:1.4rem
    }
}

@media screen and (min-width: 64em) {
    .bl_pageList_name {
        font-size:1.6rem
    }
}

.bl_philosophyLead {
    overflow: hidden;
    position: relative;
    z-index: 2;
    padding: 20px 0 0
}

@media screen and (min-width: 48em) {
    .bl_philosophyLead {
        padding:0;
        background: transparent
    }
}

.bl_philosophyLead:before {
    position: absolute;
    top: 82px;
    left: 0;
    z-index: -2;
    content: "";
    width: 100%;
    height: calc(100% - 197px);
    background: url(../img/about/philosophy/lead_shape.svg) no-repeat top left;
    background-size: auto 100%
}

.bl_philosophyLead_catchcopy {
    max-width: 505px;
    margin-top: 50px;
    margin-right: auto;
    margin-left: auto
}

@media screen and (min-width: 48em) {
    .bl_philosophyLead_catchcopy {
        width:50%;
        margin-top: 76px
    }
}

@media screen and (min-width: 64em) {
    .bl_philosophyLead_catchcopy {
        width:42%;
        margin-top: 103px
    }
}

.bl_philosophyLead_content {
    margin-top: 66px
}

@media screen and (min-width: 48em) {
    .bl_philosophyLead_content {
        margin-top:100px;
        padding-right: 47%
    }
}

@media screen and (min-width: 64em) {
    .bl_philosophyLead_content {
        margin-top:133px
    }
}

.bl_philosophyLead_feature {
    margin-top: 20px
}

@media screen and (min-width: 48em) {
    .bl_philosophyLead_feature {
        margin-top:25px
    }
}

@media screen and (min-width: 64em) {
    .bl_philosophyLead_feature {
        margin-top:38px
    }
}

.bl_philosophyLead_background {
    display: none;
    position: absolute;
    top: 379px;
    right: 0;
    z-index: -1;
    width: 63.22%
}

@media screen and (min-width: 48em) {
    .bl_philosophyLead_background {
        display:block
    }
}

.bl_philosophyLead_background .el_mediaQueryImage_inner {
    padding-top: 66.64%;
    background-image: url(../img/about/philosophy/lead_bg.png)
}

.bl_diamondTitleContent {
    counter-reset: diamondTitleContent;
    padding-top: 9.424rem
}

@media screen and (min-width: 48em) {
    .bl_diamondTitleContent {
        display:-webkit-box;
        display: -ms-flexbox;
        display: flex
    }
}

@media screen and (min-width: 64em) {
    .bl_diamondTitleContent {
        padding-top:11.78rem
    }
}

.bl_diamondTitleContent_item {
    position: relative;
    counter-increment: diamondTitleContent;
    padding: calc(9.424rem + 10px) 6% 35px;
    background: #fff
}

@media screen and (min-width: 48em) {
    .bl_diamondTitleContent_item {
        width:31.66%;
        padding: calc(9.424rem + 10px) 3% 35px
    }
}

@media screen and (min-width: 64em) {
    .bl_diamondTitleContent_item {
        padding-top:calc(11.78rem + 10px)
    }
}

.bl_diamondTitleContent_item:not(:first-child) {
    margin-top: calc(9.424rem + 24px)
}

@media screen and (min-width: 48em) {
    .bl_diamondTitleContent_item:not(:first-child) {
        margin-top:0
    }
}

@media screen and (min-width: 48em) {
    .bl_diamondTitleContent_item:not(:nth-child(3n)) {
        margin-right:2.51%
    }
}

.bl_diamondTitleContent_title {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    position: absolute;
    top: 0;
    left: 50%;
    -webkit-transform: translate(-50%,-50%);
    transform: translate(-50%,-50%);
    z-index: 2;
    width: 18.848rem;
    height: 18.848rem;
    color: #fff;
    font-family: "Shippori Mincho B1",serif;
    font-size: 2.4rem;
    font-weight: 500;
    line-height: 1.2;
    text-align: center;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center
}

@media screen and (min-width: 64em) {
    .bl_diamondTitleContent_title {
        width:23.56rem;
        height: 23.56rem;
        font-size: 3rem
    }
}

.bl_diamondTitleContent_title:before {
    display: block;
    content: counter(diamondTitleContent,decimal-leading-zero);
    margin: -0.5em 0 0 -0.25em;
    font-family: "Noto Sans JP",cursive;
    font-size: 3.2rem
}

@media screen and (min-width: 64em) {
    .bl_diamondTitleContent_title:before {
        font-size:4rem
    }
}

.bl_diamondTitleContent_title:after {
    position: absolute;
    top: 50%;
    left: 50%;
    -webkit-transform: translate(-50%,-50%) rotate(45deg);
    transform: translate(-50%,-50%) rotate(45deg);
    z-index: -1;
    content: "";
    width: 13.328rem;
    height: 13.328rem;
    border: 10px solid #fff;
    background: #ff9955
}

@media screen and (min-width: 64em) {
    .bl_diamondTitleContent_title:after {
        width:16.66rem;
        height: 16.66rem
    }
}

@media screen and (min-width: 48em) {
    .bl_message {
        display:-webkit-box;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-align: start;
        -ms-flex-align: start;
        align-items: flex-start
    }
}

@media screen and (min-width: 48em) {
    .bl_message_content {
        width:52.66%
    }
}

.bl_message_text:not(:first-child) {
    margin-top: 30px
}

.bl_message_signature {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: end;
    -ms-flex-pack: end;
    justify-content: flex-end;
    margin-top: 30px;
    letter-spacing: 0.03em;
    -webkit-box-align: end;
    -ms-flex-align: end;
    align-items: flex-end
}

.bl_message_title {
    -ms-flex-negative: 0;
    flex-shrink: 0;
    max-width: 50%
}

.bl_message_name {
    display: inline-block;
    width: auto;
    max-width: min(50%,232px);
    margin-left: 16px
}

@media screen and (min-width: 48em) {
    .bl_message_name {
        margin-left:38px
    }
}

.bl_message_image {
    margin-top: 30px
}

@media screen and (min-width: 48em) {
    .bl_message_image {
        width:28.16%;
        margin: 0 0 0 19.18%
    }
}

.el_screenshot__mobile {
    position: relative
}

.el_screenshot__mobile:before {
    display: block;
    content: "";
    width: 100%;
    padding-top: 173.535%
}

.el_screenshot__mobile img {
    position: absolute;
    top: 0;
    left: 0;
    -o-object-position: center top;
    object-position: center top
}

.bl_worksList_categoryName {
    margin-top: 80px;
    font-size: 3.3rem
}

.bl_worksList_list {
    margin-top: 80px
}

:where(.bl_worksList_categoryName)+.bl_worksList_list {
    margin-top: 60px
}

.bl_worksCategory {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    gap: 10px;
    font-size: 1.5rem
}

.bl_worksCategory_inner {
    display: inline-block;
    padding: 0 10px;
    background: #fff4ed
}

.bl_worksCategory_inner[aria-current=page] {
    background: #ff9955;
    color: #fff
}

:where(.bl_worksCategory__inBackground) .bl_worksCategory_inner {
    background: #fff
}

.bl_worksCategory_inner[href]:hover {
    background: #ff9955;
    color: #fff
}

.bl_worksCategory_inner[href]:focus-visible {
    background: #ff9955;
    color: #fff
}

:root .bl_worksCategory_inner[href]:focus,_:-ms-fullscreen {
    background: #ff9955;
    color: #fff
}

.bl_worksCategorySelect {
    position: relative;
    padding-bottom: 40px;
    border-bottom: 1px solid #e4e1e1
}

@media screen and (min-width: 64em) {
    .bl_worksCategorySelect_content {
        display:-webkit-box;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-align: start;
        -ms-flex-align: start;
        align-items: flex-start
    }
}

.bl_worksCategorySelect_content:nth-child(n+2) {
    margin-top: 30px
}

.bl_worksCategorySelect_title {
    font-size: 1.8rem;
    font-weight: 500
}

@media screen and (min-width: 64em) {
    .bl_worksCategorySelect_title {
        -ms-flex-negative:0;
        flex-shrink: 0;
        width: 5em;
        max-width: 30%;
        font-size: 2rem
    }
}

.bl_worksCategorySelect_list {
    margin-top: 16px
}

@media screen and (min-width: 64em) {
    .bl_worksCategorySelect_list {
        margin:0 0 0 50px
    }
}

.bl_worksService_title {
    padding-bottom: 14px;
    border-bottom: 1px solid #e4e1e1;
    color: #ff9955;
    font-family: "Noto Sans JP",cursive;
    font-size: 2.3rem;
    font-weight: 400;
    line-height: 1.2;
    letter-spacing: 0.03em
}

.bl_worksService_list {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    margin: 20px 0 -15px;
    font-size: 1.4rem
}

.bl_worksService_item {
    margin-bottom: 4px;
    color: #989696;
    line-height: 1.5
}

@media screen and (min-width: 48em) {
    .bl_worksService_item {
        margin-bottom:15px
    }
}

.bl_worksService_item:not(:last-child) {
    margin-right: 8px
}

@media screen and (min-width: 48em) {
    .bl_worksService_item:not(:last-child) {
        margin-right:15px
    }
}

.bl_worksService_item:not(:last-child):after {
    content: "/";
    margin-left: 8px;
    color: #ff9955;
    font-weight: 500
}

@media screen and (min-width: 48em) {
    .bl_worksService_item:not(:last-child):after {
        margin-left:15px
    }
}

.bl_worksDetail {
    overflow: visible
}

.bl_worksDetail_thumbnail {
    margin-top: 40px
}

.bl_worksDetail_title {
    font-size: 2.6rem;
    font-weight: 400
}

@media screen and (min-width: 48em) {
    .bl_worksDetail_title {
        font-size:3rem
    }
}

@media screen and (min-width: 64em) {
    .bl_worksDetail_title {
        font-size:3.3rem
    }
}

.bl_worksDetail_mockup {
    display: block;
    max-width: 985px;
    margin-top: 20px
}

@media screen and (min-width: 48em) {
    .bl_worksDetail_mockup {
        margin-top:40px
    }
}

@media screen and (min-width: 64em) {
    .bl_worksDetail_mockup {
        margin-top:62px
    }
}

.bl_worksDetail_information {
    margin-top: 60px
}

.bl_worksDetail_item:not(:first-child) {
    margin-top: 64px
}

.bl_worksDetail_contents {
    max-width: 970px
}

.bl_worksDetail_body {
    padding-bottom: 120px;
    border-bottom: 1px solid #e4e1e1
}

.bl_worksDetail_subTitle {
    position: relative
}

.bl_worksDetail_subTitle__wideLine {
    padding-left: 19px;
    font-size: 2rem;
    font-weight: 500
}

.bl_worksDetail_subTitle__wideLine:after {
    position: absolute;
    top: 0.4375em;
    left: 0;
    content: "";
    width: 7px;
    height: calc(100% - 0.875em);
    background: #ff9955
}

.bl_worksDetail_subTitle__line {
    padding-left: 30px;
    font-size: 1.6rem;
    font-weight: 500
}

.bl_worksDetail_subTitle__line:after {
    position: absolute;
    top: 0.9375em;
    left: 0;
    content: "";
    width: 20px;
    height: 1px;
    background: #ff9955
}

.bl_worksDetail_subTitle__color {
    color: #ff9955;
    font-size: 1.8rem;
    font-weight: 500
}

.bl_worksDetail_content {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    margin-top: 20px;
    gap: 16px
}

@media screen and (min-width: 48em) {
    .bl_worksDetail_content {
        margin-top:30px
    }
}

@media screen and (min-width: 64em) {
    .bl_worksDetail_content {
        margin-top:40px
    }
}

.bl_worksDetail_pager {
    margin-top: 80px
}

.bl_gallery {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap
}

.bl_gallery__differentHeight {
    -webkit-box-align: start;
    -ms-flex-align: start;
    align-items: flex-start
}

.bl_gallery_item {
    width: 47.5%
}

@media not screen and (min-width: 48em) {
    :where(.bl_gallery__mobileWide) .bl_gallery_item {
        width:100%
    }
}

@media not screen and (min-width: 48em) {
    :where(.bl_gallery__mobileWide) .bl_gallery_item:not(:first-child) {
        margin-top:16px
    }
}

.bl_gallery_item:nth-child(odd) {
    margin-right: 5%
}

@media not screen and (min-width: 48em) {
    :where(.bl_gallery__mobileWide) .bl_gallery_item:nth-child(odd) {
        margin-right:0
    }
}

.bl_gallery_item:nth-child(2)~.bl_gallery_item {
    margin-top: 5%
}

@media not screen and (min-width: 48em) {
    :where(.bl_gallery__mobileWide) .bl_gallery_item:nth-child(2)~.bl_gallery_item {
        margin-top:16px
    }
}

.bl_gallery__column3 .bl_gallery_item {
    width: 100%
}

@media screen and (min-width: 48em) {
    .bl_gallery__column3 .bl_gallery_item {
        width:30%
    }
}

@media screen and (min-width: 48em) {
    .bl_gallery__column3 .bl_gallery_item:nth-child(odd) {
        margin-right:0
    }
}

@media screen and (min-width: 48em) {
    .bl_gallery__column3 .bl_gallery_item:not(:nth-child(3n)) {
        margin-right:5%
    }
}

@media screen and (min-width: 48em) {
    .bl_gallery__column3 .bl_gallery_item:nth-child(3) {
        margin-top:0
    }
}

.bl_worksContent :first-child {
    margin-top: 0
}

.bl_worksContent :last-child {
    margin-bottom: 0
}

.bl_worksContent h2 {
    position: relative;
    margin: 40px 0 20px;
    padding-left: 28px;
    color: #ff9955;
    font-size: 2rem;
    font-weight: 500
}

@media screen and (min-width: 48em) {
    .bl_worksContent h2 {
        margin-top:54px;
        font-size: 2.2rem
    }
}

@media screen and (min-width: 64em) {
    .bl_worksContent h2 {
        margin-top:80px;
        font-size: 2.6rem
    }
}

.bl_worksContent h2:before {
    position: absolute;
    top: 0.9375em;
    left: 0;
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
    content: "";
    width: 20px;
    height: 1px;
    background: #ff9955
}

.bl_worksContent h3 {
    margin: 32px 0 20px;
    font-size: 1.8rem;
    font-weight: 500
}

@media screen and (min-width: 48em) {
    .bl_worksContent h3 {
        margin-top:34px;
        font-size: 2rem
    }
}

@media screen and (min-width: 64em) {
    .bl_worksContent h3 {
        margin-top:52px;
        font-size: 2.3rem
    }
}

.bl_worksContent p {
    margin: 19px 0
}

.bl_worksContent_gallary {
    margin: 20px 0
}

@media screen and (min-width: 48em) {
    .bl_worksContent_gallary {
        margin:30px 0
    }
}

@media screen and (min-width: 64em) {
    .bl_worksContent_gallary {
        margin:40px 0
    }
}

.bl_worksInformation_item {
    padding-bottom: 20px;
    border-bottom: 1px solid #e4e1e1
}

@media screen and (min-width: 48em) {
    .bl_worksInformation_item {
        display:-webkit-box;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-align: start;
        -ms-flex-align: start;
        align-items: flex-start
    }
}

.bl_worksInformation_item:nth-child(n+2) {
    margin-top: 20px
}

.bl_worksInformation_title {
    -ms-flex-negative: 0;
    flex-shrink: 0;
    width: 96px;
    max-width: 40%;
    font-weight: 500
}

.bl_worksInformation_data {
    margin-top: 8px
}

@media screen and (min-width: 48em) {
    .bl_worksInformation_data {
        margin:0 0 0 100px
    }
}

.bl_worksDetailIndex_item {
    padding: 20px;
    border-bottom: 1px solid #e4e1e1
}

.bl_worksDetailIndex_item:first-child {
    border-top: 1px solid #e4e1e1
}

.bl_worksDetailIndex_link {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
    color: #989696;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center
}

.bl_worksDetailIndex_link.is_current {
    color: #333
}

.bl_worksDetailIndex_link:after {
    -webkit-transform: rotate(45deg);
    transform: rotate(45deg);
    content: "";
    width: 9px;
    margin-left: 20px;
    border-right: 1px solid #ff9955;
    border-bottom: 1px solid #ff9955;
    aspect-ratio: 1
}

@media screen and (min-width: 48em) {
    .bl_brandingImage {
        display:-webkit-box;
        display: -ms-flexbox;
        display: flex
    }
}

.bl_brandingImage_item__narrow {
    -ms-flex-negative: 0;
    flex-shrink: 0
}

@media screen and (min-width: 48em) {
    .bl_brandingImage_item__narrow {
        width:46.5%
    }
}

.lp_bl_blogMainVisual {
    overflow: hidden;
    position: relative;
    z-index: 2;
    background: url(../img/lp/blog/mv_bg.jpg) no-repeat 60% center;
    background-size: cover
}

@media screen and (min-width: 64em) {
    .lp_bl_blogMainVisual {
        overflow:visible;
        background-position: center center
    }
}

.lp_bl_blogMainVisual+* {
    margin-top: 80px
}

@media screen and (min-width: 64em) {
    .lp_bl_blogMainVisual+* {
        margin-top:216px
    }
}

.lp_bl_blogMainVisual_content {
    width: 88%;
    max-width: 1200px;
    min-height: 457px;
    margin: 0 auto;
    padding: 55px 0 7.5vw
}

@media screen and (min-width: 48em) {
    .lp_bl_blogMainVisual_content {
        position:relative;
        padding-top: 84px
    }
}

@media screen and (min-width: 64em) {
    .lp_bl_blogMainVisual_content {
        min-height:805px
    }
}

@media screen and (min-width: ) {
    .lp_bl_blogMainVisual_content {
        padding:40px 0 0
    }
}

.lp_bl_blogMainVisual_lead {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    width: 100%;
    padding-bottom: 17px;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center
}

@media screen and (min-width: 48em) {
    .lp_bl_blogMainVisual_lead {
        width:63.5%;
        padding-bottom: 37px
    }
}

.lp_bl_blogMainVisual_secret {
    width: 25%;
    margin-right: 6%
}

.lp_bl_blogMainVisual_text__first {
    width: 69%
}

.lp_bl_blogMainVisual_text__last {
    width: 120%;
    max-width: 120%;
    margin: -64px 0 0 -10%
}

@media screen and (min-width: 48em) {
    .lp_bl_blogMainVisual_text__last {
        position:absolute;
        right: -5%;
        bottom: 5%;
        width: 76.5%;
        margin: 0
    }
}

@media screen and (min-width: 64em) {
    .lp_bl_blogMainVisual_text__last {
        bottom:10%
    }
}

.lp_bl_blogMainVisual_feature {
    width: 80%;
    margin-left: -2.3%
}

@media screen and (min-width: 48em) {
    .lp_bl_blogMainVisual_feature {
        width:66%;
        margin-top: -56px
    }
}

@media screen and (min-width: 64em) {
    .lp_bl_blogMainVisual_feature {
        margin-top:-72px
    }
}

.lp_bl_blogMainVisual_human {
    position: absolute;
    top: 50%;
    right: -4%;
    -webkit-transform: translateY(-60%);
    transform: translateY(-60%);
    z-index: -1;
    max-width: 45.6%
}

@media screen and (min-width: 48em) {
    .lp_bl_blogMainVisual_human {
        top:39px;
        right: 0;
        -webkit-transform: none;
        transform: none;
        width: 41%
    }
}

@media screen and (min-width: 64em) {
    .lp_bl_banner {
        -webkit-transform:translateY(86px);
        transform: translateY(86px);
        width: 88%;
        max-width: 1200px;
        margin: 0 auto;
        margin-top: -120px
    }
}

.lp_bl_banner_inner {
    position: relative;
    padding: 14px 9.6% 14px 28%;
    background: rgba(54,80,130,0.85);
    color: #fff
}

@media screen and (min-width: 48em) {
    .lp_bl_banner_inner {
        padding:32px 36% 32px 21%
    }
}

.lp_bl_banner_woman {
    position: absolute;
    bottom: 0;
    left: 4.5%;
    width: 19.4%
}

@media screen and (min-width: 48em) {
    .lp_bl_banner_woman {
        width:14%
    }
}

.lp_bl_banner_human {
    position: absolute;
    right: 2%;
    bottom: calc(4rem + 14px);
    width: 25.6%
}

@media screen and (min-width: 48em) {
    .lp_bl_banner_human {
        right:0;
        bottom: 0;
        width: 39%
    }
}

.lp_bl_banner_content {
    font-size: 1.8rem;
    font-weight: 700;
    line-height: 1.5;
    letter-spacing: 0.03em
}

@media screen and (min-width: 48em) {
    .lp_bl_banner_content {
        font-size:2.2rem
    }
}

@media screen and (min-width: 64em) {
    .lp_bl_banner_content {
        font-size:3rem
    }
}

.lp_bl_banner_largeText {
    font-size: 1.3em
}

.lp_bl_banner_narrowText {
    display: block;
    max-width: 70%
}

.lp_bl_feature_head {
    padding: 94px 0 69px;
    background: #e8eff5
}

.lp_bl_feature_title {
    font-size: 2.8rem;
    line-height: 1.6;
    text-align: center
}

@media screen and (min-width: 48em) {
    .lp_bl_feature_title {
        font-size:5rem
    }
}

.lp_bl_feature_decoration {
    margin-bottom: 24px;
    color: #365082
}

.lp_bl_feature_content {
    padding-top: 76px;
    background: #f9f4f4
}

.lp_bl_feature_lead {
    font-size: 2.4rem;
    font-weight: 700;
    text-align: center
}

@media screen and (min-width: 48em) {
    .lp_bl_feature_lead {
        font-size:2.6rem
    }
}

.lp_bl_feature_point {
    color: #365082
}

.lp_bl_feature_list {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    max-width: 978px;
    margin: 76px auto 0;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center
}

.lp_bl_feature_item {
    width: 48%;
    padding: 16px 5%;
    border-radius: 10px;
    background: #00789f;
    color: #fff;
    font-size: 2rem;
    font-weight: 700;
    line-height: 1.5;
    text-align: center
}

@media screen and (min-width: 48em) {
    .lp_bl_feature_item {
        width:31.7%;
        padding: 20px 8px;
        font-size: 2.7rem
    }
}

.lp_bl_feature_item:nth-child(odd) {
    margin-right: 4%
}

@media screen and (min-width: 48em) {
    .lp_bl_feature_item:nth-child(odd) {
        margin-right:0
    }
}

@media screen and (min-width: 48em) {
    .lp_bl_feature_item:not(:nth-child(3n)) {
        margin-right:2.45%
    }
}

.lp_bl_feature_item:nth-child(2)~.lp_bl_feature_item {
    margin-top: 4%
}

@media screen and (min-width: 48em) {
    .lp_bl_feature_item:nth-child(2)~.lp_bl_feature_item {
        margin-top:0
    }
}

@media screen and (min-width: 48em) {
    .lp_bl_feature_item:nth-child(3)~.lp_bl_feature_item {
        margin-top:2.45%
    }
}

.lp_bl_feature_item:before {
    display: inline-block;
    -webkit-transform: rotate(-45deg);
    transform: rotate(-45deg);
    content: "";
    width: 24px;
    height: 14px;
    margin-right: 13px;
    border-bottom: 6px solid #eee06d;
    border-left: 6px solid #eee06d;
    vertical-align: 0.25em
}

.lp_bl_feature_img {
    margin-top: 41px
}

.lp_bl_feature_img__narrow {
    max-width: 1040px;
    margin-right: auto;
    margin-left: auto
}

.lp_bl_itadviserMainVisual {
    overflow: hidden;
    position: relative;
    z-index: 2;
    width: 100%;
    padding: 14% 0 45px
}

@media screen and (min-width: 48em) {
    .lp_bl_itadviserMainVisual {
        padding:122px 0 95px;
        padding-bottom: 95px
    }
}

.lp_bl_itadviserMainVisual+* {
    margin-top: 64px
}

@media screen and (min-width: 48em) {
    .lp_bl_itadviserMainVisual+* {
        margin-top:97px
    }
}

.lp_bl_itadviserMainVisual_background {
    position: absolute;
    top: 0;
    left: 0;
    z-index: -1;
    width: 100%;
    height: 100%
}

.lp_bl_itadviserMainVisual_inner {
    position: relative;
    height: 100%
}

.lp_bl_itadviserMainVisual_title {
    position: relative;
    left: -7%;
    width: 90%
}

@media screen and (min-width: 48em) {
    .lp_bl_itadviserMainVisual_title {
        left:-72.5px;
        width: 79.808%
    }
}

.lp_bl_itadviserMainVisual_smallHuman {
    position: absolute;
    bottom: 0;
    left: 15%;
    width: 20%
}

.lp_bl_itadviserMainVisual_human {
    position: absolute;
    right: -5%;
    bottom: -45px;
    width: 38%;
    max-width: 426px
}

@media screen and (min-width: 48em) {
    .lp_bl_itadviserMainVisual_human {
        bottom:-95px;
        width: 40.963%
    }
}

.lp_bl_service_head {
    position: relative;
    padding: 140px 0 69px;
    background: #e8eff5
}

.lp_bl_service_head:before {
    position: absolute;
    top: 0;
    left: 50%;
    -webkit-transform: translateX(-50%);
    transform: translateX(-50%);
    content: "";
    width: 0;
    height: 0;
    border-width: 72px 102px 0 102px;
    border-color: #365082 transparent transparent transparent;
    border-style: solid
}

.lp_bl_service_title {
    font-size: 2.8rem;
    line-height: 1.6;
    text-align: center
}

@media screen and (min-width: 48em) {
    .lp_bl_service_title {
        font-size:4rem
    }
}

@media screen and (min-width: 64em) {
    .lp_bl_service_title {
        font-size:5rem
    }
}

.lp_bl_service_decoration {
    margin-bottom: 24px;
    color: #365082
}

.lp_bl_service_content {
    position: relative;
    z-index: 2;
    width: 100%;
    padding: 148px 0
}

.lp_bl_service_background {
    position: absolute;
    top: 0;
    left: 0;
    z-index: -1;
    width: 100%;
    height: 100%
}

.lp_bl_service_card {
    max-width: 468px;
    margin: 0 auto;
    padding: 26px 5%;
    background: #eee06d;
    text-align: center
}

@media screen and (min-width: 48em) {
    .lp_bl_service_card {
        padding-right:48px;
        padding-left: 48px
    }
}

.lp_bl_service_card .notes {
    margin-top: 12px;
    padding-left: 0
}

.lp_bl_service_illust {
    width: 96px;
    margin: 0 auto 10px
}

.lp_bl_service_name {
    border-bottom: 1px #000 solid;
    font-size: 3rem;
    line-height: 1.3
}

.lp_bl_service_price {
    margin-top: 20px;
    color: #365082;
    font-size: 2.5rem;
    font-weight: 900;
    line-height: 1
}

.lp_bl_service_price span {
    font-family: "Roboto",sans-serif;
    font-size: 6rem;
    font-style: italic
}

.lp_bl_service_price_note {
    font-size: 1.8rem
}

.lp_bl_service_text {
    margin-top: 24px;
    font-size: 2.2rem;
    font-weight: 700
}

@media print {
    * html body {
        zoom:0.7}

    *+html body {
        zoom:1}
}

/*# sourceMappingURL=style.css.map */
