@charset "UTF-8";
/* ##### フォント font ##### */
@import url("https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@400;700&display=swap");
@import url("https://fonts.googleapis.com/css2?family=Roboto:wght@400;700&display=swap");
@import url("https://fonts.googleapis.com/css2?family=Bebas+Neue&display=swap");

.noto {
    font-family: "Noto Sans JP", sans-serif;
}

.roboto {
    font-family: "Roboto", sans-serif;
}

.bebas {
    font-family: "Bebas Neue", cursive;
}

/* ##### base.css上書き base.css overwrite ##### */
/* ##### 共通使用 common ##### */
html {
    font-family: "Noto Sans JP", sans-serif;
    color: var(--color-default_text);
    background-color: var(--color-bgc_02);
}

::-moz-selection {
    color: white;
    background-color: var(--color-bgc_01);
}

::selection {
    color: white;
    background-color: var(--color-bgc_01);
}

.logo {
    width: 100%;
    max-width: 500px;
}

.logo a {
    width: 100%;
    display: block;
}

.logo a::before,
.logo a::after {
    content: "";
    display: block;
    clear: both;
}

.logo-001 {
    width: 60px;
    float: left;
    margin-right: 0.25em;
}

.logo-002 {
    max-width: calc(100% - 60px);
    float: left;
}

.logo .text {
    max-width: calc(100% - 70px);
    float: left;
    font-size: 10px;
}

.link-agency a {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    align-items: center;
    -ms-flex-align: center;
}

.link-agency a .icon-agency {
    width: 2em;
    height: 2em;
}

.icon-mail {
    max-width: 25px;
}

.box-w8090100 {
    width: 80%;
}

.text-indent-em1 {
    padding-left: 1em;
}

.circle-white {
    border-radius: 100%;
    background-color: white;
}

.circle-white .square-inner {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    -webkit-box-align: center;
    align-items: center;
    -ms-flex-align: center;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    padding: 2em;
}

.deco-01 {
    position: relative;
}

.deco-01::after {
    content: "";
    width: 40%;
    height: 100%;
    display: block;
    background-color: var(--color-bgc_01);
    position: absolute;
    top: 0;
    right: 0;
    z-index: -1;
}

.card-01 .card-img {
    padding: 0.25em;
    border: 1px solid var(--color-default_text);
    background-color: white;
}

.card-01 .card-content {
    margin-top: 0.5em;
}

.card-02 a {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
}

.card-02 a .card-img {
    width: 20%;
}

.card-02 a .card-content {
    width: 10%;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-flex: 1;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
    -ms-flex-positive: 1;
    flex-grow: 1;
    margin-left: 5%;
}

.color-text-01 {
    color: var(--color-text_01);
}

.color-text-02 {
    color: var(--color-text_02);
}

.color-text-03 {
    color: var(--color-text_03);
}

.color-text-04 {
    color: var(--color-text_04);
}

.color-text-05 {
    color: var(--color-text_05);
}

.color-text-06 {
    color: var(--color-text_06);
}

.color-text-07 {
    color: var(--color-text_07);
}

.color-bgc-01 {
    color: var(--color-bgc_01);
}

.color-bgc-02 {
    color: var(--color-bgc_02);
}

.color-bgc-03 {
    color: var(--color-bgc_03);
}

.color-bgc-04 {
    color: var(--color-bgc_04);
}

.color-bgc-05 {
    color: var(--color-bgc_05);
}

.color-bgc-06 {
    color: var(--color-bgc_06);
}

.color-bgc-07 {
    color: var(--color-bgc_07);
}

.case-item {
    padding: 2em 0.5em;
    border-top: 1px solid var(--color-border_04);
}

.youtube {
    width: 100%;
    padding-top: 0;
    position: relative;
}

.youtube::before {
    content: "";
    display: block;
    padding-top: 56.25%;
}

.youtube iframe {
    width: 100%;
    height: 100%;
    position: absolute;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
}

.marquee {
    -webkit-transform: translateX(100%);
    transform: translateX(100%);
    -webkit-animation: marquee 15s linear infinite;
    animation: marquee 15s linear infinite;
    z-index: -2;
}

.product-item {
    position: relative;
}

.product-item .caption {
    width: 100%;
    height: 100%;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    -webkit-box-pack: end;
    -ms-flex-pack: end;
    justify-content: flex-end;
    padding: 2em 1em;
    background: -webkit-gradient(linear, left top, left bottom, color-stop(50%, rgba(30, 87, 153, 0)), to(rgba(0, 0, 0, 0.5)));
    background: linear-gradient(to bottom, rgba(30, 87, 153, 0) 50%, rgba(0, 0, 0, 0.5) 100%);
    filter: progid:DXImageTransform.Microsoft.gradient(startColorstr="#001e5799", endColorstr="#40000000", GradientType=0);
    -webkit-transition: background 0.3s linear;
    transition: background 0.3s linear;
    position: absolute;
    top: 0;
    left: 0;
    z-index: 1;
}

.product-item a:hover {
    opacity: 1;
}

.product-item a:hover .caption {
    background: transparent;
}

.product-item a:hover .caption .category,
.product-item a:hover .caption [class*=title] {
    text-shadow: 0px 0px 6px rgba(0, 0, 0, 0.4);
}

@-webkit-keyframes marquee {
    0% {
        -webkit-transform: translateX(100%);
        transform: translateX(100%);
    }

    100% {
        -webkit-transform: translateX(-100%);
        transform: translateX(-100%);
    }
}

@keyframes marquee {
    0% {
        -webkit-transform: translateX(100%);
        transform: translateX(100%);
    }

    100% {
        -webkit-transform: translateX(-100%);
        transform: translateX(-100%);
    }
}

@media (max-width: 1024px) {
    .logo {
        width: -webkit-fit-content;
        width: -moz-fit-content;
        width: fit-content;
        max-width: 420px;
        margin-left: auto;
        margin-right: auto;
    }

    .box-w8090100 {
        width: 90%;
    }

    .card-02 a .card-img {
        width: 35%;
    }

    .marquee {
        -webkit-animation: marquee 10s linear infinite;
        animation: marquee 10s linear infinite;
    }
}

