@import"//use.fontawesome.com/releases/v5.10.2/css/all.css";

html,
body,
div,
span,
object,
iframe,
h1,
h2,
h3,
h4,
h5,
h6,
p,
blockquote,
pre,
abbr,
address,
cite,
code,
del,
dfn,
em,
img,
ins,
kbd,
q,
samp,
small,
strong,
sub,
sup,
var,
b,
i,
dl,
dt,
dd,
ol,
ul,
li,
fieldset,
form,
label,
legend,
table,
caption,
tbody,
tfoot,
thead,
tr,
th,
td,
main,
article,
aside,
dialog,
figure,
figcaption,
footer,
header,
hgroup,
menu,
nav,
section,
time,
mark,
audio,
video {
    box-sizing: border-box;
    margin: 0;
    padding: 0;
    border: 0;
    outline: 0
}

h1,
h2,
h3,
h4,
h5,
h6,
figcaption {
    font-size: 100%;
    font-weight: inherit
}

textarea {
    font-family: inherit;
    font-size: inherit;
    display: block
}

article,
aside,
dialog,
figure,
figcaption,
footer,
header,
hgroup,
nav,
section,
nav,
main {
    display: block
}

ol,
ul {
    list-style: none
}

blockquote,
q {
    quotes: none
}

blockquote:before,
blockquote:after,
q:before,
q:after {
    content: "";
    content: none
}

label:before,
label:after {
    box-sizing: border-box
}

ins {
    text-decoration: none
}

mark {
    font-style: italic;
    font-weight: bold
}

del {
    text-decoration: line-through
}

abbr[title],
dfn[title] {
    cursor: help
}

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

table th,
table td {
    font-size: inherit;
    font-weight: inherit
}

address,
caption,
cite,
code,
dfn,
em,
th,
var {
    font-style: inherit;
    font-weight: inherit
}

input,
select {
    vertical-align: middle
}

img {
    vertical-align: bottom
}

a {
    box-sizing: border-box;
    outline: none
}

input,
button {
    box-sizing: border-box;
    border: none;
    cursor: pointer;
    font: inherit;
    outline: none;
    vertical-align: baseline
}

input {
    cursor: auto
}

textarea:focus,
button:focus {
    outline: none
}

input[type=text],
input[type=email],
input[type=number],
input[type=url],
input[type=date],
input[type=tel],
input[type=password],
textarea,
select {
    font-family: inherit;
    font-size: 1.6rem;
    border: 1px solid #ccc;
    border-radius: 3px;
    box-sizing: border-box;
    padding: 8px;
    vertical-align: baseline
}

@media screen and (max-width: 320px) {

    input[type=text],
    input[type=email],
    input[type=number],
    input[type=url],
    input[type=date],
    input[type=tel],
    input[type=password],
    textarea,
    select {
        padding: 8px 4px
    }
}

@media screen and (min-width: 1100px) {

    input[type=text],
    input[type=email],
    input[type=number],
    input[type=url],
    input[type=date],
    input[type=tel],
    input[type=password],
    textarea,
    select {
        font: 500 1.4rem/1.6 "Montserrat", "Yu Gothic", "游ゴシック", "Hiragino Kaku Gothic ProN W3", Arial, "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif !important
    }
}

@media screen and (min-width: 1100px)and (min-width: 1100px) {

    input[type=text],
    input[type=email],
    input[type=number],
    input[type=url],
    input[type=date],
    input[type=tel],
    input[type=password],
    textarea,
    select {
        font: 500 1.5rem/1.6 "Montserrat", "Yu Gothic", "游ゴシック", "Hiragino Kaku Gothic ProN W3", Arial, "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif !important
    }
}

@media screen and (min-width: 1100px)and (min-width: 1100px) {

    input[type=text],
    input[type=email],
    input[type=number],
    input[type=url],
    input[type=date],
    input[type=tel],
    input[type=password],
    textarea,
    select {
        font: 500 1.6rem/1.6 "Montserrat", "Yu Gothic", "游ゴシック", "Hiragino Kaku Gothic ProN W3", Arial, "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif !important
    }
}

input[type=text]:focus,
input[type=email]:focus,
input[type=number]:focus,
input[type=url]:focus,
input[type=date]:focus,
input[type=tel]:focus,
input[type=password]:focus,
textarea:focus,
select:focus {
    box-shadow: 0 0 5px rgba(37, 143, 200, .9)
}

select {
    -webkit-appearance: button;
    -moz-appearance: button;
    appearance: button;
    background-color: #fff;
    color: inherit;
    cursor: pointer;
    line-height: inherit;
    outline: none;
    text-indent: .01px;
    text-overflow: "";
    vertical-align: middle
}

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

select:-moz-focusring {
    color: rgba(0, 0, 0, 0);
    text-shadow: 0 0 0 #828c9a
}

textarea {
    width: 100%
}

::-webkit-input-placeholder {
    color: #ccc
}

:-moz-placeholder {
    color: #ccc
}

.clear {
    clear: both;
    margin: 0px;
    padding: 0px
}

.clearfix:after {
    content: ".";
    display: block;
    height: 0;
    clear: both;
    visibility: hidden
}

.clearfix {
    display: inline-table
}

* html .clearfix {
    height: 1%
}

.clearfix {
    display: block;
    zoom: 1
}

html {
    box-sizing: border-box;
    font-size: 62.5%
}

body {
    font: 500 1.4rem/1.6 "Montserrat", "Yu Gothic", "游ゴシック", "Hiragino Kaku Gothic ProN W3", Arial, "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif !important;
    background-color: #fff;
    color: #000;
    display: flex;
    flex-direction: column;
    margin: 0;
    position: relative
}

@media screen and (min-width: 1100px) {
    body {
        font: 500 1.5rem/1.6 "Montserrat", "Yu Gothic", "游ゴシック", "Hiragino Kaku Gothic ProN W3", Arial, "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif !important
    }
}

@media screen and (min-width: 1100px) {
    body {
        font: 500 1.6rem/1.6 "Montserrat", "Yu Gothic", "游ゴシック", "Hiragino Kaku Gothic ProN W3", Arial, "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif !important
    }
}

.wrap {
    margin: 0 auto;
    position: relative;
    width: 100%
}

.container {
    background-color: #fff;
    margin: 0 auto;
    width: 100%
}

.container-inner {
    background-color: #fff;
    border-radius: 6px;
    box-shadow: 0 2px 2px rgba(0, 0, 0, .1);
    overflow: hidden;
    margin: 0 auto 15px;
    padding: 15px;
    width: 96%
}

@media screen and (min-width: 1100px) {
    .container-inner {
        width: 1100px
    }
}

.inner-pc {
    margin: 0 auto;
    width: 100%
}

@media screen and (min-width: 1100px) {
    .inner-pc {
        width: 1100px
    }
}

.content-inner {
    margin: 0 auto;
    padding: 6px;
    width: 96%
}

@media screen and (min-width: 1100px) {
    .content-inner {
        padding: 20px;
        width: 1100px
    }
}

.wrap-col {
    margin: 0 auto;
    width: 100%
}

@media screen and (min-width: 1100px) {
    .wrap-col {
        display: flex;
        flex-wrap: wrap;
        justify-content: space-between
    }
}

.col__main {
    width: 100%
}

@media screen and (min-width: 1100px) {
    .col__main {
        margin-right: 30px;
        width: 630px
    }
}

.col__sub {
    width: 100%
}

@media screen and (min-width: 1100px) {
    .col__sub {
        flex: 1
    }
}

.col__2 {
    width: 100%
}

@media screen and (min-width: 1100px) {
    .col__2 {
        width: 49%
    }
}

.col__2 .btn-link {
    width: 100%
}

.col__3 {
    width: 100%
}

@media screen and (min-width: 1100px) {
    .col__3 {
        width: 32%
    }
}

.col__3 .btn-link {
    width: 100%
}

.bold {
    font-weight: bold !important
}

.fwN {
    font-weight: normal !important
}

.fsLL {
    font-size: 2.4rem;
    font-weight: bold;
    line-height: 1.4
}

@media screen and (min-width: 1100px) {
    .fsLL {
        font-size: 3.5rem
    }
}

@media screen and (min-width: 1100px) {
    .fsLL {
        font-size: 3.5rem
    }
}

.fsL {
    font-size: 1.8rem;
    font-weight: bold;
    line-height: 1.4
}

@media screen and (min-width: 1100px) {
    .fsL {
        font-size: 2.4rem;
        line-height: 1.4
    }
}

@media screen and (min-width: 1100px) {
    .fsL {
        font-size: 2.4rem;
        line-height: 1.4
    }
}

.fsM {
    font-size: 1.6rem;
    line-height: 1.5
}

@media screen and (min-width: 1100px) {
    .fsM {
        font-size: 1.8rem;
        line-height: 1.6
    }
}

@media screen and (min-width: 1100px) {
    .fsM {
        font-size: 1.8rem;
        line-height: 1.6
    }
}

.fsS {
    font-size: 1.2rem;
    line-height: 1.5
}

@media screen and (min-width: 1100px) {
    .fsS {
        font-size: 1.3rem;
        line-height: 1.5
    }
}

@media screen and (min-width: 1100px) {
    .fsS {
        font-size: 1.4rem;
        line-height: 1.6
    }
}

.fsSS {
    font-size: 1.1rem;
    line-height: 1.3
}

@media screen and (min-width: 1100px) {
    .fsSS {
        font-size: 1.2rem;
        line-height: 1.4
    }
}

@media screen and (min-width: 1100px) {
    .fsSS {
        font-size: 1.3rem;
        line-height: 1.5
    }
}

.mt5 {
    margin-top: 5px !important
}

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

.mt15 {
    margin-top: 15px !important
}

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

.mt30 {
    margin-top: 30px !important
}

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

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

.mb5 {
    margin-bottom: 5px !important
}

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

.mb15 {
    margin-bottom: 15px !important
}

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

.mb30 {
    margin-bottom: 30px !important
}

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

.mb50 {
    margin-bottom: 50px !important
}

.txtc {
    text-align: center
}

.txtl {
    text-align: left
}

.txtr {
    text-align: right
}

.list-decimal {
    list-style-type: decimal;
    padding-left: 2.5rem
}

@media screen and (min-width: 1100px) {
    .list-decimal {
        padding-left: 3rem
    }
}

.list-decimal li {
    padding-left: 5px
}

.list-disc {
    list-style-type: disc;
    padding-left: 1.5rem
}

@media screen and (min-width: 1100px) {
    .list-disc {
        padding-left: 2rem
    }
}

.list-square {
    list-style-type: square;
    padding-left: 1.5rem
}

@media screen and (min-width: 1100px) {
    .list-square {
        padding-left: 2rem
    }
}

.list-attention li:before {
    content: "※"
}

.disp-ib {
    display: inline-block
}

.disp-b {
    display: block
}

.disp-i {
    display: inline
}

.wrap-disp-ib span {
    display: inline-block
}

.wrap-disp-b span {
    display: block
}

.wrap-disp-i span {
    display: inline
}

img {
    height: auto;
    transition: all .3s ease;
    vertical-align: bottom;
    max-width: 100%
}

.pc-only {
    display: none
}

@media screen and (min-width: 1100px) {
    .pc-only {
        display: block
    }
}

.sp-only {
    display: block
}

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

.list-empty {
    border: none !important;
    box-shadow: none !important;
    height: 0 !important;
    padding: 0 !important;
    margin: 0 !important
}

a:link {
    color: #258fc8;
    text-decoration: none
}

a:visited {
    color: #258fc8;
    text-decoration: none
}

a:hover {
    color: #299fde
}

a:active {
    color: #258fc8;
    text-decoration: none
}

a {
    text-decoration: none
}

@media screen and (min-width: 1100px) {
    a:hover {
        text-decoration: underline
    }
}

.area-link {
    cursor: pointer
}

@media screen and (min-width: 1100px) {
    .area-link:hover a {
        text-decoration: underline
    }

    .area-link:hover img {
        opacity: .8
    }
}

.wrap-btn-link-l {
    font-size: 1.6rem;
    line-height: 1.5;
    margin: 25px auto;
    text-align: center
}

@media screen and (min-width: 1100px) {
    .wrap-btn-link-l {
        font-size: 1.8rem;
        line-height: 1.6
    }
}

@media screen and (min-width: 1100px) {
    .wrap-btn-link-l {
        font-size: 1.8rem;
        line-height: 1.6
    }
}

.wrap-btn-link-l.multiple {
    display: flex;
    justify-content: center
}

.wrap-btn-link-l.multiple .btn-link {
    margin: 0 1%
}

.wrap-btn-link-l .btn-link {
    background-color: #258fc8;
    border-radius: 4rem;
    color: #fff;
    display: block;
    max-width: 80%;
    margin: 0 auto;
    padding: 10px 20px;
    text-decoration: none;
    transition: all .3s
}

@media screen and (max-width: 320px) {
    .wrap-btn-link-l .btn-link {
        padding: 10px 15px
    }
}

@media screen and (min-width: 1100px) {
    .wrap-btn-link-l .btn-link {
        padding: 12px 50px;
        max-width: 60%;
        min-width: 40%
    }
}

@media screen and (min-width: 1100px) {
    .wrap-btn-link-l .btn-link:hover {
        background-color: rgba(41, 159, 222, .8);
        text-decoration: none
    }

    .wrap-btn-link-l .btn-link:hover svg {
        fill: #fff
    }
}

.wrap-btn-link-l .btn-link svg {
    display: inline-block;
    vertical-align: sub;
    width: 2.2rem;
    height: 2.2rem;
    fill: #fff
}

@media screen and (min-width: 1100px) {
    .wrap-btn-link-l .btn-link svg {
        width: 2.6rem;
        height: 2.6rem
    }
}

@media screen and (min-width: 1100px) {
    .wrap-btn-link-l .btn-link svg {
        width: 3rem;
        height: 3rem
    }
}

.wrap-btn-link {
    margin: 20px auto;
    text-align: center
}

.wrap-btn-link .btn-link {
    background-color: #fff;
    border: 1px solid #258fc8;
    border-radius: 25px;
    color: #258fc8;
    cursor: pointer;
    display: inline-block;
    margin-left: 10px;
    padding: 10px 20px;
    text-decoration: none;
    transition: all .3s
}

@media screen and (min-width: 1100px) {
    .wrap-btn-link .btn-link {
        margin-left: 20px;
        padding: 10px 50px
    }
}

@media screen and (min-width: 1100px) {
    .wrap-btn-link .btn-link:hover {
        background-color: #299fde;
        color: #fff;
        text-decoration: none
    }

    .wrap-btn-link .btn-link:hover svg {
        fill: #fff
    }
}

.wrap-btn-link .btn-link:first-child {
    margin-left: 0
}

.wrap-btn-link .btn-link svg {
    fill: #258fc8
}

.btn-link-inline {
    background-color: #fff;
    border: 1px solid #258fc8;
    border-radius: 25px;
    color: #258fc8;
    display: inline-block;
    padding: 6px 20px;
    text-decoration: none;
    transition: all .3s
}

@media screen and (min-width: 1100px) {
    .btn-link-inline {
        padding: 6px 30px
    }
}

@media screen and (min-width: 1100px) {
    .btn-link-inline:hover {
        background-color: #299fde;
        color: #fff;
        text-decoration: none
    }

    .btn-link-inline:hover svg {
        fill: #fff
    }
}

.btn-link-inline svg {
    fill: #258fc8
}

.wrap-more {
    margin: 15px auto;
    text-align: center
}

.wrap-more .more {
    background-color: #0e6fb8;
    border-radius: 22px;
    color: #fff;
    display: inline-block;
    padding: 10px 30px;
    text-decoration: none;
    transition: all .5s
}

.wrap-more .more:after {
    display: inline-block;
    font-family: "Font Awesome 5 Free";
    font-weight: 900;
    content: "";
    padding-left: 5px
}

@media screen and (min-width: 1100px) {
    .wrap-more .more:hover {
        background-color: #ef6b0a;
        text-decoration: none
    }
}

.back-link {
    margin: 6px 0
}

.back-link a:before {
    display: inline-block;
    font-family: "Font Awesome 5 Free";
    font-weight: 900;
    content: "";
    padding-right: 5px
}

.btn-line-add {
    font-size: 1.2rem;
    line-height: 1.5;
    border: 1px solid #00b900;
    border-radius: 20px;
    color: #00b900 !important;
    display: inline-block;
    padding: 2px 8px;
    transition: all .3s ease
}

@media screen and (min-width: 1100px) {
    .btn-line-add {
        font-size: 1.3rem;
        line-height: 1.5
    }
}

@media screen and (min-width: 1100px) {
    .btn-line-add {
        font-size: 1.4rem;
        line-height: 1.6
    }
}

.btn-line-add:hover {
    background-color: #00b900;
    color: #fff !important;
    text-decoration: none
}

.zoom-thumb {
    overflow: hidden;
    padding-bottom: 100%;
    position: relative;
    width: 100%;
    height: 0
}

.zoom-thumb:hover img {
    opacity: 1;
    transform: translate(-50%, -50%) scale(1.1)
}

.zoom-thumb .zoom-thumb__photo {
    margin: auto;
    max-width: none;
    min-width: 100%;
    min-height: 100%;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%) scale(1);
    width: auto;
    height: 100%
}

.wrap-more-link-2 {
    margin: 30px auto;
    text-align: center
}

.more-link-2 {
    background-color: #fff;
    position: relative;
    display: inline-block;
    padding: 12px 20px;
    border: 1px solid #ddd;
    color: #fff;
    min-width: 200px;
    text-align: center;
    text-decoration: none;
    outline: none;
    transition: all .3s
}

.more-link-2:before,
.more-link-2:after,
.more-link-2 span:before,
.more-link-2 span:after {
    position: absolute;
    z-index: 2;
    content: "";
    width: 0;
    height: 0;
    border: 1px solid rgba(0, 0, 0, 0);
    transition: all .3s;
    visibility: hidden;
    box-sizing: content-box
}

.more-link-2:before {
    top: -1px;
    left: -1px;
    border-left-color: #258fc8
}

.more-link-2:after {
    bottom: -1px;
    right: -1px;
    border-right-color: #258fc8
}

.more-link-2 span:before {
    bottom: -1px;
    left: -1px;
    border-bottom-color: #258fc8
}

.more-link-2 span:after {
    top: -1px;
    right: -1px;
    border-top-color: #258fc8
}

.more-link-2:hover {
    color: #258fc8;
    text-decoration: none
}

.more-link-2:hover:before,
.more-link-2:hover:after {
    height: 100%;
    visibility: visible
}

.more-link-2:hover span:before,
.more-link-2:hover span:after {
    width: 100%;
    visibility: visible
}

.ac {
    color: #ff1450 !important
}

.caution {
    color: #f05c5c !important
}

.caution-sub {
    font-size: 1.2rem;
    line-height: 1.5;
    display: inline-block;
    vertical-align: top
}

@media screen and (min-width: 1100px) {
    .caution-sub {
        font-size: 1.3rem;
        line-height: 1.5
    }
}

@media screen and (min-width: 1100px) {
    .caution-sub {
        font-size: 1.4rem;
        line-height: 1.6
    }
}

.time {
    color: #8b8b8b !important
}

.no-data {
    color: #bbb !important
}

.sat {
    color: #006dc9 !important
}

.sun {
    color: #ff3f6c !important
}

.hol {
    color: #ff3f6c !important
}