@media (max-width: 599px) {
    .logo-001 {
        width: 50px;
    }

    .logo-002 {
        width: calc(100% - 120px);
    }

    .logo .text {
        max-width: calc(100% - 60px);
    }

    .box-w8090100 {
        width: 100%;
    }

    .marquee {
        -webkit-animation: marquee 5s linear infinite;
        animation: marquee 5s linear infinite;
    }
}

/* #### jsスライダー js slider ##### */
.slide01 {
    position: relative;
    z-index: 3;
}

.swiper {
    width: 95%;
    overflow: hidden;
    margin-left: -5%;
    margin-right: auto;
    z-index: 3;
}

.swiper [class*="swiper-button"] {
    width: 3em;
    height: 3em;
    display: -webkit-box !important;
    display: -ms-flexbox !important;
    display: flex !important;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    -webkit-box-align: center;
    align-items: center;
    -ms-flex-align: center;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    color: white;
    border: 1px solid white;
    border-radius: 100%;
    background-color: transparent;
    position: absolute;
    top: -4em;
    left: auto;
    z-index: 3;
}

.swiper [class*="swiper-button"]::after {
    content: "\f061";
    display: inline-block;
    font-family: "Font Awesome 5 Free";
    font-weight: 900;
    font-size: inherit;
    line-height: 1;
}

.swiper .swiper-button-prev {
    right: 20vw;
}

.swiper .swiper-button-prev::after {
    -webkit-transform: scale(-1, 1);
    transform: scale(-1, 1);
}

.swiper .swiper-button-next {
    right: 15vw;
}

@media (max-width: 1024px) {
    .swiper {
        margin-left: 0;
    }

    .swiper .swiper-button-next {
        right: 10vw;
    }
}

@media (max-width: 599px) {
    .swiper [class*="swiper-button"] {
        width: 2.5em;
        height: 2.5em;
        top: -2.5em;
    }

    .swiper .swiper-button-next {
        right: 5vw;
    }
}

/* ##### テーブル table ##### */
/* ##### タイトル title ##### */
.title-01 {
    padding: 3vw 0;
    font-weight: bold;
    font-size: clamp(1.3rem, 1.15rem + 0.63vw, 1.625rem);
    position: relative;
}

.title-01 [class*=inner] {
    display: block;
}

.title-01 .title-inner {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    padding-left: 1em;
    position: relative;
    z-index: 2;
}

.title-01 .main,
.title-01 .sub {
    position: relative;
    z-index: 2;
}

.title-01 .main {
    position: relative;
}

.title-01 .main::before {
    content: "・";
    color: var(--color-text_01);
    position: absolute;
    top: 0;
    left: -1em;
}

.title-01 .sub {
    margin-top: 0.5em;
    font-family: "Roboto", sans-serif;
    font-size: 60%;
    color: var(--color-text_01);
}

.title-01 .back {
    width: 100%;
    margin: auto;
    font-family: "Roboto", sans-serif;
    font-size: 11vw;
    color: var(--color-text_03);
    line-height: 1;
    white-space: nowrap;
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    z-index: -2;
}

.title-01.-pattern01 {
    margin-top: 11vw;
}

.title-01.-pattern01 .main {
    color: white;
}

.title-01.-pattern01 .main::before {
    color: white;
}

.title-01.-pattern01 .sub {
    color: var(--color-text_04);
}

.title-01.-pattern01 .back {
    margin-top: -1em;
}

.title-02 {
    margin-bottom: 1em;
    font-weight: bold;
    font-size: clamp(1.425rem, 0.99rem + 1.84vw, 2.375rem);
}

.title-03 {
    margin-bottom: 1em;
    font-weight: bold;
    font-size: clamp(1.2rem, 1.06rem + 0.58vw, 1.5rem);
    color: var(--color-text_01);
}

.title-04 {
    display: block;
    overflow: hidden;
    padding: 0 1.5em 0 0;
    font-weight: bold;
    font-size: clamp(0.9rem, 0.63rem + 1.16vw, 1.5rem);
    color: white;
    letter-spacing: 0.1em;
    text-overflow: ellipsis;
    white-space: nowrap;
    position: relative;
}

.title-04::after {
    content: "\f061";
    display: inline-block;
    font-family: "Font Awesome 5 Free";
    font-weight: 900;
    font-size: inherit;
    line-height: 1;
    position: absolute;
    top: 0.25em;
    right: 0;
}

.title-05 {
    font-weight: bold;
}

.title-06 {
    margin: 0.5em 0;
    font-weight: bold;
    font-size: clamp(1.4rem, 1.24rem + 0.68vw, 1.75rem);
}

.title-07 {
    font-size: 1.2em;
    color: var(--color-text_04);
}

.title-08 {
    display: inline-block;
    margin-bottom: 1em;
    padding: 0.25em 0.5em;
    font-weight: bold;
    font-size: clamp(1.2375rem, 1.18rem + 0.27vw, 1.375rem);
    color: white;
    background-color: var(--color-bgc_01);
}

.title-08.-wide {
    display: block;
}

.title-09 {
    margin-bottom: 1em;
    padding-left: 1.2em;
    font-weight: bold;
    font-size: clamp(1.2375rem, 1.18rem + 0.27vw, 1.375rem);
    color: var(--color-text_01);
    position: relative;
}

.title-09::before {
    content: "\f105";
    display: inline-block;
    font-family: "Font Awesome 5 Free";
    font-weight: 900;
    font-size: 120%;
    line-height: 1;
    position: absolute;
    top: 0.25em;
    left: 0;
}

.title-10 {
    margin-bottom: 1em;
    font-weight: bold;
    font-size: clamp(1.35rem, 1.28rem + 0.29vw, 1.5rem);
    color: var(--color-text_06);
}

.title-11 {
    margin-bottom: 1em;
    padding-left: 1em;
    font-weight: bold;
    font-size: clamp(1.1rem, 0.98rem + 0.53vw, 1.375rem);
    position: relative;
}

.title-11::before {
    content: "\f0da";
    display: inline-block;
    font-family: "Font Awesome 5 Free";
    font-weight: 900;
    font-size: 120%;
    color: var(--color-text_01);
    line-height: 1;
    position: absolute;
    top: 0.15em;
    left: 0;
}

.title-12 {
    margin-bottom: 0.5em;
    font-weight: bold;
    font-size: 1.1em;
    color: var(--color-text_01);
}

@media (max-width: 1024px) {
    .title-01 .back {
        font-size: 18vw;
    }

    .title-01.-pattern01 {
        margin-top: 20vw;
    }
}

@media (max-width: 599px) {
    .title-01 .back {
        font-size: 24vw;
    }

    .title-01.-pattern01 {
        margin-top: 30vw;
    }
}

/* #### リスト list ##### */
.list-news li {
    padding: 2em 0.5em;
    border-top: 1px solid var(--color-border_04);
}

.list-news li:last-of-type {
    border-bottom: 1px solid var(--color-border_04);
}

.list-news2 li a {
    display: block;
    padding: 3em 3em 3em 1.5em;
    font-weight: bold;
    border-bottom: 1px solid var(--color-border_04);
    background-color: white;
    position: relative;
}

.list-news2 li a::before {
    content: "\f061";
    display: inline-block;
    font-family: "Font Awesome 5 Free";
    font-weight: 900;
    font-size: inherit;
    color: var(--color-text_01);
    line-height: 1;
    position: absolute;
    top: 3em;
    right: 1em;
}

.list-news2 li a::after {
    content: "";
    width: 3em;
    height: 1px;
    display: inline-block;
    background-color: var(--color-bgc_01);
    -webkit-transition: 0.3s linear;
    transition: 0.3s linear;
    position: absolute;
    bottom: -1px;
    right: 0;
}

.list-news2 li a:hover::after {
    width: 100%;
}

.list-news2-layout {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    align-items: center;
    -ms-flex-align: center;
}

.list-news2-layout dt {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-negative: 0;
    flex-shrink: 0;
}

.list-news2-layout dt>span {
    -ms-flex-negative: 0;
    flex-shrink: 0;
}

.list-news2-layout dt>span+span {
    margin-left: 1em;
}

.list-news2-layout dd {
    width: 10%;
    -webkit-box-flex: 1;
    -ms-flex-positive: 1;
    flex-grow: 1;
    margin-left: 1em;
}

.list-flow {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
}

.list-flow li {
    width: calc((100% - 12em) / 4);
}

.list-flow li+li {
    margin-left: 4em;
    position: relative;
}

.list-flow li+li::before {
    content: "";
    width: 3em;
    height: 3em;
    background-image: url("/import/tenant_3/bt-1.a-bisu.jp/html/images/common/icon_007.webp");
    background-size: 100% auto;
    background-repeat: no-repeat;
    background-position: center center;
    -webkit-transform: translate(0, -50%);
    transform: translate(0, -50%);
    position: absolute;
    top: 50%;
    left: -3.5em;
}

.list-device li .img-wrap {
    padding: 5em 0.5em 0.5em;
    border: 1px solid var(--color-border_05);
    background-color: white;
    position: relative;
}

.list-device li .img-caption {
    position: absolute;
    top: 0;
    left: 0;
    z-index: 1;
}

.list-device li .img-category {
    display: inline-block;
    padding: 0.25em 1em;
    font-weight: bold;
    font-size: 15px;
    color: white;
    line-height: 1.2;
    background-color: var(--color-bgc_01);
}

.list-device li .img-category.-pattern01 {
    background-color: var(--color-bgc_06);
}

.list-device li .img-category.-pattern02 {
    background-color: var(--color-bgc_08);
}

.list-device li .img-title {
    padding: 0.25em 0.5em;
    font-weight: bold;
    font-size: clamp(1.5rem, 1.33rem + 0.73vw, 1.875rem);
    line-height: 1.2;
}

.list-device li .img-num {
    display: none;
    padding: 0.25em 0.5em;
    font-weight: bold;
    color: var(--color-text_01);
}

.list-device-information {
    margin: 0.5em 0;
    padding: 0.5em 0;
    position: relative;
}

.list-device-information::before,
.list-device-information::after {
    content: "";
    width: 10%;
    height: 5px;
    background-color: var(--color-bgc_01);
    position: absolute;
    left: 0;
}

.list-device-information::before {
    top: 0;
}

.list-device-information::after {
    bottom: 0;
}

.list-device-information.-pattern02 {
    padding: 1em;
    border: 1px solid var(--color-border_01);
}

.list-device-information.-pattern02::before,
.list-device-information.-pattern02::after {
    display: none;
}

.list-spec {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    font-size: 90%;
}

.list-spec dt {
    -ms-flex-negative: 0;
    flex-shrink: 0;
    margin-right: 0.5em;
    padding: 0 0.5em;
    position: relative;
}

.list-spec dt::before,
.list-spec dt::after {
    position: absolute;
    top: 0;
}

.list-spec dt::before {
    content: "[";
    left: 0;
}

.list-spec dt::after {
    content: "]";
    right: 0;
}

.list-contact {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
}

.list-contact li {
    width: calc((100% - 2px) / 3);
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    -webkit-box-align: center;
    align-items: center;
    -ms-flex-align: center;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    padding: 2.9vw;
    background-color: rgba(0, 0, 0, 0.1);
}

.list-contact li+li {
    margin-left: 1px;
}

.list-contact.-pattern02 li {
    width: calc((100% - 1px) / 2);
    background-color: var(--color-bgc_01);
}

.list-contact.-pattern03 {
    -webkit-box-pack: start;
    -ms-flex-pack: start;
    justify-content: flex-start;
}

.list-contact.-pattern03 li {
    width: 100%;
    max-width: 800px;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
    -ms-flex-direction: row;
    flex-direction: row;
    padding: 0;
    background-color: var(--color-bgc_01);
}

.list-contact.-pattern03 li [class*=element] {
    -ms-flex-negative: 0;
    flex-shrink: 0;
    padding: 2em;
}

.list-contact.-pattern03 li .element01 {
    padding: 3em;
    border-right: 1px solid rgba(255, 255, 255, 0.5);
}