.marker {
    background: linear-gradient(transparent 60%, #fff7bd 0%);
    display: inline;
    padding: 0 2px 1px
}

.marker-2 {
    background: linear-gradient(transparent 60%, #ffa3d2 60%);
    font-weight: bold
}

.truncate {
    overflow: hidden;
    white-space: nowrap;
    text-overflow: ellipsis;
    display: block
}

.pc-lsS {
    letter-spacing: 0
}

@media screen and (min-width: 1100px) {
    .pc-lsS {
        letter-spacing: -1px
    }
}

.pc-lsM {
    letter-spacing: 0
}

@media screen and (min-width: 1100px) {
    .pc-lsM {
        letter-spacing: -1.5px
    }
}

.pc-lsL {
    letter-spacing: 0
}

@media screen and (min-width: 1100px) {
    .pc-lsL {
        letter-spacing: -2px
    }
}

.pc-lsLL {
    letter-spacing: 0
}

@media screen and (min-width: 1100px) {
    .pc-lsLL {
        letter-spacing: -3px
    }
}

.sp-lsS {
    letter-spacing: -1px
}

@media screen and (min-width: 1100px) {
    .sp-lsS {
        letter-spacing: 0
    }
}

.sp-lsM {
    letter-spacing: -1.5px
}

@media screen and (min-width: 1100px) {
    .sp-lsM {
        letter-spacing: 0
    }
}

.sp-lsL {
    letter-spacing: -2px
}

@media screen and (min-width: 1100px) {
    .sp-lsL {
        letter-spacing: 0
    }
}

.sp-lsLL {
    letter-spacing: -3px
}

@media screen and (min-width: 1100px) {
    .sp-lsLL {
        letter-spacing: 0
    }
}

.sp-br {
    display: block
}

@media screen and (min-width: 1100px) {
    .sp-br {
        display: inline
    }
}

.pc-br {
    display: inline
}

@media screen and (min-width: 1100px) {
    .pc-br {
        display: block
    }
}

@keyframes fuwa-v {
    0% {
        transform: translateY(-10px)
    }

    100% {
        transform: translateY(0px)
    }
}

.tbl-base {
    border: 1px solid #ddd;
    border-width: 0 1px 1px 0;
    border-collapse: collapse;
    width: 100%
}

.tbl-base th,
.tbl-base td {
    border: 1px solid #e0e0e0;
    border-width: 1px 0 0 1px;
    padding: 10px 7px;
    text-align: left;
    word-wrap: break-word
}

@media screen and (min-width: 1100px) {

    .tbl-base th,
    .tbl-base td {
        padding: 20px
    }
}

@media screen and (min-width: 1100px) {

    .tbl-base th,
    .tbl-base td {
        padding: 20px
    }
}

.tbl-base th {
    background-color: #fdfdfd;
    display: block;
    font-weight: bold;
    width: 100%
}

@media screen and (min-width: 1100px) {
    .tbl-base th {
        display: table-cell;
        width: 34%
    }
}

.tbl-base td {
    background-color: #fff;
    display: block
}

@media screen and (min-width: 1100px) {
    .tbl-base td {
        display: table-cell
    }
}

.tbl-base .wrap-btn-action {
    width: 100%
}

@media screen and (min-width: 1100px) {
    .tbl-base .wrap-btn-action {
        display: flex;
        flex-wrap: wrap;
        justify-content: space-between
    }
}

.tbl-base .btn-action {
    transition: all .3s ease;
    border: 1px solid #258fc8;
    border-radius: 6px;
    color: #258fc8;
    display: block;
    flex: 1;
    margin: 6px 0 0 0;
    padding: 5px 10px;
    text-align: center;
    text-decoration: none;
    vertical-align: text-bottom;
    width: 100%
}

.tbl-base .btn-action:first-child {
    margin-top: 0
}

.tbl-base .btn-action svg {
    display: inline-block;
    vertical-align: sub;
    width: 1.6rem;
    height: 1.6rem;
    display: inline-block;
    fill: #258fc8
}

@media screen and (min-width: 1100px) {
    .tbl-base .btn-action svg {
        width: 1.8rem;
        height: 1.8rem
    }
}

@media screen and (min-width: 1100px) {
    .tbl-base .btn-action svg {
        width: 2rem;
        height: 2rem
    }
}

@media screen and (min-width: 1100px) {
    .tbl-base .btn-action {
        margin: 0 0 0 10px;
        width: auto
    }

    .tbl-base .btn-action:first-child {
        margin-left: 0
    }
}

@media screen and (min-width: 1100px) {
    .tbl-base .btn-action:hover {
        background-color: #258fc8;
        color: #fff
    }

    .tbl-base .btn-action:hover svg {
        fill: #fff
    }
}

.tbl-border {
    border: none !important;
    width: 100%
}

.tbl-border tr {
    background: none !important;
    border-bottom: 1px solid #ddd
}

.tbl-border tr th,
.tbl-border tr td {
    background: none !important;
    border: none !important;
    padding: 10px 7px;
    text-align: left;
    word-wrap: break-word
}

@media screen and (min-width: 1100px) {

    .tbl-border tr th,
    .tbl-border tr td {
        padding: 20px
    }
}

@media screen and (min-width: 1100px) {

    .tbl-border tr th,
    .tbl-border tr td {
        padding: 20px
    }
}

.tbl-border tr th {
    font-weight: bold;
    width: 30%
}

.tbl-sort thead tr th.sorting {
    padding-right: 20px
}

.sorting,
.sorting_asc,
.sorting_desc,
.sorting_asc_disabled,
.sorting_desc_disabled {
    cursor: pointer;
    position: relative
}

.sorting:after,
.sorting_asc:after,
.sorting_desc:after,
.sorting_asc_disabled:after,
.sorting_desc_disabled:after {
    font-family: "Font Awesome 5 Free" !important;
    font-weight: 900;
    display: block;
    line-height: 1;
    margin: auto;
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    text-align: center;
    opacity: .5;
    width: 20px;
    height: 14px
}

@media screen and (min-width: 1100px) {

    .sorting:after,
    .sorting_asc:after,
    .sorting_desc:after,
    .sorting_asc_disabled:after,
    .sorting_desc_disabled:after {
        top: 0;
        right: 8px;
        bottom: 0;
        width: 20px;
        height: 17px
    }
}

.sorting:after {
    opacity: .2;
    content: ""
}

.sorting_asc:after {
    color: #009830;
    content: ""
}

.sorting_desc:after {
    color: #ff264c;
    content: ""
}

.sorting_asc {
    background-color: #e0f8ec !important
}

.sorting_desc {
    background-color: #ffeef0 !important
}

.tbl-base-p {
    border-top: 1px solid #555;
    border-collapse: collapse;
    width: 100%
}

.tbl-base-p tr {
    border-bottom: 1px solid #555
}

.tbl-base-p th,
.tbl-base-p td {
    border: 1px solid #555;
    padding: 8px;
    word-wrap: break-word
}

.tbl-radius {
    border: 1px solid #ddd;
    border-collapse: collapse;
    overflow: hidden;
    width: 100%
}

.tbl-radius th,
.tbl-radius td {
    border: 1px solid #ddd;
    padding: 10px 7px;
    text-align: left;
    word-wrap: break-word
}

@media screen and (min-width: 1100px) {

    .tbl-radius th,
    .tbl-radius td {
        padding: 20px
    }
}

@media screen and (min-width: 1100px) {

    .tbl-radius th,
    .tbl-radius td {
        padding: 20px
    }
}

.tbl-radius th {
    background-color: #f39800;
    color: #fff;
    display: block;
    font-weight: bold;
    width: 100%
}

@media screen and (min-width: 1100px) {
    .tbl-radius th {
        display: table-cell;
        width: 34%
    }
}

.tbl-radius td {
    background-color: #fff;
    border: 1px solid #ddd;
    display: block
}

@media screen and (min-width: 1100px) {
    .tbl-radius td {
        display: table-cell
    }
}

.wrap-pagination {
    margin: 20px auto
}

@media screen and (min-width: 1100px) {
    .wrap-pagination {
        margin: 30px auto
    }
}

.pagination {
    display: flex;
    justify-content: center;
    width: 100%
}

.pagination li {
    margin: 0 .5%
}

.pagination li:first-child a,
.pagination li:first-child span,
.pagination li:last-child a,
.pagination li:last-child span {
    border-radius: 20px;
    padding: 0 15px
}

@media screen and (max-width: 320) {

    .pagination li:first-child a,
    .pagination li:first-child span,
    .pagination li:last-child a,
    .pagination li:last-child span {
        padding: 0 8px
    }
}

.pagination li:first-child a:before,
.pagination li:first-child span:before {
    display: inline-block;
    font-family: "Font Awesome 5 Free";
    font-weight: 900;
    content: "";
    padding-right: 5px
}

.pagination li:last-child a:after,
.pagination li:last-child span:after {
    display: inline-block;
    font-family: "Font Awesome 5 Free";
    font-weight: 900;
    content: "";
    padding-left: 5px
}

.pagination li a,
.pagination li span {
    background-color: #fff;
    border-radius: 50%;
    display: block;
    line-height: 2.4;
    text-align: center;
    min-width: 34px;
    height: 34px
}

@media screen and (min-width: 1100px) {

    .pagination li a,
    .pagination li span {
        line-height: 2.2;
        min-width: 36px;
        height: 36px
    }
}

.pagination li a:hover,
.pagination li span:hover {
    text-decoration: none
}

.pagination li a {
    transition: all .3s ease
}

.pagination li a:hover {
    background-color: rgba(77, 182, 172, .8);
    color: #fff
}

.pagination li .pagination--current {
    background-color: #4db6ac;
    color: #fff
}

.pagination li .pagination--none {
    color: #aaa
}

.entry-paging {
    display: flex;
    justify-content: space-between;
    margin: 10px auto;
    width: 100%
}

.entry-paging__item {
    align-items: center;
    color: #888;
    display: flex;
    width: 50%
}

.entry-paging__item:nth-child(2) {
    border-left: 1px solid #ddd;
    text-align: right
}

.entry-paging__item.area-link {
    color: #258fc8
}

.entry-paging__item-arrow {
    font-size: 2rem;
    width: 8%
}

.entry-paging__item-image {
    width: 25%
}

.entry-paging__item-ttl {
    flex: 1;
    padding: 10px;
    min-width: 0
}

.wrap-breadcrumb {
    overflow: hidden;
    width: 100%
}

.breadcrumb-mask {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    white-space: nowrap;
    width: 100%
}

.wrap-img-aspect {
    display: block;
    position: relative
}

.wrap-img-aspect:before {
    display: block;
    padding-top: 50%;
    overflow: hidden;
    content: ""
}

.img-pos,
.img-aspect {
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0
}

.img-pos {
    background-color: #efefef
}

.img-aspect {
    width: auto;
    height: auto;
    max-width: 100%;
    max-height: 100%;
    margin: auto
}

.list-simple li {
    display: inline-block
}

.list-simple li:after {
    content: "/";
    color: #888;
    display: inline-block;
    margin: 0 4px
}

.list-simple li:last-child:after {
    content: none
}

.wrap-horizontal {
    background-color: #efefef;
    overflow: hidden;
    width: 100%
}

@media screen and (min-width: 1100px) {
    .wrap-horizontal {
        background-color: inherit
    }
}

.horizontal__mask {
    overflow-x: auto;
    padding: 8px;
    -webkit-overflow-scrolling: touch;
    width: 100%
}

.scroll-x-space {
    background: inherit !important;
    border: none !important;
    box-shadow: none !important;
    min-width: 1px !important
}

@media screen and (min-width: 1100px) {
    .scroll-x-space {
        display: none
    }
}

.list-horizontal {
    display: flex
}

.list-horizontal__item {
    margin-right: 5px;
    min-width: 140px
}

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

.is-fixed-bottom {
    position: fixed;
    bottom: 0;
    left: 0;
    width: 100%;
    z-index: 2
}

.wrap-caution {
    background-color: #fff;
    border-radius: 6px;
    box-shadow: 0 2px 2px rgba(0, 0, 0, .1);
    margin-bottom: 15px;
    overflow: hidden;
    padding: 15px;
    background-color: #fff39a
}

@media screen and (min-width: 1100px) {
    .wrap-caution {
        margin-bottom: 20px;
        padding: 20px
    }
}

.form-section-ttl {
    font-size: 1.8rem;
    font-weight: bold;
    line-height: 1.4;
    border-bottom: 1px solid #ddd;
    padding-bottom: 15px;
    text-align: center
}

@media screen and (min-width: 1100px) {
    .form-section-ttl {
        font-size: 2.4rem;
        line-height: 1.4
    }
}

@media screen and (min-width: 1100px) {
    .form-section-ttl {
        font-size: 2.4rem;
        line-height: 1.4
    }
}

.form-item {
    border-bottom: 1px solid #ddd;
    margin: 15px auto;
    padding-bottom: 15px;
    width: 100%
}

@media screen and (min-width: 1100px) {
    .form-item {
        align-items: center;
        display: flex;
        flex-wrap: wrap
    }
}

@media screen and (min-width: 1100px) {

    .form-item__label,
    .form-item__input {
        padding: 8px
    }
}

.form-item__label input,
.form-item__input input {
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    width: 100%
}

.form-item__label textarea,
.form-item__input textarea {
    min-height: 100px;
    width: 100%
}

.form-item__label {
    display: inline-block
}

@media screen and (min-width: 1100px) {
    .form-item__label {
        display: block;
        width: 40%
    }
}

.form-item__label span {
    display: block
}

.form-item__input {
    clear: both;
    margin-top: 10px;
    width: 100%
}

@media screen and (min-width: 1100px) {
    .form-item__input {
        flex: 1;
        margin-top: 0
    }
}

.form-item__input .picker__input {
    cursor: pointer
}

.form-item__input-daytime .wpcf7-form-control-wrap {
    display: inline !important
}

.form-item__input-daytime .wpcf7-form-control-wrap input,
.form-item__input-daytime .wpcf7-form-control-wrap select {
    margin-bottom: 8px;
    width: 150px
}

@media screen and (min-width: 1100px) {

    .form-item__input-daytime .wpcf7-form-control-wrap input,
    .form-item__input-daytime .wpcf7-form-control-wrap select {
        width: 180px
    }
}

.form-item__input-inline .wpcf7-form-control-wrap {
    display: inline !important
}

.form-item__input-inline .wpcf7-form-control-wrap input {
    width: 130px
}

@media screen and (min-width: 1100px) {
    .form-item__input-inline .wpcf7-form-control-wrap input {
        width: 150px
    }
}

.form-item__input-inline .wpcf7-form-control-wrap select {
    width: 130px
}

@media screen and (min-width: 1100px) {
    .form-item__input-inline .wpcf7-form-control-wrap select {
        width: 150px
    }
}

.form-item__input-col-1 .wpcf7-form-control.wpcf7-checkbox span.wpcf7-list-item {
    flex-basis: 100% !important
}

.form-item__label-required,
.form-item__label-optional {
    font-size: 1.1rem;
    line-height: 1.3;
    border-radius: 3px;
    display: inline-block !important;
    line-height: 1.3;
    margin: 0;
    padding: 2px 6px;
    vertical-align: text-bottom
}

@media screen and (min-width: 1100px) {

    .form-item__label-required,
    .form-item__label-optional {
        font-size: 1.2rem;
        line-height: 1.4
    }
}

@media screen and (min-width: 1100px) {

    .form-item__label-required,
    .form-item__label-optional {
        font-size: 1.3rem;
        line-height: 1.5
    }
}

@media screen and (min-width: 1100px) {

    .form-item__label-required,
    .form-item__label-optional {
        line-height: 1.4;
        margin: 0 10px
    }
}

.form-item__label-required {
    background-color: #f39800;
    color: #fff
}

.form-item__label-optional {
    background-color: #dadada;
    color: #000
}

.form-item__label-ttl {
    font-weight: bold
}

.form-item__input-caution {
    font-size: 1.2rem;
    line-height: 1.5;
    display: block;
    margin: 5px 0
}

@media screen and (min-width: 1100px) {
    .form-item__input-caution {
        font-size: 1.3rem;
        line-height: 1.5
    }
}

@media screen and (min-width: 1100px) {
    .form-item__input-caution {
        font-size: 1.4rem;
        line-height: 1.6
    }
}

.select-wrap {
    display: inline-block;
    position: relative
}

.select-wrap:before {
    display: inline-block;
    font-family: "Font Awesome 5 Free";
    font-weight: 900;
    font-size: 1.2rem;
    line-height: 1.5;
    content: "";
    width: 16px;
    height: 16px;
    margin: auto;
    pointer-events: none;
    position: absolute;
    top: 0;
    right: 4px;
    bottom: 0;
    text-align: center;
    z-index: 1
}

@media screen and (min-width: 1100px) {
    .select-wrap:before {
        font-size: 1.3rem;
        line-height: 1.5
    }
}

@media screen and (min-width: 1100px) {
    .select-wrap:before {
        font-size: 1.4rem;
        line-height: 1.6
    }
}

@media screen and (min-width: 1100px) {
    .select-wrap:before {
        height: 18px
    }
}

.select-wrap select {
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    padding-right: 25px;
    width: 100%
}

@media screen and (max-width: 320px) {
    .select-wrap select {
        padding-right: 22px
    }
}

@media screen and (min-width: 1100px) {
    .select-wrap select {
        padding-right: 30px
    }
}

.form-item__input-group {
    align-items: center;
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-start;
    width: 100%
}

.form-item__input-group input {
    flex: 1
}

.form-item__input-group .select-wrap {
    display: flex;
    justify-content: flex-start
}

.form-item__input-group .select-wrap select {
    display: inline-block
}

.form-item__input-group .select-sub-text {
    margin-right: 2px;
    padding: 0 3px
}

@media screen and (min-width: 1100px) {
    .form-item__input-group .select-sub-text {
        margin-right: 5px;
        padding: 0 5px
    }
}

.form-item__input-group .md-checkbox {
    height: 20px;
    margin-bottom: 0
}

@media screen and (min-width: 1100px) {
    .form-item__input-group .md-checkbox {
        height: 21px
    }
}

.form-item .form-item__input-group {
    margin-top: 15px
}

.form-item .form-item__input-group:first-child {
    margin-top: 0
}

.select-wrap-group__item {
    margin-left: 20px
}

.select-wrap-group__item:first-child {
    margin-left: 0
}

.inputS {
    width: 82px
}

@media screen and (max-width: 320px) {
    .inputS {
        width: 65px
    }
}

@media screen and (min-width: 1100px) {
    .inputS {
        width: 100px
    }
}

.inputM {
    width: 100px
}

@media screen and (min-width: 1100px) {
    .inputM {
        width: 180px
    }
}

.input-sub-text {
    margin-right: 2px;
    padding: 0 3px
}

@media screen and (min-width: 1100px) {
    .input-sub-text {
        margin-right: 5px;
        padding: 0 5px
    }
}

@keyframes ripple {
    0% {
        box-shadow: 0px 0px 0px 1px rgba(0, 0, 0, 0)
    }

    50% {
        box-shadow: 0px 0px 0px 15px rgba(0, 0, 0, .1)
    }

    100% {
        box-shadow: 0px 0px 0px 15px rgba(0, 0, 0, 0)
    }
}

.md-radio {
    margin-bottom: 5px
}

.md-radio.md-radio-inline {
    display: inline-block
}

.md-radio input[type=radio] {
    display: none
}

.md-radio input[type=radio]:checked + label:before {
    border-color: #f96885;
    animation: ripple .2s linear forwards
}

.md-radio input[type=radio]:checked + label:after {
    transform: scale(1)
}

.md-radio label {
    -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
    display: inline-block;
    line-height: 1.3;
    position: relative;
    padding-left: 30px;
    margin-bottom: 0;
    cursor: pointer;
    vertical-align: middle
}

@media screen and (min-width: 1100px) {
    .md-radio label {
        line-height: 1.2
    }
}

.md-radio label:before,
.md-radio label:after {
    position: absolute;
    content: "";
    border-radius: 50%;
    transition: all .3s ease;
    transition-property: transform, border-color
}

.md-radio label:before {
    left: 0;
    top: 0;
    width: 20px;
    height: 20px;
    border: 2px solid #bbb
}

.md-radio label:after {
    top: 5px;
    left: 5px;
    width: 10px;
    height: 10px;
    transform: scale(0);
    background: #f96885
}

.md-checkbox {
    margin-bottom: 5px;
    position: relative;
    text-align: left
}

.md-checkbox.md-checkbox-inline {
    display: inline-block;
    margin-right: 25px
}

.md-checkbox.md-checkbox-center {
    display: inline-block
}

.md-checkbox label {
    -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
    cursor: pointer;
    display: inline;
    line-height: 20px;
    vertical-align: top;
    clear: both;
    padding-left: 8px
}

.md-checkbox label:before,
.md-checkbox label:after {
    content: "";
    position: absolute;
    left: 0;
    top: 0
}

.md-checkbox label:before {
    width: 20px;
    height: 20px;
    background: #fff;
    border: 2px solid #bbb;
    border-radius: 2px;
    cursor: pointer;
    transition: background .3s
}

.md-checkbox input[type=checkbox] {
    outline: 0;
    visibility: hidden;
    width: 20px;
    height: 20px;
    margin: 0;
    display: block;
    float: left;
    font-size: inherit
}

.md-checkbox input[type=checkbox]:checked + label:after {
    transform: translate(3.5px, 4.3396226415px) rotate(-45deg);
    width: 12px;
    height: 6.6666666667px;
    border: 3px solid #f96885;
    border-top-style: none;
    border-right-style: none
}

.md-checkbox input[type=checkbox]:disabled + label {
    color: #ccc
}

.md-checkbox input[type=checkbox]:disabled + label:before {
    border-color: #e2e2e2
}

.md-checkbox input[type=checkbox]:disabled:checked + label:before {
    background: rgba(0, 0, 0, .26)
}

.check-col {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between
}

@media screen and (min-width: 1100px) {
    .check-col {
        justify-content: flex-start
    }
}

.check-col div {
    width: 48.5%
}

@media screen and (min-width: 1100px) {
    .check-col div {
        width: 32%
    }
}

.check-list {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    margin-top: 5px;
    white-space: normal;
    width: 100%
}

.check-list li {
    align-items: center;
    cursor: pointer;
    display: flex;
    margin-bottom: 15px;
    text-align: center;
    width: 100%
}

@media screen and (min-width: 1100px) {
    .check-list li {
        width: 48%
    }
}

@media screen and (min-width: 1100px) {
    .check-list li {
        width: 32%
    }
}

.check-list__item input[type=checkbox] + label {
    align-items: center;
    background-color: #fff;
    border: 1px solid #ddd;
    border-radius: 4px;
    cursor: pointer;
    display: flex;
    justify-content: center;
    padding: 10px;
    transition: .2s ease-in-out;
    width: 100%;
    height: 100%
}

.check-list__item input[type=checkbox]:checked + label {
    background-color: #87b656;
    border: 1px solid #87b656;
    color: #fff
}

.check-list__item input[type=checkbox] {
    display: none
}

.form-item__action {
    font-size: 1.2rem;
    line-height: 1.5;
    border: 1px solid #ccc;
    border-radius: 6px;
    cursor: pointer;
    display: block;
    margin-left: auto;
    padding: 12.4px 6px;
    text-decoration: none
}

@media screen and (min-width: 1100px) {
    .form-item__action {
        font-size: 1.3rem;
        line-height: 1.5
    }
}

@media screen and (min-width: 1100px) {
    .form-item__action {
        font-size: 1.4rem;
        line-height: 1.6
    }
}

@media screen and (min-width: 1100px) {
    .form-item__action {
        padding: 11.2px 8px
    }
}

@media screen and (min-width: 1100px) {
    .form-item__action {
        transition: all .3s ease;
        padding: 9.6px 8px
    }

    .form-item__action:hover {
        text-decoration: none
    }
}

.form-item__action svg {
    padding-right: 2px
}

.form-item__action.form-item__action-del {
    color: #ff4141
}

.form-item__action.form-item__action-del svg {
    fill: #ff4141
}

@media screen and (min-width: 1100px) {
    .form-item__action.form-item__action-del:hover {
        background-color: #ff4141;
        border-color: #ff4141;
        color: #fff
    }

    .form-item__action.form-item__action-del:hover svg {
        fill: #fff
    }
}

.form-item__reset {
    font-size: 1.2rem;
    line-height: 1.5;
    border: 1px solid #ddd;
    border-radius: 6px;
    display: inline-block;
    float: right;
    padding: 12.4px 4px;
    text-decoration: none
}

@media screen and (min-width: 1100px) {
    .form-item__reset {
        font-size: 1.3rem;
        line-height: 1.5
    }
}

@media screen and (min-width: 1100px) {
    .form-item__reset {
        font-size: 1.4rem;
        line-height: 1.6
    }
}

@media screen and (min-width: 1100px) {
    .form-item__reset {
        padding: 11.2px 6px
    }
}

@media screen and (min-width: 1100px) {
    .form-item__reset {
        padding: 9.6px 8px
    }

    .form-item__reset:hover {
        text-decoration: none
    }
}

.form-item__btn-add {
    border: 1px solid #ccc;
    border-radius: 6px;
    color: #258fc8;
    cursor: pointer;
    display: inline-block;
    margin-top: 15px;
    padding: 11px 50px
}

.form-item__btn-add svg {
    fill: #258fc8;
    padding-right: 2px
}

@media screen and (min-width: 1100px) {
    .form-item__btn-add {
        transition: all .3s ease
    }

    .form-item__btn-add:hover {
        background-color: #258fc8;
        border-color: #258fc8;
        color: #fff
    }

    .form-item__btn-add:hover svg {
        fill: #fff
    }
}

.form-action {
    margin: 20px auto 30px
}

.form-action__submit {
    transition: all .3s ease;
    background-color: #258fc8;
    border: 1px solid #258fc8;
    border-radius: 25px;
    color: #fff;
    display: block;
    font-weight: bold;
    margin: 10px auto;
    padding: 10px;
    position: relative;
    width: 60%
}

@media screen and (min-width: 1100px) {
    .form-action__submit {
        width: 30%
    }

    .form-action__submit:hover {
        background-color: rgba(37, 143, 200, .9)
    }
}

.form-action__loader {
    position: absolute;
    top: 13px;
    left: 15px
}

.remaining {
    font-size: 1.2rem;
    line-height: 1.5;
    display: block;
    margin-top: 5px;
    opacity: .7;
    text-align: right
}

@media screen and (min-width: 1100px) {
    .remaining {
        font-size: 1.3rem;
        line-height: 1.5
    }
}

@media screen and (min-width: 1100px) {
    .remaining {
        font-size: 1.4rem;
        line-height: 1.6
    }
}

.wrap-error {
    background-color: #ff5959;
    border-radius: 6px;
    color: #fff;
    padding: 10px;
    width: 100%
}

.error-item input,
.error-item select,
.error-item textarea {
    box-shadow: 0 0 5px rgba(255, 76, 76, .9)
}

.error-item__detail {
    margin-top: 5px
}

.error-item__detail span {
    font-size: 1.2rem;
    line-height: 1.5;
    color: #ff4c4c;
    display: block
}

@media screen and (min-width: 1100px) {
    .error-item__detail span {
        font-size: 1.3rem;
        line-height: 1.5
    }
}

@media screen and (min-width: 1100px) {
    .error-item__detail span {
        font-size: 1.4rem;
        line-height: 1.6
    }
}

.error-item__detail span:before {
    display: inline-block;
    font-family: "Font Awesome 5 Free";
    font-weight: 900;
    content: "";
    display: inline-block;
    margin-right: 5px
}

.form-simple .form-item {
    border: 0;
    margin: 0;
    padding: 0
}

.form-simple .form-item .form-item__input {
    margin-bottom: 5px;
    padding: 8px
}

@media screen and (min-width: 1100px) {
    .form-simple .form-item .form-item__input {
        padding: 12px
    }
}

.form-simple .form-item .form-item__input input {
    border-radius: 25px;
    padding: 10px 20px
}

.form-simple .wrap-error {
    background: none;
    border-radius: 0;
    color: #ff5959;
    padding: 10px;
    width: 100%
}

.wp-form .wpcf7-not-valid-tip {
    font-size: 1.2rem;
    line-height: 1.5;
    color: #ffae4a
}

@media screen and (min-width: 1100px) {
    .wp-form .wpcf7-not-valid-tip {
        font-size: 1.3rem;
        line-height: 1.5
    }
}

@media screen and (min-width: 1100px) {
    .wp-form .wpcf7-not-valid-tip {
        font-size: 1.4rem;
        line-height: 1.6
    }
}

.wp-form input[type=submit] {
    transition: all .3s ease;
    background-color: #258fc8;
    border-radius: 25px;
    color: #fff;
    display: block;
    font-weight: bold;
    margin: 10px auto;
    padding: 10px;
    position: relative;
    width: 60%
}

@media screen and (min-width: 1100px) {
    .wp-form input[type=submit] {
        width: 30%
    }

    .wp-form input[type=submit]:hover {
        background-color: #299fde
    }
}

.wp-form .wpcf7-response-output {
    background-color: #fff
}

.wp-form .wpcf7-form-control-wrap {
    display: block
}

.wp-form .wpcf7-form-control.wpcf7-radio,
.wp-form .wpcf7-form-control.wpcf7-checkbox {
    display: flex;
    flex-wrap: wrap
}

.wp-form span.wpcf7-list-item {
    margin-bottom: 10px;
    position: relative;
    flex-basis: 27%
}

.wp-form .wpcf7-form-control.wpcf7-checkbox span.wpcf7-list-item {
    margin-bottom: 10px;
    position: relative;
    flex-basis: 50%
}

.wp-form .wpcf7-form-control.wpcf7-radio .wpcf7-list-item-label {
    -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
    display: inline-block;
    line-height: 1.3;
    position: relative;
    padding-left: 30px;
    margin-bottom: 0;
    cursor: pointer;
    vertical-align: middle
}

@media screen and (min-width: 1100px) {
    .wp-form .wpcf7-form-control.wpcf7-radio .wpcf7-list-item-label {
        line-height: 1.2
    }
}

.wp-form .wpcf7-form-control.wpcf7-radio .wpcf7-list-item-label:before,
.wp-form .wpcf7-form-control.wpcf7-radio .wpcf7-list-item-label:after {
    position: absolute;
    content: "";
    border-radius: 50%;
    transition: all .3s ease;
    transition-property: transform, border-color
}

.wp-form .wpcf7-form-control.wpcf7-radio .wpcf7-list-item-label:before {
    left: 0;
    top: 0;
    width: 20px;
    height: 20px;
    border: 2px solid #bbb;
    box-sizing: border-box
}

.wp-form .wpcf7-form-control.wpcf7-radio .wpcf7-list-item-label:after {
    top: 5px;
    left: 5px;
    width: 10px;
    height: 10px;
    transform: scale(0);
    background: #f96885
}

.wp-form .wpcf7-form-control.wpcf7-radio input[type=radio] {
    display: none
}

.wp-form .wpcf7-form-control.wpcf7-radio input[type=radio]:checked + .wpcf7-list-item-label:before {
    border-color: #f96885;
    animation: ripple .2s linear forwards
}

.wp-form .wpcf7-form-control.wpcf7-radio input[type=radio]:checked + .wpcf7-list-item-label:after {
    transform: scale(1)
}

.wp-form .wpcf7-form-control.wpcf7-checkbox .wpcf7-list-item {
    margin-bottom: 5px;
    position: relative;
    text-align: left
}

.wp-form .wpcf7-form-control.wpcf7-checkbox .wpcf7-list-item label {
    -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
    cursor: pointer;
    display: inline;
    line-height: 20px;
    vertical-align: top;
    clear: both;
    padding-left: 8px
}

.wp-form .wpcf7-form-control.wpcf7-checkbox .wpcf7-list-item label:before,
.wp-form .wpcf7-form-control.wpcf7-checkbox .wpcf7-list-item label:after {
    content: "";
    position: absolute;
    left: 0;
    top: 0
}

.wp-form .wpcf7-form-control.wpcf7-checkbox .wpcf7-list-item label:before {
    width: 20px;
    height: 20px;
    background: inherit;
    border: 2px solid #bbb;
    border-radius: 2px;
    cursor: pointer;
    transition: background .3s
}

.wp-form .wpcf7-form-control.wpcf7-checkbox input[type=checkbox] {
    outline: 0;
    visibility: hidden;
    width: 20px;
    height: 20px;
    margin: 0;
    display: block;
    float: left;
    font-size: inherit
}

.wp-form .wpcf7-form-control.wpcf7-checkbox input[type=checkbox]:checked + .wpcf7-list-item-label:after {
    transform: translate(3.5px, 4.3396226415px) rotate(-45deg);
    width: 12px;
    height: 6.6666666667px;
    border: 3px solid #f96885;
    border-top-style: none;
    border-right-style: none;
    position: absolute;
    top: -3px;
    left: 0
}

.wp-form .wpcf7-form-control.wpcf7-checkbox input[type=checkbox]:disabled + .wpcf7-list-item-label {
    color: #ccc
}

.wp-form .wpcf7-form-control.wpcf7-checkbox input[type=checkbox]:disabled + .wpcf7-list-item-label:before {
    border-color: #e2e2e2
}

.wp-form .wpcf7-form-control.wpcf7-checkbox input[type=checkbox]:disabled:checked + .wpcf7-list-item-label:before {
    background: rgba(0, 0, 0, .26)
}

.wp-form .inputS {
    width: 100%
}

.wp-form .inputS input {
    display: inline-block;
    width: 120px
}

.wp-form .number-747:after {
    content: "才";
    display: inline-block;
    padding-left: 4px
}

.wp-form .number-748:after {
    content: "cm";
    display: inline-block;
    padding-left: 4px
}

.wp-form .number-749:after {
    content: "kg";
    display: inline-block;
    padding-left: 4px
}

#sf-recruit {
    display: block
}

#sf-contact {
    display: none
}