.list-case {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    overflow-x: scroll;
    -webkit-overflow-scrolling: touch;
    padding-bottom: 1.5em;
}

.list-case li {
    width: 30%;
    -ms-flex-negative: 0;
    flex-shrink: 0;
}

.list-case li+li {
    margin-left: 2.5%;
}

.list-case-caption {
    margin-top: 0.25em;
    text-align: center;
}

.list-policy+.list-policy {
    margin-top: 1em;
}

.list-policy dt,
.list-policy dd {
    width: 100%;
    padding: 0;
    font-size: 95%;
}

.list-policy dt {
    font-weight: bold;
}

.list-policy dd {
    padding-left: 1.5em;
    font-size: 90%;
}

.list-policy-wrap {
    padding: 4em 2em;
    background-color: white;
}

@media (max-width: 1024px) {
    .list-contact li {
        width: 100%;
    }

    .list-contact li+li {
        margin-top: 1px;
        margin-left: 0;
    }
}

@media (max-width: 599px) {
    .list-news2 li a::before {
        -webkit-transform: translate(0, -50%);
        transform: translate(0, -50%);
        top: 50%;
    }

    .list-news2-layout {
        -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    }

    .list-news2-layout dt,
    .list-news2-layout dd {
        width: 100%;
        margin: 0;
    }

    .list-news2-layout dd {
        margin-top: 0.5em;
    }

    .list-contact.-pattern02 li {
        width: 100%;
    }

    .list-contact.-pattern03 li {
        -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    }

    .list-contact.-pattern03 li [class*=element] {
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
        -webkit-box-flex: 1;
        -webkit-box-orient: vertical;
        -webkit-box-direction: normal;
        -ms-flex-direction: column;
        flex-direction: column;
        -webkit-box-align: center;
        align-items: center;
        -ms-flex-align: center;
        -webkit-box-pack: center;
        -ms-flex-pack: center;
        justify-content: center;
        -ms-flex-positive: 1;
        flex-grow: 1;
        text-align: center;
    }

    .list-flow li {
        width: 60%;
        margin-left: auto;
        margin-right: auto;
    }

    .list-flow li+li {
        margin-top: 4em;
        margin-left: auto;
    }

    .list-flow li+li::before {
        margin: auto;
        -webkit-transform: translate(0, -100%) rotate(90deg);
        transform: translate(0, -100%) rotate(90deg);
        top: -0.5em;
        left: 0;
        right: 0;
    }

    .list-contact li {
        padding: 3em 1em;
    }

    .list-case li {
        width: 40%;
    }

    .list-case li+li {
        margin-left: 1.5%;
    }
}

/* ##### ボタン button ##### */
.btn-01 {
    width: 300px;
    max-width: 90%;
    margin-top: 5em;
}

.btn-01 a,
.btn-01 button {
    display: block;
    padding: 1em 3em;
    color: white;
    text-align: center;
    border: 2px solid var(--color-default_text);
    border-radius: 3em;
    background-color: var(--color-default_text);
    position: relative;
}

.btn-01 a::after,
.btn-01 button::after {
    content: "\f061";
    display: inline-block;
    font-family: "Font Awesome 5 Free";
    font-weight: 900;
    font-size: inherit;
    line-height: 1;
    position: absolute;
    top: 1.25em;
    right: 1em;
}

.btn-01 a:hover,
.btn-01 button:hover {
    color: var(--color-default_text);
    background-color: white;
    opacity: 1;
}

.btn-01.-back a::after,
.btn-01.-back button::after {
    content: "\f060";
    left: 1em;
    right: auto;
}

.btn-01.-colored a,
.btn-01.-colored button {
    color: white;
    border: 2px solid var(--color-border_01);
    background-color: var(--color-bgc_01);
}

.btn-01.-colored a:hover,
.btn-01.-colored button:hover {
    color: var(--color-text_01);
    background-color: white;
}

.btn-01.-reset a,
.btn-01.-reset button {
    color: var(--color-dafault_text);
    background-color: white;
}

.btn-01.-reset a:hover,
.btn-01.-reset button:hover {
    color: white;
    background-color: var(--color-default_text);
}

.btn-01.-reset a::after,
.btn-01.-reset button::after {
    content: "\f060";
    left: 1em;
    right: auto;
}

.btn-02 {
    width: 400px;
    max-width: 90%;
    margin-top: 2em;
}

.btn-02 a,
.btn-02 button {
    width: 100%;
    height: 100%;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    align-items: center;
    -ms-flex-align: center;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    padding: 1em;
    font-weight: bold;
    font-size: 1.2em;
    color: var(--color-text_01);
    background-color: white;
}

.btn-02 a [class*=icon],
.btn-02 button [class*=icon] {
    margin-right: 0.25em;
}

.btn-02.-pattern02 a,
.btn-02.-pattern02 button {
    color: var(--color-text_05);
}

.btn-03 {
    width: 600px;
    max-width: 100%;
    margin-top: 3em;
}

.btn-03[data-judge="しない"] {
    display: none;
}

.btn-03 a,
.btn-03 button {
    display: block;
    padding: 0.75em 1em;
    font-weight: bold;
    color: white;
    text-align: center;
    border: 2px solid var(--color-border_01);
    background-color: var(--color-bgc_01);
}

.btn-03.-download a,
.btn-03.-download button {
    padding: 0.75em 2em;
    position: relative;
}

.btn-03.-download a::after,
.btn-03.-download button::after {
    content: "\f56d";
    display: inline-block;
    font-family: "Font Awesome 5 Free";
    font-weight: 900;
    position: absolute;
    top: 0.75em;
    right: 0.5em;
}

.btn-03 a:hover,
.btn-03 button:hover {
    color: var(--color-text_01);
    background-color: white;
    opacity: 1;
}

@media (max-width: 599px) {
    .btn-01 {
        margin-top: 3em;
    }

    .btn-02 a,
    .btn-02 button {
        padding: 1em 0.5em;
    }
}

/* ##### ヘッダー header ##### */
header {
    background-color: white;
}

.header-content {
    width: 100%;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    background-color: white;
    -webkit-transition: background-color 0.3s linear, right 0.3s linear;
    transition: background-color 0.3s linear, right 0.3s linear;
    z-index: 30;
}