.select-form {
    text-align: center
}

.wpcf7 form.invalid .wpcf7-response-output,
.wpcf7 form.unaccepted .wpcf7-response-output,
.wpcf7 form.sent .wpcf7-response-output {
    animation: temporarilyMessage .5s ease-in 3s forwards;
    border-radius: 6px;
    box-shadow: 0 10px 20px rgba(0, 0, 0, .5);
    color: #222;
    position: fixed;
    top: 0;
    right: 0;
    left: 0;
    bottom: 0;
    margin: auto;
    padding: 30px 10px 80px 10px;
    text-align: center;
    transition: all 1s;
    height: 100px;
    width: 80%;
    max-width: 1100px;
    z-index: 10000
}

@media screen and (min-width: 1100px) {

    .wpcf7 form.invalid .wpcf7-response-output,
    .wpcf7 form.unaccepted .wpcf7-response-output,
    .wpcf7 form.sent .wpcf7-response-output {
        padding: 40px 70px 70px 70px
    }
}

@keyframes temporarilyMessage {
    0% {
        opacity: 1
    }

    80% {
        opacity: .9
    }

    100% {
        display: none;
        opacity: 0;
        z-index: -10
    }
}

.wrap-modaal {
    display: none;
    margin: 0 auto;
    width: 80%
}

@media screen and (min-width: 1100px) {
    .wrap-modaal {
        width: 40%
    }
}

.modaal-inner-wrapper {
    padding: 1vh
}

.modaal-container {
    background-color: rgba(0, 0, 0, .9);
    border: 4px solid #fff;
    border-radius: 10px;
    width: 92%
}

@media screen and (min-width: 1100px) {
    .modaal-container {
        width: 62%
    }
}

.modaal-container .form-action {
    margin: 20px auto 0
}

@media screen and (min-width: 1100px) {
    .modaal-container .form-action {
        margin: 30px auto 0
    }
}

.wrap-modaal--full {
    display: none;
    margin: 0 auto;
    width: 100%
}

.modaal-fullscreen {
    z-index: 2147483647
}

.modaal-fullscreen .modaal-inner {
    margin: 0 auto;
    width: 96%
}

@media screen and (min-width: 1100px) {
    .modaal-fullscreen .modaal-inner {
        width: 1100px
    }
}

.modaal-fullscreen .modaal-container {
    background-color: rgba(14, 111, 184, .9);
    border: none;
    border-radius: 0;
    width: 100%
}

.modaal-fullscreen .modaal-container .modaal-inner {
    padding-top: 0
}

.modaal-fullscreen .modaal-close {
    background-color: #222;
    position: fixed;
    top: 15px;
    right: 15px
}

@media screen and (min-width: 1100px) {
    .modaal-fullscreen .modaal-close {
        top: 40px;
        right: 40px
    }

    .modaal-fullscreen .modaal-close:hover {
        background-color: #333;
        color: #eee
    }
}

.modaal-fullscreen .modaal-close:after,
.modaal-fullscreen .modaal-close:before {
    top: 14px;
    left: 23px
}

@media screen and (min-width: 1100px) {

    .modaal-fullscreen .modaal-close:after,
    .modaal-fullscreen .modaal-close:before {
        left: 22px;
        height: 22px
    }
}

.modaal-content-container {
    padding: 0
}

.modaal-ttl {
    font-size: 1.8rem;
    font-weight: bold;
    line-height: 1.4;
    color: #fff;
    padding: 20px 7px 9px;
    position: absolute;
    top: 0;
    left: 0;
    text-align: center;
    width: 100%;
    z-index: 10
}

@media screen and (min-width: 1100px) {
    .modaal-ttl {
        font-size: 2.4rem;
        line-height: 1.4
    }
}

@media screen and (min-width: 1100px) {
    .modaal-ttl {
        font-size: 2.4rem;
        line-height: 1.4
    }
}

.modaal-inner {
    color: #fff;
    overflow: auto;
    padding: 58px 15px 15px 15px;
    text-align: center
}

@media screen and (min-width: 1100px) {
    .modaal-inner {
        min-height: 14vh;
        padding: 65px 30px 30px 30px
    }
}

.modaal-close:after,
.modaal-close:before {
    top: 13px;
    width: 3px;
    height: 22px
}

@media screen and (min-width: 1100px) {

    .modaal-close:after,
    .modaal-close:before {
        top: 14px
    }
}

.modaal-close {
    position: absolute;
    top: -40px;
    right: -14px;
    width: 50px;
    height: 50px;
    z-index: 20
}

@media screen and (min-width: 1100px) {
    .modaal-close {
        top: -50px;
        right: -18px;
        width: 50px;
        height: 50px
    }
}

.modaal-close:focus,
.modaal-close:hover {
    background: none;
    opacity: .9
}

.modaal-close:focus:after,
.modaal-close:focus:before,
.modaal-close:hover:after,
.modaal-close:hover:before {
    background: #555
}

.js-fixed-notice {
    background: rgba(0, 0, 0, .7);
    border-radius: 6px;
    color: #fff;
    display: none;
    padding: 20px;
    position: fixed;
    top: 50%;
    left: 50%;
    text-align: center;
    transform: translate(-50%, -50%);
    width: 80%;
    z-index: 500
}

@media screen and (min-width: 1100px) {
    .js-fixed-notice {
        max-width: 600px;
        padding: 30px;
        width: 60%
    }
}

#js-page-top {
    position: fixed;
    bottom: 0;
    right: 20px;
    z-index: 500
}

@media screen and (min-width: 1100px) {
    #js-page-top {
        right: 40px
    }
}

#js-page-top a {
    transition: all .3s ease;
    background-color: #0e6fb8;
    border-radius: 50%;
    color: #fff;
    display: block;
    font-size: 2rem;
    opacity: .9;
    padding: 8px;
    text-align: center;
    text-decoration: none;
    width: 48px;
    height: 48px
}

@media screen and (min-width: 1100px) {
    #js-page-top a {
        padding: 14px;
        width: 60px;
        height: 60px
    }

    #js-page-top a:hover {
        opacity: 1
    }
}

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

.wrap-tab-btn .tab-btn-item {
    font-size: 1.8rem;
    font-weight: bold;
    line-height: 1.4;
    background-color: rgba(77, 182, 172, .8);
    border-radius: 3px 3px 0 0;
    box-shadow: 0 0px 2px rgba(0, 0, 0, .1);
    color: #fff;
    flex: 1;
    font-weight: normal;
    margin-left: .75%;
    position: relative;
    text-align: center;
    transition: all .3s ease;
    z-index: 0
}

@media screen and (min-width: 1100px) {
    .wrap-tab-btn .tab-btn-item {
        font-size: 2.4rem;
        line-height: 1.4
    }
}

@media screen and (min-width: 1100px) {
    .wrap-tab-btn .tab-btn-item {
        font-size: 2.4rem;
        line-height: 1.4
    }
}

.wrap-tab-btn .tab-btn-item:hover {
    background-color: rgba(77, 182, 172, .7)
}

.wrap-tab-btn .tab-btn-item.active {
    background-color: #fff;
    border-top: 4px solid #4db6ac;
    box-shadow: 0 -2px 2px rgba(0, 0, 0, .1);
    color: #4db6ac;
    font-weight: bold;
    z-index: 5
}

.wrap-tab-btn .tab-btn-item.active span {
    padding-top: 11px
}

.wrap-tab-btn .tab-btn-item:first-child {
    margin-left: 0
}

.wrap-tab-btn .tab-btn-item a,
.wrap-tab-btn .tab-btn-item span {
    display: block;
    padding: 15px
}

.wrap-tab-btn .tab-btn-item a {
    color: #fff;
    text-decoration: none
}

.wrap-tab-content {
    background-color: #fff;
    border-radius: 0 0 6px 6px;
    box-shadow: 0 0px 4px rgba(0, 0, 0, .1);
    padding: 15px;
    width: 100%
}

@media screen and (min-width: 1100px) {
    .wrap-tab-content {
        padding: 20px
    }
}

.tag-pickup {
    font-size: 1.2rem;
    line-height: 1.5;
    background-color: red;
    border-radius: 6px;
    color: #fff;
    display: inline-block;
    padding: 1px 4px
}

@media screen and (min-width: 1100px) {
    .tag-pickup {
        font-size: 1.3rem;
        line-height: 1.5
    }
}

@media screen and (min-width: 1100px) {
    .tag-pickup {
        font-size: 1.4rem;
        line-height: 1.6
    }
}

.list-image-sq {
    display: flex;
    margin: 5px auto;
    flex-wrap: wrap;
    width: 100%
}

.list-image-sq li {
    margin: .417%;
    position: relative;
    width: 32.5%
}

@media screen and (min-width: 1100px) {
    .list-image-sq li {
        margin: .25%;
        width: 19.5%
    }
}

.list-image-sq li:before {
    display: block;
    content: "";
    padding-top: 100%
}

.list-image-sq li a {
    border: 1px solid #ddd;
    display: block;
    position: absolute;
    top: 0;
    width: 100%;
    height: 100%;
    overflow: hidden
}

.list-image-sq li a img {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    min-width: 100%;
    min-height: 100%;
    max-width: 300px;
    max-height: 300px;
    width: auto
}

@media screen and (min-width: 1100px) {
    .list-image-sq li a img {
        max-width: 500px;
        max-height: 500px
    }
}

.noimage {
    display: block;
    margin: auto;
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    width: 80% !important;
    height: 80% !important
}

.list-item {
    background-color: #fff;
    border-radius: 6px;
    box-shadow: 0 2px 2px rgba(0, 0, 0, .1);
    margin-bottom: 15px;
    overflow: hidden;
    padding: 15px;
    display: flex;
    flex-wrap: wrap;
    margin: 0 auto 5px;
    overflow: hidden;
    width: 100%
}

@media screen and (min-width: 1100px) {
    .list-item {
        margin-bottom: 20px;
        padding: 20px
    }
}

.list-item__thumb {
    background-color: #efefef;
    margin-right: 10px;
    overflow: hidden;
    position: relative;
    width: 90px;
    height: 90px
}

@media screen and (min-width: 1100px) {
    .list-item__thumb {
        margin-right: 20px;
        width: 150px;
        height: 150px
    }
}

.list-item__thumb .list-item__thumb-pht {
    -o-object-fit: cover;
    object-fit: cover;
    width: 90px;
    height: 90px
}

@media screen and (min-width: 1100px) {
    .list-item__thumb .list-item__thumb-pht {
        width: 150px;
        height: 150px
    }
}

.thumbS .list-item__thumb {
    width: 70px;
    height: 70px
}

@media screen and (min-width: 1100px) {
    .thumbS .list-item__thumb {
        width: 100px;
        height: 100px
    }
}

.thumbS .list-item__thumb .list-item__thumb-pht {
    -o-object-fit: cover;
    object-fit: cover;
    width: 70px;
    height: 70px
}

@media screen and (min-width: 1100px) {
    .thumbS .list-item__thumb .list-item__thumb-pht {
        width: 100px;
        height: 100px
    }
}

.thumb-circle {
    border-radius: 50%
}

.list-item__detail {
    flex: 1
}

.list-item__detail-ttl {
    font-weight: bold
}

.col__sub .list-item__detail-ttl {
    font-weight: 500
}

.list-item__detail-time {
    font-size: 1.2rem;
    line-height: 1.5;
    color: #666;
    display: block
}

@media screen and (min-width: 1100px) {
    .list-item__detail-time {
        font-size: 1.3rem;
        line-height: 1.5
    }
}

@media screen and (min-width: 1100px) {
    .list-item__detail-time {
        font-size: 1.4rem;
        line-height: 1.6
    }
}

.list-item__detail-time:before {
    display: inline-block;
    font-family: "Material Icons";
    font-weight: normal;
    font-style: normal;
    font-size: 24px;
    line-height: 1;
    text-transform: none;
    letter-spacing: normal;
    word-wrap: normal;
    white-space: nowrap;
    direction: ltr;
    -webkit-font-smoothing: antialiased;
    text-rendering: optimizeLegibility;
    -moz-osx-font-smoothing: grayscale;
    font-feature-settings: "liga";
    content: "calendar_today"
}

.list-card {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-evenly;
    width: 100%
}

.list-card .list-item {
    margin-bottom: 5px;
    padding: 0;
    width: 48%
}

@media screen and (min-width: 1100px) {
    .list-card .list-item {
        width: 32%
    }
}

@media screen and (min-width: 1100px) {
    .list-card .list-item:nth-child(3n+1) {
        margin-left: 0
    }
}

.list-card .list-item .list-item__thumb {
    margin-right: 0;
    width: 100%;
    height: auto
}

.list-card .list-item .list-item__detail {
    padding: 15px;
    width: 100%
}

.list-card .list-item .list-item__detail .list-item__detail-ttl {
    overflow: hidden;
    white-space: nowrap;
    text-overflow: ellipsis;
    display: block
}

.list-recommend {
    display: flex;
    padding: 10px 5px;
    width: 100%
}

@media screen and (min-width: 1100px) {
    .list-recommend {
        justify-content: flex-start;
        overflow: hidden;
        padding: 10px 0
    }
}

.list-recommend li {
    background-color: #fff;
    border-radius: 6px;
    margin: 0 5px;
    min-width: 200px;
    overflow: hidden;
    text-align: center
}

@media screen and (min-width: 1100px) {
    .list-recommend li {
        margin: 0 0 0 1%;
        min-width: 19.2%;
        width: 19.2%
    }
}

.list-recommend li:first-child {
    margin: 0
}

.list-recommend__thumb {
    width: 100%
}

.list-recommend__detail {
    padding: 10px;
    width: 100%
}

.list-recommend__detail-ttl {
    font-weight: bold
}

.list-recommend__detail-cate {
    font-size: 1.1rem;
    line-height: 1.3;
    color: #777
}

@media screen and (min-width: 1100px) {
    .list-recommend__detail-cate {
        font-size: 1.2rem;
        line-height: 1.4
    }
}

@media screen and (min-width: 1100px) {
    .list-recommend__detail-cate {
        font-size: 1.3rem;
        line-height: 1.5
    }
}

.list-recommend__detail-salary {
    font-size: 1.2rem;
    line-height: 1.5
}

@media screen and (min-width: 1100px) {
    .list-recommend__detail-salary {
        font-size: 1.3rem;
        line-height: 1.5
    }
}

@media screen and (min-width: 1100px) {
    .list-recommend__detail-salary {
        font-size: 1.4rem;
        line-height: 1.6
    }
}

.list-recommend__detail-salary span {
    font-size: 1.6rem;
    line-height: 1.5;
    color: #0e6fb8
}

@media screen and (min-width: 1100px) {
    .list-recommend__detail-salary span {
        font-size: 1.8rem;
        line-height: 1.6
    }
}

@media screen and (min-width: 1100px) {
    .list-recommend__detail-salary span {
        font-size: 1.8rem;
        line-height: 1.6
    }
}

.rank {
    background-color: #222;
    border-radius: 50%;
    color: #fff;
    display: none;
    font-size: 1.2rem;
    line-height: 1.8;
    position: absolute;
    top: 0;
    left: 0;
    text-align: center;
    width: 20px;
    height: 20px
}

.rank--on .rank {
    display: block
}

.rank--on .list-item:nth-child(1) .rank {
    background-color: #d9b340
}

.rank--on .list-item:nth-child(2) .rank {
    background-color: #6f7b83
}

.rank--on .list-item:nth-child(3) .rank {
    background-color: #a15326
}

#fixed-order {
    display: table;
    margin: 0 auto;
    position: relative;
    width: 100%
}

#fixed-order .item {
    background-color: #fff;
    border-radius: 6px;
    box-shadow: 0 2px 2px rgba(0, 0, 0, .1);
    overflow: hidden;
    margin: 0 auto 40px;
    overflow: hidden;
    position: relative;
    width: 100%;
    margin-bottom: 15px
}

@media screen and (min-width: 1100px) {
    #fixed-order .item {
        margin-bottom: 20px
    }
}

#fixed-order .item .header {
    background-color: #fafafa;
    border-bottom: 1px solid #eee;
    height: 43px;
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    width: 100%;
    z-index: 1
}

@media screen and (min-width: 1100px) {
    #fixed-order .item .header {
        height: 46px
    }
}

#fixed-order .item .words ol {
    display: flex;
    width: 100%
}

#fixed-order .item .words ol li {
    border-left: 1px solid #ddd;
    text-align: center;
    width: 10%
}

#fixed-order .item .words ol li:first-child {
    border-left: 0
}

#fixed-order .item .words ol li a {
    display: block;
    text-decoration: none;
    padding: 10px 5px;
    transition: all .2s ease
}

#fixed-order .item .words ol li a:hover {
    background-color: rgba(77, 182, 172, .6);
    color: #fff
}

#fixed-order .item .words ol .current a {
    background-color: #4db6ac;
    color: #fff
}

#fixed-order .item .words-content {
    margin-top: 40px;
    padding: 15px
}

@media screen and (min-width: 1100px) {
    #fixed-order .item .words-content {
        margin-top: 36px;
        padding: 20px
    }
}

.words__sub {
    font-size: 1.1rem;
    line-height: 1.3;
    color: #888;
    display: inline-block;
    font-weight: normal;
    margin-left: 5px
}

@media screen and (min-width: 1100px) {
    .words__sub {
        font-size: 1.2rem;
        line-height: 1.4
    }
}

@media screen and (min-width: 1100px) {
    .words__sub {
        font-size: 1.3rem;
        line-height: 1.5
    }
}

.words__sub:before,
.words__sub:after {
    font-weight: normal
}

.words__sub:before {
    content: "("
}

.words__sub:after {
    content: ")"
}

@keyframes anim-delay {
    0% {
        opacity: 0;
        transform: translateY(30px) scale(0.8, 0.8)
    }

    100% {
        opacity: 1;
        transform: translateY(0) scale(1, 1)
    }
}

@keyframes anim-fadeout {
    0% {
        opacity: 1;
        transform: translateY(0) scale(1, 1)
    }

    100% {
        opacity: 0;
        transform: translateY(30px) scale(0.8, 0.8)
    }
}

.js-fade-list li,
.js-fade-list .flow__item {
    animation-direction: alternate;
    animation-duration: .5s;
    animation-fill-mode: forwards;
    animation-name: anim-fadeout
}

.js-fade-list li.active,
.js-fade-list .flow__item.active {
    opacity: 0;
    animation-duration: .5s;
    animation-fill-mode: forwards;
    animation-name: anim-delay
}

.js-fade-list li:nth-child(1),
.js-fade-list .flow__item:nth-child(1) {
    animation-delay: .1s;
    transition: all ease-in-out
}

@media screen and (min-width: 1100px) {

    .js-fade-list li:nth-child(1),
    .js-fade-list .flow__item:nth-child(1) {
        animation-delay: .3s
    }
}

.js-fade-list li:nth-child(2),
.js-fade-list .flow__item:nth-child(2) {
    animation-delay: .2s;
    transition: all ease-in-out
}

@media screen and (min-width: 1100px) {

    .js-fade-list li:nth-child(2),
    .js-fade-list .flow__item:nth-child(2) {
        animation-delay: .6s
    }
}

.js-fade-list li:nth-child(3),
.js-fade-list .flow__item:nth-child(3) {
    animation-delay: .3s;
    transition: all ease-in-out
}

@media screen and (min-width: 1100px) {

    .js-fade-list li:nth-child(3),
    .js-fade-list .flow__item:nth-child(3) {
        animation-delay: .9s
    }
}

.js-fade-list li:nth-child(4),
.js-fade-list .flow__item:nth-child(4) {
    animation-delay: .4s;
    transition: all ease-in-out
}

@media screen and (min-width: 1100px) {

    .js-fade-list li:nth-child(4),
    .js-fade-list .flow__item:nth-child(4) {
        animation-delay: 1.2s
    }
}

.js-fade-list li:nth-child(5),
.js-fade-list .flow__item:nth-child(5) {
    animation-delay: .5s;
    transition: all ease-in-out
}

@media screen and (min-width: 1100px) {

    .js-fade-list li:nth-child(5),
    .js-fade-list .flow__item:nth-child(5) {
        animation-delay: 1.5s
    }
}

.js-fade-list li:nth-child(6),
.js-fade-list .flow__item:nth-child(6) {
    animation-delay: .6s;
    transition: all ease-in-out
}

@media screen and (min-width: 1100px) {

    .js-fade-list li:nth-child(6),
    .js-fade-list .flow__item:nth-child(6) {
        animation-delay: 1.8s
    }
}

.js-fade-list li:nth-child(7),
.js-fade-list .flow__item:nth-child(7) {
    animation-delay: .7s;
    transition: all ease-in-out
}

@media screen and (min-width: 1100px) {

    .js-fade-list li:nth-child(7),
    .js-fade-list .flow__item:nth-child(7) {
        animation-delay: 2.1s
    }
}

.js-fade-list li:nth-child(8),
.js-fade-list .flow__item:nth-child(8) {
    animation-delay: .8s;
    transition: all ease-in-out
}

@media screen and (min-width: 1100px) {

    .js-fade-list li:nth-child(8),
    .js-fade-list .flow__item:nth-child(8) {
        animation-delay: 2.4s
    }
}

.js-fade-list li:nth-child(9),
.js-fade-list .flow__item:nth-child(9) {
    animation-delay: .9s;
    transition: all ease-in-out
}

@media screen and (min-width: 1100px) {

    .js-fade-list li:nth-child(9),
    .js-fade-list .flow__item:nth-child(9) {
        animation-delay: 2.7s
    }
}

.js-fade-list li:nth-child(10),
.js-fade-list .flow__item:nth-child(10) {
    animation-delay: 1s;
    transition: all ease-in-out
}

@media screen and (min-width: 1100px) {

    .js-fade-list li:nth-child(10),
    .js-fade-list .flow__item:nth-child(10) {
        animation-delay: 3s
    }
}

.js-fade-list li:nth-child(11),
.js-fade-list .flow__item:nth-child(11) {
    animation-delay: 1.1s;
    transition: all ease-in-out
}

@media screen and (min-width: 1100px) {

    .js-fade-list li:nth-child(11),
    .js-fade-list .flow__item:nth-child(11) {
        animation-delay: 3.3s
    }
}

.js-fade-list li:nth-child(12),
.js-fade-list .flow__item:nth-child(12) {
    animation-delay: 1.2s;
    transition: all ease-in-out
}

@media screen and (min-width: 1100px) {

    .js-fade-list li:nth-child(12),
    .js-fade-list .flow__item:nth-child(12) {
        animation-delay: 3.6s
    }
}

.js-fade-list li:nth-child(13),
.js-fade-list .flow__item:nth-child(13) {
    animation-delay: 1.3s;
    transition: all ease-in-out
}

@media screen and (min-width: 1100px) {

    .js-fade-list li:nth-child(13),
    .js-fade-list .flow__item:nth-child(13) {
        animation-delay: 3.9s
    }
}

.js-fade-list li:nth-child(14),
.js-fade-list .flow__item:nth-child(14) {
    animation-delay: 1.4s;
    transition: all ease-in-out
}

@media screen and (min-width: 1100px) {

    .js-fade-list li:nth-child(14),
    .js-fade-list .flow__item:nth-child(14) {
        animation-delay: 4.2s
    }
}

.js-fade-list li:nth-child(15),
.js-fade-list .flow__item:nth-child(15) {
    animation-delay: 1.5s;
    transition: all ease-in-out
}

@media screen and (min-width: 1100px) {

    .js-fade-list li:nth-child(15),
    .js-fade-list .flow__item:nth-child(15) {
        animation-delay: 4.5s
    }
}

.js-fade-list li:nth-child(16),
.js-fade-list .flow__item:nth-child(16) {
    animation-delay: 1.6s;
    transition: all ease-in-out
}

@media screen and (min-width: 1100px) {

    .js-fade-list li:nth-child(16),
    .js-fade-list .flow__item:nth-child(16) {
        animation-delay: 4.8s
    }
}

.js-fade-list li:nth-child(17),
.js-fade-list .flow__item:nth-child(17) {
    animation-delay: 1.7s;
    transition: all ease-in-out
}

@media screen and (min-width: 1100px) {

    .js-fade-list li:nth-child(17),
    .js-fade-list .flow__item:nth-child(17) {
        animation-delay: 5.1s
    }
}

.js-fade-list li:nth-child(18),
.js-fade-list .flow__item:nth-child(18) {
    animation-delay: 1.8s;
    transition: all ease-in-out
}

@media screen and (min-width: 1100px) {

    .js-fade-list li:nth-child(18),
    .js-fade-list .flow__item:nth-child(18) {
        animation-delay: 5.4s
    }
}

.js-fade-list li:nth-child(19),
.js-fade-list .flow__item:nth-child(19) {
    animation-delay: 1.9s;
    transition: all ease-in-out
}

@media screen and (min-width: 1100px) {

    .js-fade-list li:nth-child(19),
    .js-fade-list .flow__item:nth-child(19) {
        animation-delay: 5.7s
    }
}

.js-fade-list li:nth-child(20),
.js-fade-list .flow__item:nth-child(20) {
    animation-delay: 2s;
    transition: all ease-in-out
}

@media screen and (min-width: 1100px) {

    .js-fade-list li:nth-child(20),
    .js-fade-list .flow__item:nth-child(20) {
        animation-delay: 6s
    }
}

.js-fade-list-fast li {
    animation-direction: alternate;
    animation-duration: .5s;
    animation-fill-mode: forwards;
    animation-name: anim-fadeout
}

.js-fade-list-fast li.active {
    opacity: 0;
    animation-duration: .5s;
    animation-fill-mode: forwards;
    animation-name: anim-delay
}

.js-fade-list-fast li:nth-child(1) {
    animation-delay: .1s;
    transition: all ease-in-out
}

@media screen and (min-width: 1100px) {
    .js-fade-list-fast li:nth-child(1) {
        animation-delay: .1s
    }
}

.js-fade-list-fast li:nth-child(2) {
    animation-delay: .2s;
    transition: all ease-in-out
}

@media screen and (min-width: 1100px) {
    .js-fade-list-fast li:nth-child(2) {
        animation-delay: .2s
    }
}

.js-fade-list-fast li:nth-child(3) {
    animation-delay: .3s;
    transition: all ease-in-out
}

@media screen and (min-width: 1100px) {
    .js-fade-list-fast li:nth-child(3) {
        animation-delay: .3s
    }
}

.js-fade-list-fast li:nth-child(4) {
    animation-delay: .4s;
    transition: all ease-in-out
}

@media screen and (min-width: 1100px) {
    .js-fade-list-fast li:nth-child(4) {
        animation-delay: .4s
    }
}

.js-fade-list-fast li:nth-child(5) {
    animation-delay: .5s;
    transition: all ease-in-out
}

@media screen and (min-width: 1100px) {
    .js-fade-list-fast li:nth-child(5) {
        animation-delay: .5s
    }
}

.js-fade-list-fast li:nth-child(6) {
    animation-delay: .6s;
    transition: all ease-in-out
}

@media screen and (min-width: 1100px) {
    .js-fade-list-fast li:nth-child(6) {
        animation-delay: .6s
    }
}

.js-fade-list-fast li:nth-child(7) {
    animation-delay: .7s;
    transition: all ease-in-out
}

@media screen and (min-width: 1100px) {
    .js-fade-list-fast li:nth-child(7) {
        animation-delay: .7s
    }
}

.js-fade-list-fast li:nth-child(8) {
    animation-delay: .8s;
    transition: all ease-in-out
}

@media screen and (min-width: 1100px) {
    .js-fade-list-fast li:nth-child(8) {
        animation-delay: .8s
    }
}

.js-fade-list-fast li:nth-child(9) {
    animation-delay: .9s;
    transition: all ease-in-out
}

@media screen and (min-width: 1100px) {
    .js-fade-list-fast li:nth-child(9) {
        animation-delay: .9s
    }
}

.js-fade-list-fast li:nth-child(10) {
    animation-delay: 1s;
    transition: all ease-in-out
}

@media screen and (min-width: 1100px) {
    .js-fade-list-fast li:nth-child(10) {
        animation-delay: 1s
    }
}

.js-fade-list-fast li:nth-child(11) {
    animation-delay: 1.1s;
    transition: all ease-in-out
}

@media screen and (min-width: 1100px) {
    .js-fade-list-fast li:nth-child(11) {
        animation-delay: 1.1s
    }
}

.js-fade-list-fast li:nth-child(12) {
    animation-delay: 1.2s;
    transition: all ease-in-out
}

@media screen and (min-width: 1100px) {
    .js-fade-list-fast li:nth-child(12) {
        animation-delay: 1.2s
    }
}

.js-fade-list-fast li:nth-child(13) {
    animation-delay: 1.3s;
    transition: all ease-in-out
}

@media screen and (min-width: 1100px) {
    .js-fade-list-fast li:nth-child(13) {
        animation-delay: 1.3s
    }
}

.js-fade-list-fast li:nth-child(14) {
    animation-delay: 1.4s;
    transition: all ease-in-out
}

@media screen and (min-width: 1100px) {
    .js-fade-list-fast li:nth-child(14) {
        animation-delay: 1.4s
    }
}

.js-fade-list-fast li:nth-child(15) {
    animation-delay: 1.5s;
    transition: all ease-in-out
}

@media screen and (min-width: 1100px) {
    .js-fade-list-fast li:nth-child(15) {
        animation-delay: 1.5s
    }
}

.js-fade-list-fast li:nth-child(16) {
    animation-delay: 1.6s;
    transition: all ease-in-out
}

@media screen and (min-width: 1100px) {
    .js-fade-list-fast li:nth-child(16) {
        animation-delay: 1.6s
    }
}

.js-fade-list-fast li:nth-child(17) {
    animation-delay: 1.7s;
    transition: all ease-in-out
}

@media screen and (min-width: 1100px) {
    .js-fade-list-fast li:nth-child(17) {
        animation-delay: 1.7s
    }
}

.js-fade-list-fast li:nth-child(18) {
    animation-delay: 1.8s;
    transition: all ease-in-out
}

@media screen and (min-width: 1100px) {
    .js-fade-list-fast li:nth-child(18) {
        animation-delay: 1.8s
    }
}

.js-fade-list-fast li:nth-child(19) {
    animation-delay: 1.9s;
    transition: all ease-in-out
}

@media screen and (min-width: 1100px) {
    .js-fade-list-fast li:nth-child(19) {
        animation-delay: 1.9s
    }
}

.js-fade-list-fast li:nth-child(20) {
    animation-delay: 2s;
    transition: all ease-in-out
}

@media screen and (min-width: 1100px) {
    .js-fade-list-fast li:nth-child(20) {
        animation-delay: 2s
    }
}

.fadeBtoT {
    opacity: 0;
    transform: translate(0, 50px);
    transition: all 1s
}

.fadeBtoT.active {
    opacity: 1;
    transform: translate(0, 0)
}

.fadeLtoR {
    opacity: 0;
    transform: translate(-50px, 0);
    transition: all 1s
}

.fadeLtoR.active {
    opacity: 1;
    transform: translate(0, 0)
}

.fadeRtoL {
    opacity: 0;
    transform: translate(50px, 0);
    transition: all 1s
}

.fadeRtoL.active {
    opacity: 1;
    transform: translate(0, 0)
}

.section-payment {
    background-color: rgba(234, 247, 253, .9)
}

.wrap-payment .payment__item:last-child .list-logo {
    margin-bottom: 0
}

.payment__item {
    position: relative;
    text-align: center
}

.payment__cat {
    position: absolute;
    top: -22px;
    left: 0;
    right: 0;
    text-align: center
}

.payment__cat span {
    background-color: #3f647e;
    border-radius: 30px;
    color: #fff;
    display: inline-block;
    padding: 8px 60px
}

.list-logo {
    align-items: center;
    background-color: #fff;
    border-radius: 12px;
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    margin-bottom: 50px;
    padding: 30px 5px 10px
}

.list-logo li {
    margin: 6px;
    padding: 5px
}

@media screen and (min-width: 1100px) {
    .list-logo li {
        margin: 10px
    }
}

.list-logo li div,
.list-logo li a {
    display: flex;
    justify-content: center;
    align-items: center;
    height: 100%
}

.list-logo li div img,
.list-logo li a img {
    width: 70px;
    height: 35px;
    -o-object-fit: contain;
    object-fit: contain
}

@media screen and (min-width: 1100px) {

    .list-logo li div img,
    .list-logo li a img {
        width: 80px;
        height: 45px
    }
}

body {
    font: 500 1.4rem/1.6 "Montserrat", "Yu Gothic", "游ゴシック", "Hiragino Kaku Gothic ProN W3", Arial, "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif !important
}

@media screen and (min-width: 1100px) {
    body {
        font: 500 1.5rem/1.6 "Montserrat", "Yu Gothic", "游ゴシック", "Hiragino Kaku Gothic ProN W3", Arial, "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif !important
    }
}

@media screen and (min-width: 1100px) {
    body {
        font: 500 1.6rem/1.6 "Montserrat", "Yu Gothic", "游ゴシック", "Hiragino Kaku Gothic ProN W3", Arial, "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif !important
    }
}

body.modaal-noscroll {
    overflow: hidden !important
}

.wrap {
    margin: 0 auto;
    position: relative;
    width: 100%
}

.inner {
    margin: 0 auto;
    width: 96%
}

@media screen and (min-width: 1100px) {
    .inner {
        width: 1100px
    }
}

.wrap-sitecol {
    margin: 0 auto;
    width: 96%;
    padding-top: 80px
}

@media screen and (min-width: 1100px) {
    .wrap-sitecol {
        width: 1100px
    }
}

@media screen and (min-width: 1100px) {
    .wrap-sitecol {
        display: flex;
        padding-top: 80px
    }
}

@media screen and (min-width: 1100px) {
    .wrap-sitecol .main-content {
        width: 724px
    }
}

.wrap-sitecol .sidebar {
    padding: 15px 0 15px 40px
}

.section {
    padding: 30px 0;
    position: relative
}

@media screen and (min-width: 1100px) {
    .section {
        padding: 80px 0
    }
}

.section-pb0 {
    padding: 80px 0 0;
    position: relative
}

.wrap-section-heading {
    padding: 30px 10px;
    text-align: center;
    width: 100%
}

@media screen and (min-width: 1100px) {
    .wrap-section-heading {
        padding: 30px 100px
    }
}

.section-heading,
.archive-title {
    font-size: 2.4rem;
    font-weight: bold;
    line-height: 1.4;
    color: #111;
    letter-spacing: .2rem;
    margin-bottom: 10px
}

@media screen and (min-width: 1100px) {

    .section-heading,
    .archive-title {
        font-size: 3.5rem
    }
}

@media screen and (min-width: 1100px) {

    .section-heading,
    .archive-title {
        font-size: 3.5rem
    }
}

@media screen and (min-width: 1100px) {

    .section-heading,
    .archive-title {
        margin-bottom: 20px
    }
}

.section-heading span,
.archive-title span {
    font-size: 1.1rem;
    line-height: 1.3;
    color: #999;
    display: block;
    font-weight: normal;
    letter-spacing: 0;
    text-transform: capitalize
}

@media screen and (min-width: 1100px) {

    .section-heading span,
    .archive-title span {
        font-size: 1.2rem;
        line-height: 1.4
    }
}

@media screen and (min-width: 1100px) {

    .section-heading span,
    .archive-title span {
        font-size: 1.3rem;
        line-height: 1.5
    }
}

.section-heading__text {
    font-size: 1.8rem;
    font-weight: bold;
    line-height: 1.4;
    font-family: "Montserrat", "Yu Gothic", "游ゴシック", "Hiragino Kaku Gothic ProN W3", Arial, "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
    font-weight: normal;
    position: relative;
    z-index: 0
}

@media screen and (min-width: 1100px) {
    .section-heading__text {
        font-size: 2.4rem;
        line-height: 1.4
    }
}

@media screen and (min-width: 1100px) {
    .section-heading__text {
        font-size: 2.4rem;
        line-height: 1.4
    }
}

.section-heading-v {
    writing-mode: vertical-rl
}

.wrap-heading-3 {
    text-align: center
}

.heading-3 {
    font-size: 1.8rem;
    font-weight: bold;
    line-height: 1.4;
    color: #000;
    display: inline-block;
    font-weight: bold;
    margin: 10px auto
}

@media screen and (min-width: 1100px) {
    .heading-3 {
        font-size: 2.4rem;
        line-height: 1.4
    }
}

@media screen and (min-width: 1100px) {
    .heading-3 {
        font-size: 2.4rem;
        line-height: 1.4
    }
}

.more-link {
    margin: 20px auto;
    text-align: center
}

.more-link a {
    background: #fff;
    border: 1px solid #258fc8;
    display: inline-block;
    position: relative;
    text-decoration: none;
    padding: 1.5rem 5.5rem 1.5rem 5rem;
    transition: all .3s
}

.more-link a:after {
    content: "";
    position: absolute;
    display: block;
    transition: all .3s;
    width: 7px;
    height: 18px;
    top: 50%;
    right: 2.5rem;
    box-shadow: 2px -2px 0 #fff;
    border-top: solid 1px #258fc8;
    border-right: solid 1px #258fc8;
    transform: translateY(-50%) rotate(45deg) skewX(-45deg)
}

.more-link a:hover:after {
    right: 5px;
    height: 40px
}

.sequential-link {
    display: inline-block;
    padding: 2px;
    position: relative;
    text-decoration: none
}

.sequential-link:after {
    position: absolute;
    right: 0;
    bottom: 0;
    content: "";
    width: 100%;
    height: 1px;
    background: #258fc8;
    transform: scale(0, 1);
    transform-origin: right bottom;
    transition: transform .3s
}

.sequential-link:hover {
    text-decoration: none
}

.sequential-link:hover:after {
    transform-origin: left bottom;
    transform: scale(1, 1)
}

.wrap-site-header {
    position: fixed;
    top: 0;
    left: 0;
    transition: all .3s ease;
    width: 100%;
    z-index: 1000
}

.site-header-pc {
    display: none
}

@media screen and (min-width: 1100px) {
    .site-header-pc {
        display: block;
        width: 100%
    }
}

.site-header-pc-main-wrap {
    background-color: #fff;
    box-shadow: 0 0 5px rgba(0, 0, 0, .2);
    position: relative;
    width: 100%;
    z-index: 1
}

@media screen and (min-width: 1100px) {
    .site-header-pc-main-wrap .site-header-pc__inner {
        display: flex;
        flex-wrap: wrap;
        justify-content: space-between;
        margin: 0 auto;
        width: 1100px
    }
}

#logo-svg .logo-svg__circle {
    stroke: #000
}

#logo-svg .logo-svg__wave {
    fill: #1292c3
}

.site-header__logo {
    transition: all .3s ease;
    width: 150px
}

@media screen and (min-width: 1100px) {
    .site-header__logo {
        margin: 0 auto;
        text-align: center;
        padding: 15px 52px;
        width: 280px
    }
}

.site-header__logo a {
    display: flex;
    justify-content: center
}

.site-header__logo #logo-svg .logo-svg__circle {
    stroke: #000
}

.site-header__logo #logo-svg .logo-svg__wave {
    fill: #1292c3
}

#logo-svg-h {
    fill: #000
}

#logo-svg-h .logo-svg__circle {
    stroke: #000
}

.site-header__nav {
    align-items: center;
    display: flex;
    justify-content: space-between;
    width: 410px
}

.site-header-sp {
    align-items: center;
    background-color: #fff;
    box-shadow: 0 0 5px rgba(0, 0, 0, .2);
    display: flex;
    justify-content: space-between;
    position: relative;
    width: 100%;
    z-index: 1
}

@media screen and (min-width: 1100px) {
    .site-header-sp {
        display: none
    }
}

.sp-header-logo {
    flex: 1;
    max-height: 40px
}

.sp-header-logo a {
    display: block;
    margin: 0 auto;
    text-align: center;
    transition: all .3s ease
}

.sp-header-logo a img {
    max-width: 180px
}

.sp-header-logo a #logo-svg {
    transition: all .3s ease;
    fill: #000;
    max-height: 88px;
    min-height: 88px;
    padding: 5px 0 0
}

.sp-header-logo a #logo-svg .logo-svg__circle {
    stroke: #000
}

.sp-header-menu {
    align-items: center;
    display: flex;
    width: 100px;
    height: 100%
}

@media screen and (min-width: 1100px) {
    .sp-header-menu {
        display: none
    }
}

.sp-header-menu li {
    border-left: 1px solid #ddd;
    width: 100%;
    height: 100%
}

.sp-header-menu li a {
    display: block;
    height: 100%;
    padding: 10px;
    text-align: center
}

.btnMenu {
    display: block;
    position: relative;
    width: 100%;
    height: 100%
}

.btnMenu i {
    display: block;
    font-size: 1.8rem;
    height: 20px;
    margin: auto;
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0
}

.sp-header-btn {
    display: block;
    width: 64px
}

@media screen and (min-width: 1100px) {
    .sp-header-btn {
        display: none
    }
}

.sp-header-btn a {
    font-size: 1.1rem;
    line-height: 1.3;
    color: #000;
    display: block;
    font-weight: bold;
    padding: 10px 4px;
    position: relative;
    text-align: center
}

@media screen and (min-width: 1100px) {
    .sp-header-btn a {
        font-size: 1.2rem;
        line-height: 1.4
    }
}

@media screen and (min-width: 1100px) {
    .sp-header-btn a {
        font-size: 1.3rem;
        line-height: 1.5
    }
}

.sp-header-btn a img {
    display: block;
    margin: 0 auto 2px;
    width: 40%
}

.sp-header-btn .ico-mi:before {
    display: inline-block;
    font-family: "Material Icons";
    font-weight: normal;
    font-style: normal;
    font-size: 24px;
    line-height: 1;
    text-transform: none;
    letter-spacing: normal;
    word-wrap: normal;
    white-space: nowrap;
    direction: ltr;
    -webkit-font-smoothing: antialiased;
    text-rendering: optimizeLegibility;
    -moz-osx-font-smoothing: grayscale;
    font-feature-settings: "liga";
    display: block;
    font-size: 29px;
    font-weight: 300
}

.sp-header-btn .ico-mail:before {
    content: "mail_outline"
}

.sp-header-btn .ico-menu:before {
    content: "menu"
}

.header-fixed .sp-header-logo a {
    max-width: 180px
}

.sub-nav,
.sub-nav-2 {
    background-color: #0d6eb8;
    display: table;
    visibility: collapse;
    opacity: 0;
    position: absolute;
    top: 0;
    transition: all 600ms cubic-bezier(0.77, 0, 0.175, 1);
    width: 100%;
    z-index: 0
}

.sub-nav ul,
.sub-nav-2 ul {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
    margin: 0 auto;
    width: 1100px
}

.sub-nav ul li,
.sub-nav-2 ul li {
    width: 16.6666%
}

.sub-nav ul li a,
.sub-nav-2 ul li a {
    color: #fff;
    display: block;
    font-weight: normal;
    padding: 25px 0;
    text-align: center;
    text-decoration: none;
    transition: all .3s ease;
    width: 100%
}

.sub-nav ul li a:hover,
.sub-nav-2 ul li a:hover {
    background-color: rgba(255, 255, 255, .1)
}

.sub-nav.sub-menu--open,
.sub-nav.sub-menu-2--open,
.sub-nav-2.sub-menu--open,
.sub-nav-2.sub-menu-2--open {
    opacity: 1;
    visibility: visible;
    top: 71px
}

.js-sub-menu .no-link,
.js-sub-menu-2 .no-link {
    display: flex;
    height: 100%
}

.js-sub-menu .no-link span,
.js-sub-menu-2 .no-link span {
    align-items: center;
    display: flex;
    font-weight: bold;
    line-height: 1.5
}

.js-sub-menu .no-link span:after,
.js-sub-menu-2 .no-link span:after {
    display: inline-block;
    font-family: "Material Icons";
    font-weight: normal;
    font-style: normal;
    font-size: 24px;
    line-height: 1;
    text-transform: none;
    letter-spacing: normal;
    word-wrap: normal;
    white-space: nowrap;
    direction: ltr;
    -webkit-font-smoothing: antialiased;
    text-rendering: optimizeLegibility;
    -moz-osx-font-smoothing: grayscale;
    font-feature-settings: "liga";
    content: "expand_more";
    padding-right: 0;
    transform: rotate(-90deg);
    transition: all .3s ease-in-out;
    vertical-align: text-bottom
}

.js-sub-menu--open .no-link span,
.js-sub-menu-2--open .no-link span {
    color: #ef6b0a
}

.js-sub-menu--open .no-link span:after,
.js-sub-menu-2--open .no-link span:after {
    transform: rotate(0)
}

.gl-nav {
    height: 100%;
    width: 100%
}

.gl-nav ul {
    align-items: center;
    display: flex;
    justify-content: space-between;
    width: 100%;
    height: 100%
}

.gl-nav ul li {
    display: table;
    height: 100%;
    width: 33.333%
}

.gl-nav ul li a,
.gl-nav ul li .no-link {
    font-size: 1.1rem;
    line-height: 1.3;
    color: #000;
    display: block;
    font-weight: bold;
    height: 100%;
    padding: 10px 6px;
    position: relative;
    text-align: center;
    text-decoration: none
}

@media screen and (min-width: 1100px) {

    .gl-nav ul li a,
    .gl-nav ul li .no-link {
        font-size: 1.2rem;
        line-height: 1.4
    }
}

@media screen and (min-width: 1100px) {

    .gl-nav ul li a,
    .gl-nav ul li .no-link {
        font-size: 1.3rem;
        line-height: 1.5
    }
}

@media screen and (min-width: 1100px) {

    .gl-nav ul li a,
    .gl-nav ul li .no-link {
        display: table-cell;
        font-size: 1.5rem;
        vertical-align: middle;
        width: 100%
    }

    .gl-nav ul li a:before,
    .gl-nav ul li a:after,
    .gl-nav ul li .no-link:before,
    .gl-nav ul li .no-link:after {
        content: "";
        width: 0;
        bottom: 0;
        transition: all .3s ease;
        border-bottom: 1px solid #ef6b0a;
        position: absolute;
        display: block
    }

    .gl-nav ul li a:before,
    .gl-nav ul li .no-link:before {
        left: 50%
    }

    .gl-nav ul li a:after,
    .gl-nav ul li .no-link:after {
        right: 50%
    }

    .gl-nav ul li a:hover,
    .gl-nav ul li .no-link:hover {
        color: #ef6b0a
    }

    .gl-nav ul li a:hover:before,
    .gl-nav ul li a:hover:after,
    .gl-nav ul li .no-link:hover:before,
    .gl-nav ul li .no-link:hover:after {
        width: 50%;
        border-bottom: 1px solid #ef6b0a
    }
}

.gl-nav ul li a img,
.gl-nav ul li .no-link img {
    display: block;
    margin: 0 auto 4px;
    max-width: 58px;
    width: 40%
}

@media screen and (min-width: 1100px) {

    .gl-nav ul li a img,
    .gl-nav ul li .no-link img {
        width: 16%
    }
}

.gl-nav ul .nav__access,
.gl-nav ul .nav__contact {
    display: none
}

@media screen and (min-width: 1100px) {

    .gl-nav ul .nav__access,
    .gl-nav ul .nav__contact {
        display: block
    }
}

.gl-nav ul .btn-nav {
    height: auto
}

.gl-nav ul .btn-nav a {
    background-color: #0e6fb8;
    border-radius: 30px;
    color: #fff;
    line-height: 1.6;
    padding: 10px 18px;
    transition: all .3s ease-in-out
}

@media screen and (min-width: 1100px) {

    .gl-nav ul .btn-nav a:before,
    .gl-nav ul .btn-nav a:after {
        content: none
    }

    .gl-nav ul .btn-nav a:hover {
        background-color: #ef6b0a;
        color: #fff
    }
}

.gl-nav ul .btn-nav a img {
    display: inline;
    padding-right: 5px;
    margin: 0;
    vertical-align: text-top;
    width: 24px
}

.gl-nav ul .sub-1 {
    display: none
}

@media screen and (min-width: 830px) {
    .gl-nav ul .sub-1 {
        display: block
    }
}

.gl-nav ul .sub-2 {
    display: none
}

@media screen and (min-width: 730px) {
    .gl-nav ul .sub-2 {
        display: block
    }
}

.gl-nav ul .sub-3 {
    display: none
}

@media screen and (min-width: 630px) {
    .gl-nav ul .sub-3 {
        display: block
    }
}

@media screen and (min-width: 1100px) {

    .header-fixed .gl-nav ul li a:before,
    .header-fixed .gl-nav ul li a:after,
    .header-fixed .gl-nav ul li .no-link:before,
    .header-fixed .gl-nav ul li .no-link:after {
        border-bottom: 2px solid #ef6b0a
    }

    .header-fixed .gl-nav ul li a:hover:before,
    .header-fixed .gl-nav ul li a:hover:after,
    .header-fixed .gl-nav ul li .no-link:hover:before,
    .header-fixed .gl-nav ul li .no-link:hover:after {
        border-bottom: 2px solid #ef6b0a
    }
}

.header-fixed .gl-nav ul .btn-nav a {
    background-color: #0e6fb8;
    color: #fff
}

@media screen and (min-width: 1100px) {
    .header-fixed .gl-nav ul .btn-nav a:hover {
        background-color: #ef6b0a;
        color: #fff
    }
}

.sp-menu li {
    border-top: 1px solid rgba(255, 255, 255, .3);
    text-align: left
}

@media screen and (min-width: 1100px) {
    .sp-menu li {
        border: none
    }
}

.sp-menu li:last-child {
    border-bottom: 1px solid rgba(255, 255, 255, .3)
}

@media screen and (min-width: 1100px) {
    .sp-menu li:last-child {
        border: none
    }
}

.sp-menu li a {
    border-bottom: #121212;
    box-sizing: border-box;
    color: #fff;
    display: block;
    font-size: 1.4rem;
    padding: 12px 8px 12px 25px;
    position: relative
}

@media screen and (min-width: 1100px) {
    .sp-menu li a {
        background: none;
        box-sizing: border-box;
        display: block;
        padding: 5px;
        position: relative
    }
}

.sp-menu li a:after {
    content: "";
    display: block;
    font-family: "Font Awesome 5 Free";
    font-weight: 900;
    line-height: 1;
    position: absolute;
    top: 0;
    right: 10px;
    bottom: 0;
    margin: auto;
    width: 15px;
    height: 15px
}

@media screen and (min-width: 1100px) {
    .sp-menu li a:after {
        content: ""
    }
}

.mv {
    overflow: hidden;
    position: relative;
    width: 100%
}

.mv:before {
    animation: AnimationName 10s ease infinite;
    background: linear-gradient(45deg, rgba(0, 0, 0, 0.7), rgba(0, 0, 0, 0.4));
    background-size: 300% 300%;
    content: "";
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: 5
}

.mv__wrap {
    position: fixed;
    overflow: hidden;
    width: 100%;
    height: 100vh
}

.mv__wrap:before {
    background-image: url(./img/overlays/02.png?v=20240216135235);
    background-repeat: repeat;
    content: "";
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: 1
}

.fitMovie {
    -o-object-fit: cover;
    object-fit: cover;
    min-width: 100%;
    min-height: 100vh;
    z-index: 0
}

@keyframes AnimationName {
    0% {
        background-position: 0% 50%
    }

    50% {
        background-position: 100% 50%
    }

    100% {
        background-position: 0% 50%
    }
}

.mv__centered {
    margin: 0 auto;
    position: absolute;
    top: 50%;
    right: 0;
    left: 0;
    text-align: center;
    transform: translateY(-50%);
    width: 90%;
    z-index: 10
}

.mv__title {
    color: #fff;
    font-size: 5vw;
    font-weight: bold;
    opacity: 0
}

@media screen and (min-width: 1100px) {
    .mv__title {
        font-size: 5rem
    }
}

.mv__text {
    color: #fff
}

.sec {
    margin-bottom: 120px
}

#vegas:before {
    background-color: rgba(0, 0, 0, .5);
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: 10000
}

.ec-ttl {
    color: #fff;
    font-size: 5vw;
    font-weight: bold;
    line-height: 1.4;
    position: absolute;
    top: 50%;
    left: 5%;
    transform: translateY(-50%)
}

@media screen and (min-width: 1100px) {
    .ec-ttl {
        font-size: 4.4rem
    }
}

.ec-ttl span {
    font-size: 1.2rem;
    line-height: 1.5;
    display: block;
    margin-top: 20px
}

@media screen and (min-width: 1100px) {
    .ec-ttl span {
        font-size: 1.3rem;
        line-height: 1.5
    }
}

@media screen and (min-width: 1100px) {
    .ec-ttl span {
        font-size: 1.4rem;
        line-height: 1.6
    }
}

@media screen and (min-width: 1100px) {
    .ec-ttl span {
        font-size: 2.4rem
    }
}

#content {
    background-color: #fff;
    position: relative
}