.header-box {
    padding: 0.5em 2em;
}

.header-box-wrap {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-flex: 1;
    -webkit-box-align: center;
    align-items: center;
    -ms-flex-align: center;
    -webkit-box-pack: end;
    -ms-flex-pack: end;
    justify-content: flex-end;
    -ms-flex-positive: 1;
    flex-grow: 1;
}

.header-logo {
    margin-right: auto;
}

.header-link {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    align-items: center;
    -ms-flex-align: center;
    -webkit-box-pack: end;
    -ms-flex-pack: end;
    justify-content: flex-end;
}

.header-link .header-element {
    -ms-flex-negative: 0;
    flex-shrink: 0;
}

.header-link .header-element+.header-element {
    margin-left: 1em;
}

.header-btn {
    min-width: 180px;
}

.header-btn a {
    width: 100%;
    height: 100%;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    -webkit-box-align: center;
    align-items: center;
    -ms-flex-align: center;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    padding: 1em;
    color: white;
    text-align: center;
    background-color: var(--color-bgc_01);
}

@media (max-width: 1024px) {
    .header-content {
        width: 65%;
        height: 100%;
        -webkit-box-orient: vertical;
        -webkit-box-direction: normal;
        -ms-flex-direction: column;
        flex-direction: column;
        position: fixed;
        top: 0;
        left: auto;
        right: -65%;
    }

    .header-box {
        width: 100%;
        padding: 0;
    }

    .header-box-wrap {
        -webkit-box-orient: vertical;
        -webkit-box-direction: normal;
        -ms-flex-direction: column;
        flex-direction: column;
        padding: 2em 1em;
    }

    .header-link {
        -webkit-box-pack: center;
        -ms-flex-pack: center;
        justify-content: center;
        margin: 1em 0;
    }

    .header-info {
        -webkit-box-flex: 1;
        -ms-flex-positive: 1;
        flex-grow: 1;
    }
}

@media (max-width: 599px) {
    .header-content {
        width: 80%;
        right: -80%;
    }

    .header-link {
        -webkit-box-orient: vertical;
        -webkit-box-direction: normal;
        -ms-flex-direction: column;
        flex-direction: column;
        -webkit-box-align: start;
        align-items: flex-start;
        -ms-flex-align: start;
        padding: 0 1.5em;
    }

    .header-link .header-element+.header-element {
        margin-left: 0;
    }
}

/* ##### ナビ nav ##### */
.nav-list {
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
}

.nav-list li a {
    padding: 0.5em 0;
    position: relative;
}

.nav-list li a::after {
    content: "・";
    width: -webkit-fit-content;
    width: -moz-fit-content;
    width: fit-content;
    display: none;
    margin: auto;
    line-height: 1;
    text-align: center;
    -webkit-transform: translate(0, 50%);
    transform: translate(0, 50%);
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
}

.nav-list li a:hover {
    color: var(--color-text_01);
    opacity: 1;
}

.nav-list li a:hover::after {
    display: block;
}

.nav-list li.current a {
    color: var(--color-text_01);
}

.nav-list li.current a::after {
    display: block;
}

@media (max-width: 1024px) {
    .nav-list li a {
        padding: 0 1em 0 1.5em;
    }

    .nav-list li a::after {
        content: "\f04b";
        font-family: "Font Awesome 5 Free";
        font-weight: 900;
        font-size: 90%;
        -webkit-transform: translate(0, 25%);
        transform: translate(0, 25%);
        top: 0;
        right: auto;
    }
}

/* ##### フッター footer ##### */
footer {
    padding-bottom: 100px;
    position: relative;
}

footer::after {
    content: "";
    width: 65%;
    height: 110%;
    display: block;
    background-color: white;
    position: absolute;
    top: -10%;
    right: 0;
    z-index: -3;
}

.footer-upper {
    width: 90%;
    margin-right: auto;
    padding: 0 5vw 5vw 5vw;
    background-color: var(--color-bgc_01);
}

.footer-bottom {
    border-top: 1px solid var(--color-border_04);
}

.footer-content {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
}

.footer-content .footer-logo {
    width: 35%;
}

.footer-content .footer-nav {
    width: 10%;
    -webkit-box-flex: 1;
    -ms-flex-positive: 1;
    flex-grow: 1;
    margin-left: 5%;
}

.footer-content .footer-nav-list {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-pack: end;
    -ms-flex-pack: end;
    justify-content: flex-end;
}

.footer-content .footer-nav-list li+li {
    margin-left: 2em;
}

.footer-content .footer-nav-list li a {
    font-weight: bold;
}

.copyright {
    margin: 30px 0;
    font-size: 14px;
    color: var(--color-text_05);
}

.totop {
    width: 3em;
    height: 3em;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    -webkit-box-align: center;
    align-items: center;
    -ms-flex-align: center;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    padding: 1em;
    color: white;
    border-radius: 100%;
    background-color: var(--color-bgc_05);
    opacity: 0;
    -webkit-transition: opacity 0.3s linear;
    transition: opacity 0.3s linear;
    position: fixed;
    bottom: 5em;
    right: 1em;
    z-index: -999;
}

.totop::before {
    content: "\f062";
    display: inline-block;
    font-family: "Font Awesome 5 Free";
    font-weight: 900;
    font-size: inherit;
    line-height: 1;
}

.fixed-content {
    width: 100%;
    padding: 0 calc(50% - 600px);
    position: fixed;
    bottom: 1em;
    right: 0;
    z-index: 10;
}

.fixed-content-list {
    width: calc(100% - 2em);
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    margin: 0 1em;
}

.fixed-content-list li {
    width: calc((100% - 2px) / 3);
}

.fixed-content-list li+li {
    margin-left: 1px;
}

.fixed-content-list li a {
    width: 100%;
    height: 100%;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    align-items: center;
    -ms-flex-align: center;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    padding: 0.5em;
    font-size: clamp(1rem, 0.773rem + 0.97vw, 1.5rem);
    color: var(--color-text_01);
    border: 2px solid var(--color-border_01);
    background-color: white;
}

.fixed-content-list li a [class*=icon] {
    -ms-flex-negative: 0;
    flex-shrink: 0;
    margin-right: 0.25em;
}

.fixed-content-list li .tel3 {
    height: 100%;
}

.fixed-content-list li .tel3 a {
    font-size: 16px;
}

.fixed-content-list li .tel3 a .tel3-text {
    display: inline-block;
    margin-left: 0.5em;
    font-size: clamp(1rem, 0.773rem + 0.97vw, 1.5rem);
}

.fixed-content-list li .tel3 a::before {
    content: "\f095";
    display: inline-block;
    margin-right: 0.25em;
    font-family: "Font Awesome 5 Free";
    font-weight: 900;
    font-size: 110%;
    line-height: 1;
    -webkit-transform: scale(-1, 1);
    transform: scale(-1, 1);
}

@media (max-width: 1024px) {
    .footer-content .footer-item {
        width: 100%;
        margin-left: 0;
    }

    .footer-content .footer-nav {
        margin-top: 5%;
    }

    .footer-content .footer-nav-list {
        -webkit-box-pack: center;
        -ms-flex-pack: center;
        justify-content: center;
    }

    .fixed-content-list li .tel3 a {
        font-size: clamp(1rem, 0.773rem + 0.97vw, 1.5rem);
    }
}

@media (max-width: 599px) {
    footer {
        padding-bottom: 120px;
    }

    footer .logo-002 {
        width: calc(100% - 200px);
    }

    .footer-content .footer-nav-list {
        display: block;
        -webkit-column-count: 2;
        -moz-column-count: 2;
        column-count: 2;
        -webkit-column-gap: 0.5em;
        -moz-column-gap: 0.5em;
        column-gap: 0.5em;
    }

    .footer-content .footer-nav-list li {
        -webkit-column-break-inside: avoid;
        -moz-column-break-inside: avoid;
        break-inside: avoid;
    }

    .footer-content .footer-nav-list li+li {
        margin-top: 1em;
        margin-left: 0;
    }

    .footer-content .footer-nav-list li a {
        font-size: 15px;
    }

    .totop {
        bottom: 6em;
    }

    .fixed-content {
        width: calc(100% - 2em);
        right: 1em;
    }

    .fixed-content-list {
        width: 100%;
        margin: 0;
    }

    .fixed-content-list li .tel3 a,
    .fixed-content-list li a {
        -webkit-box-orient: vertical;
        -webkit-box-direction: normal;
        -ms-flex-direction: column;
        flex-direction: column;
        -webkit-box-align: center;
        align-items: center;
        -ms-flex-align: center;
        font-size: 12px;
    }

    .fixed-content-list li.fixed-content-phone a::before {
        padding: 0.1em;
        font-size: 1.8em;
    }
}

/* ##### メインビジュアル hero section ##### */
.hero-section {
    padding-bottom: 5%;
    position: relative;
}

.hero-section::after {
    content: "";
    width: 85%;
    height: 30%;
    background-color: var(--color-bgc_01);
    position: absolute;
    bottom: 0;
    left: 0;
    z-index: 1;
}

.hero-section .hero-section-content {
    width: 90%;
    margin: auto;
    margin-left: auto;
    -webkit-transform: translate(0, -75%);
    transform: translate(0, -75%);
    position: absolute;
    top: 50%;
    left: 0;
    right: 0;
    z-index: 2;
}

.hero-section .hero-section-img {
    width: 90%;
    margin-left: auto;
    position: relative;
    z-index: 2;
}

.hero-section .hero-section-title {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
}

.hero-section .hero-section-title .sub,
.hero-section .hero-section-title .main {
    width: -webkit-fit-content;
    width: -moz-fit-content;
    width: fit-content;
    margin: 0.1em 0;
    padding: 0.1em 0.5em;
    line-height: 1.2;
}

.hero-section .hero-section-title .main {
    font-weight: bold;
    font-size: clamp(1.74375rem, 0.78rem + 4.13vw, 3.875rem);
    background-color: white;
}

.hero-section .hero-section-title .sub {
    margin-bottom: 0.55em;
    font-size: clamp(1.275rem, 0.89rem + 1.65vw, 2.125rem);
    color: white;
    background-color: var(--color-bgc_01);
}

.hero-section .scroll {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    line-height: 1;
    -ms-writing-mode: tb-rl;
    -webkit-writing-mode: vertical-rl;
    writing-mode: vertical-rl;
    position: absolute;
    bottom: 15%;
    left: 2.5%;
    z-index: 2;
}

.hero-section .scroll::after {
    content: "";
    width: 2px;
    height: 150px;
    display: block;
    margin: 1em auto;
    background-color: var(--color-default_text);
}

.hero-section .scroll:hover {
    opacity: 0.6;
    cursor: pointer;
    -webkit-transition: opacity 0.3s linear;
    transition: opacity 0.3s linear;
}

.hero-section.-top .hero-section-img {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
}

.hero-section.-top .hero-section-img .hero-section-slide {
    width: 33.3333333333%;
}

.hero-section.-lower .hero-section-img .img {
    width: 100%;
    display: block;
    position: relative;
}

.hero-section.-lower .hero-section-img .img::after {
    content: "";
    display: block;
    padding-top: 45%;
}

.hero-section.-lower .hero-section-img .img img {
    width: 100%;
    height: 100% !important;
    -o-object-fit: cover;
    object-fit: cover;
    -o-object-position: 50% 50%;
    object-position: 50% 50%;
    font-family: "object-fit: cover; object-position: 50% 50%;";
    position: absolute;
    top: 0;
    left: 0;
}

@media (max-width: 1024px) {
    .hero-section.-top .hero-section-img {
        -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    }

    .hero-section.-top .hero-section-img .hero-section-slide {
        width: 50%;
    }

    .hero-section.-top .hero-section-img .hero-section-slide.-mobile-wide {
        width: 100%;
    }

    .hero-section.-top .hero-section-img .hero-section-slide.-mobile-wide .uk-slideshow::after {
        padding-top: 50%;
    }

    .hero-section.-lower .hero-section-img .img::after {
        padding-top: 80%;
    }
}