.main-content {
    background-color: #fff;
    position: relative;
    width: 100%
}

@media screen and (min-width: 1100px) {
    .main-content {
        flex: 1
    }
}

.deco-text {
    color: #929292;
    font-size: 8rem;
    font-family: "Bitter", "Shippori Mincho", 游明朝, "Yu Mincho", YuMincho, "Hiragino Mincho ProN", HGS明朝E, serif;
    font-weight: bold;
    line-height: .5;
    margin: auto;
    opacity: .2;
    position: absolute;
    top: 0;
    right: 0;
    left: 0;
    text-align: center;
    white-space: nowrap
}

@media screen and (min-width: 1100px) {
    .deco-text {
        font-size: 40rem
    }
}

.list-service {
    margin-top: 50px
}

.list-service li {
    align-items: center;
    display: block;
    margin-bottom: 60px;
    width: 100%
}

@media screen and (min-width: 1100px) {
    .list-service li {
        display: flex;
        margin-bottom: 120px
    }
}

.list-service li figure {
    width: 100%
}

@media screen and (min-width: 1100px) {
    .list-service li figure {
        width: 50%
    }
}

.list-service li figure img {
    width: 100%
}

.list-service li .text-container {
    padding-top: 3rem;
    width: 100%
}

@media screen and (min-width: 1100px) {
    .list-service li .text-container {
        padding: 0 5vw;
        width: 50%
    }
}

.list-service li:nth-child(even) .img-container {
    order: 2
}

.list-service li:nth-child(even) .text-container {
    order: 1
}

.img-container {
    width: 100%;
    order: 1;
    overflow: hidden;
    position: relative
}

.img-container__img {
    display: block;
    max-width: 100%;
    opacity: 0;
    position: relative;
    transition: all .5s .3s ease;
    z-index: 0
}

.img-container:before {
    background: #ccc;
    content: "";
    display: block;
    height: 100%;
    position: absolute;
    transform: translateX(-101%);
    transition: all .8s 0s ease;
    width: 100%;
    z-index: 1
}

.text-container {
    order: 2;
    padding: 0 10px
}

.text-container__title {
    color: #333;
    display: inline-block;
    overflow: hidden;
    position: relative;
    z-index: 0
}

.text-container__title:before {
    background: #ccc;
    content: "";
    display: block;
    height: 100%;
    position: absolute;
    transform: translateX(-101%);
    transition: all .8s .3s ease;
    width: 100%;
    z-index: 1
}

.text-container__title__inner {
    font-size: 1.8rem;
    font-weight: bold;
    line-height: 1.4;
    display: inline-block;
    line-height: 1.6;
    margin-bottom: 20px;
    opacity: 0;
    transition: all .8s .5s ease
}

@media screen and (min-width: 1100px) {
    .text-container__title__inner {
        font-size: 2.4rem;
        line-height: 1.4
    }
}

@media screen and (min-width: 1100px) {
    .text-container__title__inner {
        font-size: 2.4rem;
        line-height: 1.4
    }
}

.text-container__title__inner span {
    font-size: 1.4rem;
    line-height: 1.4;
    display: block;
    font-weight: bold
}

@media screen and (min-width: 1100px) {
    .text-container__title__inner span {
        font-size: 1.5rem;
        line-height: 1.6
    }
}

@media screen and (min-width: 1100px) {
    .text-container__title__inner span {
        font-size: 1.6rem;
        line-height: 1.6
    }
}

.text-container__text {
    left: -50px;
    opacity: 0;
    position: relative;
    transition: all .5s .5s ease
}

.img-container.active img,
.img-container2.active img,
.img-container3.active img {
    opacity: 1
}

.img-container.active:before,
.img-container2.active:before,
.img-container3.active:before {
    transform: translateX(101%)
}

.text-container.active .text-container__title:before {
    transform: translateX(101%)
}

.text-container.active .text-container__title__inner {
    opacity: 1
}

.text-container.active .text-container__text {
    left: 0;
    opacity: 1
}

.swiper-ec {
    padding: 64px 0 0
}

@media screen and (min-width: 1100px) {
    .swiper-ec {
        padding: 95px 0 0
    }
}

.swiper-ec .swiper-pagination-ec {
    margin-top: 22px;
    text-align: center;
    width: 100%
}

.swiper-ec .swiper-pagination-bullet {
    margin: 4px;
    width: 12px;
    height: 12px
}

.swiper-ec .swiper-button-next,
.swiper-ec .swiper-button-prev {
    display: none
}

@media screen and (min-width: 1100px) {

    .swiper-ec .swiper-button-next,
    .swiper-ec .swiper-button-prev {
        background-color: #000;
        color: #fff;
        display: block;
        padding-top: 17px;
        text-align: center;
        width: 60px;
        height: 60px
    }
}

.swiper-ec .swiper-button-next:after,
.swiper-ec .swiper-button-prev:after {
    font-size: 24px
}

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

.list-categories li {
    margin: 15px 0 30px;
    position: relative;
    width: 100%
}

@media screen and (min-width: 1100px) {
    .list-categories li {
        width: 32%
    }
}

.list-categories li .categories__thumb {
    border-radius: 6px;
    padding-bottom: 65%
}

.list-categories li .categories__ttl {
    font-weight: bold;
    margin-top: 10px;
    text-align: center
}

.list-categories li .categories__detail {
    font-size: 1.2rem;
    line-height: 1.5;
    color: #666
}

@media screen and (min-width: 1100px) {
    .list-categories li .categories__detail {
        font-size: 1.3rem;
        line-height: 1.5
    }
}

@media screen and (min-width: 1100px) {
    .list-categories li .categories__detail {
        font-size: 1.4rem;
        line-height: 1.6
    }
}

.list-categories li .ico-cate {
    margin: auto;
    position: absolute;
    top: -15px;
    left: 0;
    right: 0;
    width: 100px
}

.list-categories li:hover .ico-cate {
    opacity: 1
}

.section-ranking {
    padding-top: 20px
}

.wrap-ranking {
    background-color: #f7f5f0;
    padding: 40px 0;
    width: 100%
}

.ranking__heading {
    text-align: center;
    position: relative;
    z-index: 10
}

@media screen and (min-width: 1100px) {
    .ranking__heading {
        flex-basis: 280px
    }
}

.ranking__heading .ranking__heading-ttl {
    margin-bottom: 20px;
    position: relative
}

@media screen and (min-width: 1100px) {
    .ranking__heading .ranking__heading-ttl {
        margin-bottom: 0;
        top: 50%;
        transform: translateY(-50%)
    }
}

.ranking__heading .ranking__heading-ttl img {
    display: block;
    margin: 0 auto 20px;
    width: 80%
}

@media screen and (min-width: 1100px) {
    .ranking__heading .ranking__heading-ttl img {
        width: 100%
    }
}

.ranking__slider {
    position: relative;
    z-index: 0
}

.swiper-container {
    width: 100%
}

.list-ranking {
    align-items: center;
    display: flex;
    padding: 0 0 40px
}

@media screen and (min-width: 1100px) {
    .list-ranking {
        padding: 15px 0 80px
    }
}

.list-ranking li {
    background-color: #fff;
    border-radius: 6px;
    box-shadow: 0 0 15px rgba(0, 0, 0, .2);
    counter-increment: number;
    margin-left: 10px;
    width: 200px !important
}

@media screen and (min-width: 1100px) {
    .list-ranking li {
        margin-left: 10px;
        width: 255px !important
    }
}

.list-ranking li:after {
    background-image: url(./img/ico-rank.png?v=20240216135235);
    background-size: 24px;
    color: #fff;
    content: counter(number);
    font-family: "Bitter", "Shippori Mincho", 游明朝, "Yu Mincho", YuMincho, "Hiragino Mincho ProN", HGS明朝E, serif;
    font-size: 1.35rem;
    line-height: 1.8;
    position: absolute;
    top: 0;
    left: 12px;
    text-align: center;
    width: 24px;
    height: 24px
}

.list-ranking li:nth-child(1):after {
    background-image: url(./img/ico-rank-1.png?v=20240216135235);
    line-height: 1.6
}

.list-ranking li:nth-child(2):after {
    background-image: url(./img/ico-rank-2.png?v=20240216135235);
    line-height: 1.6
}

.list-ranking li:nth-child(3):after {
    background-image: url(./img/ico-rank-3.png?v=20240216135235);
    line-height: 1.6
}

.list-ranking li.list-ranking-last {
    width: 200px !important
}

.list-ranking li.list-ranking-last div {
    margin: auto;
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    text-align: center;
    width: 100px;
    height: 100px
}

.list-ranking li.list-ranking-last div a {
    display: block
}

.list-ranking li.list-ranking-last div a span {
    background-color: #fff;
    border-radius: 50%;
    display: block;
    font-size: 3rem;
    line-height: 2.1;
    margin: 0 auto 10px;
    width: 60px;
    height: 60px
}

.list-ranking li.list-ranking-last:after {
    content: none
}

.ranking__thumb {
    background-color: #ccc;
    border-radius: 6px 6px 0 0;
    overflow: hidden;
    padding-bottom: 100%;
    position: relative;
    width: 100%;
    height: 0
}

.ranking__thumb:hover img {
    opacity: 1;
    transform: translate(-50%, -50%) scale(1.1)
}

.ranking__thumb .ranking__thumb__photo {
    margin: auto;
    max-width: none;
    min-width: 100%;
    min-height: 100%;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%) scale(1);
    width: auto;
    height: 100%
}

.ranking__detail {
    padding: 20px
}

.ranking__detail__ttl {
    overflow: hidden;
    white-space: nowrap;
    text-overflow: ellipsis;
    display: block;
    display: block;
    font-weight: bold
}

.ranking__detail__price {
    font-size: 1.2rem;
    line-height: 1.5
}

@media screen and (min-width: 1100px) {
    .ranking__detail__price {
        font-size: 1.3rem;
        line-height: 1.5
    }
}

@media screen and (min-width: 1100px) {
    .ranking__detail__price {
        font-size: 1.4rem;
        line-height: 1.6
    }
}

.ranking__detail__time {
    font-size: 1.2rem;
    line-height: 1.5;
    display: block
}

@media screen and (min-width: 1100px) {
    .ranking__detail__time {
        font-size: 1.3rem;
        line-height: 1.5
    }
}

@media screen and (min-width: 1100px) {
    .ranking__detail__time {
        font-size: 1.4rem;
        line-height: 1.6
    }
}

.ranking__detail__cate {
    font-size: 1.2rem;
    line-height: 1.5;
    border: 1px solid #ddd;
    border-radius: 2px;
    display: inline-block;
    padding: 2px 4px
}

@media screen and (min-width: 1100px) {
    .ranking__detail__cate {
        font-size: 1.3rem;
        line-height: 1.5
    }
}

@media screen and (min-width: 1100px) {
    .ranking__detail__cate {
        font-size: 1.4rem;
        line-height: 1.6
    }
}

.ranking__detail__cate a {
    color: #888
}

.swiper-ranking .swiper-page-nav {
    text-align: center;
    width: 100%
}

@media screen and (min-width: 1100px) {
    .swiper-ranking .swiper-page-nav {
        margin: 0 auto;
        width: 1100px
    }
}

.swiper-ranking .swiper-page-nav .swiper-pagination,
.swiper-ranking .swiper-page-nav .swiper-button-prev,
.swiper-ranking .swiper-page-nav .swiper-button-next {
    display: inline-block;
    position: relative
}

.swiper-ranking .swiper-page-nav .swiper-button-prev:after,
.swiper-ranking .swiper-page-nav .swiper-button-next:after {
    font-size: 24px
}

.swiper-ranking .swiper-page-nav .swiper-button-prev {
    left: 0
}

.swiper-ranking .swiper-page-nav .swiper-button-next {
    right: 0
}

.swiper-ranking .swiper-page-nav .swiper-pagination-bullet {
    margin: 0 4px 5px
}

.section-recent {
    background: url(./img/bg-recent.png?v=20240216135235) no-repeat;
    background-position: right 35% top;
    overflow: hidden;
    width: 100%
}

@media screen and (min-width: 1100px) {
    .section-recent {
        background-position: right top
    }
}

.bg-top-construction {
    width: 800px;
    opacity: .5;
    pointer-events: none;
    position: absolute;
    top: 110px;
    right: -124px;
    z-index: 0
}

@media screen and (min-width: 1100px) {
    .bg-top-construction {
        top: -50px;
        right: -80px
    }
}

.wrap-recent {
    width: 100%
}

.recent-header {
    width: 100%
}

@media screen and (min-width: 1100px) {
    .recent-header-top {
        display: flex
    }
}

.recent-header-top__main {
    text-align: center
}

@media screen and (min-width: 1100px) {
    .recent-header-top__main {
        text-align: left;
        width: 24%
    }
}

.recent-header-top__sub {
    padding-top: 15px
}

@media screen and (min-width: 1100px) {
    .recent-header-top__sub {
        flex: 1;
        padding-top: 16px
    }
}

.recent__heading {
    text-align: center;
    position: relative;
    z-index: 10
}

@media screen and (min-width: 1100px) {
    .recent__heading {
        flex-basis: 280px
    }
}

.recent__heading .recent__heading-ttl {
    margin-bottom: 20px;
    position: relative
}

@media screen and (min-width: 1100px) {
    .recent__heading .recent__heading-ttl {
        margin-bottom: 0;
        top: 50%;
        transform: translateY(-50%)
    }
}

.recent__heading .recent__heading-ttl img {
    display: block;
    margin: 0 auto 20px;
    width: 80%
}

@media screen and (min-width: 1100px) {
    .recent__heading .recent__heading-ttl img {
        width: 100%
    }
}

.recent__slider {
    position: relative;
    width: 100%;
    z-index: 0
}

.recent__slider .swiper-container {
    overflow: visible;
    width: 100%
}

.list-recent {
    display: flex;
    padding: 0
}

@media screen and (min-width: 1100px) {
    .list-recent {
        padding: 15px 0
    }
}

.list-recent li {
    background-color: #fff;
    border-radius: 6px;
    box-shadow: 0 2px 15px rgba(0, 0, 0, .15);
    display: flex;
    flex-direction: column;
    padding-bottom: 10px;
    position: relative;
    width: 275px !important
}

@media screen and (min-width: 1100px) {
    .list-recent li {
        width: 330px !important
    }
}

.list-recent li.list-recent-last {
    width: 200px !important
}

.list-recent li.list-recent-last div {
    margin: auto;
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    text-align: center;
    width: 100px;
    height: 100px
}

.list-recent li.list-recent-last div a {
    display: block
}

.list-recent li.list-recent-last div a span {
    background-color: #fff;
    border-radius: 50%;
    display: block;
    font-size: 3rem;
    line-height: 2.1;
    margin: 0 auto 10px;
    width: 60px;
    height: 60px
}

.list-recent li.list-recent-last:after {
    content: none
}

.list-recent li:hover .recent__thumb img {
    opacity: 1;
    transform: scale(1.1)
}

.recent__thumb {
    border-radius: 6px 6px 0 0;
    overflow: hidden;
    position: relative;
    width: 100%
}

.recent__thumb:before {
    content: "";
    display: block;
    padding-top: 60%
}

.recent__thumb .recent__thumb__photo {
    -o-object-fit: cover;
    object-fit: cover;
    position: absolute;
    top: 0;
    width: 100%;
    height: 100%
}

.recent__detail {
    flex-grow: 1;
    padding: 20px;
    width: 100%
}

.recent__detail__ttl {
    overflow: hidden;
    white-space: nowrap;
    text-overflow: ellipsis;
    display: block;
    display: block;
    font-weight: bold
}

.recent__detail__price {
    font-size: 1.2rem;
    line-height: 1.5
}

@media screen and (min-width: 1100px) {
    .recent__detail__price {
        font-size: 1.3rem;
        line-height: 1.5
    }
}

@media screen and (min-width: 1100px) {
    .recent__detail__price {
        font-size: 1.4rem;
        line-height: 1.6
    }
}

.recent__detail__time {
    font-size: 1.2rem;
    line-height: 1.5;
    display: block
}

@media screen and (min-width: 1100px) {
    .recent__detail__time {
        font-size: 1.3rem;
        line-height: 1.5
    }
}

@media screen and (min-width: 1100px) {
    .recent__detail__time {
        font-size: 1.4rem;
        line-height: 1.6
    }
}

.recent__detail__content {
    font-size: 1.2rem;
    line-height: 1.5
}

@media screen and (min-width: 1100px) {
    .recent__detail__content {
        font-size: 1.3rem;
        line-height: 1.5
    }
}

@media screen and (min-width: 1100px) {
    .recent__detail__content {
        font-size: 1.4rem;
        line-height: 1.6
    }
}

.recent__detail__price {
    font-size: 1.2rem;
    line-height: 1.5;
    color: #777;
    display: block
}

@media screen and (min-width: 1100px) {
    .recent__detail__price {
        font-size: 1.3rem;
        line-height: 1.5
    }
}

@media screen and (min-width: 1100px) {
    .recent__detail__price {
        font-size: 1.4rem;
        line-height: 1.6
    }
}

.recent__detail__price span {
    color: #b12704
}

.swiper-recent {
    padding-top: 68px;
    position: relative
}

@media screen and (min-width: 1100px) {
    .swiper-recent {
        padding-top: 55px
    }
}

.swiper-recent .swiper-slide {
    height: auto
}

.swiper-recent .swiper-page-nav {
    position: absolute;
    top: 20px;
    left: 0
}

@media screen and (min-width: 1100px) {
    .swiper-recent .swiper-page-nav {
        top: 10px
    }
}

.swiper-recent .swiper-page-nav .swiper-pagination,
.swiper-recent .swiper-page-nav .swiper-button-prev,
.swiper-recent .swiper-page-nav .swiper-button-next {
    display: inline-block;
    position: relative
}

.swiper-recent .swiper-page-nav .swiper-button-prev,
.swiper-recent .swiper-page-nav .swiper-button-next {
    border: 1px solid #258fc8;
    border-radius: 50%;
    text-align: center;
    width: 44px;
    height: 44px
}

.swiper-recent .swiper-page-nav .swiper-button-prev:after,
.swiper-recent .swiper-page-nav .swiper-button-next:after {
    font-size: 18px;
    line-height: 2.3
}

.swiper-recent .swiper-page-nav .swiper-button-prev {
    left: 0;
    margin-right: 10px
}

.swiper-recent .swiper-page-nav .swiper-button-next {
    right: 0
}

.swiper-recent .swiper-page-nav .swiper-pagination-bullet {
    margin: 0 4px 5px
}

.list-tags {
    font-size: 1.1rem;
    line-height: 1.3;
    background-color: #f07700;
    border-radius: 3px;
    color: #fff;
    display: inline-block;
    margin: 5px 5px 0 0;
    padding: 2px 6px
}

@media screen and (min-width: 1100px) {
    .list-tags {
        font-size: 1.2rem;
        line-height: 1.4
    }
}

@media screen and (min-width: 1100px) {
    .list-tags {
        font-size: 1.3rem;
        line-height: 1.5
    }
}

.wrap-recent-ranking {
    margin-top: 45px;
    text-align: center
}

@media screen and (min-width: 1100px) {
    .wrap-recent-ranking .ranking__item {
        display: flex
    }
}

.wrap-recent-ranking .ranking__item .ranking__item-heading {
    margin: 0 auto 15px;
    width: 230px
}

@media screen and (min-width: 1100px) {
    .wrap-recent-ranking .ranking__item .ranking__item-heading {
        align-items: center;
        display: flex;
        margin: 0;
        text-align: left;
        width: 250px
    }
}

.wrap-recent-ranking .ranking__item .recent-ranking {
    counter-reset: number 0;
    display: flex;
    justify-content: space-between;
    margin: 0 auto;
    overflow-x: scroll;
    padding: 15px 0
}

@media screen and (min-width: 1100px) {
    .wrap-recent-ranking .ranking__item .recent-ranking {
        overflow: hidden;
        width: 850px
    }
}

.wrap-recent-ranking .ranking__item .recent-ranking li {
    margin-left: 10px;
    position: relative;
    width: 160px
}

@media screen and (min-width: 1100px) {
    .wrap-recent-ranking .ranking__item .recent-ranking li {
        margin: 0
    }
}

.wrap-recent-ranking .ranking__item .recent-ranking li:first-child {
    margin-left: 0
}

.wrap-recent-ranking .ranking__item .recent-ranking li:after {
    font-size: 1.2rem;
    line-height: 1.5;
    background-color: #333;
    color: #fff;
    counter-increment: number 1;
    content: counter(number);
    line-height: 1.8;
    position: absolute;
    top: 0;
    left: 0;
    text-align: center;
    width: 24px;
    height: 24px
}

@media screen and (min-width: 1100px) {
    .wrap-recent-ranking .ranking__item .recent-ranking li:after {
        font-size: 1.3rem;
        line-height: 1.5
    }
}

@media screen and (min-width: 1100px) {
    .wrap-recent-ranking .ranking__item .recent-ranking li:after {
        font-size: 1.4rem;
        line-height: 1.6
    }
}

.wrap-recent-ranking .ranking__item .recent-ranking li:nth-child(1):after {
    background-color: #f4a800
}

.wrap-recent-ranking .ranking__item .recent-ranking li:nth-child(2):after {
    background-color: #838383
}

.wrap-recent-ranking .ranking__item .recent-ranking li:nth-child(3):after {
    background-color: #af6300
}

.wrap-recent-ranking .ranking__item .recent-ranking li .ranking-thumb {
    margin-bottom: 10px;
    width: 160px;
    height: 160px
}

.wrap-recent-ranking .ranking__item .recent-ranking li .ranking-thumb .wpp-thumbnail {
    margin: 0
}

.wrap-recent-ranking .ranking__item .recent-ranking li .ranking-detail__ttl {
    overflow: hidden;
    white-space: nowrap;
    text-overflow: ellipsis;
    display: block
}

.wrap-recent-ranking .ranking__item .recent-ranking li .ranking-detail__sub {
    font-size: 1.2rem;
    line-height: 1.5;
    display: none
}

@media screen and (min-width: 1100px) {
    .wrap-recent-ranking .ranking__item .recent-ranking li .ranking-detail__sub {
        font-size: 1.3rem;
        line-height: 1.5
    }
}

@media screen and (min-width: 1100px) {
    .wrap-recent-ranking .ranking__item .recent-ranking li .ranking-detail__sub {
        font-size: 1.4rem;
        line-height: 1.6
    }
}

.home .wrap {
    padding-top: 0
}

#section-about {
    position: relative;
    width: 100%
}

.about-bg {
    margin: 0 auto;
    padding: 40px 0;
    position: relative
}

@media screen and (min-width: 1100px) {
    .about-bg {
        max-width: 1920px;
        padding: 100px 0
    }
}

.about-image {
    border-radius: 10px;
    height: 100%;
    margin: 35px auto 0;
    position: relative;
    right: 0;
    width: 80%;
    z-index: 2
}

@media screen and (min-width: 1100px) {
    .about-image {
        border-radius: 10px 0 0 10px;
        margin: 0 0 0 auto;
        position: absolute;
        top: 0;
        right: 0;
        width: 47%
    }
}

.about-image .about-image__pht {
    border-radius: 10px;
    margin: auto;
    max-width: auto;
    min-height: 65%;
    -o-object-fit: cover;
    object-fit: cover
}

@media screen and (min-width: 1100px) {
    .about-image .about-image__pht {
        border-radius: 10px 0 0 10px;
        position: absolute;
        top: 0;
        bottom: 0;
        width: auto
    }
}

.about-image-2 {
    margin: auto;
    position: absolute;
    top: 50%;
    right: 35%;
    transform: translateY(-330%);
    width: 25%;
    z-index: 10
}

@media screen and (min-width: 1100px) {
    .about-image-2 {
        top: 50%;
        right: 30%;
        bottom: auto;
        transform: translate(0, -250%);
        width: 30%
    }
}

.wrap-about {
    margin: 0 auto;
    position: relative;
    width: 96%;
    z-index: 2
}

@media screen and (min-width: 1100px) {
    .wrap-about {
        margin-left: calc((100% - 1100px)/2);
        width: calc(50% - (100% - 1100px)/2)
    }
}

.wrap-about-pht-1 {
    position: absolute;
    top: 1%;
    right: -20%;
    width: 49%;
    z-index: 0
}

@media screen and (min-width: 1100px) {
    .wrap-about-pht-1 {
        top: 10%;
        right: -20%;
        width: 47%
    }
}

.wrap-about-pht-1 img {
    width: 100%;
    height: auto
}

.wrap-about-pht-2 {
    position: absolute;
    bottom: 0;
    left: 0;
    transform: translateX(-15%);
    width: 37%;
    height: auto;
    z-index: 0
}

.wrap-about-pht-2 img {
    width: 100%;
    height: auto
}

.list-news .news-item {
    border-bottom: 1px solid #ddd;
    padding: 20px 0;
    position: relative
}

.list-news .news-item time {
    color: #777;
    display: inline-block
}

.list-news .news-item .tag {
    font-size: 1.1rem;
    line-height: 1.3;
    background-color: #0fbaed;
    border-radius: 4px;
    color: #fff;
    display: inline-block;
    margin: 0 20px 0 4px;
    min-width: 120px;
    padding: 2px 12px;
    text-align: center;
    vertical-align: text-bottom
}

@media screen and (min-width: 1100px) {
    .list-news .news-item .tag {
        font-size: 1.2rem;
        line-height: 1.4
    }
}

@media screen and (min-width: 1100px) {
    .list-news .news-item .tag {
        font-size: 1.3rem;
        line-height: 1.5
    }
}

@media screen and (min-width: 1100px) {
    .list-news .news-item .tag {
        vertical-align: text-top
    }
}

.list-news .news-item .news-item__ttl {
    font-weight: bold;
    display: block;
    margin-top: 5px
}

@media screen and (min-width: 1100px) {
    .list-news .news-item .news-item__ttl {
        display: inline-block;
        margin-top: 0
    }
}

.list-news .news-item a {
    text-decoration: none
}

.list-news .news-item:after {
    position: absolute;
    bottom: -1px;
    left: 0;
    content: "";
    width: 100%;
    height: 1px;
    background: #258fc8;
    transform: scale(0, 1);
    transform-origin: left top;
    transition: transform .3s
}

.list-news .news-item:hover:after {
    transform: scale(1, 1)
}

.cate-id-2 {
    background-color: #13ab30 !important
}

.section-mgr-msg {
    background-image: url(./img/bg-mgr-message.png?v=20240216135235);
    background-position: center right 124%;
    background-repeat: no-repeat;
    background-size: 98vh;
    padding: 4% 0
}