@media (max-width: 599px) {
    .hero-section.-top .hero-section-img {
        -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    }

    .hero-section.-top .hero-section-img .hero-section-slide.-mobile-wide .uk-slideshow::after {
        padding-top: 60%;
    }

    .hero-section.-lower .hero-section-img .img::after {
        padding-top: 50vh;
    }

    .hero-section.-lower .hero-section-content {
        -webkit-transform: translate(0, -100%);
        transform: translate(0, -100%);
        top: 45%;
    }

    .hero-section .scroll {
        bottom: -10%;
    }
}

/* ##### bodyにクラス名が追加された時のcss add-class ##### */
.header-fixed .header-content {
    background-color: rgba(255, 255, 255, 0.8);
    -webkit-box-shadow: 0px 4px 2px -2px rgba(0, 0, 0, 0.2);
    box-shadow: 0px 4px 2px -2px rgba(0, 0, 0, 0.2);
    position: fixed;
    top: 0;
    left: 0;
}

.scrolled .header-link {
    display: none;
}

.scrolled .header-btn a {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
    -ms-flex-direction: row;
    flex-direction: row;
}

.scrolled .header-btn a .icon-mail {
    margin-right: 0.25em;
}

.appeared.totop {
    opacity: 1;
    z-index: 20;
}

.appeared.totop:hover {
    opacity: 0.6;
    cursor: pointer;
}

@media (max-width: 1024px) {
    .header-fixed .header-content {
        left: auto;
    }

    .drawer-active .header-content {
        -webkit-box-shadow: -2px 0px 15px -5px #000;
        box-shadow: -2px 0px 15px -5px #000;
        right: 0;
    }

    .drawer-active main,
    .drawer-active footer {
        -webkit-filter: blur(3px);
        filter: blur(3px);
    }
}

@media (max-width: 599px) {
    .scrolled .header-link {
        display: -webkit-box;
        display: -ms-flexbox;
        display: flex;
    }
}

/* ##### カスタムコンテンツ custom contents ##### */
.category {
    font-family: "Roboto", sans-serif;
    font-weight: bold;
    color: var(--color-text_01);
}

.category span {
    display: inline-block;
}

.category span+span {
    margin-left: 1em;
}

.category.-box span {
    min-width: 140px;
    display: inline-block;
    margin: 0.1em;
    padding: 0.2em 1em 0.1em;
    color: white;
    line-height: 1.2;
    text-align: center;
    border: 1px solid var(--color-border_01);
    background-color: var(--color-bgc_01);
}

.category.-box span.パンフレット {
    border: 1px solid var(--color-border_01);
    background-color: var(--color-bgc_01);
}

.category.-box span.資料 {
    border: 1px solid var(--color-border_06);
    background-color: var(--color-bgc_06);
}

.category.-box span.動画 {
    border: 1px solid var(--color-border_07);
    background-color: var(--color-bgc_07);
}

.category.-tag span {
    display: inline-block;
    padding: 0.25em 1em 0.15em;
    font-size: clamp(0.7875rem, 0.75rem + 0.17vw, 0.875rem);
    color: var(--color-text_01);
    border: 1px solid var(--color-border_01);
    border-radius: 3em;
}

.category.-tag2 span {
    display: inline-block;
    padding: 0.25em 1em;
    font-weight: normal;
    font-size: 12px;
    color: white;
    line-height: 1.2;
    background-color: var(--color-bgc_05);
}

.category.-tag2 span+span {
    margin-left: 0.5em;
}

.date {
    font-family: "Roboto", sans-serif;
    color: var(--color-text_05);
}

.detail-box {
    padding: 2em;
}

.detail-information {
    margin-bottom: 2em;
    padding: 2em 0.5em;
    border-bottom: 1px solid var(--color-border_04);
}

.detail-information-item {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-align: center;
    align-items: center;
    -ms-flex-align: center;
}

.detail-information .category {
    margin-left: 1em;
}

.detail-title {
    width: 100%;
    font-weight: bold;
    font-size: clamp(1.8rem, 1.6rem + 0.87vw, 2.25rem);
    color: var(--color-text_05);
}

.product-image-wrap .image-thumb {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    margin-top: 3px;
}

.product-image-wrap .image-thumb li {
    width: calc(25% - 9px);
}

.product-image-wrap .image-thumb li+li {
    margin-left: 3px;
}

.product-image-wrap .image-thumb li.active-img {
    outline: 2px solid var(--color-border_01);
}

.product-category {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
}

.product-category dt {
    -ms-flex-negative: 0;
    flex-shrink: 0;
    padding-right: 1em;
    font-family: "Roboto", sans-serif;
    font-weight: bold;
    font-size: clamp(1.35rem, 1.28rem + 0.29vw, 1.5rem);
    color: var(--color-text_01);
    position: relative;
}

.product-category dt::after {
    content: "：";
    display: inline-block;
    position: absolute;
    top: 0;
    right: 0;
}

.product-category dd {
    width: 10%;
    -webkit-box-flex: 1;
    -ms-flex-positive: 1;
    flex-grow: 1;
    font-weight: bold;
    font-size: clamp(1.2375rem, 1.18rem + 0.27vw, 1.375rem);
}

.recommend-list {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
}

.recommend-list .product-item {
    width: calc(25% - 3px);
}

.recommend-list .product-item+.product-item {
    margin-left: 1px;
}

@media (max-width: 599px) {
    .detail-box {
        padding: 2em 1em;
    }
}

/* ##### お問い合わせ メールフォーム form ##### */
.contact-item dd input,
.contact-item dd select,
.contact-item dd textarea {
    border: 1px solid var(--color-border_01);
    border-radius: 0;
}

.contact-item.radiobtn dd {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
}

.contact-item.radiobtn dd label {
    width: 48%;
    margin: 1%;
    padding: 0.5em 0.5em 0.5em 2.5em;
}

.contact-item.radiobtn dd label::before {
    width: 2em;
    height: 2em;
    border: 1px solid var(--color-border_01);
    border-radius: 0;
    top: 0.35em;
}

.contact-item.radiobtn dd input+label {
    margin-left: 0;
}