@media screen and (min-width: 1100px) {
    .section-mgr-msg {
        background-position: center right;
        background-size: 60vw
    }
}

.mgr-msg {
    margin: 0 auto
}

@media screen and (min-width: 1100px) {
    .mgr-msg {
        display: flex;
        flex-wrap: wrap;
        width: 70%
    }
}

.mgr-msg__thumb {
    margin: 0 auto 15px;
    width: 122px
}

@media screen and (min-width: 1100px) {
    .mgr-msg__thumb {
        margin: 0 50px 0 0
    }
}

.mgr-msg__detail {
    width: 100%
}

@media screen and (min-width: 1100px) {
    .mgr-msg__detail {
        flex: 1
    }
}

.wrap-access-map {
    margin-bottom: 15px
}

.wrap-access-map iframe {
    width: 100%;
    height: 350px
}

@media screen and (min-width: 1100px) {
    .wrap-access-map iframe {
        height: 500px
    }
}

.wrap-floor-guide {
    margin: 10px auto;
    text-align: center
}

@media screen and (min-width: 1100px) {
    .wrap-floor-guide {
        display: flex;
        justify-content: space-between
    }
}

.wrap-floor-guide div {
    margin: 0 auto 15px
}

.wrap-floor-guide div:nth-child(1) {
    width: 55%
}

@media screen and (min-width: 1100px) {
    .wrap-floor-guide div:nth-child(1) {
        width: 62%
    }
}

.wrap-floor-guide div:nth-child(2) {
    width: 55%
}

@media screen and (min-width: 1100px) {
    .wrap-floor-guide div:nth-child(2) {
        width: 35.25%
    }
}

.wrap-floor-guide a {
    margin: 0 auto;
    display: block;
    overflow: hidden
}

.wrap-floor-guide a img {
    transform: scale(1);
    transition: transform .3s;
    width: 100%
}

.wrap-floor-guide a:hover img {
    transform: scale(1.1)
}

.wrap-map {
    position: relative
}

.wrap-map iframe {
    width: 100%;
    height: 430px
}

@media screen and (min-width: 1100px) {
    .wrap-map iframe {
        height: 500px
    }
}

#map {
    width: 100%;
    height: 430px
}

.map-info {
    background-color: #000;
    border-radius: 50%;
    box-sizing: border-box;
    color: #fff;
    margin: auto;
    opacity: .9;
    padding-top: 7px;
    position: absolute;
    top: 0;
    right: 195px;
    bottom: -200px;
    left: 0;
    text-align: center;
    width: 170px;
    height: 170px
}

.map-info img {
    padding-bottom: 5px
}

.col__2 iframe {
    margin: 10px auto;
    width: 100%;
    height: 430px
}

@media screen and (min-width: 1100px) {
    .col__2 iframe {
        height: 500px
    }
}

.wrap-recommended-line {
    margin: 0 auto;
    width: 100%
}

@media screen and (min-width: 1100px) {
    .wrap-recommended-line {
        display: flex;
        justify-content: space-between;
        width: 64%
    }
}

.wrap-recommended-line__thumb {
    margin: 0 auto;
    width: 50%
}

@media screen and (min-width: 1100px) {
    .wrap-recommended-line__thumb {
        width: 30%
    }
}

.wrap-recommended-line__detail {
    margin: 15px auto;
    width: 96%
}

@media screen and (min-width: 1100px) {
    .wrap-recommended-line__detail {
        margin: 0;
        width: 60%
    }
}

.recommended-line__detail-list li {
    font-size: 1.8rem;
    font-weight: bold;
    line-height: 1.4;
    border-bottom: 1px dotted #666;
    font-weight: normal;
    margin-bottom: 10px
}

@media screen and (min-width: 1100px) {
    .recommended-line__detail-list li {
        font-size: 2.4rem;
        line-height: 1.4
    }
}

@media screen and (min-width: 1100px) {
    .recommended-line__detail-list li {
        font-size: 2.4rem;
        line-height: 1.4
    }
}

@media screen and (min-width: 1100px) {
    .recommended-line__detail-list li {
        font-size: 1.8rem;
        font-weight: bold;
        line-height: 1.4;
        margin-bottom: 15px
    }
}

@media screen and (min-width: 1100px)and (min-width: 1100px) {
    .recommended-line__detail-list li {
        font-size: 2.4rem;
        line-height: 1.4
    }
}

@media screen and (min-width: 1100px)and (min-width: 1100px) {
    .recommended-line__detail-list li {
        font-size: 2.4rem;
        line-height: 1.4
    }
}

.recommended-line__detail-list li span {
    color: #eb173f;
    font-weight: bold
}

.wrap-line-step .line-step__item {
    margin: 0 auto;
    width: 100%
}

@media screen and (min-width: 1100px) {
    .wrap-line-step .line-step__item {
        width: 70%
    }
}

.wrap-line-step .line-step__item:after {
    display: inline-block;
    font-family: "Material Icons";
    font-weight: normal;
    font-style: normal;
    font-size: 24px;
    line-height: 1;
    text-transform: none;
    letter-spacing: normal;
    word-wrap: normal;
    white-space: nowrap;
    direction: ltr;
    -webkit-font-smoothing: antialiased;
    text-rendering: optimizeLegibility;
    -moz-osx-font-smoothing: grayscale;
    font-feature-settings: "liga";
    content: "";
    display: block;
    font-size: 3rem;
    margin: 20px auto;
    text-align: center
}

.wrap-line-step .line-step__item:last-child:after {
    content: none
}

.wrap-line-step .line-step__item .step__item-wrap {
    display: flex;
    width: 100%
}

.wrap-line-step .line-step__item .step__item-wrap .step__item-detail {
    flex: 1;
    padding-right: 15px
}

.wrap-line-step .line-step__item .step__item-wrap .step__item-detail .step__item-num {
    font-size: 1.2rem;
    line-height: 1.5;
    background-color: #00b900;
    border-radius: 50%;
    color: #fff;
    margin-bottom: 10px;
    padding: 15px 10px;
    text-align: center;
    width: 80px;
    height: 80px
}

@media screen and (min-width: 1100px) {
    .wrap-line-step .line-step__item .step__item-wrap .step__item-detail .step__item-num {
        font-size: 1.3rem;
        line-height: 1.5
    }
}

@media screen and (min-width: 1100px) {
    .wrap-line-step .line-step__item .step__item-wrap .step__item-detail .step__item-num {
        font-size: 1.4rem;
        line-height: 1.6
    }
}

@media screen and (min-width: 1100px) {
    .wrap-line-step .line-step__item .step__item-wrap .step__item-detail .step__item-num {
        padding: 10px
    }
}

.wrap-line-step .line-step__item .step__item-wrap .step__item-detail .step__item-num span {
    font-size: 1.8rem;
    font-weight: bold;
    line-height: 1.4;
    display: block
}

@media screen and (min-width: 1100px) {
    .wrap-line-step .line-step__item .step__item-wrap .step__item-detail .step__item-num span {
        font-size: 2.4rem;
        line-height: 1.4
    }
}

@media screen and (min-width: 1100px) {
    .wrap-line-step .line-step__item .step__item-wrap .step__item-detail .step__item-num span {
        font-size: 2.4rem;
        line-height: 1.4
    }
}

.wrap-line-step .line-step__item .step__item-wrap .step__item-detail .step__item-ttl {
    font-size: 1.8rem;
    font-weight: bold;
    line-height: 1.4;
    margin-bottom: 10px
}

@media screen and (min-width: 1100px) {
    .wrap-line-step .line-step__item .step__item-wrap .step__item-detail .step__item-ttl {
        font-size: 2.4rem;
        line-height: 1.4
    }
}

@media screen and (min-width: 1100px) {
    .wrap-line-step .line-step__item .step__item-wrap .step__item-detail .step__item-ttl {
        font-size: 2.4rem;
        line-height: 1.4
    }
}

.wrap-line-step .line-step__item .step__item-wrap .step__item-detail .btn-line a {
    width: 100%
}

.wrap-line-step .line-step__item .step__item-wrap .step__item-thumb {
    text-align: center;
    width: 25%
}

@media screen and (min-width: 1100px) {
    .wrap-line-step .line-step__item .step__item-wrap .step__item-thumb {
        width: 40%
    }
}

.wrap-line-step .line-step__item .step__item-wrap .step__item-thumb img {
    max-height: 400px;
    width: auto
}

.line-other-service {
    background-image: url(./img/bg-rule-line.png?v=20240216135235);
    background-repeat: repeat;
    margin: 10px 0 0 0;
    padding: 30px 20px;
    position: relative;
    width: 100%
}

@media screen and (min-width: 1100px) {
    .line-other-service {
        margin: 20px auto;
        padding: 50px 20px
    }
}

.line-other-service .inner {
    position: relative
}

.other-service__ttl {
    font-size: 2.4rem;
    font-weight: bold;
    line-height: 1.4;
    margin-bottom: 20px
}

@media screen and (min-width: 1100px) {
    .other-service__ttl {
        font-size: 3.5rem
    }
}

@media screen and (min-width: 1100px) {
    .other-service__ttl {
        font-size: 3.5rem
    }
}

.other-service__item {
    font-size: 1.6rem;
    line-height: 1.5;
    font-weight: normal;
    margin-top: 6px
}

@media screen and (min-width: 1100px) {
    .other-service__item {
        font-size: 1.8rem;
        line-height: 1.6
    }
}

@media screen and (min-width: 1100px) {
    .other-service__item {
        font-size: 1.8rem;
        line-height: 1.6
    }
}

.other-service__item span {
    color: #0e6fb8;
    font-weight: bold
}

.other-service__item:before {
    background-image: url(./img/check.png?v=20240216135235);
    background-repeat: no-repeat;
    background-size: 24px;
    content: "";
    display: inline-block;
    margin-right: 5px;
    width: 24px;
    height: 24px;
    vertical-align: text-bottom
}

.other-service__image {
    display: block;
    margin: 15px auto;
    width: 70%
}

@media screen and (min-width: 1100px) {
    .other-service__image {
        margin: 0;
        position: absolute;
        top: 0;
        right: 60px;
        width: 300px
    }
}

.other-service__image-2 {
    display: block;
    margin: 15px auto;
    width: 30%
}

@media screen and (min-width: 1100px) {
    .other-service__image-2 {
        margin: 0;
        position: absolute;
        bottom: 0;
        right: 60px;
        width: 300px
    }
}

.section-line {
    background-color: #c1d2e2;
    margin: 20px auto;
    padding: 20px 0
}

.section-line .inner {
    position: relative
}

.wrap-line-msg {
    margin: 0 auto;
    width: 100%
}

@media screen and (min-width: 1100px) {
    .wrap-line-msg {
        width: 70%
    }
}

.line-msg {
    display: flex;
    margin: 1.5em 0;
    overflow: hidden;
    width: 100%
}

.line-msg__thumb {
    margin: 0 10px;
    width: 44px
}

@media screen and (min-width: 1100px) {
    .line-msg__thumb {
        width: 120px
    }
}

.line-msg__ballon-wrap {
    flex: 1;
    padding: 10px
}

.line-msg__ballon {
    background: #fff;
    border-radius: 12px;
    display: inline-block;
    max-width: 92%;
    padding: 17px 13px;
    position: relative
}

@media screen and (min-width: 1100px) {
    .line-msg__ballon {
        max-width: 80%
    }
}

.line-msg__ballon:after {
    border: 12px solid rgba(0, 0, 0, 0);
    border-right: 12px solid #fff;
    content: "";
    display: inline-block;
    position: absolute;
    top: 18px;
    left: -24px
}

.line-msg__ballon p {
    text-align: left
}

.line-msg--me .line-msg__thumb {
    order: 2
}

.line-msg--me .line-msg__ballon-wrap {
    text-align: right
}

.line-msg--me .line-msg__ballon {
    background: #8ee388
}

.line-msg--me .line-msg__ballon:after {
    border-right: rgba(0, 0, 0, 0);
    border-left: 12px solid #8ee388;
    right: -12px;
    left: auto
}

@media screen and (min-width: 1100px) {
    .section-compatible-area .wrap-compatible-area {
        display: flex;
        justify-content: space-between
    }
}

.section-compatible-area .wrap-compatible-area .compatible-area__map {
    margin: 0 auto;
    text-align: center;
    width: 48%
}

.section-compatible-area .wrap-compatible-area .compatible-area__item {
    width: 100%
}

@media screen and (min-width: 1100px) {
    .section-compatible-area .wrap-compatible-area .compatible-area__item {
        width: 50%
    }
}

.section-compatible-area .wrap-compatible-area .compatible-area__item-wrap {
    display: flex;
    justify-content: space-between
}

.section-compatible-area .wrap-compatible-area .compatible-area__item-list {
    width: 30%
}

.section-compatible-area .wrap-compatible-area h2 {
    font-size: 2.4rem;
    font-weight: bold;
    line-height: 1.4;
    color: #ed6d00;
    margin: 15px auto;
    text-align: center
}

@media screen and (min-width: 1100px) {
    .section-compatible-area .wrap-compatible-area h2 {
        font-size: 3.5rem
    }
}

@media screen and (min-width: 1100px) {
    .section-compatible-area .wrap-compatible-area h2 {
        font-size: 3.5rem
    }
}

.section-compatible-area .wrap-compatible-area h3 {
    font-size: 1.6rem;
    line-height: 1.5;
    font-weight: bold;
    margin-bottom: 15px
}

@media screen and (min-width: 1100px) {
    .section-compatible-area .wrap-compatible-area h3 {
        font-size: 1.8rem;
        line-height: 1.6
    }
}

@media screen and (min-width: 1100px) {
    .section-compatible-area .wrap-compatible-area h3 {
        font-size: 1.8rem;
        line-height: 1.6
    }
}

.btn-line a {
    transition: all .3s ease;
    background-color: #00b900;
    border-radius: 6px;
    color: #fff;
    display: block;
    margin: 0 auto;
    padding: 10px;
    text-align: center;
    text-decoration: none;
    width: 70%
}

@media screen and (min-width: 1100px) {
    .btn-line a {
        width: 300px
    }
}

.btn-line a img {
    display: inline-block;
    margin-right: 6px;
    vertical-align: middle;
    width: 44px;
    height: 44px
}

.btn-line a:hover {
    background-color: rgba(0, 185, 0, .8);
    text-decoration: none
}

.wrap-cta {
    background-color: #d1d1d1;
    background-image: url(./img/bg-cta-2-sp.png.webp?v=20240216135235);
    background-repeat: no-repeat;
    background-size: cover;
    background-position: center;
    padding: 50px 0;
    position: relative;
    transform: translate3d(0, 0, 0)
}

@media screen and (min-width: 1100px) {
    .wrap-cta {
        background-image: url(./img/bg-cta-2.png.webp?v=20240216135235);
        padding: 80px 0
    }
}

.cta-box {
    align-items: center;
    background: none;
    width: 100%
}

@media screen and (min-width: 1100px) {
    .cta-box {
        display: flex;
        justify-content: space-between
    }
}

.cta-box__item {
    align-items: center;
    background-color: #fff;
    border-radius: 6px;
    box-shadow: 0 0 5px rgba(0, 0, 0, .1);
    color: #333;
    display: flex;
    flex-wrap: wrap;
    margin-bottom: 10px;
    padding: 15px;
    text-align: left;
    width: 100%
}

@media screen and (min-width: 1100px) {
    .cta-box__item {
        display: block;
        margin-bottom: 0;
        padding: 25px;
        text-align: center;
        width: 32%
    }
}

.cta-box__item:hover .cta-box__item-action a {
    background-color: #ef6b0a;
    color: #fff;
    text-decoration: none
}

.cta-box__item:hover .cta-box__item-icon p {
    border-color: #555
}

.cta-box__item-icon p {
    transition: all .3s ease;
    border: 1.5px solid #bbb;
    border-radius: 50%;
    display: inline-block;
    margin: 0 10px 0 0;
    padding: 10px;
    width: 50px;
    height: 50px
}

@media screen and (min-width: 1100px) {
    .cta-box__item-icon p {
        margin: 0 0 10px 0
    }
}

.cta-box__item-icon img {
    opacity: .3;
    vertical-align: top
}

.cta-box__item-content {
    flex: 1
}

.cta-box__item-ttl {
    font-size: 1.8rem;
    font-weight: bold;
    margin: 0;
    width: 100%
}

@media screen and (min-width: 1100px) {
    .cta-box__item-ttl {
        font-size: 2rem;
        margin: 10px 0
    }
}

.cta-box__item-des {
    color: #666
}

.cta-box__item-action {
    text-align: right
}

@media screen and (min-width: 1100px) {
    .cta-box__item-action {
        margin: 15px auto 0;
        text-align: center;
        width: 100%
    }
}

.cta-box__item-action:after {
    display: inline-block;
    font-family: "Material Icons";
    font-weight: normal;
    font-style: normal;
    font-size: 24px;
    line-height: 1;
    text-transform: none;
    letter-spacing: normal;
    word-wrap: normal;
    white-space: nowrap;
    direction: ltr;
    -webkit-font-smoothing: antialiased;
    text-rendering: optimizeLegibility;
    -moz-osx-font-smoothing: grayscale;
    font-feature-settings: "liga";
    content: "arrow_forward";
    color: #258fc8;
    display: block;
    text-align: right;
    width: 44px
}

@media screen and (min-width: 1100px) {
    .cta-box__item-action:after {
        content: none
    }
}

.cta-box__item-action a {
    transition: all .3s ease;
    background-color: #0e6fb8;
    border-radius: 50px;
    box-shadow: 0 4px 0 rgba(170, 170, 170, .6);
    color: #fff;
    display: none;
    font-weight: bold;
    margin: 15px auto 0;
    padding: 15px 40px;
    text-align: center;
    text-decoration: none;
    width: 80%
}

@media screen and (min-width: 1100px) {
    .cta-box__item-action a {
        display: block;
        width: 80%
    }
}

.cta-box__item-action a span {
    font-size: 1.1rem;
    line-height: 1.3;
    font-weight: normal;
    display: block
}

@media screen and (min-width: 1100px) {
    .cta-box__item-action a span {
        font-size: 1.2rem;
        line-height: 1.4
    }
}

@media screen and (min-width: 1100px) {
    .cta-box__item-action a span {
        font-size: 1.3rem;
        line-height: 1.5
    }
}

.cta-box__item-action a:hover {
    background-color: #ef6b0a;
    color: #fff;
    text-decoration: none
}

.cta {
    margin: 0 auto
}

@media screen and (min-width: 1100px) {
    .cta {
        display: flex;
        flex-wrap: wrap;
        width: 700px
    }
}

.cta .cta__sub {
    margin: 0 auto;
    width: 40%
}

.cta .cta__main {
    width: 100%
}

@media screen and (min-width: 1100px) {
    .cta .cta__main {
        width: 60%
    }
}

.cta .cta_half {
    width: 100%
}

@media screen and (min-width: 1100px) {
    .cta .cta_half {
        margin: 0 auto;
        width: 48%
    }
}

.cta .cta-btn {
    font-size: 1.6rem;
    line-height: 1.5;
    transition: all .3s ease;
    background-color: #0e6fb8;
    border-radius: 50px;
    box-shadow: 0 4px 0 rgba(170, 170, 170, .6);
    color: #fff;
    display: block;
    font-weight: bold;
    margin: 15px auto 0;
    padding: 15px 40px;
    text-align: center;
    text-decoration: none;
    width: 80%
}

@media screen and (min-width: 1100px) {
    .cta .cta-btn {
        font-size: 1.8rem;
        line-height: 1.6
    }
}

@media screen and (min-width: 1100px) {
    .cta .cta-btn {
        font-size: 1.8rem;
        line-height: 1.6
    }
}

@media screen and (min-width: 1100px) {
    .cta .cta-btn {
        width: 100%
    }
}

.cta .cta-btn span {
    font-size: 1.1rem;
    line-height: 1.3;
    font-weight: normal;
    display: block
}

@media screen and (min-width: 1100px) {
    .cta .cta-btn span {
        font-size: 1.2rem;
        line-height: 1.4
    }
}

@media screen and (min-width: 1100px) {
    .cta .cta-btn span {
        font-size: 1.3rem;
        line-height: 1.5
    }
}

.cta .cta-btn:hover {
    background-color: #ef6b0a;
    color: #fff
}

.cta-ttl {
    color: #fff;
    margin: 0 auto 20px;
    line-height: 2.4;
    text-align: center
}

.cta-ttl .text-wrap {
    background-color: #fff;
    padding: 4px
}

.cta-ttl a {
    color: #fff;
    text-decoration: none
}

.fixed-footer {
    background-color: #ffa50f;
    padding: 15px 10px;
    position: fixed;
    bottom: 0;
    left: 0;
    width: 100%;
    z-index: 100
}

@media screen and (min-width: 1100px) {
    .fixed-footer {
        padding: 20px
    }
}

.fixed-footer .fixed-footer__inner {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    margin: 0 auto;
    position: relative;
    width: 100%
}

@media screen and (min-width: 1100px) {
    .fixed-footer .fixed-footer__inner {
        width: 1100px
    }
}

.fixed-footer .fixed-footer__inner .fixed-footer__inner-btn-content {
    align-items: center;
    display: flex
}

.fixed-footer .fixed-footer__inner .fixed-footer__inner-txt {
    font-size: 1.8rem;
    font-weight: bold;
    line-height: 1.4;
    line-height: 1.1 !important;
    width: 100%
}

@media screen and (min-width: 1100px) {
    .fixed-footer .fixed-footer__inner .fixed-footer__inner-txt {
        font-size: 2.4rem;
        line-height: 1.4
    }
}

@media screen and (min-width: 1100px) {
    .fixed-footer .fixed-footer__inner .fixed-footer__inner-txt {
        font-size: 2.4rem;
        line-height: 1.4
    }
}

@media screen and (min-width: 1100px) {
    .fixed-footer .fixed-footer__inner .fixed-footer__inner-txt {
        flex: 1;
        line-height: 1.4 !important;
        padding-left: 150px;
        text-align: left;
        width: auto
    }
}

.fixed-footer .fixed-footer__inner .fixed-footer__inner-txt div {
    text-align: center;
    width: 100%
}

@media screen and (min-width: 1100px) {
    .fixed-footer .fixed-footer__inner .fixed-footer__inner-txt div {
        text-align: left
    }
}

.fixed-footer .fixed-footer__inner .fixed-footer__inner-btn {
    transition: all .3s ease;
    background-color: #fff;
    border-radius: 6px;
    margin: 10px 0 0 0;
    padding: 8px 2px;
    width: 28%
}

@media screen and (min-width: 1100px) {
    .fixed-footer .fixed-footer__inner .fixed-footer__inner-btn {
        box-shadow: 0 0 2px rgba(0, 0, 0, .2);
        margin: 0 0 0 15px;
        padding: 10px 12px;
        width: 19%
    }
}

.fixed-footer .fixed-footer__inner .fixed-footer__inner-btn:hover {
    box-shadow: 0 0 8px rgba(0, 0, 0, .4)
}

.fixed-footer .fixed-footer__inner .fixed-footer__inner-btn a {
    color: #000;
    text-align: center;
    text-decoration: none;
    width: 100%
}

.fixed-footer .fixed-footer__inner .fixed-footer__inner-btn .fixed-footer__inner-btn-ttl {
    font-size: 1.2rem;
    line-height: 1.5;
    font-weight: bold
}

@media screen and (min-width: 1100px) {
    .fixed-footer .fixed-footer__inner .fixed-footer__inner-btn .fixed-footer__inner-btn-ttl {
        font-size: 1.3rem;
        line-height: 1.5
    }
}

@media screen and (min-width: 1100px) {
    .fixed-footer .fixed-footer__inner .fixed-footer__inner-btn .fixed-footer__inner-btn-ttl {
        font-size: 1.4rem;
        line-height: 1.6
    }
}

@media screen and (min-width: 1100px) {
    .fixed-footer .fixed-footer__inner .fixed-footer__inner-btn .fixed-footer__inner-btn-ttl {
        font-size: 1.6rem;
        line-height: 1.5
    }
}

@media screen and (min-width: 1100px)and (min-width: 1100px) {
    .fixed-footer .fixed-footer__inner .fixed-footer__inner-btn .fixed-footer__inner-btn-ttl {
        font-size: 1.8rem;
        line-height: 1.6
    }
}

@media screen and (min-width: 1100px)and (min-width: 1100px) {
    .fixed-footer .fixed-footer__inner .fixed-footer__inner-btn .fixed-footer__inner-btn-ttl {
        font-size: 1.8rem;
        line-height: 1.6
    }
}

.fixed-footer .fixed-footer__inner .fixed-footer__inner-btn .fixed-footer__inner-btn-ttl img {
    display: block;
    height: 22px;
    margin: 0 auto;
    vertical-align: top
}

@media screen and (min-width: 1100px) {
    .fixed-footer .fixed-footer__inner .fixed-footer__inner-btn .fixed-footer__inner-btn-ttl img {
        display: inline-block;
        height: 28px;
        margin: 0 4px 0 0
    }
}

.fixed-footer .fixed-footer__inner .fixed-footer__inner-btn-sub {
    font-size: 1.2rem;
    line-height: 1.5;
    display: none
}

@media screen and (min-width: 1100px) {
    .fixed-footer .fixed-footer__inner .fixed-footer__inner-btn-sub {
        font-size: 1.3rem;
        line-height: 1.5
    }
}

@media screen and (min-width: 1100px) {
    .fixed-footer .fixed-footer__inner .fixed-footer__inner-btn-sub {
        font-size: 1.4rem;
        line-height: 1.6
    }
}

@media screen and (min-width: 1100px) {
    .fixed-footer .fixed-footer__inner .fixed-footer__inner-btn-sub {
        display: block
    }
}

.fixed-footer .fixed-footer__inner .ico-a-contact {
    position: absolute;
    left: -26px;
    bottom: -15px;
    width: 28%
}

@media screen and (min-width: 600px) {
    .fixed-footer .fixed-footer__inner .ico-a-contact {
        width: 20%
    }
}

@media screen and (min-width: 1100px) {
    .fixed-footer .fixed-footer__inner .ico-a-contact {
        left: 0;
        bottom: -23px;
        width: 150px
    }
}

.fixed-footer .fixed-footer__inner .ico-a-contact img {
    animation: aniarita 2s linear infinite
}

.fixed-footer .fixed-footer__inner .fixed-footer__inner-btn-line {
    background-color: #00b900
}

.fixed-footer .fixed-footer__inner .fixed-footer__inner-btn-line a {
    color: #fff
}

.fixed-footer .fixed-footer__inner .sp-only {
    background: none;
    width: 13%
}