.contact-item.radiobtn dd input:checked+label::after {
    font-size: 2em;
}

.contact-item.radiobtn2 dd {
    width: 100%;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
}

@media (max-width: 599px) {
    .contact-item.radiobtn dd label {
        width: 98%;
    }
}

/* ##### PDF pdf ##### */
.pdf-area[data-pdflink=""] {
    display: none;
}

.detail-pdf {
    width: 62%;
    margin-top: 50px;
    margin-left: auto;
    margin-right: auto;
}

.up-pdf {
    width: 100%;
    display: block;
    position: relative;
}

.up-pdf::after {
    content: "";
    display: block;
    padding-top: 81%;
}

.up-pdf iframe {
    width: 100%;
    height: 100% !important;
    -o-object-fit: cover;
    object-fit: cover;
    -o-object-position: 50% 50%;
    object-position: 50% 50%;
    font-family: "object-fit: cover; object-position: 50% 50%;";
    position: absolute;
    top: 0;
    left: 0;
}

.detail-box .btn-03.表示しない {
    display: none;
}

@media (max-width: 1024px) {
    .detail-pdf {
        width: 90%;
    }

    .up-pdf::after {
        padding-top: 120%;
    }
}

@media (max-width: 599px) {
    .detail-pdf {
        width: 100%;
    }
}

/* ##### 見たまま編集画面 edit page ##### */
[data-element-id] header {
    margin-top: 30px;
}

[data-element-id] .uk-slideshow>li {
    opacity: 1;
}

[data-element-id] [data-ab-test-contents] {
    padding: 1.5em 0.2em 0.2em;
    border: 2px solid #8b008b;
    position: relative;
}

[data-element-id] [data-ab-test-contents]::before {
    content: "Aパターン";
    width: 100%;
    display: block;
    padding: 0.5em 0.2em;
    font-size: 10px;
    color: white;
    line-height: 1.2;
    text-align: center;
    background-color: #8b008b;
    position: absolute;
    top: 0;
    left: 0;
}

[data-element-id] [data-ab-test-contents]+[data-ab-test-contents] {
    border: 2px solid #556b2f;
}

[data-element-id] [data-ab-test-contents]+[data-ab-test-contents]::before {
    content: "Bパターン";
    background-color: #556b2f;
}

[data-element-id] .abtest-parent>div>div {
    opacity: 1;
}

[data-element-id] .abtest-parent>div>div:nth-of-type(n+2) {
    display: block;
}

[data-element-id] *::before,
[data-element-id] *::after {
    pointer-events: none;
}

[data-element-id] .bg-content {
    width: -webkit-fit-content;
    width: -moz-fit-content;
    width: fit-content;
    height: auto;
    margin-left: auto;
    margin-right: auto;
}

[data-element-id] .only-mobile,
[data-element-id] .only-sp {
    display: block;
    padding: 2em 1em 1em;
    border: 2px solid blue;
    position: relative;
}

[data-element-id] .only-mobile::before,
[data-element-id] .only-sp::before {
    content: "モバイルのみ表示";
    width: 100%;
    display: block;
    padding: 0.5em;
    font-size: 10px;
    color: white;
    line-height: 1.2;
    text-align: center;
    background-color: blue;
    position: absolute;
    top: 0;
    left: 0;
    z-index: 1;
}

[data-element-id] .edit-landmark {
    padding: 2em 1em 1em;
    outline: 2px solid silver;
    position: relative;
}

[data-element-id] .edit-landmark::before {
    content: "要素のコピー、複製、削除、移動はここをダブルクリック";
    width: 100%;
    display: block;
    padding: 1em 0.5em;
    font-size: 10px;
    color: white;
    line-height: 1.2;
    text-align: center;
    background-color: silver;
    position: absolute;
    top: 0;
    left: 0;
}

[data-element-id] .nav-list {
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    -webkit-box-align: start;
    align-items: flex-start;
    -ms-flex-align: start;
}

[data-element-id] .dropdown-menu {
    overflow: visible;
    padding: 2em 1em 1em;
    border: 2px solid blue;
    position: relative;
}

[data-element-id] .dropdown-menu::before {
    content: "ドロップダウン";
    width: 100%;
    display: block;
    padding: 0.5em;
    font-size: 10px;
    color: white;
    line-height: 1.2;
    text-align: center;
    background-color: blue;
    position: absolute;
    top: 0;
    left: 0;
    z-index: 1;
}

[data-element-id] .dropdown-menu .dropdown-box {
    visibility: visible;
    opacity: 1;
    -webkit-transform: translate(0, 0);
    transform: translate(0, 0);
    position: static;
}

.abtest-parent>div>div[data-ab-test-contents] {
    opacity: 1;
}

.abtest-parent>div>div[data-ab-test-contents]:nth-of-type(n+2) {
    display: block;
}

[data-element-id] .marquee {
    -webkit-transform: translateX(0);
    transform: translateX(0);
    -webkit-animation: unset;
    animation: unset;
    right: auto;
    z-index: 0;
}

[data-element-id] .fead-order>* {
    opacity: 1;
    -webkit-transform: translateY(0);
    transform: translateY(0);
}

[data-element-id] .swiper {
    width: 100%;
    margin-left: 0;
}

[data-element-id] .swiper .swiper-wrapper {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    overflow-x: scroll;
    -webkit-overflow-scrolling: touch;
}

[data-element-id] .swiper-slide {
    width: 23%;
    -ms-flex-negative: 0;
    flex-shrink: 0;
    margin: 1%;
}

[data-element-id] .product-item {
    width: 100%;
}

[data-element-id] .fixed-content {
    max-width: 1200px;
    margin: auto;
    padding: 50px 30px 90px;
    border: 2px solid green;
    position: relative;
    bottom: auto;
    left: auto;
    right: auto;
}

[data-element-id] .fixed-content::before {
    content: "画面下部に固定されます";
    width: 100%;
    display: block;
    padding: 0.5em;
    font-size: 10px;
    color: white;
    line-height: 1.2;
    text-align: center;
    background-color: green;
    position: absolute;
    top: 0;
    left: 0;
    z-index: 1;
}