@keyframes aniarita {

    0%,
    100% {
        transform: rotate(3deg)
    }

    50% {
        transform: rotate(-3deg)
    }
}

.footer {
    color: #fff;
    margin: 0 auto
}

.site-footer {
    background-color: #0b2866;
    background-size: cover;
    padding: 60px 0 160px;
    position: relative;
    z-index: 0
}

@media screen and (min-width: 1100px) {
    .site-footer {
        padding: 80px 0 150px
    }
}

.footer-inner {
    box-sizing: border-box;
    padding: 0 2%;
    width: 100%
}

@media screen and (min-width: 1100px) {
    .footer-inner {
        margin: 0 auto;
        padding: 0;
        width: 1100px
    }
}

.footer-inner a {
    color: #d1d1d1;
    transition: .1s ease-in-out
}

@media screen and (min-width: 1100px) {
    .footer-inner a:hover {
        color: #eee
    }
}

.footer-col {
    border-right: 0;
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    width: 100%
}

.footer-col__ttl {
    font-weight: bold;
    margin-bottom: 10px;
    text-align: center
}

@media screen and (min-width: 1100px) {
    .footer-col__ttl {
        text-align: left
    }
}

.footer-col__shop {
    font-size: 1.2rem;
    line-height: 1.5;
    line-height: 2 !important;
    order: 3;
    text-align: center;
    width: 100%
}

@media screen and (min-width: 1100px) {
    .footer-col__shop {
        font-size: 1.3rem;
        line-height: 1.5
    }
}

@media screen and (min-width: 1100px) {
    .footer-col__shop {
        font-size: 1.4rem;
        line-height: 1.6
    }
}

@media screen and (min-width: 1100px) {
    .footer-col__shop {
        order: 1;
        padding-right: 25px;
        text-align: left;
        width: 35%
    }
}

.footer-col__shop a {
    display: inline-block;
    position: relative;
    text-decoration: none
}

.footer-col__shop a:after {
    position: absolute;
    bottom: 0px;
    left: 0;
    content: "";
    width: 100%;
    height: 1px;
    background: #fff;
    transform: scale(0, 1);
    transform-origin: right top;
    transition: transform .3s
}

.footer-col__shop a:hover:after {
    transform-origin: left top;
    transform: scale(1, 1)
}

@media screen and (min-width: 1100px) {
    .footer-col__shop .footer-col__shop-info {
        margin-top: 20px
    }
}

.footer-col__nav {
    border-left: 0;
    margin: 0 auto 20px;
    padding: 0 20px;
    width: 100%
}

@media screen and (min-width: 1100px) {
    .footer-col__nav {
        border-left: 1px solid rgba(255, 255, 255, .2);
        flex: 1;
        margin-bottom: 0;
        order: 2;
        padding: 6px 0 0 25px;
        width: 100%
    }
}

.footer-col__nav ul {
    font-size: 1.2rem;
    line-height: 1.5;
    text-align: center
}

@media screen and (min-width: 1100px) {
    .footer-col__nav ul {
        font-size: 1.3rem;
        line-height: 1.5
    }
}

@media screen and (min-width: 1100px) {
    .footer-col__nav ul {
        font-size: 1.4rem;
        line-height: 1.6
    }
}

@media screen and (min-width: 1100px) {
    .footer-col__nav ul {
        text-align: left
    }
}

.footer-col__nav ul li {
    display: inline-block;
    padding-right: 12px
}

.footer-col__nav ul li a {
    display: inline-block;
    padding: 2px;
    position: relative;
    text-decoration: none
}

.footer-col__nav ul li a:after {
    position: absolute;
    bottom: 0px;
    left: 0;
    content: "";
    width: 100%;
    height: 1px;
    background: #fff;
    transform: scale(0, 1);
    transform-origin: right top;
    transition: transform .3s
}

.footer-col__nav ul li a:hover:after {
    transform-origin: left top;
    transform: scale(1, 1)
}

#logo-svg-h {
    fill: #000;
    width: 70%
}

@media screen and (min-width: 1100px) {
    #logo-svg-h {
        width: 240px
    }
}

#logo-svg-h .logo-svg__circle {
    stroke: #000
}

#logo-svg-h .logo-svg__wave {
    fill: #1292c3
}

.logo-footer {
    font-size: 1.8rem;
    font-weight: bold
}

.logo-footer #logo-svg-h {
    fill: #fff;
    width: 70%
}

@media screen and (min-width: 1100px) {
    .logo-footer #logo-svg-h {
        width: 240px
    }
}

.logo-footer #logo-svg-h .logo-svg__circle {
    stroke: #fff
}

.logo-footer #logo-svg-h .logo-svg__wave {
    fill: #1292c3
}

.authorization {
    font-size: 1.1rem;
    line-height: 1.3;
    border: 1px solid rgba(255, 255, 255, .2);
    border-width: 1px 0;
    line-height: 1.8;
    margin: 20px auto;
    padding: 20px 0;
    text-align: center
}

@media screen and (min-width: 1100px) {
    .authorization {
        font-size: 1.2rem;
        line-height: 1.4
    }
}

@media screen and (min-width: 1100px) {
    .authorization {
        font-size: 1.3rem;
        line-height: 1.5
    }
}

@media screen and (min-width: 1100px) {
    .authorization {
        margin: 40px auto
    }
}

.authorization ul {
    margin-top: 5px
}

.authorization ul li {
    display: inline-block
}

.wrap-footer-auth {
    border: 1px solid rgba(255, 255, 255, .2);
    border-width: 1px 0 0 0;
    margin: 20px auto;
    padding-top: 20px;
    width: 100%
}

@media screen and (min-width: 1100px) {
    .wrap-footer-auth {
        display: flex;
        justify-content: space-between;
        margin: 30px auto;
        padding-top: 30px
    }
}

.footer-auth {
    order: 1;
    text-align: center
}

@media screen and (min-width: 1100px) {
    .footer-auth {
        order: 2;
        text-align: right
    }
}

.footer-auth a {
    display: inline-block;
    padding: 2px
}

.footer-auth a img {
    height: 26px;
    filter: grayscale(100);
    transition: .2s ease-in-out
}

@media screen and (min-width: 1100px) {
    .footer-auth a img {
        height: 32px
    }
}

@media screen and (min-width: 1100px) {
    .footer-auth a:hover img {
        filter: grayscale(0)
    }
}

.copyright {
    font-size: 1.2rem;
    line-height: 1.5;
    margin-top: 15px;
    order: 2;
    text-align: center
}

@media screen and (min-width: 1100px) {
    .copyright {
        font-size: 1.3rem;
        line-height: 1.5
    }
}

@media screen and (min-width: 1100px) {
    .copyright {
        font-size: 1.4rem;
        line-height: 1.6
    }
}

@media screen and (min-width: 1100px) {
    .copyright {
        margin-top: 0;
        order: 1;
        text-align: left
    }
}

#js-page-top a {
    background: none;
    color: #ababab;
    font-size: 1rem;
    position: relative;
    writing-mode: vertical-lr;
    width: 28px;
    height: 96px
}

#js-page-top a:before {
    position: absolute;
    left: 0;
    top: 0;
    content: "";
    width: 1px;
    height: 100%;
    background: rgba(170, 170, 170, .3);
    transform: scale(1, 1);
    transform-origin: right bottom;
    z-index: 1
}

#js-page-top a:after {
    position: absolute;
    left: 0;
    top: 0;
    content: "";
    width: 1px;
    height: 100%;
    background: #999;
    transform: scale(1, 0);
    transform-origin: left top;
    transition: transform .6s
}

#js-page-top a:hover:after {
    background: rgba(170, 170, 170, .9);
    transform-origin: right bottom;
    transform: scale(1, 1)
}

#js-page-top a span {
    display: block;
    text-align: center;
    padding: 4px;
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%
}

#js-page-top a span:before {
    display: inline-block;
    font-family: "Material Icons";
    font-weight: normal;
    font-style: normal;
    font-size: 24px;
    line-height: 1;
    text-transform: none;
    letter-spacing: normal;
    word-wrap: normal;
    white-space: nowrap;
    direction: ltr;
    -webkit-font-smoothing: antialiased;
    text-rendering: optimizeLegibility;
    -moz-osx-font-smoothing: grayscale;
    font-feature-settings: "liga";
    color: #aaa;
    content: "arrow_drop_up";
    display: inline-block;
    position: absolute;
    left: -11px;
    top: 0;
    transform: rotate(-90deg);
    width: 13px;
    height: 14px;
    z-index: 2
}

.wrap-page {
    padding-top: 60px
}

@media screen and (min-width: 1100px) {
    .wrap-page {
        padding-top: 55px
    }
}

.wrap-page-ttl {
    background-color: #0e6fb8;
    background-size: cover;
    background-position: center;
    color: #fff;
    padding: 50px 0;
    position: relative
}

@media screen and (min-width: 1100px) {
    .wrap-page-ttl {
        padding: 80px 0
    }
}

.wrap-page-ttl:before {
    background-color: rgba(0, 0, 0, .4);
    content: "";
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%
}

.wrap-page-ttl .page-title {
    font-size: 1.8rem;
    font-weight: bold;
    line-height: 1.4;
    padding-bottom: 0;
    position: relative;
    text-align: center
}

@media screen and (min-width: 1100px) {
    .wrap-page-ttl .page-title {
        font-size: 2.4rem;
        line-height: 1.4
    }
}

@media screen and (min-width: 1100px) {
    .wrap-page-ttl .page-title {
        font-size: 2.4rem;
        line-height: 1.4
    }
}

.page-id-142 .wrap-page-ttl {
    background-image: url(./img/bg-header-washbasin.png.webp?v=20240216135235)
}

.page-id-140 .wrap-page-ttl {
    background-image: url(./img/bg-header-toilet.png.webp?v=20240216135235)
}

.page-id-138 .wrap-page-ttl {
    background-image: url(./img/bg-header-bathroom.png.webp?v=20240216135235)
}

.page-id-120 .wrap-page-ttl {
    background-image: url(./img/bg-header-kitchen.png.webp?v=20240216135235)
}

.page-id-146 .wrap-page-ttl {
    background-image: url(./img/bg-header-exterior.png.webp?v=20240216135235)
}

.page-template-page-privacy .wrap-page-ttl {
    background-image: url(./img/bg-header-privacy.png.webp?v=20240216135235)
}

.page-template-page-company .wrap-page-ttl {
    background-image: url(./img/bg-header-company.png.webp?v=20240216135235)
}

.page-template-page-faq .wrap-page-ttl {
    background-image: url(./img/bg-header-faq.png.webp?v=20240216135235)
}

.page-template-page-estimate .wrap-page-ttl {
    background-image: url(./img/bg-header-estimate.png.webp?v=20240216135235)
}

.page-template-page-visit .wrap-page-ttl {
    background-image: url(./img/bg-header-visit.png.webp?v=20240216135235)
}

.page-template-page-contact .wrap-page-ttl {
    background-image: url(./img/bg-header-contact.png.webp?v=20240216135235)
}

.page-template-page-line .wrap-page-ttl {
    background-image: url(./img/bg-header-line.png.webp?v=20240216135235)
}

.page-template-page-subsidy .wrap-page-ttl {
    background-image: url(./img/bg-header-subsidy.png.webp?v=20240216135235)
}

.wrap-menuheading {
    display: flex;
    margin-bottom: 20px
}

.menuheading__ttl {
    order: 2;
    width: 58px;
    writing-mode: vertical-rl
}

@media screen and (min-width: 1100px) {
    .menuheading__ttl {
        width: 75px
    }
}

.menuheading__thumb {
    flex: 1
}

@media screen and (min-width: 1100px) {
    .wrap-menuheading-sub {
        display: flex
    }
}

.menuheading__des {
    border: 1px solid #f1f1f1;
    border-width: 0 0 1px 0;
    padding-bottom: 20px;
    width: 100%
}

@media screen and (min-width: 1100px) {
    .menuheading__des {
        border-width: 0 1px 0 0;
        padding-right: 20px;
        width: 58%
    }
}

.menuheading__des h3 {
    font-size: 1.6rem;
    line-height: 1.5;
    font-weight: bold;
    margin-bottom: 15px
}

@media screen and (min-width: 1100px) {
    .menuheading__des h3 {
        font-size: 1.8rem;
        line-height: 1.6
    }
}

@media screen and (min-width: 1100px) {
    .menuheading__des h3 {
        font-size: 1.8rem;
        line-height: 1.6
    }
}

.menu-info {
    padding: 20px 0 0 0
}

@media screen and (min-width: 1100px) {
    .menu-info {
        flex: 1;
        padding: 0 90px 0 20px
    }
}

.menu-info .menu-info__item {
    align-items: center
}

.menu-info .menu-info__item .menu-info__item-ttl {
    font-weight: bold;
    padding: 5px 10px
}

.menu-info .menu-info__item .menu-info__item-ttl img {
    margin-right: 5px;
    vertical-align: middle;
    width: 24px
}

.menu-info .menu-info__item .menu-info__item-detail {
    font-size: 1.2rem;
    line-height: 1.5;
    align-items: center;
    display: flex;
    flex: 1;
    padding: 5px 10px
}

@media screen and (min-width: 1100px) {
    .menu-info .menu-info__item .menu-info__item-detail {
        font-size: 1.3rem;
        line-height: 1.5
    }
}

@media screen and (min-width: 1100px) {
    .menu-info .menu-info__item .menu-info__item-detail {
        font-size: 1.4rem;
        line-height: 1.6
    }
}

.section-faq {
    padding-top: 150px;
    margin-top: -150px
}

@media screen and (min-width: 1100px) {
    .section-faq {
        padding-top: 180px;
        margin-top: -180px
    }
}

.wrap-nav-faq {
    padding: 8px;
    position: sticky;
    top: 53px;
    width: 100%;
    z-index: 10
}

.nav-faq {
    margin: 0 auto;
    width: 96%;
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    width: 100%
}

@media screen and (min-width: 1100px) {
    .nav-faq {
        width: 1100px
    }
}

.nav-faq li {
    border-radius: 6px;
    box-shadow: 0 0 10px rgba(0, 0, 0, .1);
    text-align: center;
    width: 16%
}

@media screen and (min-width: 1100px) {
    .nav-faq li {
        margin-top: 7px;
        width: 16%
    }
}

.nav-faq li a {
    font-size: 1.1rem;
    line-height: 1.3;
    background-color: #fff;
    border-radius: 5px;
    display: block;
    font-weight: bold;
    padding: 10px 4px;
    text-decoration: none;
    transition: .3s
}

@media screen and (min-width: 1100px) {
    .nav-faq li a {
        font-size: 1.2rem;
        line-height: 1.4
    }
}

@media screen and (min-width: 1100px) {
    .nav-faq li a {
        font-size: 1.3rem;
        line-height: 1.5
    }
}

.nav-faq li a .ico-faq {
    display: block;
    margin: 0 auto 10px;
    width: 40px
}

@media screen and (min-width: 1100px) {
    .nav-faq li a .ico-faq {
        width: 60px
    }
}

.nav-faq li a:hover {
    background-color: #ffefda;
    color: #fb9108
}

.faq-item {
    display: block;
    margin-bottom: 20px
}

.faq-item .faq-que,
.faq-item .faq-ans {
    display: flex
}

.faq-item .faq-que:before,
.faq-item .faq-ans:before {
    border-radius: 50%;
    color: #fff;
    display: block;
    font-weight: normal;
    font-size: 1.6rem;
    letter-spacing: 0;
    margin-right: 5px;
    text-align: center;
    width: 26px;
    height: 26px
}

@media screen and (min-width: 1100px) {

    .faq-item .faq-que:before,
    .faq-item .faq-ans:before {
        font-size: 1.85rem;
        width: 30px;
        height: 30px
    }
}

.faq-item .faq-que {
    margin-bottom: 10px
}

.faq-item .faq-que:before {
    background-color: #0e6fb8;
    content: "Q"
}

.faq-item .faq-que .faq-ttl {
    font-size: 1.6rem;
    line-height: 1.5;
    flex: 1;
    font-weight: bold
}

@media screen and (min-width: 1100px) {
    .faq-item .faq-que .faq-ttl {
        font-size: 1.8rem;
        line-height: 1.6
    }
}

@media screen and (min-width: 1100px) {
    .faq-item .faq-que .faq-ttl {
        font-size: 1.8rem;
        line-height: 1.6
    }
}

.faq-item .faq-ans {
    background-color: #f4f4f4;
    border-radius: 10px;
    padding: 22px;
    margin-bottom: 30px
}

.faq-item .faq-ans:before {
    background-color: #b57219;
    content: "A"
}

.faq-item .faq-ans p {
    flex: 1
}

.tbl-construction th,
.tbl-construction td {
    padding: 10px 6px
}

.tbl-construction th {
    width: 20%
}

.tbl-construction td {
    background-color: #fff;
    width: 30%
}

.wrap-ba {
    align-items: center;
    display: flex;
    justify-content: flex-start
}

.wrap-ba div {
    margin-right: 2%;
    position: relative;
    width: 32%
}

.wrap-ba div:after {
    font-size: 1.2rem;
    line-height: 1.5;
    color: #fff;
    display: inline-block;
    position: absolute;
    left: 0;
    top: 0;
    padding: 4px 10px
}

@media screen and (min-width: 1100px) {
    .wrap-ba div:after {
        font-size: 1.3rem;
        line-height: 1.5
    }
}

@media screen and (min-width: 1100px) {
    .wrap-ba div:after {
        font-size: 1.4rem;
        line-height: 1.6
    }
}

.wrap-ba div:last-child {
    margin-right: 0
}

.ba__before:after {
    background-color: rgba(0, 0, 0, .7);
    content: "施工前"
}

.ba__middle:after {
    background-color: rgba(27, 48, 105, .7);
    content: "施工中"
}

.ba__after:after {
    background-color: rgba(255, 84, 0, .7);
    content: "施工後"
}

@keyframes swipe-animation {
    0% {
        transform: translate(0px, 0px)
    }

    25% {
        transform: translate(0px, 0px)
    }

    75% {
        transform: translate(-80px, 0px)
    }

    100% {
        transform: translate(0px, 0px)
    }
}

.swipe-anime {
    animation: swipe-animation 2s;
    animation-iteration-count: 1
}

.ico-swipe {
    width: 26px;
    height: 26px;
    display: block;
    margin: 4px 4px 10px auto
}

@media screen and (min-width: 1100px) {
    .ico-swipe {
        display: none
    }
}

.tbl-price {
    display: block;
    overflow-x: scroll;
    white-space: nowrap;
    -webkit-overflow-scrolling: touch;
    margin: 0 auto 15px;
    width: 100%
}

@media screen and (min-width: 1100px) {
    .tbl-price {
        display: table;
        width: 100%
    }
}

.tbl-price tr th,
.tbl-price tr td {
    font-size: 1.4rem;
    line-height: 1.4;
    background: none;
    letter-spacing: 0;
    padding: 15px;
    text-align: center
}

@media screen and (min-width: 1100px) {

    .tbl-price tr th,
    .tbl-price tr td {
        font-size: 1.5rem;
        line-height: 1.6
    }
}

@media screen and (min-width: 1100px) {

    .tbl-price tr th,
    .tbl-price tr td {
        font-size: 1.6rem;
        line-height: 1.6
    }
}

@media screen and (min-width: 1100px) {

    .tbl-price tr th,
    .tbl-price tr td {
        font-size: 1.6rem;
        line-height: 1.5
    }
}

@media screen and (min-width: 1100px)and (min-width: 1100px) {

    .tbl-price tr th,
    .tbl-price tr td {
        font-size: 1.8rem;
        line-height: 1.6
    }
}

@media screen and (min-width: 1100px)and (min-width: 1100px) {

    .tbl-price tr th,
    .tbl-price tr td {
        font-size: 1.8rem;
        line-height: 1.6
    }
}

.tbl-price thead th {
    background-color: #0e6fb8;
    color: #fff
}

.tbl-price tbody td:nth-child(1),
.tbl-price tbody td:nth-child(2) {
    text-align: center
}

.tbl-price tbody td:nth-child(3),
.tbl-price tbody td:nth-child(4),
.tbl-price tbody td:nth-child(5) {
    text-align: right
}

.tbl-price tbody tr:hover {
    background-color: rgba(181, 114, 25, .3)
}

.tbl-price tbody tr td:hover {
    background-color: rgba(181, 114, 25, .6);
    color: #fff
}

.price-attention p:before {
    display: inline-block;
    font-family: "Material Icons";
    font-weight: normal;
    font-style: normal;
    font-size: 24px;
    line-height: 1;
    text-transform: none;
    letter-spacing: normal;
    word-wrap: normal;
    white-space: nowrap;
    direction: ltr;
    -webkit-font-smoothing: antialiased;
    text-rendering: optimizeLegibility;
    -moz-osx-font-smoothing: grayscale;
    font-feature-settings: "liga";
    content: "report_problem";
    font-size: 2rem;
    vertical-align: middle
}

.price-attention ul {
    font-size: 1.2rem;
    line-height: 1.5
}

@media screen and (min-width: 1100px) {
    .price-attention ul {
        font-size: 1.3rem;
        line-height: 1.5
    }
}

@media screen and (min-width: 1100px) {
    .price-attention ul {
        font-size: 1.4rem;
        line-height: 1.6
    }
}

.wrap-area {
    margin: 15px auto
}

.wrap-area .list-area {
    font-size: 1.2rem;
    line-height: 1.5
}

@media screen and (min-width: 1100px) {
    .wrap-area .list-area {
        font-size: 1.3rem;
        line-height: 1.5
    }
}

@media screen and (min-width: 1100px) {
    .wrap-area .list-area {
        font-size: 1.4rem;
        line-height: 1.6
    }
}

.wrap-area .list-area li {
    display: inline-block;
    margin: 15px 15px 0 0
}

.wrap-area .list-area li:nth-child(1) {
    background-color: #0e6fb8;
    color: #fff;
    padding: 3px 8px 1px;
    text-align: center
}

.list-product {
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-start;
    margin: 0 auto;
    width: 94%
}

@media screen and (min-width: 1100px) {
    .list-product {
        width: 100%
    }
}

.list-product li {
    box-shadow: 0 3px 10px rgba(0, 0, 0, .2);
    margin: 0 1% 20px;
    padding: 20px;
    text-align: center;
    width: 100%
}

@media screen and (min-width: 1100px) {
    .list-product li {
        margin: 0 1% 30px;
        width: 31%
    }
}

.list-product li a figure div {
    overflow: hidden;
    width: 100%;
    height: auto
}

.list-product li a figure div img {
    width: 100%
}

.list-product li a:hover figure div img {
    transform: scale(1.2)
}

.list-product .product__col-1 {
    box-shadow: none;
    margin: 0 0 20px;
    padding: 0;
    width: 100%
}

@media screen and (min-width: 1100px) {
    .list-product .product__col-1 {
        margin: 0 0 30px
    }
}

.list-product .product__col-1 .more-detail-plan-btn {
    text-align: left
}

@media screen and (min-width: 1100px) {
    .list-product .product__col-1 .more-detail-plan-btn {
        display: inline-block;
        margin: 15px auto
    }
}

.list-product .product__col-1 .more-detail-plan-btn a {
    background-color: #e23684;
    color: #fff;
    padding: 4px 6px
}

@media screen and (min-width: 1100px) {
    .list-product .product__col-1 .more-detail-plan-btn a {
        border-radius: 20px;
        padding: 10px 20px
    }
}

.balloon1-top {
    position: relative;
    display: inline-block;
    margin: 1.5em 0;
    padding: 7px 15px;
    min-width: 120px;
    max-width: 100%;
    color: #555;
    font-size: 16px;
    background: #e0edff
}

.balloon1-top:before {
    content: "";
    position: absolute;
    top: -30px;
    left: 50%;
    margin-left: -15px;
    border: 15px solid rgba(0, 0, 0, 0);
    border-bottom: 15px solid #e0edff
}

.balloon1-top p {
    margin: 0;
    padding: 0
}

.wrap-exterior-price {
    border: 1px solid #e23684;
    display: flex;
    flex-wrap: wrap;
    width: 100%
}

@media screen and (min-width: 1100px) {
    .wrap-exterior-price {
        border: none
    }
}

.exterior-price__plan {
    align-items: center;
    background-color: #e23684;
    border-radius: 0;
    display: flex;
    padding: 5px 0 2px;
    width: 100%
}

@media screen and (min-width: 1100px) {
    .exterior-price__plan {
        border-radius: 10px;
        width: 15%
    }
}

.exterior-price__plan p {
    color: #fff;
    font-size: 1.1rem;
    width: 100%
}

@media screen and (min-width: 1100px) {
    .exterior-price__plan p {
        font-size: 1.4rem
    }
}

.exterior-price__plan p span {
    display: block;
    font-size: 3rem;
    font-weight: bold;
    line-height: 1
}

@media screen and (min-width: 1100px) {
    .exterior-price__plan p span {
        font-size: 6rem
    }
}

.exterior-price__detail {
    border-top: 5px solid #e23684;
    flex: 1
}

@media screen and (min-width: 1100px) {
    .exterior-price__detail {
        margin-left: -10px;
        padding: 0 10px
    }
}

.exterior-price__detail .exterior-price__detail-copy {
    border-bottom: 2px solid #e23684;
    color: #e23684;
    font-size: 1.1rem;
    font-weight: bold;
    line-height: 1.2;
    padding: 8px 2px
}

@media screen and (min-width: 1100px) {
    .exterior-price__detail .exterior-price__detail-copy {
        font-size: 2rem
    }
}

.exterior-price__detail .exterior-price__detail-ttl {
    font-size: 2rem;
    font-weight: bold;
    line-height: 1.3;
    padding-top: 5px
}

@media screen and (min-width: 1100px) {
    .exterior-price__detail .exterior-price__detail-ttl {
        font-size: 4rem;
        padding-top: 8px
    }
}

.exterior-price__detail .exterior-price__detail-service-life {
    font-size: 1rem;
    padding-bottom: 5px
}

@media screen and (min-width: 1100px) {
    .exterior-price__detail .exterior-price__detail-service-life {
        font-size: 1.6rem;
        padding-bottom: 0
    }
}

.exterior-price__detail .exterior-price__detail-service-life span {
    color: #e30212;
    font-size: 1.6rem;
    font-weight: bold
}

@media screen and (min-width: 1100px) {
    .exterior-price__detail .exterior-price__detail-service-life span {
        font-size: 3rem
    }
}

.exterior-price__detail .exterior-price__detail-material {
    background-color: #e23684;
    color: #fff;
    font-size: 1.1rem;
    margin: 5px 0 0;
    padding: 2px 4px
}

@media screen and (min-width: 1100px) {
    .exterior-price__detail .exterior-price__detail-material {
        font-size: 1.3rem;
        margin: 5px 10px 0
    }
}

.exterior-price__price {
    align-items: center;
    border-top: 5px solid #e23684;
    color: #e30212;
    display: flex;
    text-align: right;
    width: 34%;
    min-width: 110px
}

@media screen and (min-width: 1100px) {
    .exterior-price__price {
        width: 25%
    }
}

.exterior-price__price .exterior-price__price-main {
    font-size: 4.8rem;
    font-weight: bold;
    padding-right: 2px;
    text-align: right;
    width: 60%
}

@media screen and (min-width: 1100px) {
    .exterior-price__price .exterior-price__price-main {
        font-size: 10rem;
        padding-right: 5px;
        width: 65%
    }
}

.exterior-price__price .exterior-price__price-sub {
    flex: 1;
    font-size: 2.8rem;
    font-weight: bold;
    line-height: 1.2;
    text-align: left
}

@media screen and (min-width: 1100px) {
    .exterior-price__price .exterior-price__price-sub {
        font-size: 4rem
    }
}

.exterior-price__price .exterior-price__price-sub .exterior-price__price-sub-num span {
    color: #000;
    font-size: 1rem;
    font-weight: normal;
    padding-left: 2px;
    writing-mode: vertical-rl
}

@media screen and (min-width: 1100px) {
    .exterior-price__price .exterior-price__price-sub .exterior-price__price-sub-num span {
        font-size: 1.2rem;
        padding-left: 5px
    }
}

.exterior-price__price .exterior-price__price-yen {
    color: #000;
    font-size: 1.2rem
}

@media screen and (min-width: 1100px) {
    .exterior-price__price .exterior-price__price-yen {
        font-size: 3rem
    }
}

.list-product li:nth-child(2) .wrap-exterior-price,
.list-product li:nth-child(2) .exterior-price__plan,
.list-product li:nth-child(2) .exterior-price__detail,
.list-product li:nth-child(2) .exterior-price__detail-copy,
.list-product li:nth-child(2) .exterior-price__price {
    border-color: #29abe3
}

.list-product li:nth-child(2) .exterior-price__plan,
.list-product li:nth-child(2) .exterior-price__detail-material {
    background-color: #29abe3
}

.list-product li:nth-child(2) .exterior-price__detail-copy {
    color: #29abe3
}

.list-product li:nth-child(3) .wrap-exterior-price,
.list-product li:nth-child(3) .exterior-price__plan,
.list-product li:nth-child(3) .exterior-price__detail,
.list-product li:nth-child(3) .exterior-price__detail-copy,
.list-product li:nth-child(3) .exterior-price__price {
    border-color: #23b674
}

.list-product li:nth-child(3) .exterior-price__plan,
.list-product li:nth-child(3) .exterior-price__detail-material {
    background-color: #23b674
}

.list-product li:nth-child(3) .exterior-price__detail-copy {
    color: #23b674
}

.modaal-plan-content {
    background-color: #ddd;
    height: 100%;
    min-height: 100vh
}

.modal-plan-a {
    background-color: #e23684
}

.modal-plan-b {
    background-color: #29abe3
}

.modal-plan-c {
    background-color: #23b674
}

.modaal-plan-header {
    font-size: 1.8rem;
    font-weight: bold;
    line-height: 1.4;
    color: #fff;
    padding: 20px;
    text-align: center
}

@media screen and (min-width: 1100px) {
    .modaal-plan-header {
        font-size: 2.4rem;
        line-height: 1.4
    }
}

@media screen and (min-width: 1100px) {
    .modaal-plan-header {
        font-size: 2.4rem;
        line-height: 1.4
    }
}

.modaal-plan-inner {
    color: #111;
    padding: 30px;
    text-align: left;
    margin: 0 auto;
    width: 96%
}

@media screen and (min-width: 1100px) {
    .modaal-plan-inner {
        width: 1100px
    }
}

.philosophy {
    font-size: 1.6rem;
    line-height: 1.5;
    font-weight: bold
}

@media screen and (min-width: 1100px) {
    .philosophy {
        font-size: 1.8rem;
        line-height: 1.6
    }
}

@media screen and (min-width: 1100px) {
    .philosophy {
        font-size: 1.8rem;
        line-height: 1.6
    }
}

.message-image {
    margin-top: 30px;
    text-align: right
}

.message-image__logo #logo-svg-h {
    width: 175px
}

@media screen and (min-width: 1100px) {
    .message-image__logo #logo-svg-h {
        width: 200px
    }
}

.message-image__sign img {
    width: 200px
}

@media screen and (min-width: 1100px) {
    .message-image__sign img {
        width: 280px
    }
}

.wrap-staff {
    margin: 0 auto;
    width: 100%
}

@media screen and (min-width: 1100px) {
    .wrap-staff {
        display: flex;
        flex-wrap: wrap;
        justify-content: space-between
    }
}

.staff__thumb {
    margin: 0 auto;
    max-width: 240px;
    width: 50%
}

@media screen and (min-width: 1100px) {
    .staff__thumb {
        margin-right: 30px;
        max-width: 300px;
        width: 300px
    }
}

.staff__detail {
    width: 100%
}

@media screen and (min-width: 1100px) {
    .staff__detail {
        flex: 1
    }
}

@media screen and (min-width: 1100px) {
    .wrap-col-subsidy-construction {
        display: flex;
        justify-content: space-between
    }
}

.wrap-col-subsidy-construction table {
    margin-top: 10px
}

.wrap-col-subsidy-construction table td {
    vertical-align: top
}

@media screen and (min-width: 1100px) {
    .col-subsidy-construction__basic {
        width: 68%
    }
}

.col-subsidy-construction__basic table th {
    background-color: green
}

@media screen and (min-width: 1100px) {
    .col-subsidy-construction__option {
        width: 23%
    }
}

.col-subsidy-construction__plus {
    text-align: center
}

@media screen and (min-width: 1100px) {
    .col-subsidy-construction__plus {
        align-items: center;
        display: flex
    }
}

.col-subsidy-construction__plus i {
    font-size: 3rem;
    font-weight: bold;
    line-height: 1.4;
    color: #888;
    display: inline-block;
    vertical-align: middle
}

@media screen and (min-width: 1100px) {
    .col-subsidy-construction__plus i {
        font-size: 4.4rem
    }
}

@media screen and (min-width: 1100px) {
    .col-subsidy-construction__plus i {
        font-size: 4.4rem
    }
}

@media screen and (min-width: 1100px) {
    .subsidy-construction-item-wrap {
        border-left: 1px solid #ddd;
        display: flex;
        margin-top: 10px;
        justify-content: space-between
    }
}

.subsidy-construction__item {
    padding: 0 0 10px 0;
    width: 100%
}

@media screen and (min-width: 1100px) {
    .subsidy-construction__item {
        border-right: 1px solid #ddd;
        padding: 0 10px 10px 10px;
        width: 33.3333%
    }
}

.subsidy-construction__item .subsidy__ttl {
    background-color: green;
    color: #fff;
    margin-bottom: 10px;
    padding: 10px
}

.col-subsidy-construction__option .subsidy-construction__item {
    width: 100%
}

.col-subsidy-construction__option .subsidy-construction__item .subsidy__ttl {
    background-color: orange
}

.hojo {
    color: red;
    font-weight: bold
}

.hojo span {
    font-size: 3rem
}

.inquiry {
    border: none;
    margin: 0 auto;
    width: 100%
}

.inquiry tr {
    border-bottom: 1px solid #ddd
}

.inquiry th,
.inquiry td {
    border: none;
    display: block
}

@media screen and (min-width: 1100px) {

    .inquiry th,
    .inquiry td {
        display: table-cell
    }
}

.inquiry .haveto,
.inquiry .any {
    font-size: 1rem
}

.inquiry th {
    background-color: #fff !important;
    text-align: left;
    color: #444;
    padding: 20px;
    width: 100%
}

@media screen and (min-width: 1100px) {
    .inquiry th {
        width: 30%
    }
}

.inquiry td {
    background-color: #fff;
    padding: 0 20px 20px 20px;
    width: 100%
}

@media screen and (min-width: 1100px) {
    .inquiry td {
        padding: 20px;
        width: 70%
    }
}

.inquiry td .content {
    margin-top: 0
}

.haveto {
    font-size: 1rem;
    padding: 5px;
    background: #ff9393;
    color: #fff;
    border-radius: 2px;
    margin-right: 5px;
    position: relative;
    bottom: 1px
}

.any {
    font-size: 1rem;
    padding: 5px;
    background: #93c9ff;
    color: #fff;
    border-radius: 2px;
    margin-right: 5px;
    position: relative;
    bottom: 1px
}

.verticallist .wpcf7-list-item {
    display: block
}

#formbtn {
    border-radius: 2px;
    border: none;
    display: block;
    background: #258fc8;
    color: #fff;
    font-size: 18px;
    font-weight: bold;
    margin: 30px auto 0;
    padding: 1em 0;
    transition: .3s;
    width: 40%
}

#formbtn:hover {
    background: #299fde
}

.wpcf7-list-item {
    margin: 0
}

.codedropz-upload-inner h3 {
    font-size: 1.8rem;
    font-weight: bold;
    line-height: 1.4;
    background: none;
    border: 0
}

@media screen and (min-width: 1100px) {
    .codedropz-upload-inner h3 {
        font-size: 2.4rem;
        line-height: 1.4
    }
}

@media screen and (min-width: 1100px) {
    .codedropz-upload-inner h3 {
        font-size: 2.4rem;
        line-height: 1.4
    }
}

.content-bottom {
    background-color: #eee;
    margin: 20px 0 0
}

.breadcrumbs {
    margin: 0 auto;
    width: 96%;
    font-size: 1.1rem;
    line-height: 1.3;
    margin: 0 auto;
    padding: 15px 0
}

@media screen and (min-width: 1100px) {
    .breadcrumbs {
        width: 1100px
    }
}

@media screen and (min-width: 1100px) {
    .breadcrumbs {
        font-size: 1.2rem;
        line-height: 1.4
    }
}

@media screen and (min-width: 1100px) {
    .breadcrumbs {
        font-size: 1.3rem;
        line-height: 1.5
    }
}

.widget_breadcrumb_navxt {
    margin-bottom: 0 !important
}

.sns-buttons a {
    color: #fff
}

.sns-buttons a:hover {
    text-decoration: none
}

.cat-link {
    color: #fff !important
}

.cat-link:hover {
    text-decoration: none
}

.post-date {
    color: #777 !important
}

.post-date:hover {
    text-decoration: none
}

.wp-block-search .wp-block-search__button {
    padding: 0
}

.wp-block-search__inside-wrapper {
    margin-bottom: 10px
}

.wp-block-search .wp-block-search__label {
    display: none
}

.search-submit {
    top: calc(50% - 16px)
}

.search-box {
    margin-top: 0
}

.widget h2,
.sidebar h3 {
    background-color: #0e6fb8;
    color: #fff;
    margin-bottom: 6px;
    padding: 10px
}

.wp-block-group,
.widget-entry-cards.ranking-visible {
    margin-bottom: 10px
}

.a-wrap {
    color: #222 !important
}

.a-wrap:hover {
    text-decoration: none
}

.a-wrap:hover h2,
.a-wrap:hover h3 {
    text-decoration: underline
}

.popular-posts ul {
    counter-reset: number 0
}

.popular-posts ul li {
    counter-increment: number;
    position: relative
}

.popular-posts ul li:after {
    background-color: #333;
    color: #fff;
    content: counter(number);
    font-size: 1.35rem;
    line-height: 1.8;
    position: absolute;
    top: 0;
    left: 0;
    text-align: center;
    width: 24px;
    height: 24px
}

.popular-posts ul li:nth-child(1):after {
    background-color: #f4a800
}

.popular-posts ul li:nth-child(2):after {
    background-color: #838383
}

.popular-posts ul li:nth-child(3):after {
    background-color: #af6300
}

.slideshow {
    overflow: hidden;
    position: relative;
    width: 100%;
    height: 100vh;
    z-index: 1
}

.slideshow .btn {
    display: inline-block;
    padding: 13px 20px;
    color: #fff;
    text-decoration: none;
    position: relative;
    background: rgba(0, 0, 0, 0);
    border: 1px solid #e1e1e1;
    letter-spacing: .4em;
    text-align: center;
    text-indent: 2px;
    text-transform: uppercase;
    transition: color .1s linear .05s
}

.slideshow .btn:before {
    content: "";
    display: block;
    position: absolute;
    top: 50%;
    left: 0;
    width: 100%;
    height: 1px;
    background: #e1e1e1;
    z-index: 1;
    opacity: 0;
    transition: height .2s ease, top .2s ease, opacity 0s linear .2s
}

.slideshow .btn:after {
    transition: border .1s linear .05s
}

.slideshow .btn .btn-inner {
    position: relative;
    z-index: 2
}

.slideshow .btn:hover {
    color: #373737;
    transition: color .1s linear 0s
}

.slideshow .btn:hover:before {
    top: 0;
    height: 100%;
    opacity: 1;
    transition: height .2s ease, top .2s ease, opacity 0s linear 0s
}

.slideshow .btn:hover:after {
    border-color: #373737;
    transition: border .1s linear 0s
}

.slideshow .slideshow-inner {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%
}

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

.slideshow .slide {
    display: none;
    overflow: hidden;
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: 1;
    opacity: 0;
    transition: opacity .3s ease
}

.slideshow .slide .caption {
    padding: 0 8%
}

@media screen and (min-width: 1100px) {
    .slideshow .slide .caption {
        padding: 0 100px
    }
}

.slideshow .slide .image-container {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-position: center;
    z-index: 1;
    background-size: cover;
    image-rendering: optimizeQuality
}

.slideshow .slide .image-container:before {
    content: "";
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, .5)
}

.slideshow .slide .image {
    width: 100%;
    width: 100%;
    -o-object-fit: cover;
    object-fit: cover;
    height: 100%
}

.slideshow .slide .title {
    font-family: "Bitter", "Shippori Mincho", 游明朝, "Yu Mincho", YuMincho, "Hiragino Mincho ProN", HGS明朝E, serif;
    letter-spacing: .2rem;
    margin: 0 auto 15px;
    max-width: 800px;
    font-size: 2.4rem;
    letter-spacing: .35em;
    text-transform: uppercase
}

@media screen and (min-width: 1100px) {
    .slideshow .slide .title {
        font-size: 5rem
    }
}

.slideshow .slide .text {
    font-family: "Bitter", "Shippori Mincho", 游明朝, "Yu Mincho", YuMincho, "Hiragino Mincho ProN", HGS明朝E, serif;
    letter-spacing: .2rem;
    font-size: 1.4rem;
    line-height: 1.4;
    margin: 0 auto;
    max-width: 800px;
    font-weight: normal
}

@media screen and (min-width: 1100px) {
    .slideshow .slide .text {
        font-size: 1.5rem;
        line-height: 1.6
    }
}

@media screen and (min-width: 1100px) {
    .slideshow .slide .text {
        font-size: 1.6rem;
        line-height: 1.6
    }
}

@media screen and (min-width: 1100px) {
    .slideshow .slide .text {
        font-size: 1.6rem;
        line-height: 1.5
    }
}

@media screen and (min-width: 1100px)and (min-width: 1100px) {
    .slideshow .slide .text {
        font-size: 1.8rem;
        line-height: 1.6
    }
}

@media screen and (min-width: 1100px)and (min-width: 1100px) {
    .slideshow .slide .text {
        font-size: 1.8rem;
        line-height: 1.6
    }
}

.slideshow .slide .btn {
    margin: 15px 0 0;
    border-color: #fff
}

.slideshow .slide .btn:before {
    background: #fff
}

.slideshow .slide.is-active {
    display: block
}

.slideshow .slide.is-loaded {
    opacity: 1
}

.slideshow .slide-content {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    z-index: 2;
    color: #fff;
    text-align: center;
    display: flex;
    justify-content: center;
    align-items: center
}

.slideshow .pagination {
    position: absolute;
    bottom: 35px;
    left: 0;
    width: 100%;
    height: 12px;
    cursor: default;
    z-index: 2;
    text-align: center
}

.slideshow .pagination .item {
    display: inline-block;
    padding: 15px 5px;
    position: relative;
    width: 46px;
    height: 32px;
    cursor: pointer;
    text-indent: -999em;
    z-index: 1
}

.slideshow .pagination .item + .page {
    margin-left: -2px
}

.slideshow .pagination .item::before {
    content: "";
    display: block;
    position: absolute;
    top: 15px;
    left: 5px;
    width: 36px;
    height: 2px;
    background: rgba(255, 255, 255, .5);
    transition: background .2s ease
}

.slideshow .pagination .item::after {
    width: 0;
    background: #fff;
    z-index: 2;
    transition: width .2s ease
}

.slideshow .pagination .item:hover::before,
.slideshow .pagination .item.is-active::before {
    background-color: #fff
}

.slideshow .arrows .arrow {
    margin: -33px 0 0;
    padding: 10px;
    position: absolute;
    top: 50%;
    cursor: pointer;
    z-index: 3
}

@media screen and (min-width: 1100px) {
    .slideshow .arrows .arrow {
        padding: 20px
    }
}

.slideshow .arrows .prev {
    left: 0
}

@media screen and (min-width: 1100px) {
    .slideshow .arrows .prev {
        left: 30px
    }
}

.slideshow .arrows .prev:hover .svg {
    left: -10px
}

.slideshow .arrows .next {
    right: 0
}

@media screen and (min-width: 1100px) {
    .slideshow .arrows .next {
        right: 30px
    }
}

.slideshow .arrows .next:hover .svg {
    left: 10px
}

.slideshow .arrows .svg {
    position: relative;
    left: 0;
    width: 14px;
    height: 26px;
    fill: #fff;
    transition: left .2s ease
}

.section-menu {
    background: url(./img/bg.png?v=20240216135235) repeat
}

.menu-heading {
    margin-bottom: 30px
}

@media screen and (min-width: 1100px) {
    .menu-heading {
        display: flex
    }
}

.menu-heading .menu-heading__detail {
    width: 100%
}

@media screen and (min-width: 1100px) {
    .menu-heading .menu-heading__detail {
        width: 70%
    }
}

.menu-heading .menu-heading__detail p {
    margin-top: 10px
}

@media screen and (min-width: 1100px) {
    .menu-heading .menu-heading__detail p {
        margin-top: 0
    }
}

.menu-heading .menu-heading__thumb {
    position: absolute;
    top: 20px;
    right: 4%;
    text-align: right;
    width: 42%
}

@media screen and (min-width: 1100px) {
    .menu-heading .menu-heading__thumb {
        padding-left: 30px;
        position: static;
        width: 30%
    }
}

.wrap-list-menu ul {
    border-top: 1px solid #c8ccc2;
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    width: 100%
}

@media screen and (min-width: 1100px) {
    .wrap-list-menu ul {
        border-top: 0
    }
}

.wrap-list-menu ul li {
    align-items: center;
    border: 1px solid #c8ccc2;
    border-width: 0 0 1px 0;
    display: flex;
    padding: 18px 0;
    width: 100%
}

@media screen and (min-width: 1100px) {
    .wrap-list-menu ul li {
        border: none;
        display: block;
        width: 18%
    }
}

@media screen and (min-width: 1100px) {

    .wrap-list-menu ul li:nth-child(1),
    .wrap-list-menu ul li:nth-child(2),
    .wrap-list-menu ul li:nth-child(3) {
        border-width: 1px 0
    }
}

.wrap-list-menu ul li:after {
    display: inline-block;
    font-family: "Material Icons";
    font-weight: normal;
    font-style: normal;
    font-size: 24px;
    line-height: 1;
    text-transform: none;
    letter-spacing: normal;
    word-wrap: normal;
    white-space: nowrap;
    direction: ltr;
    -webkit-font-smoothing: antialiased;
    text-rendering: optimizeLegibility;
    -moz-osx-font-smoothing: grayscale;
    font-feature-settings: "liga";
    content: "arrow_right";
    position: relative;
    transition: all .3s ease-in-out;
    left: 0
}

@media screen and (min-width: 1100px) {
    .wrap-list-menu ul li:after {
        content: none
    }
}

.wrap-list-menu ul li .list-menu__thumb {
    border-radius: 4px;
    margin-right: 15px;
    overflow: hidden;
    width: 90px;
    height: 90px
}

@media screen and (min-width: 1100px) {
    .wrap-list-menu ul li .list-menu__thumb {
        margin: 0 0 15px 0;
        width: 100%;
        height: auto
    }
}

.wrap-list-menu ul li .list-menu__detail {
    flex: 1
}

.wrap-list-menu ul li .list-menu__detail .list-menu__detail-ttl a {
    font-weight: bold;
    text-decoration: none;
    transition: all .3s ease-in-out
}

.wrap-list-menu ul li .list-menu__detail .list-menu__detail-time {
    font-size: 1.1rem;
    line-height: 1.3;
    color: #777;
    display: none
}

@media screen and (min-width: 1100px) {
    .wrap-list-menu ul li .list-menu__detail .list-menu__detail-time {
        font-size: 1.2rem;
        line-height: 1.4
    }
}

@media screen and (min-width: 1100px) {
    .wrap-list-menu ul li .list-menu__detail .list-menu__detail-time {
        font-size: 1.3rem;
        line-height: 1.5
    }
}

.wrap-list-menu ul li:hover .list-menu__thumb img {
    transform: scale(1.1)
}

.wrap-list-menu ul li:hover .list-menu__detail-ttl a {
    color: #ef6b0a
}

.wrap-list-menu ul li:hover:after {
    color: #ef6b0a;
    left: 5px
}

.wrap-flow {
    counter-reset: number 0
}

@media screen and (min-width: 1100px) {
    .wrap-flow {
        display: flex;
        flex-wrap: wrap
    }
}

.wrap-flow .flow__item {
    display: flex;
    flex-wrap: wrap;
    padding: 0;
    position: relative;
    width: 100%
}

@media screen and (min-width: 1100px) {
    .wrap-flow .flow__item {
        padding: 44px 1% 0;
        width: 100%
    }
}

.wrap-flow .flow__item .flow__item-step {
    border-right: 1px solid #ddd;
    order: 1;
    width: 30px
}

@media screen and (min-width: 1100px) {
    .wrap-flow .flow__item .flow__item-step {
        order: 2;
        width: .2%
    }
}

.wrap-flow .flow__item .flow__item-thumb {
    display: none
}

@media screen and (min-width: 1100px) {
    .wrap-flow .flow__item .flow__item-thumb {
        opacity: 0;
        transform: translate(0, 50px);
        transition: all 1s;
        display: block;
        margin: 0 auto;
        order: 1;
        padding: 30px;
        position: relative;
        text-align: center;
        width: 49.9%
    }

    .wrap-flow .flow__item .flow__item-thumb.active {
        opacity: 1;
        transform: translate(0, 0)
    }
}

.wrap-flow .flow__item .flow__item-thumb img {
    max-height: 300px;
    max-width: 84%;
    -o-object-fit: cover;
    object-fit: cover
}

.wrap-flow .flow__item .flow__item-detail {
    opacity: 0;
    transform: translate(50px, 0);
    transition: all 1s;
    border-radius: 6px;
    flex: 1;
    order: 2;
    padding: 10px 40px 40px;
    width: 40%
}

.wrap-flow .flow__item .flow__item-detail.active {
    opacity: 1;
    transform: translate(0, 0)
}

@media screen and (min-width: 1100px) {
    .wrap-flow .flow__item .flow__item-detail {
        order: 3;
        width: 49.9%
    }
}

.wrap-flow .flow__item .flow__item-detail .flow__item-detail__ttl {
    font-size: 1.8rem;
    font-weight: bold;
    line-height: 1.4;
    color: #0d6eb8;
    font-weight: bold;
    margin-bottom: 20px;
    text-align: center
}

@media screen and (min-width: 1100px) {
    .wrap-flow .flow__item .flow__item-detail .flow__item-detail__ttl {
        font-size: 2.4rem;
        line-height: 1.4
    }
}

@media screen and (min-width: 1100px) {
    .wrap-flow .flow__item .flow__item-detail .flow__item-detail__ttl {
        font-size: 2.4rem;
        line-height: 1.4
    }
}

.wrap-flow .flow__item .flow__item-detail .flow__item-detail-image {
    display: block;
    margin: 0 auto 20px;
    max-height: 200px;
    max-width: 60%
}

@media screen and (min-width: 1100px) {
    .wrap-flow .flow__item .flow__item-detail .flow__item-detail-image {
        display: none
    }
}

.wrap-flow .flow__item:after {
    font-size: 1.8rem;
    font-weight: bold;
    line-height: 1.4;
    background-color: #0d6eb8;
    border: 2px solid rgba(14, 111, 184, .8);
    border-radius: 50%;
    content: counter(number);
    counter-increment: number 1;
    color: #fff;
    display: block;
    font-weight: bold;
    line-height: 1.9 !important;
    margin: 0 auto;
    padding: 10px;
    position: absolute;
    top: -14px;
    left: 0;
    right: auto;
    text-align: center;
    width: 36px;
    height: 36px
}

@media screen and (min-width: 1100px) {
    .wrap-flow .flow__item:after {
        font-size: 2.4rem;
        line-height: 1.4
    }
}

@media screen and (min-width: 1100px) {
    .wrap-flow .flow__item:after {
        font-size: 2.4rem;
        line-height: 1.4
    }
}

@media screen and (min-width: 1100px) {
    .wrap-flow .flow__item:after {
        line-height: 1.8 !important;
        top: 0;
        left: 0;
        right: 0;
        width: 44px;
        height: 44px
    }
}

@media screen and (min-width: 1100px) {
    .wrap-flow .flow__item:nth-child(odd) .flow__item-detail {
        opacity: 0;
        transform: translate(50px, 0);
        transition: all 1s
    }

    .wrap-flow .flow__item:nth-child(odd) .flow__item-detail.active {
        opacity: 1;
        transform: translate(0, 0)
    }
}

@media screen and (min-width: 1100px) {
    .wrap-flow .flow__item:nth-child(even) .flow__item-thumb {
        order: 3
    }
}

@media screen and (min-width: 1100px) {
    .wrap-flow .flow__item:nth-child(even) .flow__item-detail {
        opacity: 0;
        transform: translate(-50px, 0);
        transition: all 1s;
        order: 1
    }

    .wrap-flow .flow__item:nth-child(even) .flow__item-detail.active {
        opacity: 1;
        transform: translate(0, 0)
    }
}
